8. Automated keyset management¶
AKM is based on the two RFCs:
- RFC 7344 Automating DNSSEC Delegation Trust Maintenance, 
- RFC 8078 Managing DS Records from the Parent via CDS/CDNSKEY. 
Domains are included in the AKM strictly on demand when they publish valid CDNSKEY resource records [1] on domains’ name servers. Registrants are supposed to ask their DNS operators to do so or not to do so.
Tip
The KnotDNS can be easily configured to support automatic key management.
A CDNSKEY contains the KSK of a child zone (domain) solely for the purpose to request updates to DS records in the parent zone (Registry). DS records are calculated by the Registry; see also zone generation concept.
The CDNSKEY resource records are recognized by the FRED as valid when they comply with the same constraints as the rest of managed keysets – see keyset attributes in the EPP Reference Manual.
A special case is the “delete key” (CDNSKEY 0 3 0 AA==) which can be
published to request removal of a domain from AKM.
8.1. Security status cases¶
The Registry handles the request for update according to the security status of a domain:
- an insecured domain (registered without a keyset) requests to be included in AKM, 
- a domain secured with a manually-managed keyset requests to be switched to AKM, 
- a domain secured with an auto-managed keyset requests to update the keys. 
8.2. Acceptance of new keys¶
When introducing a new domain in AKM, the Registry handles differently domains which do not register yet as DNSSEC-enabled (without a keyset, insecured) and those that are secured with a keyset:
- When a domain is already secured with a keyset, adoption of new keys happens immediately because the new keys can be authenticated using the old keys, and the domain is switched to AKM. 
- When a domain is not secured yet, the detected keys must undergo the acceptance period during which they must remain valid and unchanged on all name servers in the associated nsset. The acceptance period acts as a security measure instead of key authentication. After the keys pass the acceptance period successfully, then they are adopted and the domain is switched to AKM. 
The acceptance period is initiated when valid CDNSKEY resource records are found for the first time during a scan. In subsequent scans, the records must be found again in exactly the same state and on all the name servers as before, otherwise the acceptance period is broken and the whole process must be restarted.
In special cases where there is a network unavailability of all domain nameservers, AKM-NG ignores the invalid scan results. However, valid scans of the original responses must occure so that there is less than 48 hours between two valid neighboring scans.
8.3. Management task¶
The task of keyset management is performed in several steps:
- Loads selected domains and all name servers of insecured domains from their nssets, and sorts them in the scan queue. 
- Scans domains in the scan queue: - if a domain is insecured, name servers are asked by the scanner directly via TCP queries whether they have CDNSKEY records for domains, 
- if a domain is secured, the CDNSKEY records are requested via a local resolver and a response is validated with DNSSEC inside the scanner, 
 - and saves the results. 
- Updates keys: - checks if the domain has a blocking status (e.g. - serverblockedand- deletecandidate), AKM ignores the- serverUpdateProhibitedstatus,
- applies new keys if they have passed the acceptance period (EPP operations create_keyset & update_domain), 
- switches domains to AKM if they have been secured and they have requested AKM (EPP operations create_keyset & update_domain), 
- updates auto-managed keysets (AKM keyset update operation), 
- removes auto-managed keysets where removal from AKM has been requested (EPP operation update_domain). 
 
See also the AKM periodic task.
8.4. Components¶
The AKM subsystem includes the following components:
- CDNSKEY scanner
- binary cdnskey-scannerfrom the fred/cdnskey-scanner project
- scans for the existence of - CDNSKEYrecords for the specified set of domains
 
 
- binary 
 
 
- Control part of AKM (CDNSKEY processor)
- binary fred-akm-ngfrom the fred/akm-ng project
- via the gRPC API to/from the - cdnskey-processor-apiservice, it exports a list of domains to scan obtained from the- fredregistry database or obtains a list of accepted- CDNSKEYentries and applies them back to the registry
 
 
- binary 
- binary cdnskey-processor-apifrom the fred/cdnskey-processor project
- via the gRPC API allows to specify a list of domains to scan and get a list of scanned - CDNSKEYrecords
- stores and retrieves data from the PostgreSQL database - cdnskey_processor, runs every 10 minutes
 
 
- binary 
- binary cdnskey-processor-masterfrom the fred/cdnskey-processor project
- stores and retrieves data from the PostgreSQL database - cdnskey_processor
- divides the set of domains to be scanned into smaller parts and sends them to worker via - rabbitMQ
- reads the scan results of worker from - rabbitMQ
 
 
- binary 
- binary cdnskey-processor-workerfrom the fred/cdnskey-processor project
- from - rabbitMQreads the domain sets to be scanned from master
- runs - cdnskey-scanner
- writes the scan results for master to - rabbitMQ
 
 
- binary 
 
 
- testing tools
- binary cdnskey-processor-db-loaderfrom the fred/cdnskey-processor project
- used to set up data in the - cdnskey_processordatabase for testing purposes
 
 
- binary 
 
 
See also the overall architecture for component relations.
8.5. Notifications¶
The utilized EPP operations (create_keyset, update_domain) trigger the following notifications:
8.6. Scan results¶
Scan results are webwhois extension of the domain name details page.
Secured domain is a domain with DNSSEC. Unsecured domain is a domain without DNSSEC.
The following results are possible:
- insecure
- Nameserver on the IP address contains for the unsecured domain a - CDNSKEYrecord with values: flags, protocol, algorithm, public key.
 
 
- insecure-empty
- Nameserver on the IP address for the unsecured domain doesn’t contain a - CDNSKEYrecord.
 
 
- secure
- For secured domain exists a - CDNSKEYrecord with trustworthy signature and values: flags, protocol, algorithm, public key.
 
 
- secure-empty
- For secured domain there is no trustworthy - CDNSKEYrecord.
 
 
- untrustworthy
- (Non)Existence of - CDNSKEYrecord for secured domain could not be reliably verified.
 
 
- unknown
- No information could be obtained from the DNS about a secured domain. 
 
 
- unresolved
- No information could be obtained from the nameserver on the IP address about the unsecured domain. 
 
 
- unresolved-ip
- Unable to obtain any IP address of the nameserver.