Puppet Plan: peadm::modify_cert_extensions

Defined in:
plans/modify_cert_extensions.pp

Overview

Parameters:

  • targets (TargetSpec)
  • primary_host (Peadm::SingleTargetSpec)
  • add (Hash) (defaults to: { })
  • remove (Array) (defaults to: [ ])


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
# File 'plans/modify_cert_extensions.pp', line 1

plan peadm::modify_cert_extensions (
  TargetSpec              $targets,
  Peadm::SingleTargetSpec $primary_host,
  Hash                    $add = { },
  Array                   $remove = [ ],
) {
  $all_targets = peadm::get_targets($targets)
  $primary_target = get_target($primary_host)

  # Short-circuit if there are no targets
  if $all_targets.empty { return(0) }

  # TODO: convert $add and $remove to OIDs, if friendly names have been given

  $primary_certname = run_task('peadm::cert_data', $primary_target).first['certname']

  # Do the primary first, if it's in the list
  if ($primary_target in $all_targets) {
    run_plan('peadm::subplans::modify_cert_extensions', $primary_target,
      primary_host     => $primary_target,
      primary_certname => $primary_certname,
      add              => $add,
      remove           => $remove,
    )
  }

  # Then do the rest
  parallelize($all_targets - $primary_target) |$target| {
    run_plan('peadm::subplans::modify_cert_extensions', $target,
      primary_host     => $primary_target,
      primary_certname => $primary_certname,
      add              => $add,
      remove           => $remove,
    )
  }

  return('Modified cert extensions')
}