Blame SOURCES/0007-Wipe-the-ipa-ca-DNS-record-when-updating-system-records_rhbz#2158775.patch

711f45
From b35c75d864040b98ed3f9214d5d17d32f06d6ee1 Mon Sep 17 00:00:00 2001
711f45
From: Rob Crittenden <rcritten@redhat.com>
711f45
Date: Mon, 11 Jul 2022 14:20:32 -0400
711f45
Subject: [PATCH] Wipe the ipa-ca DNS record when updating system records
711f45
711f45
If a server with a CA has been marked as hidden and
711f45
contains the last A or AAAA address then that address
711f45
would remain in the ipa-ca entry.
711f45
711f45
This is because update-dns-system-records did not delete
711f45
values, it just re-computed them. So if no A or AAAA
711f45
records were found then the existing value was left.
711f45
711f45
Fixes: https://pagure.io/freeipa/issue/9195
711f45
711f45
Signed-off-by: Rob Crittenden <rcritten@redhat.com>
711f45
---
711f45
 ipaserver/dns_data_management.py | 12 +++++++++++-
711f45
 1 file changed, 11 insertions(+), 1 deletion(-)
711f45
711f45
diff --git a/ipaserver/dns_data_management.py b/ipaserver/dns_data_management.py
711f45
index e2bc530ee8a..aaae5446856 100644
711f45
--- a/ipaserver/dns_data_management.py
711f45
+++ b/ipaserver/dns_data_management.py
711f45
@@ -19,6 +19,7 @@
711f45
 from time import sleep, time
711f45
 
711f45
 from ipalib import errors
711f45
+from ipalib.constants import IPA_CA_RECORD
711f45
 from ipalib.dns import record_name_format
711f45
 from ipapython.dnsutil import DNSName
711f45
 from ipaserver.install import installutils
711f45
@@ -187,7 +188,7 @@ def __add_uri_records(
711f45
 
711f45
     def __add_ca_records_from_hostname(self, zone_obj, hostname):
711f45
         assert isinstance(hostname, DNSName) and hostname.is_absolute()
711f45
-        r_name = DNSName('ipa-ca') + self.domain_abs
711f45
+        r_name = DNSName(IPA_CA_RECORD) + self.domain_abs
711f45
         rrsets = None
711f45
         end_time = time() + CA_RECORDS_DNS_TIMEOUT
711f45
         while True:
711f45
@@ -210,6 +211,7 @@ def __add_ca_records_from_hostname(self, zone_obj, hostname):
711f45
 
711f45
         for rrset in rrsets:
711f45
             for rd in rrset:
711f45
+                logger.debug("Adding CA IP %s for %s", rd.to_text(), hostname)
711f45
                 rdataset = zone_obj.get_rdataset(
711f45
                     r_name, rd.rdtype, create=True)
711f45
                 rdataset.add(rd, ttl=self.TTL)
711f45
@@ -461,6 +463,14 @@ def update_base_records(self):
711f45
             )
711f45
         )
711f45
 
711f45
+        # Remove the ipa-ca record(s). They will be reconstructed in
711f45
+        # get_base_records().
711f45
+        r_name = DNSName(IPA_CA_RECORD) + self.domain_abs
711f45
+        try:
711f45
+            self.api_instance.Command.dnsrecord_del(
711f45
+                self.domain_abs, r_name, del_all=True)
711f45
+        except errors.NotFound:
711f45
+            pass
711f45
         base_zone = self.get_base_records()
711f45
         for record_name, node in base_zone.items():
711f45
             set_cname_template = record_name in names_requiring_cname_templates