From 3327f6d8692753bf89b31a569c158562fbd09916 Mon Sep 17 00:00:00 2001 From: Arne Teuke Date: Tue, 25 Jul 2017 15:48:39 +0100 Subject: [PATCH] added commands.pp --- README.md | 3 +- manifests/nagios/objects/commands.pp | 249 +++++++++++++++++++++++++++ 2 files changed, 251 insertions(+), 1 deletion(-) create mode 100644 manifests/nagios/objects/commands.pp diff --git a/README.md b/README.md index 0332d36..c2de47d 100644 --- a/README.md +++ b/README.md @@ -44,7 +44,8 @@ Configuration * manage directories (filesystem permissions, selinux ) * manage cgi.cfg through parameters * manage nagios.cfg through parameters -* manage nagios users through external Puppet rules via define +* manage Nagios users through external Puppet rules via define +* manage Nagios commands through Puppet exports * configure NRPE on clients (optional) * configure firewall (optional) * configure selinux policies (optional) diff --git a/manifests/nagios/objects/commands.pp b/manifests/nagios/objects/commands.pp new file mode 100644 index 0000000..9b44306 --- /dev/null +++ b/manifests/nagios/objects/commands.pp @@ -0,0 +1,249 @@ +## cd_nagios::nagios::objects::commands.pp +# Module name: cd_nagios +# Author: Arne Teuke (arne_teuke@ConfDroid.com) +# # License: +# This file is part of cd_nagios. +# +# cd_nagios is used for providing automatic configuration of Nagios +# Copyright (C) 2016 ConfDroid (copyright@ConfDroid.com) +# This program is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# This program is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with this program. If not, see . +# @summary Class manages all configuration files required for cd_nagios. +############################################################################## +class cd_nagios::nagios::objects::commands ( + +) inherits cd_nagios::params { + + require cd_nagios::main::install + + @@nagios_command { 'notify-host-by-email': + ensure => present, + command_name => 'notify-host-by-email', + command_line => '/usr/bin/printf "%b" "***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\nHost: $HOSTADDRESS$\nState: $HOSTSTATE$\nAddress: $HOSTADDRESS$\nInfo: $HOSTOUTPUT$\n\nDate/Time: $LONGDATETIME$\n" | /bin/mail -s "** $NOTIFICATIONTYPE$ Host Alert: $HOSTADDRESS$ is $HOSTSTATE$ **" $CONTACTEMAIL$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'notify-service-by-email': + ensure => present, + command_name => 'notify-service-by-email', + command_line => '/usr/bin/printf "%b" "***** Nagios *****\n\nNotification Type: $NOTIFICATIONTYPE$\n\nService: $SERVICEDESC$\nHost: $HOSTALIAS$\nAddress: $HOSTADDRESS$\nState: $SERVICESTATE$\n\nDate/Time: $LONGDATETIME$\n\nAdditional Info:\n\n$SERVICEOUTPUT$\n" | /bin/mail -s "** $NOTIFICATIONTYPE$ Service Alert: $HOSTALIAS$/$SERVICEDESC$ is $SERVICESTATE$ **" $CONTACTEMAIL$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check-host-alive': + ensure => present, + command_name => 'check-host-alive', + command_line => '$USER1$/check_ping -H $HOSTADDRESS$ -w 3000.0,80% -c 5000.0,100% -p 5', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_disk': + ensure => present, + command_name => 'check_disk', + command_line => '$USER1$/check_disk -w $ARG1$ -c $ARG2$ -p $ARG3$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_local_load': + ensure => present, + command_name => 'check_local_load', + command_line => '$USER1$/check_load -w $ARG1$ -c $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_local_procs': + ensure => present, + command_name => 'check_local_procs', + command_line => '$USER1$/check_procs -w $ARG1$ -c $ARG2$ -s $ARG3$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_local_users': + ensure => present, + command_name => 'check_local_users', + command_line => '$USER1$/check_users -w $ARG1$ -c $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_local_swap': + ensure => present, + command_name => 'check_local_swap', + command_line => '$USER1$/check_swap -w $ARG1$ -c $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_ftp': + ensure => present, + command_name => 'check_ftp', + command_line => '$USER1$/check_ftp -H $HOSTADDRESS$ $ARG1$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_snmp': + ensure => present, + command_name => 'check_snmp', + command_line => '$USER1$/check_snmp -H $HOSTADDRESS$ $ARG1$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_http': + ensure => present, + command_name => 'check_http', + command_line => '$USER1$/check_http -I $HOSTADDRESS$ $ARG1$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_ssh': + ensure => present, + command_name => 'check_ssh', + command_line => '$USER1$/check_ssh $ARG1$ $HOSTADDRESS$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_ping': + ensure => present, + command_name => 'check_ping', + command_line => '$USER1$/check_ping -H $HOSTADDRESS$ -w $ARG1$ -c $ARG2$ -p 5', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_tcp': + ensure => present, + command_name => 'check_tcp', + command_line => '$USER1$/check_tcp -H $HOSTADDRESS$ -p $ARG1$ $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_udp': + ensure => present, + command_name => 'check_udp', + command_line => '$USER1$/check_udp -H $HOSTADDRESS$ -p $ARG1$ $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_nrpe': + ensure => present, + command_name => 'check_nrpe', + command_line => '$USER1$/check_nrpe -t 30 -H $HOSTADDRESS$ -c $ARG1$ -a $ARG2$ $ARG3$ $ARG4$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_nagios': + ensure => present, + command_name => 'check_nagios', + command_line => '$USER1$/check_nagios -F $ARG1$ -e $ARG2$ -C $ARG3$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_bandwidth': + ensure => present, + command_name => 'check_bandwidth', + command_line => '$USER1$/check_bandwidth.sh -t 30 -H $HOSTADDRESS$ linux $ARG1$ $ARG2$ $ARG3$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_jenkins_api': + ensure => present, + command_name => 'check_jenkins_api', + command_line => '$USER1$/check_http -H $HOSTADDRESS$ -u /api/xml?depth=0 -R quietingDown.false $ARG1$ $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + + @@nagios_command { 'process-service-perfdata-file': + ensure => present, + command_name => 'process-service-perfdata-file', + command_line => '/bin/mv /var/log/pnp4nagios/service-perfdata /var/spool/pnp4nagios/service-perfdata.$TIMET$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'process-host-perfdata-file': + ensure => present, + command_name => 'process-host-perfdata-file', + command_line => '/bin/mv /var/log/pnp4nagios/host-perfdata /var/spool/pnp4nagios/host-perfdata.$TIMET$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } + + @@nagios_command { 'check_ntp_time': + ensure => present, + command_name => 'check_ntp_time', + command_line => '$USER1$/check_ntp_time -H $HOSTADDRESS$ -w $ARG1$ -c $ARG2$', + owner => 'nagios', + group => 'nagios', + mode => '0640', + target => $ng_target_command, + } +}