sendmail: Add automatic ca certificate updates
This commit is contained in:
parent
778f8e99d7
commit
7c9727c6a6
4 changed files with 50 additions and 1 deletions
25
roles/sendmail/files/update-sendmail-certs.sh
Normal file
25
roles/sendmail/files/update-sendmail-certs.sh
Normal file
|
@ -0,0 +1,25 @@
|
||||||
|
#!/bin/sh
|
||||||
|
|
||||||
|
set -eu
|
||||||
|
umask 022
|
||||||
|
|
||||||
|
tmpdir="$(mktemp -d -p /etc/mail)"
|
||||||
|
trap 'rm -rf "$tmpdir"' EXIT
|
||||||
|
chmod 0755 "$tmpdir"
|
||||||
|
|
||||||
|
awk '{
|
||||||
|
if ($0 == "-----BEGIN CERTIFICATE-----") cert=""
|
||||||
|
else if ($0 == "-----END CERTIFICATE-----") print cert
|
||||||
|
else cert=cert$0
|
||||||
|
}' /etc/pki/tls/certs/ca-bundle.crt /etc/pki/tls/certs/ca.crt | while read -r CERT; do
|
||||||
|
echo "$CERT" | base64 -d | openssl x509 -inform DER > \
|
||||||
|
"${tmpdir}/$(echo "$CERT" | base64 -d | openssl x509 -inform DER -hash -noout).0"
|
||||||
|
done
|
||||||
|
|
||||||
|
if ! diff -q "$tmpdir" "/etc/mail/certs" > /dev/null 2>&1 ; then
|
||||||
|
rm -rf /etc/mail/certs
|
||||||
|
mv "$tmpdir" /etc/mail/certs
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
exit 1
|
|
@ -21,3 +21,11 @@
|
||||||
- newaliases
|
- newaliases
|
||||||
register: result
|
register: result
|
||||||
changed_when: result.rc == 0
|
changed_when: result.rc == 0
|
||||||
|
|
||||||
|
- name: Update sendmail root certs
|
||||||
|
ansible.builtin.command:
|
||||||
|
argv:
|
||||||
|
- update-sendmail-certs
|
||||||
|
register: result
|
||||||
|
failed_when: false
|
||||||
|
changed_when: result.rc == 0
|
||||||
|
|
|
@ -1,5 +1,5 @@
|
||||||
---
|
---
|
||||||
|
|
||||||
dependencies:
|
dependencies:
|
||||||
- {role: dhparams}
|
- {role: dhparams}
|
||||||
|
- {role: pki}
|
||||||
- {role: saslauthd}
|
- {role: saslauthd}
|
||||||
|
|
|
@ -16,6 +16,22 @@
|
||||||
owner: root
|
owner: root
|
||||||
group: "{{ ansible_wheel }}"
|
group: "{{ ansible_wheel }}"
|
||||||
|
|
||||||
|
- name: Add script to update root certs
|
||||||
|
ansible.builtin.copy:
|
||||||
|
dest: /usr/local/sbin/update-sendmail-certs
|
||||||
|
src: update-sendmail-certs.sh
|
||||||
|
mode: "0755"
|
||||||
|
owner: root
|
||||||
|
group: "{{ ansible_wheel }}"
|
||||||
|
notify: Update sendmail root certs
|
||||||
|
|
||||||
|
- name: Add cronjob to update root certs
|
||||||
|
ansible.builtin.cron:
|
||||||
|
name: update-sendmail-certs
|
||||||
|
job: /usr/local/sbin/update-sendmail-certs
|
||||||
|
hour: "05"
|
||||||
|
minute: "30"
|
||||||
|
|
||||||
- name: Copy private key
|
- name: Copy private key
|
||||||
ansible.builtin.copy:
|
ansible.builtin.copy:
|
||||||
dest: "{{ tls_private }}/{{ mail_server }}.key"
|
dest: "{{ tls_private }}/{{ mail_server }}.key"
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue