5
0
Derivar 0
module-icinga2/manifests/object/idopgsqlconnection.pp

94 linhas
3,1 KiB
Puppet

# == Defined type: icinga2::object::idopgsqlconnection
#
# This is a defined type for Icinga 2 IDO Postgres connection objects.
# See the following Icinga 2 doc page for more info:
# http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-idopgsqlconnection
#
# === Parameters
#
# See the inline comments.
#
define icinga2::object::idopgsqlconnection (
$object_name = $name,
$host = '127.0.0.1',
$port = 5432,
$user = 'icinga',
$password = 'icinga',
$database = 'icinga',
$table_prefix = 'icinga_',
$instance_name = 'default',
$instance_description = undef,
$cleanup = {
acknowledgements_age => 0,
commenthistory_age => 0,
contactnotifications_age => 0,
contactnotificationmethods_age => 0,
downtimehistory_age => 0,
eventhandlers_age => 0,
externalcommands_age => 0,
flappinghistory_age => 0,
hostchecks_age => 0,
logentries_age => 0,
notifications_age => 0,
processevents_age => 0,
statehistory_age => 0,
servicechecks_age => 0,
systemcommands_age => 0
},
$categories = [],
$target_dir = '/etc/icinga2/conf.d',
$target_file_name = "${name}.conf",
$target_file_ensure = file,
$target_file_owner = 'root',
$target_file_group = 'root',
$target_file_mode = '0644',
$refresh_icinga2_service = true
) {
#Do some validation of the class' parameters:
validate_string($object_name)
validate_string($template_to_import)
validate_string($host)
validate_string($user)
validate_string($password)
validate_string($database)
validate_string($table_prefix)
validate_string($instance_name)
validate_hash($cleanup)
validate_array($categories)
validate_string($target_dir)
validate_string($target_file_name)
validate_string($target_file_owner)
validate_string($target_file_group)
validate_string($target_file_mode)
validate_bool($refresh_icinga2_service)
#If the refresh_icinga2_service parameter is set to true...
if $refresh_icinga2_service == true {
file { "${target_dir}/${target_file_name}":
ensure => $target_file_ensure,
owner => $target_file_owner,
group => $target_file_group,
mode => $target_file_mode,
content => template('icinga2/object_idopgsqlconnection.conf.erb'),
#...notify the Icinga 2 daemon so it can restart and pick up changes made to this config file...
notify => Service['icinga2'],
}
}
#...otherwise, use the same file resource but without a notify => parameter:
else {
file { "${target_dir}/${target_file_name}":
ensure => $target_file_ensure,
owner => $target_file_owner,
group => $target_file_group,
mode => $target_file_mode,
content => template('icinga2/object_idopgsqlconnection.conf.erb'),
}
}
}