Pull request 2005: 6181-safebrowsing-default

Updates #6181.

Squashed commit of the following:

commit 3c4d0fe0750823c81548c2e81988ec27c718028f
Author: Ainar Garipov <A.Garipov@AdGuard.COM>
Date:   Fri Sep 8 14:23:13 2023 +0300

    home: fix default safe browsing, parental
This commit is contained in:
Ainar Garipov 2023-09-08 15:04:25 +03:00
parent 62da8f4974
commit 5f696da9dc
4 changed files with 35 additions and 8 deletions

View File

@ -23,6 +23,13 @@ See also the [v0.107.38 GitHub milestone][ms-v0.107.38].
NOTE: Add new changes BELOW THIS COMMENT. NOTE: Add new changes BELOW THIS COMMENT.
--> -->
### Fixed
- Empty or default Safe Browsing and Parental Control settings ([#6181]).
- Various UI issues.
[#6181]: https://github.com/AdguardTeam/AdGuardHome/issues/6181
<!-- <!--
NOTE: Add new changes ABOVE THIS COMMENT. NOTE: Add new changes ABOVE THIS COMMENT.
--> -->

View File

@ -282,6 +282,12 @@ type statsConfig struct {
Enabled bool `yaml:"enabled"` Enabled bool `yaml:"enabled"`
} }
// Default block host constants.
const (
defaultSafeBrowsingBlockHost = "standard-block.dns.adguard.com"
defaultParentalBlockHost = "family-block.dns.adguard.com"
)
// config is the global configuration structure. // config is the global configuration structure.
// //
// TODO(a.garipov, e.burkov): This global is awful and must be removed. // TODO(a.garipov, e.burkov): This global is awful and must be removed.
@ -389,6 +395,9 @@ var config = &configuration{
Schedule: schedule.EmptyWeekly(), Schedule: schedule.EmptyWeekly(),
IDs: []string{}, IDs: []string{},
}, },
ParentalBlockHost: defaultParentalBlockHost,
SafeBrowsingBlockHost: defaultSafeBrowsingBlockHost,
}, },
DHCP: &dhcpd.ServerConfig{ DHCP: &dhcpd.ServerConfig{
LocalDomainName: "lan", LocalDomainName: "lan",

View File

@ -359,9 +359,6 @@ func setupDNSFilteringConf(conf *filtering.Config) (err error) {
pcService = "parental control" pcService = "parental control"
defaultParentalServer = `https://family.adguard-dns.com/dns-query` defaultParentalServer = `https://family.adguard-dns.com/dns-query`
pcTXTSuffix = `pc.dns.adguard.com.` pcTXTSuffix = `pc.dns.adguard.com.`
defaultSafeBrowsingBlockHost = "standard-block.dns.adguard.com"
defaultParentalBlockHost = "family-block.dns.adguard.com"
) )
conf.EtcHosts = Context.etcHosts conf.EtcHosts = Context.etcHosts
@ -398,8 +395,15 @@ func setupDNSFilteringConf(conf *filtering.Config) (err error) {
CacheSize: conf.SafeBrowsingCacheSize, CacheSize: conf.SafeBrowsingCacheSize,
}) })
if conf.SafeBrowsingBlockHost != "" { // Protect against invalid configuration, see #6181.
conf.SafeBrowsingBlockHost = defaultSafeBrowsingBlockHost //
// TODO(a.garipov): Validate against an empty host instead of setting it to
// default.
if conf.SafeBrowsingBlockHost == "" {
host := defaultSafeBrowsingBlockHost
log.Info("%s: warning: empty blocking host; using default: %q", sbService, host)
conf.SafeBrowsingBlockHost = host
} }
parUps, err := upstream.AddressToUpstream(defaultParentalServer, upsOpts) parUps, err := upstream.AddressToUpstream(defaultParentalServer, upsOpts)
@ -415,8 +419,15 @@ func setupDNSFilteringConf(conf *filtering.Config) (err error) {
CacheSize: conf.ParentalCacheSize, CacheSize: conf.ParentalCacheSize,
}) })
if conf.ParentalBlockHost != "" { // Protect against invalid configuration, see #6181.
conf.ParentalBlockHost = defaultParentalBlockHost //
// TODO(a.garipov): Validate against an empty host instead of setting it to
// default.
if conf.ParentalBlockHost == "" {
host := defaultParentalBlockHost
log.Info("%s: warning: empty blocking host; using default: %q", pcService, host)
conf.ParentalBlockHost = host
} }
conf.SafeSearchConf.CustomResolver = safeSearchResolver{} conf.SafeSearchConf.CustomResolver = safeSearchResolver{}

View File

@ -30,7 +30,7 @@ const (
twoskyURI = "https://twosky.int.agrd.dev/api/v1" twoskyURI = "https://twosky.int.agrd.dev/api/v1"
readLimit = 1 * 1024 * 1024 readLimit = 1 * 1024 * 1024
uploadTimeout = 10 * time.Second uploadTimeout = 20 * time.Second
) )
// blockerLangCodes is the codes of languages which need to be fully translated. // blockerLangCodes is the codes of languages which need to be fully translated.