summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorChristian Breunig <christian@breunig.cc>2025-03-31 17:58:49 +0200
committerGitHub <noreply@github.com>2025-03-31 17:58:49 +0200
commita6ff1933a99a9b43a70f030647287bad6b9a8bbd (patch)
tree3271a16350c3eea111d12d729361b7de47259944 /src
parent5ec0a28f6b5bc85aed1ba13a0d96b0128b5bb8e9 (diff)
parent1f82952b36c75d3b3965f4837b815aef8d307d5b (diff)
downloadvyos-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-xsrc/conf_mode/pki.py12
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