Puppet Class: profile::ldap::client::ldaptui

Defined in:
modules/profile/manifests/ldap/client/ldaptui.pp

Overview

SPDX-License-Identifier: Apache-2.0

Class: profile::ldap::client::ldaptui

This installs a basic LDAP terminal UI for creating editing and resetting of passwords.

Parameters:

  • ldap_config (Hash) (defaults to: lookup('ldap'))
  • ldap_user (String) (defaults to: lookup('profile::openstack::base::ldap_user_dn'))
  • ldap_user_pass (String) (defaults to: lookup('profile::openstack::codfw1dev::ldap_user_pass'))


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
# File 'modules/profile/manifests/ldap/client/ldaptui.pp', line 7

class profile::ldap::client::ldaptui(
    Hash   $ldap_config    = lookup('ldap'),
    String $ldap_user      = lookup('profile::openstack::base::ldap_user_dn'),
    String $ldap_user_pass = lookup('profile::openstack::codfw1dev::ldap_user_pass'),
) {
    ensure_packages([
        'python3-bitu-ldap',
        'python3-passlib',
        'python3-textual'
    ])

    $ldap_rw_host = $ldap_config['rw-server']
    $base_dir = '/srv/ldaptui'

    file { $base_dir:
        ensure =>  directory
    }

    file { '/etc/ldaptui':
        ensure =>  directory
    }

    file { '/usr/local/bin/ldaptui':
        mode   => '0550',
        source => 'puppet:///modules/profile/ldap/client/ldaptui.sh'
    }

    file { '/etc/ldaptui/config.json':
        mode    => '0400',
        content => template('profile/ldap/client/ldaptui.config.json.erb')
    }

    file { "${base_dir}/ldaptui.py":
        source => 'puppet:///modules/profile/ldap/client/ldaptui/ldaptui.py'
    }

    file { "${base_dir}/.venv":
        ensure => absent
    }
}