Puppet Class: keycloak::sssd
- Defined in:
- manifests/sssd.pp
Overview
Private class.
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 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 96 97 |
# File 'manifests/sssd.pp', line 2
class keycloak::sssd {
assert_private()
if $facts['java_default_home'] {
$jvm_path = $facts['java_default_home']
} else {
$jvm_path = '$(dirname $(dirname $(readlink -f $(which javac))))'
}
if $keycloak::install_libunix_dbus_java_build_dependencies {
$build_dependency_defaults = {
'ensure' => 'installed',
'before' => Exec['libunix-dbus-java-setup'],
}
ensure_packages($keycloak::libunix_dbus_java_build_dependencies, $build_dependency_defaults)
}
file { '/usr/local/src/libunix-dbus-java':
ensure => 'directory',
owner => 'root',
group => 'root',
mode => '0755',
}
-> archive { 'libunix-dbus-java.tar.gz':
ensure => 'present',
extract => true,
path => '/tmp/libunix-dbus-java.tar.gz',
extract_path => '/usr/local/src/libunix-dbus-java',
extract_command => 'tar xfz %s --strip-components=1',
source => $keycloak::libunix_dbus_java_source,
creates => '/usr/local/src/libunix-dbus-java/src',
cleanup => true,
user => 'root',
group => 'root',
before => Exec['libunix-dbus-java-setup'],
}
exec { 'libunix-dbus-java-setup':
path => '/usr/bin:/bin:/usr/sbin:/sbin',
cwd => '/usr/local/src/libunix-dbus-java',
command => 'libtoolize && aclocal && autoconf && automake --add-missing',
creates => '/usr/local/src/libunix-dbus-java/configure',
}
-> exec { 'libunix-dbus-java-configure':
path => '/usr/bin:/bin:/usr/sbin:/sbin',
cwd => '/usr/local/src/libunix-dbus-java',
command => "/usr/local/src/libunix-dbus-java/configure --with-jvm=${jvm_path} --libdir=${keycloak::libunix_dbus_java_libdir} CFLAGS='-std=c99'", # lint:ignore:140chars
creates => '/usr/local/src/libunix-dbus-java/Makefile',
}
-> exec { 'libunix-dbus-java-make':
path => '/usr/bin:/bin:/usr/sbin:/sbin',
cwd => '/usr/local/src/libunix-dbus-java',
command => 'make',
creates => '/usr/local/src/libunix-dbus-java/.libs/libunix_dbus_java.so.0.0.8',
}
-> exec { 'libunix-dbus-java-make-install':
path => '/usr/bin:/bin:/usr/sbin:/sbin',
cwd => '/usr/local/src/libunix-dbus-java',
command => 'make install',
creates => "${keycloak::libunix_dbus_java_libdir}/libunix_dbus_java.so.0.0.8",
}
package { 'jna':
ensure => 'installed',
name => $keycloak::jna_package_name,
}
if $keycloak::manage_sssd_config {
if empty($keycloak::sssd_ifp_user_attributes) {
$user_attributes = undef
} else {
$attrs = $keycloak::sssd_ifp_user_attributes.map |$a| { "+${a}" }
$user_attributes = "user_attributes = ${join($attrs, ', ')}"
}
$sssd_config = delete_undef_values([
'# File managed by Puppet',
'[ifp]',
'allowed_uids = root, keycloak',
$user_attributes,
])
if $keycloak::restart_sssd {
$sssd_notify = Service['sssd']
} else {
$sssd_notify = undef
}
file { '/etc/sssd/conf.d/keycloak.conf':
ensure => 'file',
owner => 'root',
group => 'root',
mode => '0600',
content => join($sssd_config, "\n"),
notify => $sssd_notify,
}
}
}
|