Get a certificate from a CA with ACME and setup automatic renewal using step-cli renew
.
This role uses step-cli
to request and save a certificate from the configured CA,
before setting up a renewal service using step-cli ca renew
s --daemon
mode.
- The following distributions are currently supported:
- Ubuntu 18.04 LTS or newer
- Debian 10 or newer
- A CentOS 8-compatible distribution like RockyLinux or AlmaLinux. RockyLinux is used for testing
- This role requires root access. Make sure to run this role with
become: yes
or equivalent - The host must be bootstrapped with
step_bootstrap_host
and the root user must be able to access the CA.
- Path or name of the step-cli executable to use for executing commands in this role
- Can be an absolute path or a command (make sure the executable is in $PATH) for all users
- Default:
step-cli
- Optionally set a custom
$STEPPATH
from which to read the step config - Example:
/etc/step-cli
- Default:
/root/.step/
- Name of the provisioner on the CA that will issue the ACME cert
- Required: Yes
- If set, this role will use
step-cli
s webroot mode to get a new certificate. - If empty, this role will use the standalone mode instead, causing
step-cli
to bind itself to port 80. Make sure that no other services are listening on this port. Note thatstep-cli
only needs to bind to this port when getting a new certificate. It does not need to bind if it is only renewing a certificate. - Default: ""
- The subject name that the certificate will be issued for
- Default:
{{ ansible_fqdn }}
- Subject Alternate Names to add to the cert
- Must be a list of valid SANs
- Default:
[]
- Valid duration of the certificate
- Default: undefined (uses the default for the given provisioner, typically 24h)
- Contact email for the CA for important notifications
- Default:
root@localhost
- Details about the cert/key files on disk
- Is a dict with the following elements:
path
: Absolute path to the cert/key file. Defaults to/etc/ssl/step.crt|step.key
. The directory must already exist.mode
: File mode for the cert/key file. Defaults to644
for the cert and600
for the keyowner
/group
: Owner and group of the file. Defaults to root.
- Name of the systemd service that will handle cert renewals
- If you have multiple cert/key pairs on one system, you will have to set a unique service name for each pair. If you only have one, then you can leave this as is.
- Default:
step-renew
- Renew the cert when its remaining valid time crosses this threshold
- Default: undefined (uses the smallstep default: 1/3 of the certificates valid duration, i.e. 8 hours for a 24h cert)
- Reload or restart these systemd services after a cert renewal
- Must be a list of systemd units
- Example:
["nginx", "mysqld"]
- Default:
[]
NOTE
Make sure that you are familiar with the way ACME works. You will need a functioning DNS environment at the very least to make use of ACME certs.
# Configure your CA to include an ACME provisioner
- hosts: step_ca
become: yes
tasks:
- name: Add an ACME provisioner to the CA
maxhoesel.smallstep.step_ca_provisioner:
name: ACME
type: ACME
become_user: step-ca
notify: reload step-ca
handlers:
- name: reload step-ca
systemd:
name: step-ca
state: reloaded
- hosts: clients
tasks:
# Bootstrap the host to trust the CA
- role: maxhoesel.smallstep.step_bootstrap_host
vars:
step_bootstrap_ca_url: https://myca.localdomain
step_bootstrap_fingerprint: your CAs fingerprint
become: yes
# This will download a certificate to /etc/step/ that you can then use in other applications.
# See the step_acme_cert README for more options
- name: Configure an ACME cert + renewal
include_role:
name: maxhoesel.smallstep.step_acme_cert
vars:
step_acme_cert_ca_provisioner: ACME
become: yes