Puppet Class: ipa::client
- Defined in:
- manifests/client.pp
Overview
Class: ipa::client
This class configures an IPA client
Parameters:
Actions:
Requires: Exported resources, puppetlabs/puppetlabs-firewall, puppetlabs/stdlib
Sample Usage:
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 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 |
# File 'manifests/client.pp', line 13
class ipa::client (
$clntpkg = {},
$ldaputils = {},
$ldaputilspkg = {},
$sssdtools = {},
$sssdtoolspkg = {},
$sssd = {},
$client = {},
$domain = {},
$realm = {},
$otp = {},
$mkhomedir = false,
$ntp = false,
$desc = {},
$locality = {},
$location = {}
) {
$mkhomediropt = $ipa::client::mkhomedir ? {
true => '--mkhomedir',
default => ''
}
$ntpopt = $ipa::client::ntp ? {
true => '',
default => '--no-ntp'
}
Ipa::Clientinstall <<| |>> {
name => $::fqdn,
otp => $ipa::client::otp,
mkhomedir => $ipa::client::mkhomediropt,
ntp => $ipa::client::ntpopt,
require => Package[$ipa::client::clntpkg]
}
if ! defined(Package[$ipa::client::clntpkg]) {
realize Package["$ipa::client::clntpkg"]
}
if $ipa::client::ldaputils {
if ! defined(Package[$ipa::client::ldaputilspkg]) {
realize Package["$ipa::client::ldaputilspkg"]
}
}
if $ipa::client::sssdtools {
if ! defined(Package[$ipa::client::sssdtoolspkg]) {
realize Package["$ipa::client::sssdtoolspkg"]
}
}
if $ipa::client::sssd {
realize Service["sssd"]
}
if $::osfamily == 'Debian' {
file { "/etc/pki":
ensure => directory,
mode => 755,
owner => root,
group => root,
require => Package[$ipa::client::clntpkg]
}
file {"/etc/pki/nssdb":
ensure => directory,
mode => 755,
owner => root,
group => root,
require => File["/etc/pki"]
}
File["/etc/pki/nssdb"] -> Ipa::Clientinstall <<| |>>
}
@@ipa::hostadd { "$::fqdn":
otp => $ipa::client::otp,
desc => $ipa::client::desc,
locality => $ipa::client::locality,
location => $ipa::client::location
}
}
|