HomeVyOS Platform

pki: T5886: add support for ACME protocol (LetsEncrypt)

This commit no longer exists in the repository. It may have been part of a branch which was deleted.This commit has been deleted in the repository: it is no longer reachable from any branch, tag, or ref.

Description

pki: T5886: add support for ACME protocol (LetsEncrypt)

The "idea" of this PR is to add new CLI nodes under the pki subsystem to
activate ACME for any given certificate.

vyos@vyos# set pki certificate NAME acme
Possible completions:
+ domain-name Domain Name

email                Email address to associate with certificate
listen-address       Local IPv4 addresses to listen on
rsa-key-size         Size of the RSA key (default: 2048)
url                  Remote URL (default:
                     https://acme-v02.api.letsencrypt.org/directory)

Users choose if the CLI based custom certificates are used

set pki certificate EXAMPLE acme certificate <base64>

or if it should be generated via ACME.

The ACME server URL defaults to LetsEncrypt but can be changed to their staging
API for testing to not get blacklisted.

set pki certificate EXAMPLE acme url https://acme-staging-v02.api.letsencrypt.org/directory

Certificate retrieval has a certbot --dry-run stage in verify() to see if it
can be generated.

After successful generation, the certificate is stored in under
/config/auth/letsencrypt. Once a certificate is referenced in the CLI (e.g. set
interfaces ethernet eth0 eapol certificate EXAMPLE) we call
vyos.config.get_config_dict() which will (if with_pki=True is set) blend in the
base64 encoded certificate into the JSON data structure normally used when
using a certificate set by the CLI.

Using this "design" does not need any change to any other code referencing the
PKI system, as the base64 encoded certificate is already there.

certbot renewal will call the PKI python script to trigger dependency updates.

(cherry picked from commit b8db1a9d7baf91b70c1b735e58710f1e2bc9fc7a)

  1. Conflicts:
  2. debian/control

Details

Provenance
c-poAuthored on Jan 5 2024, 9:27 PM
MergifyCommitted on Jan 8 2024, 8:06 PM

Event Timeline

Commit No Longer Exists

This commit no longer exists in the repository.