mihomo/dns/filters.go

70 lines
1.3 KiB
Go
Raw Normal View History

2019-09-15 13:36:45 +08:00
package dns
2020-01-11 21:07:01 +08:00
import (
"net"
2021-10-28 00:06:55 +08:00
"strings"
2020-01-11 21:07:01 +08:00
"github.com/Dreamacro/clash/component/geodata/router"
2021-10-28 00:06:55 +08:00
"github.com/Dreamacro/clash/component/mmdb"
"github.com/Dreamacro/clash/component/trie"
2021-10-28 00:06:55 +08:00
C "github.com/Dreamacro/clash/constant"
2020-01-11 21:07:01 +08:00
)
2019-09-15 13:36:45 +08:00
type fallbackIPFilter interface {
2019-09-15 13:36:45 +08:00
Match(net.IP) bool
}
2021-08-25 15:15:13 +08:00
type geoipFilter struct {
code string
}
2019-09-15 13:36:45 +08:00
func (gf *geoipFilter) Match(ip net.IP) bool {
2021-10-28 00:06:55 +08:00
record, _ := mmdb.Instance().Country(ip)
2022-03-13 01:21:23 +08:00
return !strings.EqualFold(record.Country.IsoCode, gf.code) &&
!ip.IsPrivate() &&
!ip.IsLoopback() &&
!ip.IsUnspecified() &&
!ip.Equal(C.TunBroadcastAddr)
2019-09-15 13:36:45 +08:00
}
type ipnetFilter struct {
ipnet *net.IPNet
}
func (inf *ipnetFilter) Match(ip net.IP) bool {
return inf.ipnet.Contains(ip)
}
type fallbackDomainFilter interface {
Match(domain string) bool
}
type domainFilter struct {
tree *trie.DomainTrie
}
func NewDomainFilter(domains []string) *domainFilter {
df := domainFilter{tree: trie.New()}
for _, domain := range domains {
df.tree.Insert(domain, "")
}
return &df
}
func (df *domainFilter) Match(domain string) bool {
return df.tree.Search(domain) != nil
}
type geoSiteFilter struct {
matchers []*router.DomainMatcher
}
func (gsf *geoSiteFilter) Match(domain string) bool {
for _, matcher := range gsf.matchers {
if matcher.ApplyDomain(domain) {
return true
}
}
return false
}