2022-03-02 19:58:31 -05:00
|
|
|
- name: Ensure relevant packages are installed
|
2022-02-27 16:05:34 -05:00
|
|
|
community.general.pacman:
|
2022-03-02 19:58:31 -05:00
|
|
|
name:
|
|
|
|
- nginx
|
|
|
|
- certbot
|
|
|
|
- certbot-nginx
|
|
|
|
|
2022-03-01 17:43:44 -05:00
|
|
|
state: present
|
2022-02-27 16:05:34 -05:00
|
|
|
|
2022-05-22 20:47:58 -04:00
|
|
|
- name: Create SSL read group
|
|
|
|
group:
|
|
|
|
name: sslr
|
|
|
|
state: present
|
|
|
|
|
2022-02-27 16:05:34 -05:00
|
|
|
- name: Create directories for ACME
|
|
|
|
file:
|
2022-05-21 18:43:54 -04:00
|
|
|
path: "/etc/ssl-acme/{{ item }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
state: directory
|
|
|
|
owner: root
|
|
|
|
group: root
|
2022-06-05 13:20:53 -04:00
|
|
|
mode: 0755
|
2022-02-27 16:05:34 -05:00
|
|
|
with_items:
|
|
|
|
- account
|
|
|
|
- certs
|
|
|
|
- csrs
|
|
|
|
- keys
|
|
|
|
|
|
|
|
- name: Generate ACME account key
|
|
|
|
community.crypto.openssl_privatekey:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "/etc/ssl-acme/account/{{ account_name }}.key"
|
2022-05-22 20:47:58 -04:00
|
|
|
owner: root
|
|
|
|
group: sslr
|
|
|
|
mode: 0640
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Generate ACME private key
|
|
|
|
community.crypto.openssl_privatekey:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "/etc/ssl-acme/keys/{{ key_name }}.key"
|
2022-05-22 20:47:58 -04:00
|
|
|
owner: root
|
|
|
|
group: sslr
|
|
|
|
mode: 0640
|
2022-02-27 16:05:34 -05:00
|
|
|
|
2022-06-05 13:20:53 -04:00
|
|
|
- name: Check if certificate file exists
|
2022-02-27 16:05:34 -05:00
|
|
|
stat:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "/etc/ssl-acme/certs/{{ cert_name }}.crt"
|
2022-02-27 16:05:34 -05:00
|
|
|
register: cert_file
|
|
|
|
|
|
|
|
- name: Check if certificate is expired
|
|
|
|
community.crypto.x509_certificate_info:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "{{ cert_file.stat.path }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
valid_at:
|
2022-04-09 20:54:10 -04:00
|
|
|
now: "+3w"
|
2022-02-27 16:05:34 -05:00
|
|
|
when: cert_file.stat.exists
|
2022-06-05 13:20:53 -04:00
|
|
|
register: expired_cert
|
2022-02-27 16:05:34 -05:00
|
|
|
|
2022-03-02 19:58:31 -05:00
|
|
|
- name: Determine whether the certificate should be regenerated
|
2022-02-27 16:05:34 -05:00
|
|
|
set_fact:
|
2022-06-05 13:20:53 -04:00
|
|
|
to_regen: "{{ ssl_domains }}"
|
|
|
|
when: not cert_file.stat.exists or not expired_cert.valid_at.now
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Configure nginx for ACME
|
|
|
|
template:
|
|
|
|
src: nginx_bare.conf.j2
|
|
|
|
dest: /etc/nginx/nginx.conf
|
2022-06-05 13:20:53 -04:00
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
2022-03-01 17:43:44 -05:00
|
|
|
- name: Restart nginx service
|
2022-02-27 16:05:34 -05:00
|
|
|
service:
|
|
|
|
name: nginx
|
|
|
|
state: restarted
|
|
|
|
enabled: yes
|
2022-06-05 13:20:53 -04:00
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Create ACME account
|
|
|
|
community.crypto.acme_account:
|
2022-06-05 13:20:53 -04:00
|
|
|
account_key_src: "/etc/ssl-acme/account/{{ account_name }}.key"
|
2022-02-27 16:05:34 -05:00
|
|
|
state: present
|
|
|
|
allow_creation: yes
|
|
|
|
contact:
|
|
|
|
- "mailto:{{ acme_email }}"
|
2022-05-21 18:43:54 -04:00
|
|
|
acme_directory: "{{ acme_dir }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
terms_agreed: 1
|
|
|
|
acme_version: 2
|
2022-06-05 13:20:53 -04:00
|
|
|
external_account_binding: "{{ (acme_eab.key != '') | ternary(acme_eab, omit) }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
register: account
|
2022-06-05 13:20:53 -04:00
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Generate ACME CSR
|
|
|
|
community.crypto.openssl_csr:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "/etc/ssl-acme/csrs/{{ cert_name }}.csr"
|
|
|
|
subject_alt_name: "{{ to_regen | map('regex_replace', '^', 'DNS:') | join(',') }}"
|
|
|
|
privatekey_path: "/etc/ssl-acme/keys/{{ key_name }}.key"
|
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Retrieve ACME challenge
|
|
|
|
community.crypto.acme_certificate:
|
2022-05-21 18:43:54 -04:00
|
|
|
acme_directory: "{{ acme_dir }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
acme_version: 2
|
2022-06-05 13:20:53 -04:00
|
|
|
account_key_src: "/etc/ssl-acme/account/{{ account_name }}.key"
|
2022-02-27 16:05:34 -05:00
|
|
|
account_uri: "{{ account.account_uri }}"
|
|
|
|
account_email: "{{ acme_email }}"
|
|
|
|
terms_agreed: 1
|
|
|
|
challenge: http-01
|
2022-06-05 13:20:53 -04:00
|
|
|
csr: "/etc/ssl-acme/csrs/{{ cert_name }}.csr"
|
|
|
|
dest: "/etc/ssl-acme/certs/{{ cert_name }}.crt"
|
|
|
|
fullchain_dest: "/etc/ssl-acme/certs/fullchain_{{ cert_name }}.crt"
|
2022-02-27 16:05:34 -05:00
|
|
|
remaining_days: 91
|
|
|
|
register: acme_challenge
|
2022-06-05 13:20:53 -04:00
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Create ACME challenge directory
|
|
|
|
file:
|
2022-06-05 13:20:53 -04:00
|
|
|
path: "{{ webroot }}/{{ item }}/.well-known/acme-challenge"
|
2022-02-27 16:05:34 -05:00
|
|
|
state: directory
|
|
|
|
owner: root
|
|
|
|
group: root
|
|
|
|
mode: 0755
|
2022-06-05 13:20:53 -04:00
|
|
|
with_items: "{{ to_regen }}"
|
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Add ACME challenge files
|
|
|
|
copy:
|
2022-06-05 13:20:53 -04:00
|
|
|
content: "{{ item.value['http-01']['resource_value'] }}"
|
|
|
|
dest: "{{ webroot }}/{{ item.key }}/{{ item.value['http-01']['resource'] }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
owner: root
|
|
|
|
group: root
|
|
|
|
mode: 644
|
2022-06-05 13:20:53 -04:00
|
|
|
with_items: "{{ acme_challenge['challenge_data'] | dict2items }}"
|
|
|
|
when: to_regen is defined
|
2022-02-27 16:05:34 -05:00
|
|
|
|
|
|
|
- name: Complete ACME challenge
|
|
|
|
community.crypto.acme_certificate:
|
2022-05-21 18:43:54 -04:00
|
|
|
acme_directory: "{{ acme_dir }}"
|
2022-02-27 16:05:34 -05:00
|
|
|
acme_version: 2
|
2022-06-05 13:20:53 -04:00
|
|
|
account_key_src: "/etc/ssl-acme/account/{{ account_name }}.key"
|
2022-02-27 16:05:34 -05:00
|
|
|
account_email: "{{ acme_email }}"
|
|
|
|
account_uri: "{{ account.account_uri }}"
|
|
|
|
challenge: http-01
|
|
|
|
terms_agreed: 1
|
2022-06-05 13:20:53 -04:00
|
|
|
csr: "/etc/ssl-acme/csrs/{{ cert_name }}.csr"
|
|
|
|
dest: "/etc/ssl-acme/certs/{{ cert_name }}.crt"
|
|
|
|
fullchain_dest: "/etc/ssl-acme/certs/fullchain_{{ cert_name }}.crt"
|
|
|
|
chain_dest: "/etc/ssl-acme/certs/chain_{{ cert_name }}.crt"
|
2022-02-27 16:05:34 -05:00
|
|
|
data: "{{ acme_challenge }}"
|
2022-11-20 21:35:13 -05:00
|
|
|
remaining_days: 21
|
2022-06-05 13:20:53 -04:00
|
|
|
when: to_regen is defined
|