aboutsummaryrefslogtreecommitdiff
path: root/manifests/cert.pp
blob: a8cc94e1049d644cd3bf467929f3fe22c50e8846 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
# A single certificate
# TODO possibly default cert_name to $::fqdn instead
define letsencrypt::cert (
  String $cert_name                 => $::name,
  Enum['present', 'absent'] $ensure => 'present',
  Boolean $include_self             => true,
) {

  # TODO these env files are systemd specific
  # TODO concat::fragment is clumsy, look at re-implementing the
  # functionallity internally

  concat { "${letsencrypt::config_dir}/env/${cert_name}":
    ensure         => present,
    warn           => true,
  }

  concat::fragment { "letsencrypt ${cert_name} preamble":
    target  => "${letsencrypt::config_dir}/env/${cert_name}",
    order   => '0',
    content => @(EOF)
    AUTHENTICATOR = ''
    POST_HOOK = ''
    DOMAINS =
    |- EOF
  }
  concat::fragment { "letsencrypt ${cert_name} postamble":
    target  => "${letsencrypt::config_dir}/env/${cert_name}",
    order   => '99',
    content => "\n\n",
  }

  if $include_self {
    letsencrypt::domain { $cert_name: }
  }

  letsencrypt::renew { $cert_name:
  }
}