HAPROXY: OCSP management is now conditional.

This commit is contained in:
Andrea Dell'Amico 2024-10-07 17:13:17 +02:00
parent ee6087de29
commit 500f83aab8
Signed by: adellam
GPG Key ID: 147ABE6CEB9E20FF
3 changed files with 43 additions and 11 deletions

View File

@ -43,8 +43,9 @@ haproxy_admin_socket_dir: /run/haproxy
haproxy_admin_socket_file: admin.sock
haproxy_admin_socket: '{{ haproxy_admin_socket_dir }}/{{ haproxy_admin_socket_file }}'
haproxy_letsencrypt_managed: True
haproxy_letsencrypt_managed: true
haproxy_cert_dir: '{{ pki_dir }}/haproxy'
haproxy_ssl_ocsp_enabled: false
haproxy_install_additional_pkgs: False
haproxy_additional_pkgs:

View File

@ -1,17 +1,39 @@
---
- block:
- name: Install the socat binary needed to talk to the haproxy socket
apt: name=socat state=latest update_cache=yes cache_valid_time=3600
- name: haproxy-ssl | Manage OCSP
tags: ['haproxy', 'letsencrypt', 'ssl', 'ssl_ocsp']
when: haproxy_ssl_ocsp_enabled
block:
- name: haproxy-ssl | Install the socat binary needed to talk to the haproxy socket
ansible.builtin.apt:
name: socat
state: present
cache_valid_time: 3600
- name: Install a script that refreshes the OCSP configuration and reloads haproxy if needed
get_url: url='https://raw.githubusercontent.com/pierky/haproxy-ocsp-stapling-updater/master/hapos-upd' dest=/usr/local/bin/hapos-upd owner=root group=root mode=0755
- name: haproxy-ssl | Install a script that refreshes the OCSP configuration and reloads haproxy if needed
ansible.builtin.get_url:
url: 'https://raw.githubusercontent.com/pierky/haproxy-ocsp-stapling-updater/master/hapos-upd'
dest: /usr/local/bin/hapos-upd
owner: root
group: root
mode: "0755"
- name: Install a cron job that refreshes the OCSP configuration
cron:
- name: haproxy-ssl | Install a cron job that refreshes the OCSP configuration
ansible.builtin.cron:
name: "Refresh the haproxy OCSP information"
user: root
cron_file: haproxy_ocsp
special_time: daily
state: present
job: "/usr/local/bin/hapos-upd {% if haproxy_docker_container %}-S{% endif %} --cert {{ haproxy_cert_dir }}/haproxy.pem -v {{ letsencrypt_acme_certs_dir }}/fullchain -s {% if not haproxy_docker_container %}{{ haproxy_admin_socket }}{% else %}{{ haproxy_docker_socket_dir }}/{{ haproxy_admin_socket_file }}{% endif %} -v - >/var/log/hapos-upd.log 2>&1{% if haproxy_docker_container %} ; docker kill --signal USR2 $(docker container ls --filter name=haproxy_haproxy --quiet){% endif %}"
- name: haproxy-ssl | Disable the OCSP handling
tags: ['haproxy', 'letsencrypt', 'ssl', 'ssl_ocsp']
when: not haproxy_ssl_ocsp_enabled
block:
- name: haproxy-ssl | Remove the cron job that refreshes the OCSP configuration
ansible.builtin.cron:
name: "Refresh the haproxy OCSP information"
user: root
cron_file: haproxy_ocsp
special_time: daily
state: absent

View File

@ -23,8 +23,17 @@ fi
haproxy_socket={% if not haproxy_docker_container %}{{ haproxy_admin_socket }}{% else %}{{ haproxy_docker_socket_dir }}/{{ haproxy_admin_socket_file }}{% endif %}
echo "Check if the certificate must be replaced" >> $LE_LOG_DIR/haproxy.log
cat ${LE_CERTS_DIR}/{fullchain,privkey} > ${HAPROXY_CERTFILE}.new
cmp ${HAPROXY_CERTFILE}.new ${HAPROXY_CERTFILE} 2>/dev/null
if [ $? -eq 0 ] ; then
echo "The certificate is up to date" >> $LE_LOG_DIR/haproxy.log
rm -f ${HAPROXY_CERTFILE}.new
exit 0
fi
echo "Building the new certificate file" >> $LE_LOG_DIR/haproxy.log
cat ${LE_CERTS_DIR}/{fullchain,privkey} > ${HAPROXY_CERTFILE}
/bin/mv -f ${HAPROXY_CERTFILE}.new ${HAPROXY_CERTFILE}
chmod 440 ${HAPROXY_CERTFILE}
chgrp haproxy ${HAPROXY_CERTFILE}