- Description
- Setup - The basics of getting started with ca_extend
- Usage - Configuration options and additional functionality
A set of Plans and Tasks to extend the expiration date of the certificate for the certificate authority in Puppet Enterprise and distrubute the certificate to agent nodes.
This module requires a Bolt installation >= 1.8.0 on either a client machine or the Puppet master
The recommended installation procedure for this module is to use a Bolt Puppetfile. From within a Boltdir, specify this module and puppetlabs-stdlib
as dependencies and run bolt puppetfile install
. For example:
~/Boltdir$ cat Puppetfile
mod 'puppetlabs-stdlib'
mod 'm0dular/ca_extend',
git: 'https://github.com/m0dular/ca_extend.git'
~/Boltdir$ bolt puppetfile install
Successfully synced modules from /home/adrian/Boltdir/Puppetfile to /home/adrian/Boltdir/modules
- A Bolt installation >= 1.8.0
- puppetlabs-stdlib >= 3.2.0 < 6.0.0
- A
base64
binary on the master which supports the-w
flag bash
>= 4.0 on the master
This module works best with a Bolt inventory file to support simultaneous uploads to *nix and Windows agents. See the Bolt documentation for how to configure the inventory. See the REFERENCE.md
for a sample inventory file.
Alternatively, one can use an ssh
config file if only using this protocol to connect to agents. Bolt defaults to using ssh
, which in turn will use ~/.ssh/config
for options such as the username and identity file.
Another convenient way to specify targets for the ca_extend::upload_ca_cert
plan is by connecting Bolt to PuppetDB, after which the --query can be used to specify a node list. See REFERENCE.md
for an example.
The functionality of this module is divided into two main plans:
ca_extend::extend_ca_cert
- Extends the CA certificate and configures the master and any compile masters to use the new certificate
ca_extend::upload_ca_cert
- Distributes the certificate to any number of agents. Any protocol supported by Bolt can be used, such as
ssh
,winrm
, orPCP
.
- Distributes the certificate to any number of agents. Any protocol supported by Bolt can be used, such as
There are also two complementary tasks to check the expiry of the CA cert and any agent certificates.
ca_extend::check_agent_expiry
- Checks if any agent certificates expire by a certain date. Defaults to 3 months from today
ca_extend::check_ca_expiry
- Checks if the CA certificate expires by a certain date. Defaults to 3 months from today
bolt plan run ca_extend::extend_ca_cert master=<master_fqdn> compile_masters=<comma_separated_compile_master_fqdns>
bolt plan run ca_extend::upload_ca_cert cert=<path_to_cert> --nodes <TargetSpec>
bolt task run ca_extend::check_ca_expiry --nodes <TargetSpec>
bolt task run ca_extend::check_agent_expiry --nodes <TargetSpec>
See REFERENCE.md
for example commands