parent
6fa865d538
commit
349320f291
|
@ -4,8 +4,8 @@ banner.*
|
|||
banners.*
|
||||
creatives.*
|
||||
oas.*
|
||||
oascentral.*
|
||||
stats.*
|
||||
oascentral.* # test inline comment
|
||||
stats.* # test inline comment with trailing spaces
|
||||
tag.*
|
||||
telemetry.*
|
||||
tracker.*
|
||||
|
|
|
@ -1,3 +1,3 @@
|
|||
cloaked.* one.one.one.one
|
||||
*.cloaked2.* one.one.one.one
|
||||
*.cloaked2.* one.one.one.one # inline comment
|
||||
=www.dnscrypt-test 192.168.100.100
|
||||
|
|
|
@ -143,6 +143,18 @@ func StringStripSpaces(str string) string {
|
|||
}, str)
|
||||
}
|
||||
|
||||
func TrimAndStripInlineComments(str string) string {
|
||||
if idx := strings.LastIndexByte(str, '#'); idx >= 0 {
|
||||
if idx == 0 {
|
||||
return ""
|
||||
}
|
||||
if prev := str[idx-1]; prev == ' ' || prev == '\t' {
|
||||
str = str[:idx-1]
|
||||
}
|
||||
}
|
||||
return strings.TrimFunc(str, unicode.IsSpace)
|
||||
}
|
||||
|
||||
func ExtractHostAndPort(str string, defaultPort int) (host string, port int) {
|
||||
host, port = str, defaultPort
|
||||
if idx := strings.LastIndex(str, ":"); idx >= 0 && idx < len(str)-1 {
|
||||
|
|
|
@ -21,7 +21,7 @@ banner.*
|
|||
banners.*
|
||||
creatives.*
|
||||
oas.*
|
||||
oascentral.*
|
||||
oascentral.* # inline comments are allowed after a pound sign
|
||||
stats.*
|
||||
tag.*
|
||||
telemetry.*
|
||||
|
|
|
@ -13,7 +13,7 @@ www.google.* forcesafesearch.google.com
|
|||
|
||||
www.bing.com strict.bing.com
|
||||
|
||||
yandex.ru familysearch.yandex.ru
|
||||
yandex.ru familysearch.yandex.ru # inline comments are allowed after a pound sign
|
||||
|
||||
=duckduckgo.com safe.duckduckgo.com
|
||||
|
||||
|
|
|
@ -10,4 +10,4 @@
|
|||
|
||||
163.5.1.4
|
||||
94.46.118.*
|
||||
[fe80:53:*]
|
||||
[fe80:53:*] # IPv6 prefix example
|
||||
|
|
|
@ -6,7 +6,6 @@ import (
|
|||
"net"
|
||||
"strings"
|
||||
"time"
|
||||
"unicode"
|
||||
|
||||
iradix "github.com/hashicorp/go-immutable-radix"
|
||||
"github.com/jedisct1/dlog"
|
||||
|
@ -38,8 +37,8 @@ func (plugin *PluginBlockIP) Init(proxy *Proxy) error {
|
|||
plugin.blockedPrefixes = iradix.New()
|
||||
plugin.blockedIPs = make(map[string]interface{})
|
||||
for lineNo, line := range strings.Split(string(bin), "\n") {
|
||||
line = strings.TrimFunc(line, unicode.IsSpace)
|
||||
if len(line) == 0 || strings.HasPrefix(line, "#") {
|
||||
line = TrimAndStripInlineComments(line)
|
||||
if len(line) == 0 {
|
||||
continue
|
||||
}
|
||||
ip := net.ParseIP(line)
|
||||
|
|
|
@ -94,8 +94,8 @@ func (plugin *PluginBlockName) Init(proxy *Proxy) error {
|
|||
patternMatcher: NewPatternPatcher(),
|
||||
}
|
||||
for lineNo, line := range strings.Split(string(bin), "\n") {
|
||||
line = strings.TrimFunc(line, unicode.IsSpace)
|
||||
if len(line) == 0 || strings.HasPrefix(line, "#") {
|
||||
line = TrimAndStripInlineComments(line)
|
||||
if len(line) == 0 {
|
||||
continue
|
||||
}
|
||||
parts := strings.Split(line, "@")
|
||||
|
|
|
@ -45,8 +45,8 @@ func (plugin *PluginCloak) Init(proxy *Proxy) error {
|
|||
plugin.patternMatcher = NewPatternPatcher()
|
||||
cloakedNames := make(map[string]*CloakedName)
|
||||
for lineNo, line := range strings.Split(string(bin), "\n") {
|
||||
line = strings.TrimFunc(line, unicode.IsSpace)
|
||||
if len(line) == 0 || strings.HasPrefix(line, "#") {
|
||||
line = TrimAndStripInlineComments(line)
|
||||
if len(line) == 0 {
|
||||
continue
|
||||
}
|
||||
var target string
|
||||
|
|
|
@ -35,8 +35,8 @@ func (plugin *PluginForward) Init(proxy *Proxy) error {
|
|||
return err
|
||||
}
|
||||
for lineNo, line := range strings.Split(string(bin), "\n") {
|
||||
line = strings.TrimFunc(line, unicode.IsSpace)
|
||||
if len(line) == 0 || strings.HasPrefix(line, "#") {
|
||||
line = TrimAndStripInlineComments(line)
|
||||
if len(line) == 0 {
|
||||
continue
|
||||
}
|
||||
domain, serversStr, ok := StringTwoFields(line)
|
||||
|
|
|
@ -37,8 +37,8 @@ func (plugin *PluginWhitelistName) Init(proxy *Proxy) error {
|
|||
plugin.allWeeklyRanges = proxy.allWeeklyRanges
|
||||
plugin.patternMatcher = NewPatternPatcher()
|
||||
for lineNo, line := range strings.Split(string(bin), "\n") {
|
||||
line = strings.TrimFunc(line, unicode.IsSpace)
|
||||
if len(line) == 0 || strings.HasPrefix(line, "#") {
|
||||
line = TrimAndStripInlineComments(line)
|
||||
if len(line) == 0 {
|
||||
continue
|
||||
}
|
||||
parts := strings.Split(line, "@")
|
||||
|
|
Loading…
Reference in New Issue