2019-10-28 00:02:23 +08:00
|
|
|
package rules
|
|
|
|
|
|
|
|
import (
|
|
|
|
"errors"
|
2021-08-31 21:46:04 +08:00
|
|
|
"net"
|
2022-01-28 22:52:35 +08:00
|
|
|
"strings"
|
2021-07-01 22:49:29 +08:00
|
|
|
|
|
|
|
C "github.com/Dreamacro/clash/constant"
|
2019-10-28 00:02:23 +08:00
|
|
|
)
|
|
|
|
|
|
|
|
var (
|
2020-12-17 22:17:27 +08:00
|
|
|
errPayload = errors.New("payload error")
|
2019-10-28 00:02:23 +08:00
|
|
|
|
|
|
|
noResolve = "no-resolve"
|
|
|
|
)
|
|
|
|
|
|
|
|
func HasNoResolve(params []string) bool {
|
|
|
|
for _, p := range params {
|
|
|
|
if p == noResolve {
|
|
|
|
return true
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return false
|
|
|
|
}
|
2021-07-01 22:49:29 +08:00
|
|
|
|
|
|
|
func findNetwork(params []string) C.NetWork {
|
|
|
|
for _, p := range params {
|
2022-01-28 22:52:35 +08:00
|
|
|
if strings.EqualFold(p, "tcp") {
|
2021-07-01 22:49:29 +08:00
|
|
|
return C.TCP
|
2022-01-28 22:52:35 +08:00
|
|
|
} else if strings.EqualFold(p, "udp") {
|
2021-07-01 22:49:29 +08:00
|
|
|
return C.UDP
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return C.ALLNet
|
|
|
|
}
|
2021-08-31 21:46:04 +08:00
|
|
|
|
|
|
|
func findSourceIPs(params []string) []*net.IPNet {
|
|
|
|
var ips []*net.IPNet
|
|
|
|
for _, p := range params {
|
|
|
|
if p == noResolve || len(p) < 7 {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
_, ipnet, err := net.ParseCIDR(p)
|
|
|
|
if err != nil {
|
|
|
|
continue
|
|
|
|
}
|
|
|
|
ips = append(ips, ipnet)
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(ips) > 0 {
|
|
|
|
return ips
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|
2022-01-28 22:52:35 +08:00
|
|
|
|
|
|
|
func findProcessName(params []string) []string {
|
|
|
|
var processNames []string
|
|
|
|
for _, p := range params {
|
|
|
|
if strings.HasPrefix(p, "P:") {
|
|
|
|
processNames = append(processNames, strings.TrimPrefix(p, "P:"))
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if len(processNames) > 0 {
|
|
|
|
return processNames
|
|
|
|
}
|
|
|
|
return nil
|
|
|
|
}
|