2017-09-11 23:50:14 +03:00
|
|
|
MAILTO="{{ matrix_ssl_support_email }}"
|
2017-07-31 23:07:30 +03:00
|
|
|
|
|
|
|
# The goal of this cronjob is to ask acmetool to check
|
|
|
|
# the current SSL certificates and to see if some need renewal.
|
2017-08-06 19:10:50 +03:00
|
|
|
# If so, it would attempt to renew.
|
2017-07-31 23:07:30 +03:00
|
|
|
#
|
|
|
|
# Various services depend on these certificates and would need to be restarted.
|
|
|
|
# This is not our concern here. We simply make sure the certificates are up to date.
|
|
|
|
# Restarting of services happens on its own different schedule (other cronjobs).
|
|
|
|
#
|
2017-08-06 19:10:50 +03:00
|
|
|
#
|
|
|
|
# How renewal works?
|
|
|
|
#
|
2017-09-12 12:41:44 +03:00
|
|
|
# acmetool will fail to bind to port :80 (because matrix-nginx-proxy or some other server is running there),
|
2017-08-06 19:10:50 +03:00
|
|
|
# and will fall back to its "webroot" validation method.
|
|
|
|
#
|
|
|
|
# Thus, it would put validation files in `/var/run/acme/acme-challenge`.
|
|
|
|
# These files can be retrieved via any vhost on port 80 of matrix-nginx-proxy,
|
|
|
|
# because it aliases `/.well-known/acme-challenge` to that same directory.
|
2017-09-12 12:41:44 +03:00
|
|
|
#
|
|
|
|
# When a custom proxy server (not matrix-nginx-proxy provided by this playbook),
|
2017-09-23 15:08:54 +03:00
|
|
|
# you'd need to make sure you alias these files correctly or SSL renewal would not work.
|
2017-07-31 23:07:30 +03:00
|
|
|
|
2017-11-11 10:38:38 +02:00
|
|
|
{{ matrix_ssl_renew_cron_time_definition }} root /usr/bin/docker run --rm --net=host -v {{ matrix_ssl_certs_path }}:/certs -v {{ matrix_ssl_certs_path }}/run:/var/run/acme -e ACME_EMAIL={{ matrix_ssl_support_email }} willwill/acme-docker acmetool --batch reconcile # --xlog.severity=debug
|