package hy2 import ( "sync" "github.com/InazumaV/V2bX/common/counter" "github.com/InazumaV/V2bX/common/format" "github.com/InazumaV/V2bX/limiter" "go.uber.org/zap" ) type HookServer struct { Tag string logger *zap.Logger Counter sync.Map } func (h *HookServer) LogTraffic(id string, tx, rx uint64) (ok bool) { var c interface{} var exists bool limiterinfo, err := limiter.GetLimiter(h.Tag) if err != nil { h.logger.Error("Get limiter error", zap.String("tag", h.Tag), zap.Error(err)) return false } userLimit, ok := limiterinfo.UserLimitInfo.Load(format.UserTag(h.Tag, id)) if ok { userlimitInfo := userLimit.(*limiter.UserLimitInfo) if userlimitInfo.OverLimit { userlimitInfo.OverLimit = false return false } } if c, exists = h.Counter.Load(h.Tag); !exists { c = counter.NewTrafficCounter() h.Counter.Store(h.Tag, c) } if tc, ok := c.(*counter.TrafficCounter); ok { tc.Rx(id, int(rx)) tc.Tx(id, int(tx)) return true } return false } func (s *HookServer) LogOnlineState(id string, online bool) { }