]> git.ipfire.org Git - thirdparty/bind9.git/commitdiff
Report non-effective primaries
authorMark Andrews <marka@isc.org>
Wed, 29 Nov 2023 01:35:20 +0000 (12:35 +1100)
committerMark Andrews <marka@isc.org>
Mon, 3 Jun 2024 08:34:31 +0000 (18:34 +1000)
When named is started with -4 or -6 and the primaries for a zone
do not have an IPv4 or IPv6 address respectively issue a log message.

lib/dns/zone.c

index a28cd78a4322ad27e6e53303f82a96db567856a2..8aaeec0cc6ded0ae6e994354ad70b079c25d7b55 100644 (file)
@@ -5910,6 +5910,32 @@ unlock:
        UNLOCK_ZONE(zone);
 }
 
+static bool
+has_pf(isc_sockaddr_t *addresses, size_t count, int pf) {
+       for (size_t i = 0; i < count; i++) {
+               if (isc_sockaddr_pf(&addresses[i]) == pf) {
+                       return (true);
+               }
+       }
+       return (false);
+}
+
+static void
+report_no_active_addresses(dns_zone_t *zone, isc_sockaddr_t *addresses,
+                          size_t count, const char *what) {
+       if (isc_net_probeipv4() == ISC_R_DISABLED) {
+               if (!has_pf(addresses, count, AF_INET6)) {
+                       dns_zone_log(zone, ISC_LOG_NOTICE,
+                                    "IPv4 disabled and no IPv6 %s", what);
+               }
+       } else if (isc_net_probeipv6() == ISC_R_DISABLED) {
+               if (!has_pf(addresses, count, AF_INET)) {
+                       dns_zone_log(zone, ISC_LOG_NOTICE,
+                                    "IPv6 disabled and no IPv4 %s", what);
+               }
+       }
+}
+
 void
 dns_zone_setprimaries(dns_zone_t *zone, isc_sockaddr_t *addresses,
                      isc_sockaddr_t *sources, dns_name_t **keynames,
@@ -5950,6 +5976,8 @@ dns_zone_setprimaries(dns_zone_t *zone, isc_sockaddr_t *addresses,
                goto unlock;
        }
 
+       report_no_active_addresses(zone, addresses, count, "primaries");
+
        /*
         * Now set up the primaries and primary key lists.
         */