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.

8.3. Management task

The task of keyset management is performed in several steps:

  1. Loads selected domains and all name servers of insecured domains from their nssets, and sorts them in the scan queue.

  2. 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.

  3. Notifies technical contacts of the nssets about the initiated or broken acceptance period (insecure domains only).

  4. Updates keys:

    • checks if the domain has a blocking status (e.g. serverblocked and deletecandidate `), AKM ignores the ``serverUpdateProhibited` status

    • 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) and notifies technical contacts of nssets,

    • 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-scanner from the fred/cdnskey-scanner project
      • scans for the existence of CDNSKEY records for the specified set of domains

  • Control part of AKM (CDNSKEY processor)
    • binary fred-akm-ng from the fred/akm-ng project
      • via the gRPC API to/from the cdnskey-processor-api service, it exports a list of domains to scan obtained from the fred registry database or obtains a list of accepted CDNSKEY entries and applies them back to the registry

    • binary cdnskey-processor-api from the fred/cdnskey-processor project
      • via the gRPC API allows to specify a list of domains to scan and get a list of scanned CDNSKEY records

      • stores and retrieves data from the PostgreSQL database cdnskey_processor, runs every 10 minutes

    • binary cdnskey-processor-master from 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 cdnskey-processor-worker from the fred/cdnskey-processor project
      • from rabbitMQ reads the domain sets to be scanned from master

      • runs cdnskey-scanner

      • writes the scan results for master to rabbitMQ

  • testing tools
    • binary cdnskey-processor-db-loader from the fred/cdnskey-processor project
      • used to set up data in the cdnskey_processor database for testing purposes

See also the overall architecture for component relations.

8.5. Notifications

The AKM task triggers the following notifications:

The utilized EPP operations (create_keyset, update_domain) trigger additional notifications of their own:

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 CDNSKEY record with values: flags, protocol, algorithm, public key.

  • insecure-empty
    • Nameserver on the IP address for the unsecured domain doesn’t contain a CDNSKEY record.

  • secure
    • For secured domain exists a CDNSKEY record with trustworthy signature and values: flags, protocol, algorithm, public key.

  • secure-empty
    • For secured domain there is no trustworthy CDNSKEY record.

  • untrustworthy
    • (Non)Existence of CDNSKEY record 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.