diff options
author | Christian Breunig <christian@breunig.cc> | 2025-03-31 17:58:49 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2025-03-31 17:58:49 +0200 |
commit | a6ff1933a99a9b43a70f030647287bad6b9a8bbd (patch) | |
tree | 3271a16350c3eea111d12d729361b7de47259944 /src | |
parent | 5ec0a28f6b5bc85aed1ba13a0d96b0128b5bb8e9 (diff) | |
parent | 1f82952b36c75d3b3965f4837b815aef8d307d5b (diff) | |
download | vyos-1x-a6ff1933a99a9b43a70f030647287bad6b9a8bbd.tar.gz vyos-1x-a6ff1933a99a9b43a70f030647287bad6b9a8bbd.zip |
Merge pull request #4424 from c-po/acme-race-T7299
pki: T7299: race condition for acme requested certificates / CA chain
Diffstat (limited to 'src')
-rwxr-xr-x | src/conf_mode/pki.py | 12 |
1 files changed, 10 insertions, 2 deletions
diff --git a/src/conf_mode/pki.py b/src/conf_mode/pki.py index acea2c9be..724f97555 100755 --- a/src/conf_mode/pki.py +++ b/src/conf_mode/pki.py @@ -440,13 +440,21 @@ def generate(pki): for name, cert_conf in pki['certificate'].items(): if 'acme' in cert_conf: certbot_list.append(name) - # generate certificate if not found on disk + # There is no ACME/certbot managed certificate presend on the + # system, generate it if name not in certbot_list_on_disk: certbot_request(name, cert_conf['acme'], dry_run=False) + # Now that the certificate was properly generated we have + # the PEM files on disk. We need to add the certificate to + # certbot_list_on_disk to automatically import the CA chain + certbot_list_on_disk.append(name) + # We alredy had an ACME managed certificate on the system, but + # something changed in the configuration elif changed_certificates != None and name in changed_certificates: - # when something for the certificate changed, we should delete it + # Delete old ACME certificate first if name in certbot_list_on_disk: certbot_delete(name) + # Request new certificate via certbot certbot_request(name, cert_conf['acme'], dry_run=False) # Cleanup certbot configuration and certificates if no longer in use by CLI |