clash/rule/logic/and.go

69 lines
1.1 KiB
Go
Raw Normal View History

package logic
2022-03-17 15:24:07 +00:00
import (
"fmt"
2022-03-17 15:24:07 +00:00
C "github.com/Dreamacro/clash/constant"
"github.com/Dreamacro/clash/rule/common"
"strings"
2022-03-17 15:24:07 +00:00
)
type AND struct {
*common.Base
rules []C.Rule
payload string
adapter string
needIP bool
}
2022-03-15 16:43:08 +00:00
func (A *AND) ShouldFindProcess() bool {
return false
}
func NewAND(payload string, adapter string) (*AND, error) {
and := &AND{Base: &common.Base{}, payload: payload, adapter: adapter}
2022-04-15 16:21:08 +00:00
rules, err := parseRuleByPayload(payload)
if err != nil {
return nil, err
}
and.rules = rules
payloads := make([]string, 0, len(rules))
for _, rule := range rules {
payloads = append(payloads, fmt.Sprintf("(%s)", rule.Payload()))
if rule.ShouldResolveIP() {
and.needIP = true
break
}
}
and.payload = strings.Join(payloads, " && ")
return and, nil
}
func (A *AND) RuleType() C.RuleType {
return C.AND
}
func (A *AND) Match(metadata *C.Metadata) bool {
for _, rule := range A.rules {
if !rule.Match(metadata) {
return false
}
}
return true
}
func (A *AND) Adapter() string {
return A.adapter
}
func (A *AND) Payload() string {
return A.payload
}
func (A *AND) ShouldResolveIP() bool {
return A.needIP
}