p2p: allow CIDR notation in DNS blocklist

This commit is contained in:
moneromooo-monero 2021-01-20 15:18:39 +00:00
parent a7663f4ba1
commit 57edfd78fd
No known key found for this signature in database
GPG Key ID: 686F07454D6CEFC3
1 changed files with 13 additions and 6 deletions

View File

@ -2002,15 +2002,22 @@ namespace nodetool
{ {
if (ip.empty()) if (ip.empty())
continue; continue;
const expect<epee::net_utils::network_address> parsed_addr = net::get_network_address(ip, 0); auto subnet = net::get_ipv4_subnet_address(ip);
if (!parsed_addr) if (subnet)
{ {
MWARNING("Invalid IP address from DNS blocklist: " << ip << " - " << parsed_addr.error()); block_subnet(*subnet, DNS_BLOCKLIST_LIFETIME);
++bad; ++good;
continue; continue;
} }
block_host(*parsed_addr, DNS_BLOCKLIST_LIFETIME, true); const expect<epee::net_utils::network_address> parsed_addr = net::get_network_address(ip, 0);
++good; if (parsed_addr)
{
block_host(*parsed_addr, DNS_BLOCKLIST_LIFETIME, true);
++good;
continue;
}
MWARNING("Invalid IP address or subnet from DNS blocklist: " << ip << " - " << parsed_addr.error());
++bad;
} }
} }
if (good > 0) if (good > 0)