initial commit
This commit is contained in:
parent
81e2115868
commit
0bdd8faa16
2
defaults/main.yml
Normal file
2
defaults/main.yml
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
---
|
||||||
|
letsencryt_email: 'admin@brainsys.io'
|
36
files/renew-hook
Normal file
36
files/renew-hook
Normal file
@ -0,0 +1,36 @@
|
|||||||
|
#!/bin/bash
|
||||||
|
|
||||||
|
_logfile="/var/log/renew_ssl.txt"
|
||||||
|
|
||||||
|
echo "Date: $(date +%Y%m%d)" | tee -a $_logfile
|
||||||
|
echo "Nb of args: $?" | tee -a $_logfile
|
||||||
|
|
||||||
|
if [ ! -z "$RENEWED_DOMAINS" ]; then
|
||||||
|
for domain in $RENEWED_DOMAINS; do
|
||||||
|
if [[ $domain = www.* ]]; then
|
||||||
|
domain=`echo $domain | sed 's/www.\(.*\)/\1/g'`
|
||||||
|
else
|
||||||
|
echo "Processing domain: $domain" | tee -a $_logfile
|
||||||
|
mkdir -p /etc/haproxy/ssl/archives
|
||||||
|
|
||||||
|
if test -f /etc/haproxy/ssl/certs/$domain.pem; then
|
||||||
|
cp /etc/haproxy/ssl/certs/$domain.pem /etc/haproxy/ssl/archives/$domain.pem.$(date +%Y%m%d)
|
||||||
|
fi
|
||||||
|
|
||||||
|
cat /etc/letsencrypt/live/$domain/privkey.pem /etc/letsencrypt/live/$domain/fullchain.pem > /etc/haproxy/ssl/certs/$domain.pem
|
||||||
|
|
||||||
|
# check if pem file in haproxy dir is empty and rm it if it is
|
||||||
|
if [ ! -s /etc/haproxy/ssl/certs/$domain.pem ]; then
|
||||||
|
rm /etc/haproxy/ssl/certs/$domain.pem
|
||||||
|
fi
|
||||||
|
|
||||||
|
/usr/sbin/haproxy -c -f /etc/haproxy/haproxy.cfg && /bin/systemctl reload haproxy.service
|
||||||
|
echo "$domain renewed at $(date)" | tee -a $_logfile
|
||||||
|
fi
|
||||||
|
done
|
||||||
|
else
|
||||||
|
echo "$domain renewal failed at $(date)" | tee -a $_logfile
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
#/* vim: set tabstop=4:softtabstop=4:shiftwidth=4:noexpandtab */
|
32
tasks/main.yml
Normal file
32
tasks/main.yml
Normal file
@ -0,0 +1,32 @@
|
|||||||
|
---
|
||||||
|
- name: letsencrypt | apt update cache
|
||||||
|
apt:
|
||||||
|
update_cache: yes
|
||||||
|
cache_valid_time: 86400 #One day
|
||||||
|
|
||||||
|
- name: letsencrypt | install packages
|
||||||
|
apt:
|
||||||
|
name:
|
||||||
|
- certbot
|
||||||
|
state: present
|
||||||
|
|
||||||
|
- name: letsencrypt | copy configuration files
|
||||||
|
template:
|
||||||
|
src: "cli.ini.j2"
|
||||||
|
dest: "/etc/letsencrypt/cli.ini"
|
||||||
|
mode: "0644"
|
||||||
|
force: yes
|
||||||
|
backup: yes
|
||||||
|
|
||||||
|
- name: letsencrypt | create hook directory
|
||||||
|
file:
|
||||||
|
path: /usr/local/bin/letsencrypt/
|
||||||
|
state: directory
|
||||||
|
owner: root
|
||||||
|
group: root
|
||||||
|
|
||||||
|
- name: letsencrypt | copy renew hook
|
||||||
|
copy:
|
||||||
|
src: "renew-hook"
|
||||||
|
dest: "/usr/local/bin/letsencrypt/renew-hook"
|
||||||
|
mode: "0755"
|
8
templates/cli.ini.j2
Normal file
8
templates/cli.ini.j2
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
# {{ ansible_managed }}
|
||||||
|
# Because we are using logrotate for greater flexibility, disable the
|
||||||
|
# internal certbot logrotation.
|
||||||
|
max-log-backups = 0
|
||||||
|
email = {{ letsencrypt_email }}
|
||||||
|
deploy-hook = /usr/local/bin/letsencrypt/renew-hook
|
||||||
|
#renew-before-expiry = 20
|
||||||
|
agree-tos = True
|
Loading…
x
Reference in New Issue
Block a user