module-icingaweb2/manifests/init.pp
Stefan Kleindl 5a786c6d49 Add possibility to set auth_backend to ldap
next to the already existing possibilities db and external. If auth_backend is set
to ldap an ldap ressource and an ldap authentication configuration is generated.

Also support for ldap encryption is added.
2016-05-12 16:10:51 +02:00

360 lines
13 KiB
Puppet

# == Class icingaweb2
#
# $admin_permissions::
# Default:
#
# $admin_users::
# Default:
#
# $auth_backend::
# Default:
#
# $auth_ldap_base_dn:: LDAP base dn.
# Default: undef
#
# $auth_ldap_filter:: LDAP authentication filter.
# Default: undef
#
# $auth_ldap_user_class:: LDAP authentication user class.
# Default: inetOrgPerson
#
# $auth_ldap_user_name_attribute:: LDAP authentication user name attribute.
# Default: uid
#
# $auth_resource::
# Default:
#
# $config_dir:: Location of the main configuration directory.
# Default: operating system specific.
#
# $config_dir_mode:: Posix file mode for configuration directories.
# Default: 0755.
#
# $config_dir_purge:: The $config_dir is purge at each puppet run.
# Unmanaged puppet file will be lost
# Default: false.
#
# $config_dir_recurse:: Apply the same posix permissions as $config_dir to any
# directory contained in $config_dir.
# Default: false.
#
# $config_file_mode:: Posix file mode for configuration files.
# Default: 0644.
#
# $config_group:: Posix group for configuration files.
# Default: operating system specific.
#
# $config_user:: Posix user for configuration files.
# Default: operating system specific.
#
# $git_repo:: Source repository containing upstream IcingaWeb2.
# Default: 'https://git.icinga.org/icingaWeb2.git'
#
# $git_revision:: Allows git revisions, tags, hashes, ... to be
# specified.
# Default: undef.
#
# $ido_db::
# Default:
#
# $ido_db_host::
# Default:
#
# $ido_db_name::
# Default:
#
# $ido_db_pass::
# Default:
#
# $ido_db_port::
# Default:
#
# $ido_db_user::
# Default:
#
# $ido_type::
# Default:
#
# $install_method:: Defines how to install install IcingaWeb2.
# Options: git, package
# Default: git.
#
# $ldap_bind_dn:: LDAP bind dn
# Default: undef
#
# $ldap_bind_pw:: LDAP bind pw
# Default: undef
#
# $ldap_encryption:: LDAP encryption method
# Allowed values are "starttls" and "ldaps".
# Default: undef
#
# $ldap_host:: LDAP hostname
# Default: undef
#
# $ldap_port:: LDAP bind port
# Default: 389
#
# $ldap_root_dn:: LDAP root dn
# Default: undef
#
# $log_application::
# Default:
#
# $log_level::
# Default:
#
# $log_method::
# Default:
#
# $log_resource::
# Default:
#
# $log_store::
# Default:
#
# $manage_apache_vhost:: Define wether or not this module should manage
# the virtualhost using Puppetlabs' apache module.
# Default: false.
#
# $manage_repo:: Add a custom package repository.
# Default: false.
#
# $manage_user:: Defines if user and group should be managed
# by this module. Set to false if you don't want
# user and group to be managed by this module.
# Default: true.
#
# $pkg_deps:: Any dependencies that need to be resolved before
# installing the main package.
# Default: operating system specific.
#
# $pkg_ensure:: Ensure state for packages.
# Default: present.
#
# $pkg_list:: An array containing the main package and possibly
# a number of dependencies.
# Default: operating system specific.
#
# $pkg_repo_version::
# Options: release, snapshot.
# Default: release.
#
# $pkg_repo_release_key::
# Default: operating system specific.
#
# $pkg_repo_release_metadata_expire::
# Default: operating system specific.
#
# $pkg_repo_release_url::
# Default: operating system specific.
#
# $pkg_repo_snapshot_key::
# Default: operating system specific.
#
# $pkg_repo_snapshot_metadata_expire::
# Default: operating system specific.
#
# $pkg_repo_snapshot_url::
# Default: operating system specific.
#
# $template_auth::
# Default: icingaweb2/authentication.ini.erb
#
# $template_config::
# Default: icingaweb2/config.ini.erb
#
# $template_resources::
# Default: icingaweb2/resources.ini.erb
#
# $template_roles::
# Default: icingaweb2/roles.ini.erb
#
# $template_apache::
# Default: icingaweb2/apache2.ini.erb
#
# $web_db::
# Default:
#
# $web_db_host::
# Default:
#
# $web_db_name::
# Default:
#
# $web_db_pass::
# Default:
#
# $web_db_port::
# Default:
#
# $web_db_prefix::
# Default:
#
# $web_db_user::
# Default:
#
# $web_root:: Default location for when using using git.
# Default: operating system specific.
#
# $web_type::
# Default:
#
# $initialize:: Whether or not to initialize a db scheme and a user
# Default : false
class icingaweb2 (
$admin_permissions = $::icingaweb2::params::admin_permissions,
$admin_users = $::icingaweb2::params::admin_users,
$auth_backend = $::icingaweb2::params::auth_backend,
$auth_ldap_base_dn = $::icingaweb2::params::auth_base_dn,
$auth_ldap_filter = $::icingaweb2::params::auth_ldap_filter,
$auth_ldap_user_class = $::icingaweb2::params::auth_ldap_user_class,
$auth_ldap_user_name_attribute = $::icingaweb2::params::auth_ldap_user_name_attribute,
$auth_resource = $::icingaweb2::params::auth_resource,
$config_dir = $::icingaweb2::params::config_dir,
$config_dir_mode = $::icingaweb2::params::config_dir_mode,
$config_dir_purge = $::icingaweb2::params::config_dir_purge,
$config_dir_recurse = $::icingaweb2::params::config_dir_recurse,
$config_file_mode = $::icingaweb2::params::config_file_mode,
$config_group = $::icingaweb2::params::config_group,
$config_user = $::icingaweb2::params::config_user,
$git_repo = $::icingaweb2::params::git_repo,
$git_revision = $::icingaweb2::params::git_revision,
$ido_db = $::icingaweb2::params::ido_db,
$ido_db_host = $::icingaweb2::params::ido_db_host,
$ido_db_name = $::icingaweb2::params::ido_db_name,
$ido_db_pass = $::icingaweb2::params::ido_db_pass,
$ido_db_port = $::icingaweb2::params::ido_db_port,
$ido_db_user = $::icingaweb2::params::ido_db_user,
$ido_type = $::icingaweb2::params::ido_type,
$install_method = $::icingaweb2::params::install_method,
$ldap_bind_dn = $::icingaweb2::params::ldap_bind_dn,
$ldap_bind_pw = $::icingaweb2::params::ldap_bind_pw,
$ldap_encryption = $::icingaweb2::params::ldap_encryption,
$ldap_host = $::icingaweb2::params::ldap_host,
$ldap_port = $::icingaweb2::params::ldap_port,
$ldap_root_dn = $::icingaweb2::params::ldap_root_dn,
$log_application = $::icingaweb2::params::log_application,
$log_level = $::icingaweb2::params::log_level,
$log_method = $::icingaweb2::params::log_method,
$log_resource = $::icingaweb2::params::log_resource,
$log_store = $::icingaweb2::params::log_store,
$manage_apache_vhost = $::icingaweb2::params::manage_apache_vhost,
$manage_repo = $::icingaweb2::params::manage_repo,
$manage_user = $::icingaweb2::params::manage_user,
$pkg_deps = $::icingaweb2::params::pkg_deps,
$pkg_ensure = $::icingaweb2::params::pkg_ensure,
$pkg_list = $::icingaweb2::params::pkg_list,
$pkg_repo_release_key = $::icingaweb2::params::pkg_repo_release_key,
$pkg_repo_release_metadata_expire = $::icingaweb2::params::pkg_repo_release_metadata_expire,
$pkg_repo_release_url = $::icingaweb2::params::pkg_repo_release_url,
$pkg_repo_snapshot_key = $::icingaweb2::params::pkg_repo_snapshot_key,
$pkg_repo_snapshot_metadata_expire = $::icingaweb2::params::pkg_repo_snapshot_metadata_expire,
$pkg_repo_snapshot_url = $::icingaweb2::params::pkg_repo_snapshot_url,
$pkg_repo_version = $::icingaweb2::params::pkg_repo_version,
$template_auth = $::icingaweb2::params::template_auth,
$template_config = $::icingaweb2::params::template_config,
$template_resources = $::icingaweb2::params::template_resources,
$template_roles = $::icingaweb2::params::template_roles,
$template_apache = $::icingaweb2::params::template_apache,
$web_db = $::icingaweb2::params::web_db,
$web_db_host = $::icingaweb2::params::web_db_host,
$web_db_name = $::icingaweb2::params::web_db_name,
$web_db_pass = $::icingaweb2::params::web_db_pass,
$web_db_port = $::icingaweb2::params::web_db_port,
$web_db_prefix = $::icingaweb2::params::web_db_prefix,
$web_db_user = $::icingaweb2::params::web_db_user,
$web_root = $::icingaweb2::params::web_root,
$web_type = $::icingaweb2::params::web_type,
$initialize = $::icingaweb2::params::initialize,
) inherits ::icingaweb2::params {
class { '::icingaweb2::preinstall': } ->
class { '::icingaweb2::install': } ->
class { '::icingaweb2::config': } ->
class { '::icingaweb2::initialize': } ->
Class['::icingaweb2']
validate_absolute_path($config_dir)
validate_absolute_path($web_root)
validate_array($pkg_deps)
validate_array($pkg_list)
validate_bool($config_dir_recurse)
validate_bool($manage_repo)
validate_bool($manage_user)
validate_bool($initialize)
validate_slength($config_dir_mode, 4)
validate_slength($config_file_mode, 4)
validate_string($admin_permissions)
validate_string($admin_users)
validate_string($auth_backend)
validate_string($auth_resource)
validate_string($config_dir_mode)
validate_string($config_file_mode)
validate_string($config_group)
validate_string($config_user)
validate_string($log_application)
validate_string($log_level)
validate_string($log_method)
validate_string($log_resource)
validate_string($log_store)
validate_string($pkg_ensure)
validate_string($pkg_repo_release_key)
validate_string($pkg_repo_release_url)
validate_string($pkg_repo_snapshot_key)
validate_string($pkg_repo_snapshot_url)
validate_string($template_auth)
validate_string($template_config)
validate_string($template_resources)
validate_string($template_roles)
if $::icingaweb2::auth_backend == 'ldap' {
validate_integer($ldap_port)
validate_string($auth_ldap_base_dn)
validate_string($auth_ldap_filter)
validate_string($auth_ldap_user_class)
validate_string($auth_ldap_user_name_attribute)
validate_string($ldap_host)
validate_string($ldap_bind_dn)
validate_string($ldap_bind_pw)
validate_string($ldap_root_dn)
if $::icingaweb2::ldap_encryption {
validate_re( $ldap_encryption, '^(ldaps|starttls)$', "\$ldap_encryption must be either 'ldaps' or 'starttls', got '${ldap_encryption}'")
}
}
if $::icingaweb2::manage_apache_vhost {
validate_string($template_apache)
}
if $pkg_repo_release_metadata_expire {
validate_string($pkg_repo_release_metadata_expire)
}
if $pkg_repo_snapshot_metadata_expire {
validate_string($pkg_repo_snapshot_metadata_expire)
}
validate_re($install_method,
[
'git',
'package',
]
)
validate_re($pkg_ensure,
[
'absent',
'latest',
'present',
'purged',
]
)
validate_re($pkg_repo_version,
[
'release',
'snapshot',
]
)
}