mirror of
https://github.com/v2fly/v2ray-core.git
synced 2025-01-04 16:37:12 -05:00
move size stats writer into vio
This commit is contained in:
parent
33becfe553
commit
dcae6c63dd
@ -15,12 +15,11 @@ import (
|
|||||||
"v2ray.com/core/common/net"
|
"v2ray.com/core/common/net"
|
||||||
"v2ray.com/core/common/protocol"
|
"v2ray.com/core/common/protocol"
|
||||||
"v2ray.com/core/common/session"
|
"v2ray.com/core/common/session"
|
||||||
"v2ray.com/core/common/stats"
|
|
||||||
"v2ray.com/core/common/vio"
|
"v2ray.com/core/common/vio"
|
||||||
"v2ray.com/core/features/outbound"
|
"v2ray.com/core/features/outbound"
|
||||||
"v2ray.com/core/features/policy"
|
"v2ray.com/core/features/policy"
|
||||||
"v2ray.com/core/features/routing"
|
"v2ray.com/core/features/routing"
|
||||||
feature_stats "v2ray.com/core/features/stats"
|
"v2ray.com/core/features/stats"
|
||||||
"v2ray.com/core/transport/pipe"
|
"v2ray.com/core/transport/pipe"
|
||||||
)
|
)
|
||||||
|
|
||||||
@ -87,7 +86,7 @@ type DefaultDispatcher struct {
|
|||||||
ohm outbound.Manager
|
ohm outbound.Manager
|
||||||
router routing.Router
|
router routing.Router
|
||||||
policy policy.Manager
|
policy policy.Manager
|
||||||
stats feature_stats.Manager
|
stats stats.Manager
|
||||||
}
|
}
|
||||||
|
|
||||||
// NewDefaultDispatcher create a new DefaultDispatcher.
|
// NewDefaultDispatcher create a new DefaultDispatcher.
|
||||||
@ -144,8 +143,8 @@ func (d *DefaultDispatcher) getLink(ctx context.Context) (*vio.Link, *vio.Link)
|
|||||||
p := d.policy.ForLevel(user.Level)
|
p := d.policy.ForLevel(user.Level)
|
||||||
if p.Stats.UserUplink {
|
if p.Stats.UserUplink {
|
||||||
name := "user>>>" + user.Email + ">>>traffic>>>uplink"
|
name := "user>>>" + user.Email + ">>>traffic>>>uplink"
|
||||||
if c, _ := feature_stats.GetOrRegisterCounter(d.stats, name); c != nil {
|
if c, _ := stats.GetOrRegisterCounter(d.stats, name); c != nil {
|
||||||
inboundLink.Writer = &stats.SizeStatWriter{
|
inboundLink.Writer = &vio.SizeStatWriter{
|
||||||
Counter: c,
|
Counter: c,
|
||||||
Writer: inboundLink.Writer,
|
Writer: inboundLink.Writer,
|
||||||
}
|
}
|
||||||
@ -153,8 +152,8 @@ func (d *DefaultDispatcher) getLink(ctx context.Context) (*vio.Link, *vio.Link)
|
|||||||
}
|
}
|
||||||
if p.Stats.UserDownlink {
|
if p.Stats.UserDownlink {
|
||||||
name := "user>>>" + user.Email + ">>>traffic>>>downlink"
|
name := "user>>>" + user.Email + ">>>traffic>>>downlink"
|
||||||
if c, _ := feature_stats.GetOrRegisterCounter(d.stats, name); c != nil {
|
if c, _ := stats.GetOrRegisterCounter(d.stats, name); c != nil {
|
||||||
outboundLink.Writer = &stats.SizeStatWriter{
|
outboundLink.Writer = &vio.SizeStatWriter{
|
||||||
Counter: c,
|
Counter: c,
|
||||||
Writer: outboundLink.Writer,
|
Writer: outboundLink.Writer,
|
||||||
}
|
}
|
||||||
|
@ -1,4 +1,4 @@
|
|||||||
package stats
|
package vio
|
||||||
|
|
||||||
import (
|
import (
|
||||||
"v2ray.com/core/common"
|
"v2ray.com/core/common"
|
46
common/vio/stats_test.go
Normal file
46
common/vio/stats_test.go
Normal file
@ -0,0 +1,46 @@
|
|||||||
|
package vio_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
|
||||||
|
"v2ray.com/core/common"
|
||||||
|
"v2ray.com/core/common/buf"
|
||||||
|
. "v2ray.com/core/common/vio"
|
||||||
|
)
|
||||||
|
|
||||||
|
type TestCounter int64
|
||||||
|
|
||||||
|
func (c *TestCounter) Value() int64 {
|
||||||
|
return int64(*c)
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *TestCounter) Add(v int64) int64 {
|
||||||
|
x := int64(*c) + v
|
||||||
|
*c = TestCounter(x)
|
||||||
|
return x
|
||||||
|
}
|
||||||
|
|
||||||
|
func (c *TestCounter) Set(v int64) int64 {
|
||||||
|
*c = TestCounter(v)
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestStatsWriter(t *testing.T) {
|
||||||
|
var c TestCounter
|
||||||
|
writer := &SizeStatWriter{
|
||||||
|
Counter: &c,
|
||||||
|
Writer: buf.Discard,
|
||||||
|
}
|
||||||
|
|
||||||
|
var mb buf.MultiBuffer
|
||||||
|
common.Must2(mb.Write([]byte("abcd")))
|
||||||
|
common.Must(writer.WriteMultiBuffer(mb))
|
||||||
|
|
||||||
|
mb.Release()
|
||||||
|
common.Must2(mb.Write([]byte("efg")))
|
||||||
|
common.Must(writer.WriteMultiBuffer(mb))
|
||||||
|
|
||||||
|
if c.Value() != 7 {
|
||||||
|
t.Fatal("unexpected counter value. want 7, but got ", c.Value())
|
||||||
|
}
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user