mirror of https://github.com/v2ray/v2ray-core
optimize network matcher
parent
120058310a
commit
b9c8506c23
|
@ -182,21 +182,23 @@ func (v *PortMatcher) Apply(ctx context.Context) bool {
|
||||||
}
|
}
|
||||||
|
|
||||||
type NetworkMatcher struct {
|
type NetworkMatcher struct {
|
||||||
network *net.NetworkList
|
list [8]bool
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewNetworkMatcher(network *net.NetworkList) *NetworkMatcher {
|
func NewNetworkMatcher(network *net.NetworkList) NetworkMatcher {
|
||||||
return &NetworkMatcher{
|
var matcher NetworkMatcher
|
||||||
network: network,
|
for _, n := range network.Network {
|
||||||
|
matcher.list[int(n)] = true
|
||||||
}
|
}
|
||||||
|
return matcher
|
||||||
}
|
}
|
||||||
|
|
||||||
func (v *NetworkMatcher) Apply(ctx context.Context) bool {
|
func (v NetworkMatcher) Apply(ctx context.Context) bool {
|
||||||
outbound := session.OutboundFromContext(ctx)
|
outbound := session.OutboundFromContext(ctx)
|
||||||
if outbound == nil || !outbound.Target.IsValid() {
|
if outbound == nil || !outbound.Target.IsValid() {
|
||||||
return false
|
return false
|
||||||
}
|
}
|
||||||
return v.network.HasNetwork(outbound.Target.Network)
|
return v.list[int(outbound.Target.Network)]
|
||||||
}
|
}
|
||||||
|
|
||||||
type UserMatcher struct {
|
type UserMatcher struct {
|
||||||
|
|
Loading…
Reference in New Issue