Fix geosite usage

This commit is contained in:
世界 2024-01-23 11:05:37 +08:00
parent 9fb2abc833
commit 17101f7d11
No known key found for this signature in database
GPG Key ID: CD109927C34A63C4
3 changed files with 18 additions and 88 deletions

View File

@ -114,47 +114,17 @@ func (t *Template) renderDNS(metadata M.Metadata, options *option.Options) error
if !t.DisableTrafficBypass { if !t.DisableTrafficBypass {
if t.DisableRuleSet || (metadata.Version != nil && metadata.Version.LessThan(semver.ParseVersion("1.8.0-alpha.10"))) { if t.DisableRuleSet || (metadata.Version != nil && metadata.Version.LessThan(semver.ParseVersion("1.8.0-alpha.10"))) {
options.DNS.Rules = append(options.DNS.Rules, option.DNSRule{ options.DNS.Rules = append(options.DNS.Rules, option.DNSRule{
Type: C.RuleTypeLogical,
LogicalOptions: option.LogicalDNSRule{
Mode: C.LogicalTypeAnd,
Rules: []option.DNSRule{
{
Type: C.RuleTypeDefault, Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultDNSRule{ DefaultOptions: option.DefaultDNSRule{
Geosite: []string{"geolocation-!cn"}, Geosite: []string{"geolocation-cn"},
Invert: true,
},
},
{
Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultDNSRule{
Geosite: []string{"cn"},
},
},
},
Server: DNSLocalTag, Server: DNSLocalTag,
}, },
}) })
} else { } else {
options.DNS.Rules = append(options.DNS.Rules, option.DNSRule{ options.DNS.Rules = append(options.DNS.Rules, option.DNSRule{
Type: C.RuleTypeLogical,
LogicalOptions: option.LogicalDNSRule{
Mode: C.LogicalTypeAnd,
Rules: []option.DNSRule{
{
Type: C.RuleTypeDefault, Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultDNSRule{ DefaultOptions: option.DefaultDNSRule{
RuleSet: []string{"geosite-geolocation-!cn"}, RuleSet: []string{"geosite-geolocation-cn"},
Invert: true,
},
},
{
Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultDNSRule{
RuleSet: []string{"geosite-cn"},
},
},
},
Server: DNSLocalTag, Server: DNSLocalTag,
}, },
}) })

View File

@ -68,19 +68,10 @@ func (t *Template) renderGeoResources(metadata M.Metadata, options *option.Optio
}, },
{ {
Type: C.RuleSetTypeRemote, Type: C.RuleSetTypeRemote,
Tag: "geosite-cn", Tag: "geosite-geolocation-cn",
Format: C.RuleSetFormatBinary, Format: C.RuleSetFormatBinary,
RemoteOptions: option.RemoteRuleSet{ RemoteOptions: option.RemoteRuleSet{
URL: downloadURL + "SagerNet/sing-geosite" + branchSplit + "rule-set/geosite-cn.srs", URL: downloadURL + "SagerNet/sing-geosite" + branchSplit + "rule-set/geosite-geolocation-cn.srs",
DownloadDetour: downloadDetour,
},
},
{
Type: C.RuleSetTypeRemote,
Tag: "geosite-geolocation-!cn",
Format: C.RuleSetFormatBinary,
RemoteOptions: option.RemoteRuleSet{
URL: downloadURL + "SagerNet/sing-geosite" + branchSplit + "rule-set/geosite-geolocation-!cn.srs",
DownloadDetour: downloadDetour, DownloadDetour: downloadDetour,
}, },
}, },

View File

@ -121,50 +121,19 @@ func (t *Template) renderRoute(metadata M.Metadata, options *option.Options) err
if !t.DisableTrafficBypass { if !t.DisableTrafficBypass {
if t.DisableRuleSet || disable18Features { if t.DisableRuleSet || disable18Features {
options.Route.Rules = append(options.Route.Rules, option.Rule{ options.Route.Rules = append(options.Route.Rules, option.Rule{
Type: C.RuleTypeLogical,
LogicalOptions: option.LogicalRule{
Mode: C.LogicalTypeAnd,
Rules: []option.Rule{
{
Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultRule{
Geosite: []string{"geolocation-!cn"},
Invert: true,
},
},
{
Type: C.RuleTypeDefault, Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultRule{ DefaultOptions: option.DefaultRule{
GeoIP: []string{"cn"}, GeoIP: []string{"cn"},
Geosite: []string{"cn"}, Geosite: []string{"geolocation-cn"},
Domain: []string{"download.jetbrains.com"},
},
},
},
Outbound: directTag, Outbound: directTag,
}, },
}) })
} else { } else {
options.Route.Rules = append(options.Route.Rules, option.Rule{ options.Route.Rules = append(options.Route.Rules, option.Rule{
Type: C.RuleTypeLogical,
LogicalOptions: option.LogicalRule{
Mode: C.LogicalTypeAnd,
Rules: []option.Rule{
{
Type: C.RuleTypeDefault, Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultRule{ DefaultOptions: option.DefaultRule{
RuleSet: []string{"geosite-geolocation-!cn"}, RuleSet: []string{"geoip-cn", "geosite-geolocation-cn"},
Invert: true, Outbound: directTag,
},
},
{
Type: C.RuleTypeDefault,
DefaultOptions: option.DefaultRule{
RuleSet: []string{"geoip-cn", "geosite-cn"},
},
},
},
Outbound: "direct",
}, },
}) })
} }