diff options
author | Christian Pointner <equinox@spreadspace.org> | 2019-10-13 17:29:11 +0200 |
---|---|---|
committer | Christian Pointner <equinox@spreadspace.org> | 2019-10-13 17:29:11 +0200 |
commit | b523cf86c8cbedb43cf625a1a847ca828afd5fba (patch) | |
tree | fd48b4d7792ca75c31d197414ba8463e57cade1e /roles/nginx/vhost/tasks/acme.yml | |
parent | nextcloud: fix systemd timer shuffling (diff) |
nextcloud basic installation is finally working properly
Diffstat (limited to 'roles/nginx/vhost/tasks/acme.yml')
-rw-r--r-- | roles/nginx/vhost/tasks/acme.yml | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/roles/nginx/vhost/tasks/acme.yml b/roles/nginx/vhost/tasks/acme.yml new file mode 100644 index 00000000..99ad7856 --- /dev/null +++ b/roles/nginx/vhost/tasks/acme.yml @@ -0,0 +1,44 @@ +--- +- name: check if acme certs already exist + loop: "{{ nginx_vhost.hostnames }}" + loop_control: + loop_var: acme_hostname + stat: + path: "/var/lib/acme/live/{{ acme_hostname }}" + register: acme_cert_stat + +- name: set acmecert_missing_hostnames variable + set_fact: + acmecert_missing_hostnames: "{{ acme_cert_stat.results | acme_cert_nonexistent(nginx_vhost.hostnames) }}" + +- name: link nonexistent hostnames to self-signed interim cert + when: acmecert_missing_hostnames | length > 0 + block: + - name: get id of existing selfsigned interim certificate + command: cat /var/lib/acme/.selfsigned-interim-cert + changed_when: false + check_mode: false + register: selfsigned_interim_cert_id + + - name: set selfsigned_interim_cert_id variable + set_fact: + selfsigned_interim_cert_id: "{{ selfsigned_interim_cert_id.stdout }}" + + - name: link to snakeoil cert for nonexistent hostnames + loop: "{{ acmecert_missing_hostnames }}" + loop_control: + loop_var: acme_missing_hostname + file: + src: "../certs/{{ selfsigned_interim_cert_id }}" + dest: "/var/lib/acme/live/{{ acme_missing_hostname }}" + state: link + +- name: make sure nginx config has been (re)loaded + meta: flush_handlers + +- name: get certificate using acmetool + import_role: + name: acmetool/cert + vars: + acmetool_cert_name: "{{ nginx_vhost.hostnames[0] }}" + acmetool_cert_hostnames: "{{ nginx_vhost.hostnames }}" |