github.com/metacubex/mihomo@v1.18.5/component/geodata/attr.go (about) 1 package geodata 2 3 import ( 4 "strings" 5 6 "github.com/metacubex/mihomo/component/geodata/router" 7 ) 8 9 type AttributeList struct { 10 matcher []AttributeMatcher 11 } 12 13 func (al *AttributeList) Match(domain *router.Domain) bool { 14 for _, matcher := range al.matcher { 15 if !matcher.Match(domain) { 16 return false 17 } 18 } 19 return true 20 } 21 22 func (al *AttributeList) IsEmpty() bool { 23 return len(al.matcher) == 0 24 } 25 26 func parseAttrs(attrs []string) *AttributeList { 27 al := new(AttributeList) 28 for _, attr := range attrs { 29 trimmedAttr := strings.ToLower(strings.TrimSpace(attr)) 30 if len(trimmedAttr) == 0 { 31 continue 32 } 33 al.matcher = append(al.matcher, BooleanMatcher(trimmedAttr)) 34 } 35 return al 36 } 37 38 type AttributeMatcher interface { 39 Match(*router.Domain) bool 40 } 41 42 type BooleanMatcher string 43 44 func (m BooleanMatcher) Match(domain *router.Domain) bool { 45 for _, attr := range domain.Attribute { 46 if strings.EqualFold(attr.GetKey(), string(m)) { 47 return true 48 } 49 } 50 return false 51 }