r/lego-nginx: Configure LEGO for nginx
The *lego-nginx* role automates obtaining certificates for *nginx* via ACME using `lego`. It generates a shell script with the appropriate arguments for `lego run`, runs it once to obtain a certificate initially, then schedules it to run periodically via a systemd timer unit. Using `lego`'s "hook" capability, the script signals the `nginx` server process to reload. This uses `doas` for now, but could be adapted easily to use `sudo`, if the need ever arises.
This commit is contained in:
10
roles/lego/files/lego-renew.service
Normal file
10
roles/lego/files/lego-renew.service
Normal file
@@ -0,0 +1,10 @@
|
||||
[Unit]
|
||||
Description=Renew certificates with LEGO
|
||||
Wants=network-online.target
|
||||
After=network-online.target
|
||||
After=httpd.service nginx.service
|
||||
|
||||
[Service]
|
||||
Type=oneshot
|
||||
User=lego
|
||||
ExecStart=/bin/sh /var/lib/lego/renew.sh
|
||||
9
roles/lego/files/lego-renew.timer
Normal file
9
roles/lego/files/lego-renew.timer
Normal file
@@ -0,0 +1,9 @@
|
||||
[Unit]
|
||||
Description=Periodically renew certificates with LEGO
|
||||
|
||||
[Timer]
|
||||
RandomizedDelaySec=15m
|
||||
OnActiveSec=4h
|
||||
|
||||
[Install]
|
||||
WantedBy=timers.target
|
||||
2
roles/lego/meta/main.yml
Normal file
2
roles/lego/meta/main.yml
Normal file
@@ -0,0 +1,2 @@
|
||||
dependencies:
|
||||
- systemd-base
|
||||
66
roles/lego/tasks/main.yml
Normal file
66
roles/lego/tasks/main.yml
Normal file
@@ -0,0 +1,66 @@
|
||||
- name: load os-specific values
|
||||
include_vars: '{{ item }}'
|
||||
with_first_found:
|
||||
- '{{ ansible_distribution }}-{{ ansible_distribution_version }}.yml'
|
||||
- '{{ ansible_distribution }}-{{ ansible_distribution_major_version }}.yml'
|
||||
- '{{ ansible_os_family }}-{{ ansible_distribution_major_version }}.yml'
|
||||
- '{{ ansible_distribution }}.yml'
|
||||
- '{{ ansible_os_family }}.yml'
|
||||
- defaults.yml
|
||||
tags:
|
||||
- always
|
||||
|
||||
- name: ensure lego is installed
|
||||
package:
|
||||
name:
|
||||
- acl # required for `become_user: lego`
|
||||
- '{{ lego_package }}'
|
||||
state: present
|
||||
tags:
|
||||
- install
|
||||
|
||||
- name: ensure lego group exists
|
||||
group:
|
||||
name: lego
|
||||
system: true
|
||||
tags:
|
||||
- user
|
||||
- group
|
||||
- name: ensure lego user exists
|
||||
user:
|
||||
name: lego
|
||||
group: lego
|
||||
system: true
|
||||
home: /var/lib/lego
|
||||
createhome: true
|
||||
shell: /bin/false
|
||||
tags:
|
||||
- user
|
||||
|
||||
- name: ensure lego-renew systemd units are installed
|
||||
copy:
|
||||
src: '{{ item }}'
|
||||
dest: /etc/systemd/system/
|
||||
owner: root
|
||||
group: root
|
||||
mode: u=rw,go=r
|
||||
loop:
|
||||
- lego-renew.service
|
||||
- lego-renew.timer
|
||||
notify:
|
||||
- reload systemd
|
||||
tags:
|
||||
- systemd
|
||||
|
||||
- name: ensure lego-renew systemd timer is enabled
|
||||
systemd:
|
||||
name: lego-renew.timer
|
||||
enabled: true
|
||||
tags:
|
||||
- service
|
||||
- name: ensure lego-renew systemd timer is running
|
||||
systemd:
|
||||
name: lego-renew.timer
|
||||
state: started
|
||||
tags:
|
||||
- service
|
||||
1
roles/lego/vars/defaults.yml
Normal file
1
roles/lego/vars/defaults.yml
Normal file
@@ -0,0 +1 @@
|
||||
lego_package: golang-github-acme-lego
|
||||
Reference in New Issue
Block a user