Skip to content

Commit

Permalink
all: upd chlog
Browse files Browse the repository at this point in the history
  • Loading branch information
schzhn committed Apr 11, 2024
1 parent c8184be commit decb768
Show file tree
Hide file tree
Showing 2 changed files with 8 additions and 4 deletions.
3 changes: 3 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,6 +25,8 @@ NOTE: Add new changes BELOW THIS COMMENT.

### Added

- Support for link-local subnets, i.e. `fe80::/16`, in the access settings
([#6192]).
- Support for comments in the ipset file ([#5345]).

### Fixed
Expand All @@ -36,6 +38,7 @@ NOTE: Add new changes BELOW THIS COMMENT.
([#6875]).

[#5345]: https://github.com/AdguardTeam/AdGuardHome/issues/5345
[#6192]: https://github.com/AdguardTeam/AdGuardHome/issues/6192
[#6854]: https://github.com/AdguardTeam/AdGuardHome/issues/6854
[#6875]: https://github.com/AdguardTeam/AdGuardHome/issues/6875

Expand Down
9 changes: 5 additions & 4 deletions internal/dnsforward/access.go
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,7 @@ func processAccessClients(
var ip netip.Addr
var ipnet netip.Prefix
if ip, err = netip.ParseAddr(s); err == nil {
ips.Add(ip.WithZone(""))
ips.Add(ip)
} else if ipnet, err = netip.ParsePrefix(s); err == nil {
*nets = append(*nets, ipnet)
} else {
Expand Down Expand Up @@ -140,8 +140,6 @@ func (a *accessManager) isBlockedHost(host string, qt rules.RRType) (ok bool) {
// isBlockedIP returns the status of the IP address blocking as well as the rule
// that blocked it.
func (a *accessManager) isBlockedIP(ip netip.Addr) (blocked bool, rule string) {
ip = ip.WithZone("")

blocked = true
ips := a.blockedIPs
ipnets := a.blockedNets
Expand All @@ -158,7 +156,10 @@ func (a *accessManager) isBlockedIP(ip netip.Addr) (blocked bool, rule string) {
}

for _, ipnet := range ipnets {
if ipnet.Contains(ip) {
// Remove zone before checking because prefixes stip zones.
//
// TODO(d.kolyshev): Cover with tests.
if ipnet.Contains(ip.WithZone("")) {
return blocked, ipnet.String()
}
}
Expand Down

0 comments on commit decb768

Please sign in to comment.