2022-01-22 22:10:45 +08:00
|
|
|
package common
|
2018-06-10 22:50:03 +08:00
|
|
|
|
|
|
|
import (
|
2022-04-20 01:52:51 +08:00
|
|
|
"net/netip"
|
2018-06-10 22:50:03 +08:00
|
|
|
|
|
|
|
C "github.com/Dreamacro/clash/constant"
|
|
|
|
)
|
|
|
|
|
2019-10-28 00:02:23 +08:00
|
|
|
type IPCIDROption func(*IPCIDR)
|
|
|
|
|
|
|
|
func WithIPCIDRSourceIP(b bool) IPCIDROption {
|
|
|
|
return func(i *IPCIDR) {
|
|
|
|
i.isSourceIP = b
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
func WithIPCIDRNoResolve(noResolve bool) IPCIDROption {
|
|
|
|
return func(i *IPCIDR) {
|
2019-11-04 10:42:39 +08:00
|
|
|
i.noResolveIP = noResolve
|
2019-10-28 00:02:23 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2018-06-10 22:50:03 +08:00
|
|
|
type IPCIDR struct {
|
2022-03-13 01:21:23 +08:00
|
|
|
*Base
|
2023-10-26 10:39:54 +08:00
|
|
|
ipnet netip.Prefix
|
2019-10-28 00:02:23 +08:00
|
|
|
adapter string
|
|
|
|
isSourceIP bool
|
|
|
|
noResolveIP bool
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
func (i *IPCIDR) RuleType() C.RuleType {
|
2019-02-02 21:03:13 +08:00
|
|
|
if i.isSourceIP {
|
2019-05-09 21:00:29 +08:00
|
|
|
return C.SrcIPCIDR
|
2019-02-02 21:03:13 +08:00
|
|
|
}
|
2018-06-10 22:50:03 +08:00
|
|
|
return C.IPCIDR
|
|
|
|
}
|
|
|
|
|
feat: support sub-rule, eg.
rules:
- SUB-RULE,(AND,((NETWORK,TCP),(DOMAIN-KEYWORD,google))),TEST2
- SUB-RULE,(GEOIP,!CN),TEST1
- MATCH,DIRECT
sub-rules:
TEST2:
- MATCH,Proxy
TEST1:
- RULE-SET,Local,DIRECT,no-resolve
- GEOSITE,CN,Domestic
- GEOIP,CN,Domestic
- MATCH,Proxy
2022-09-06 17:30:35 +08:00
|
|
|
func (i *IPCIDR) Match(metadata *C.Metadata) (bool, string) {
|
2019-05-09 21:00:29 +08:00
|
|
|
ip := metadata.DstIP
|
2019-02-02 21:03:13 +08:00
|
|
|
if i.isSourceIP {
|
2019-05-09 21:00:29 +08:00
|
|
|
ip = metadata.SrcIP
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
feat: support sub-rule, eg.
rules:
- SUB-RULE,(AND,((NETWORK,TCP),(DOMAIN-KEYWORD,google))),TEST2
- SUB-RULE,(GEOIP,!CN),TEST1
- MATCH,DIRECT
sub-rules:
TEST2:
- MATCH,Proxy
TEST1:
- RULE-SET,Local,DIRECT,no-resolve
- GEOSITE,CN,Domestic
- GEOIP,CN,Domestic
- MATCH,Proxy
2022-09-06 17:30:35 +08:00
|
|
|
return ip.IsValid() && i.ipnet.Contains(ip), i.adapter
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
|
|
|
|
2018-06-20 22:41:02 +08:00
|
|
|
func (i *IPCIDR) Adapter() string {
|
|
|
|
return i.adapter
|
|
|
|
}
|
|
|
|
|
|
|
|
func (i *IPCIDR) Payload() string {
|
|
|
|
return i.ipnet.String()
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
|
|
|
|
2020-07-27 11:57:55 +08:00
|
|
|
func (i *IPCIDR) ShouldResolveIP() bool {
|
|
|
|
return !i.noResolveIP
|
2019-10-28 00:02:23 +08:00
|
|
|
}
|
|
|
|
|
2022-03-13 01:21:23 +08:00
|
|
|
func NewIPCIDR(s string, adapter string, opts ...IPCIDROption) (*IPCIDR, error) {
|
2022-04-20 01:52:51 +08:00
|
|
|
ipnet, err := netip.ParsePrefix(s)
|
2018-06-10 22:50:03 +08:00
|
|
|
if err != nil {
|
2019-10-28 00:02:23 +08:00
|
|
|
return nil, errPayload
|
|
|
|
}
|
|
|
|
|
|
|
|
ipcidr := &IPCIDR{
|
2022-03-13 01:21:23 +08:00
|
|
|
Base: &Base{},
|
2023-10-26 10:39:54 +08:00
|
|
|
ipnet: ipnet,
|
2022-03-13 01:21:23 +08:00
|
|
|
adapter: adapter,
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
2019-10-28 00:02:23 +08:00
|
|
|
|
|
|
|
for _, o := range opts {
|
|
|
|
o(ipcidr)
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
2019-10-28 00:02:23 +08:00
|
|
|
|
|
|
|
return ipcidr, nil
|
2018-06-10 22:50:03 +08:00
|
|
|
}
|
2022-03-13 01:21:23 +08:00
|
|
|
|
feat: support sub-rule, eg.
rules:
- SUB-RULE,(AND,((NETWORK,TCP),(DOMAIN-KEYWORD,google))),TEST2
- SUB-RULE,(GEOIP,!CN),TEST1
- MATCH,DIRECT
sub-rules:
TEST2:
- MATCH,Proxy
TEST1:
- RULE-SET,Local,DIRECT,no-resolve
- GEOSITE,CN,Domestic
- GEOIP,CN,Domestic
- MATCH,Proxy
2022-09-06 17:30:35 +08:00
|
|
|
//var _ C.Rule = (*IPCIDR)(nil)
|