diff options
Diffstat (limited to 'src')
| -rwxr-xr-x | src/conf_mode/pki.py | 29 | ||||
| -rwxr-xr-x | src/init/vyos-router | 6 | 
2 files changed, 35 insertions, 0 deletions
| diff --git a/src/conf_mode/pki.py b/src/conf_mode/pki.py index 4ff15d56e..acea2c9be 100755 --- a/src/conf_mode/pki.py +++ b/src/conf_mode/pki.py @@ -50,6 +50,7 @@ from vyos import airbag  airbag.enable()  vyos_certbot_dir = directories['certbot'] +vyos_ca_certificates_dir = directories['ca_certificates']  # keys to recursively search for under specified path  sync_search = [ @@ -397,10 +398,33 @@ def verify(pki):      return None +def cleanup_system_ca(): +    if not os.path.exists(vyos_ca_certificates_dir): +        os.mkdir(vyos_ca_certificates_dir) +    else: +        for filename in os.listdir(vyos_ca_certificates_dir): +            full_path = os.path.join(vyos_ca_certificates_dir, filename) +            if os.path.isfile(full_path): +                os.unlink(full_path) +  def generate(pki):      if not pki: +        cleanup_system_ca()          return None +    # Create or cleanup CA install directory +    if 'changed' in pki and 'ca' in pki['changed']: +        cleanup_system_ca() + +        if 'ca' in pki: +            for ca, ca_conf in pki['ca'].items(): +                if 'system_install' in ca_conf: +                    ca_obj = load_certificate(ca_conf['certificate']) +                    ca_path = os.path.join(vyos_ca_certificates_dir, f'{ca}.crt') + +                    with open(ca_path, 'w') as f: +                        f.write(encode_certificate(ca_obj)) +      # Certbot renewal only needs to re-trigger the services to load up the      # new PEM file      if 'certbot_renew' in pki: @@ -467,6 +491,7 @@ def apply(pki):      systemd_certbot_name = 'certbot.timer'      if not pki:          call(f'systemctl stop {systemd_certbot_name}') +        call('update-ca-certificates')          return None      has_certbot = False @@ -484,6 +509,10 @@ def apply(pki):      if 'changed' in pki:          call_dependents() +        # Rebuild ca-certificates bundle +        if 'ca' in pki['changed']: +            call('update-ca-certificates') +      return None  if __name__ == '__main__': diff --git a/src/init/vyos-router b/src/init/vyos-router index 8825cc16a..f8cc87507 100755 --- a/src/init/vyos-router +++ b/src/init/vyos-router @@ -471,6 +471,12 @@ start ()          touch /tmp/vyos.smoketest.debug      fi +    # Cleanup PKI CAs +    if [ -d /usr/local/share/ca-certificates/vyos ]; then +        rm -f /usr/local/share/ca-certificates/vyos/*.crt +        update-ca-certificates >/dev/null 2>&1 +    fi +      log_action_begin_msg "Mounting VyOS Config"      # ensure the vyatta_configdir supports a large number of inodes since      # the config hierarchy is often inode-bound (instead of size). | 
