2016-06-27 23:52:39 +03:00
|
|
|
---
|
|
|
|
|
2021-03-19 23:39:30 +02:00
|
|
|
# Use acme.sh instead of certbot because they only support installation via
|
|
|
|
# snap now.
|
2018-04-26 11:00:47 +03:00
|
|
|
- block:
|
2021-03-19 23:39:30 +02:00
|
|
|
- name: Remove certbot
|
2021-03-19 23:45:41 +02:00
|
|
|
apt:
|
|
|
|
name: certbot
|
|
|
|
state: absent
|
2021-03-19 23:39:30 +02:00
|
|
|
|
|
|
|
- name: Remove old certbot post and pre hooks for nginx
|
2021-03-19 23:45:41 +02:00
|
|
|
file:
|
|
|
|
dest: "{{ item }}"
|
|
|
|
state: absent
|
2021-03-19 23:39:30 +02:00
|
|
|
with_items:
|
|
|
|
- /etc/letsencrypt/renewal-hooks/pre/stop-nginx.sh
|
|
|
|
- /etc/letsencrypt/renewal-hooks/post/start-nginx.sh
|
|
|
|
|
2021-09-27 13:40:17 +03:00
|
|
|
- name: Check if acme.sh is installed
|
|
|
|
stat:
|
|
|
|
path: "{{ letsencrypt_acme_home }}"
|
|
|
|
register: acme_home
|
|
|
|
|
2021-03-19 23:39:30 +02:00
|
|
|
- name: Download acme.sh
|
|
|
|
get_url:
|
|
|
|
url: https://raw.githubusercontent.com/acmesh-official/acme.sh/master/acme.sh
|
2021-09-27 13:40:17 +03:00
|
|
|
dest: "{{ letsencrypt_acme_script_temp }}"
|
2021-09-07 17:10:35 +03:00
|
|
|
mode: 0700
|
2021-09-27 13:40:17 +03:00
|
|
|
register: acme_download
|
|
|
|
when: not acme_home.stat.exists
|
2021-03-19 23:39:30 +02:00
|
|
|
|
2021-09-27 11:28:02 +03:00
|
|
|
# Run the "install" for acme.sh so it creates the .acme.sh dir (currently I
|
|
|
|
# have to chdir to the /root directory where the script exists or else it
|
|
|
|
# fails. Ansible runs it, but the script can't find itself...).
|
|
|
|
- name: Install acme.sh
|
|
|
|
ansible.builtin.command:
|
2021-09-27 13:40:17 +03:00
|
|
|
cmd: "{{ letsencrypt_acme_script_temp }} --install --no-profile --no-cron"
|
2021-09-27 11:28:02 +03:00
|
|
|
creates: "{{ letsencrypt_acme_home }}/acme.sh"
|
|
|
|
chdir: /root
|
2021-09-27 13:40:17 +03:00
|
|
|
register: acme_install
|
|
|
|
when: acme_download is changed
|
|
|
|
|
|
|
|
- name: Remove temporary acme.sh script
|
|
|
|
file:
|
|
|
|
dest: "{{ letsencrypt_acme_script_temp }}"
|
|
|
|
state: absent
|
|
|
|
when: acme_install.rc is defined and acme_install.rc == 0
|
2021-09-27 11:28:02 +03:00
|
|
|
|
|
|
|
- name: Set default certificate authority for acme.sh
|
|
|
|
ansible.builtin.command:
|
2021-09-27 13:40:17 +03:00
|
|
|
cmd: "{{ letsencrypt_acme_home }}/acme.sh --set-default-ca --server letsencrypt"
|
2021-09-27 11:28:02 +03:00
|
|
|
|
2021-03-19 23:39:30 +02:00
|
|
|
- name: Prepare Let's Encrypt well-known directory
|
|
|
|
file:
|
|
|
|
state: directory
|
|
|
|
path: /var/lib/letsencrypt/.well-known
|
|
|
|
owner: root
|
|
|
|
group: nginx
|
|
|
|
mode: g+s
|
|
|
|
|
2018-04-26 11:00:47 +03:00
|
|
|
- name: Copy systemd service to renew Let's Encrypt certs
|
2021-03-19 23:39:30 +02:00
|
|
|
template:
|
|
|
|
src: renew-letsencrypt.service.j2
|
|
|
|
dest: /etc/systemd/system/renew-letsencrypt.service
|
|
|
|
mode: 0644
|
|
|
|
owner: root
|
|
|
|
group: root
|
2018-04-26 11:00:47 +03:00
|
|
|
|
|
|
|
- name: Copy systemd timer to renew Let's Encrypt certs
|
2021-03-19 23:39:30 +02:00
|
|
|
copy:
|
|
|
|
src: renew-letsencrypt.timer
|
|
|
|
dest: /etc/systemd/system/renew-letsencrypt.timer
|
|
|
|
mode: 0644
|
|
|
|
owner: root
|
|
|
|
group: root
|
|
|
|
|
|
|
|
# always issues daemon-reload just in case the service/timer changed
|
2018-04-26 11:00:47 +03:00
|
|
|
- name: Start and enable systemd timer to renew Let's Encrypt certs
|
2021-03-19 23:39:30 +02:00
|
|
|
systemd:
|
|
|
|
name: renew-letsencrypt.timer
|
|
|
|
state: started
|
|
|
|
enabled: yes
|
|
|
|
daemon_reload: yes
|
2020-06-06 20:38:08 +03:00
|
|
|
|
2021-09-07 17:07:33 +03:00
|
|
|
when: (ansible_distribution == 'Ubuntu' and ansible_distribution_version is version('20.04', '=='))
|
|
|
|
or (ansible_distribution == 'Debian' and ansible_distribution_version is version('11', '=='))
|
2018-04-25 20:03:32 +03:00
|
|
|
tags: letsencrypt
|
2016-06-27 23:52:39 +03:00
|
|
|
|
|
|
|
# vim: set ts=2 sw=2:
|