123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115 |
- # == Defined type: icinga2::object::checkcommand
- #
- # This is a defined type for Icinga 2 apply objects that create check commands
- # See the following Icinga 2 doc page for more info:
- # http://docs.icinga.org/icinga2/latest/doc/module/icinga2/chapter/configuring-icinga2#objecttype-checkcommand
- #
- # === Parameters
- #
- # See the inline comments.
- #
- define icinga2::object::checkcommand (
- $object_checkcommandname = $name,
- $template_to_import = 'plugin-check-command',
- #$methods = undef, Need to get more details about this attribute
- $command = undef,
- $cmd_path = 'PluginDir',
- $arguments = {},
- $env = undef,
- $vars = {},
- $timeout = undef,
- $target_dir = '/etc/icinga2/objects/checkcommands',
- $checkcommand_template_module = 'icinga2',
- $checkcommand_template = 'object_checkcommand.conf.erb',
- $checkcommand_source_file = undef,
- $checkcommand_file_distribution_method = 'content',
- $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_checkcommandname)
- if $checkcommand_template == 'object_checkcommand.conf.erb' {
- validate_string($template_to_import)
- validate_array($command)
- validate_string($cmd_path)
- if $env {
- validate_hash($env)
- }
- validate_hash($vars)
- if $timeout {
- validate_re($timeout, '^\d+$')
- }
- }
- validate_string($target_dir)
- validate_string($target_file_name)
- validate_string($target_file_owner)
- validate_string($target_file_group)
- validate_re($target_file_mode, '^\d{4}$')
- validate_bool($refresh_icinga2_service)
- #If the refresh_icinga2_service parameter is set to true...
- if $refresh_icinga2_service == true {
- if $checkcommand_file_distribution_method == 'content' {
- file {"${target_dir}/${target_file_name}":
- ensure => $target_file_ensure,
- owner => $target_file_owner,
- group => $target_file_group,
- mode => $target_file_mode,
- content => template("${checkcommand_template_module}/${checkcommand_template}"),
- notify => Service['icinga2'],
- }
- }
- elsif $checkcommand_file_distribution_method == 'source' {
- file {"${target_dir}/${target_file_name}":
- ensure => $target_file_ensure,
- owner => $target_file_owner,
- group => $target_file_group,
- mode => $target_file_mode,
- source => $checkcommand_source_file,
- notify => Service['icinga2'],
- }
- }
- else {
- notify {'Missing/Incorrect File Distribution Method':
- message => 'The parameter checkcommand_file_distribution_method is missing or incorrect. Please set content or source',
- }
- }
- }
- #...otherwise, use the same file resource but without a notify => parameter:
- else {
-
- if $checkcommand_file_distribution_method == 'content' {
- file {"${target_dir}/${target_file_name}":
- ensure => $target_file_ensure,
- owner => $target_file_owner,
- group => $target_file_group,
- mode => $target_file_mode,
- content => template("${checkcommand_template_module}/${checkcommand_template}"),
- }
- }
- elsif $checkcommand_file_distribution_method == 'source' {
- file {"${target_dir}/${target_file_name}":
- ensure => $target_file_ensure,
- owner => $target_file_owner,
- group => $target_file_group,
- mode => $target_file_mode,
- source => $checkcommand_source_file,
- }
- }
- else {
- notify {'Missing/Incorrect File Distribution Method':
- message => 'The parameter checkcommand_file_distribution_method is missing or incorrect. Please set content or source',
- }
- }
-
- }
- }
|