diff options
-rw-r--r-- | manifests/defines.pp | 35 | ||||
-rw-r--r-- | manifests/init.pp | 2 |
2 files changed, 31 insertions, 6 deletions
diff --git a/manifests/defines.pp b/manifests/defines.pp index 7dede0e..c473f73 100644 --- a/manifests/defines.pp +++ b/manifests/defines.pp @@ -1,6 +1,7 @@ # manifests/defines.pp define nagios::host( + $ensure = present, $ip = $fqdn, $nagios_alias = $hostname, $check_command = 'check-host-alive', @@ -22,7 +23,7 @@ define nagios::host( } @@nagios_host { $name: - ensure => present, + ensure => $ensure, address => $ip, alias => $nagios_alias, check_command => $check_command, @@ -39,8 +40,15 @@ define nagios::host( # this will define a host which isn't managed by puppet. # a ping serivce is automatically added -define nagios::extra_host($ip, $nagios_alias, $use = 'generic-host', $parents = 'localhost' ) { +define nagios::extra_host( + $ensure = present, + $ip, + $nagios_alias, + $use = 'generic-host', + $parents = 'localhost' +) { nagios::host{$name: + ensure => $ensure, ip => $ip, nagios_alias => $nagios_alias, use => $use, @@ -48,6 +56,7 @@ define nagios::extra_host($ip, $nagios_alias, $use = 'generic-host', $parents = } nagios::service { "check_ping_${name}": + ensure => $ensure, host_name => $name, check_command => 'check_ping!100.0,20%!500.0,60%', host_name => $name, @@ -56,14 +65,19 @@ define nagios::extra_host($ip, $nagios_alias, $use = 'generic-host', $parents = } # just a wrapper to make the notify more easy -define nagios::command( $command_line ){ +define nagios::command( + $ensure = present, + $command_line +){ nagios_command{$name: + ensure => $ensure, command_line => $command_line, notify => Service[nagios], } } define nagios::service( + $ensure = present, $check_command, $host_name = $fqdn, $use = 'generic-service', @@ -86,6 +100,7 @@ define nagios::service( default => $nagios_contact_groups_in } @@nagios_service {$name: + ensure => $ensure, check_command => $check_command, use => $use, host_name => $host_name, @@ -109,13 +124,16 @@ define nagios::service( } } -define nagios::service::ping(){ +define nagios::service::ping( + $ensure = present +){ $real_nagios_ping_rate = $nagios_ping_rate ? { '' => '!100.0,20%!500.0,60%', default => $nagios_ping_rate } nagios::service{ "check_ping_${hostname}": + ensure => $ensure, check_command => "check_ping${real_nagios_ping_rate}", } } @@ -126,6 +144,7 @@ define nagios::service::ping(){ # - force: http is permanent redirect to https # - only: check only https define nagios::service::http( + $ensure = present, $check_domain = 'absent', $check_url = '/', $check_code = 'OK', @@ -138,11 +157,13 @@ define nagios::service::http( case $ssl_mode { 'force',true,'only': { nagios::service{"https_${name}_${check_code}_${hostname}": + ensure => $ensure, check_command => "check_https_url_regex!${real_check_domain}!${check_url}!'${check_code}'", } case $ssl_mode { 'force': { nagios::service{"httprd_${name}_${hostname}": + ensure => $ensure, check_command => "check_http_url_regex!${real_check_domain}!${check_url}!'301'", } } @@ -152,18 +173,22 @@ define nagios::service::http( case $ssl_mode { false,true: { nagios::service{"http_${name}_${check_code}_${hostname}": + ensure => $ensure, check_command => "check_http_url_regex!${real_check_domain}!${check_url}!'${check_code}'", } } } } -define nagios::plugin(){ +define nagios::plugin( + $ensure = present +){ file{$name: path => $hardwaremodel ? { 'x86_64' => "/usr/lib64/nagios/plugins/$name", default => "/usr/lib/nagios/plugins/$name", }, + ensure => $ensure, source => "puppet://$server/nagios/plugins/$name", require => Package['nagios-plugins'], owner => root, group => 0, mode => 0755; diff --git a/manifests/init.pp b/manifests/init.pp index 38f57ed..27923d0 100644 --- a/manifests/init.pp +++ b/manifests/init.pp @@ -125,7 +125,7 @@ class nagios::base { command_line => '$USER1$/check_tcp -p 706 -H $ARG1$'; check_jabber: command_line => '$USER1$/check_jabber -H $ARG1$'; - check_jabber: + check_jabber_login: command_line => '$USER1$/check_jabber_login $ARG1$ $ARG2$', require => Nagios::Plugin['check_jabber_login']; } |