diff options
Diffstat (limited to 'plugins-scripts')
| -rw-r--r-- | plugins-scripts/Makefile.am | 2 | ||||
| -rwxr-xr-x | plugins-scripts/check_breeze.pl | 3 | ||||
| -rwxr-xr-x | plugins-scripts/check_disk_smb.pl | 9 | ||||
| -rwxr-xr-x | plugins-scripts/check_file_age.pl | 22 | ||||
| -rwxr-xr-x | plugins-scripts/check_flexlm.pl | 7 | ||||
| -rwxr-xr-x | plugins-scripts/check_ifoperstatus.pl | 16 | ||||
| -rwxr-xr-x | plugins-scripts/check_ifstatus.pl | 15 | ||||
| -rwxr-xr-x | plugins-scripts/check_ircd.pl | 9 | ||||
| -rwxr-xr-x | plugins-scripts/check_log.sh | 29 | ||||
| -rwxr-xr-x | plugins-scripts/check_mailq.pl | 105 | ||||
| -rwxr-xr-x | plugins-scripts/check_mssql.pl | 4 | ||||
| -rwxr-xr-x | plugins-scripts/check_netdns.pl | 3 | ||||
| -rwxr-xr-x | plugins-scripts/check_oracle.sh | 4 | ||||
| -rwxr-xr-x | plugins-scripts/check_rpc.pl | 7 | ||||
| -rwxr-xr-x | plugins-scripts/check_wave.pl | 3 | ||||
| -rw-r--r-- | plugins-scripts/subst.in | 16 | ||||
| -rw-r--r-- | plugins-scripts/t/check_file_age.t | 7 | ||||
| -rw-r--r-- | plugins-scripts/utils.pm.in | 4 | ||||
| -rw-r--r-- | plugins-scripts/utils.sh.in | 10 |
19 files changed, 168 insertions, 107 deletions
diff --git a/plugins-scripts/Makefile.am b/plugins-scripts/Makefile.am index 58db0604..4ea262af 100644 --- a/plugins-scripts/Makefile.am +++ b/plugins-scripts/Makefile.am | |||
| @@ -19,7 +19,7 @@ libexec_SCRIPTS = check_breeze check_disk_smb check_flexlm check_ircd \ | |||
| 19 | utils.sh utils.pm | 19 | utils.sh utils.pm |
| 20 | 20 | ||
| 21 | EXTRA_DIST=check_breeze.pl check_disk_smb.pl check_flexlm.pl check_ircd.pl \ | 21 | EXTRA_DIST=check_breeze.pl check_disk_smb.pl check_flexlm.pl check_ircd.pl \ |
| 22 | check_log.sh check_ntp.pl check_oracle.sh check_rpc.pl check_sensors.sh \ | 22 | check_log.sh check_oracle.sh check_rpc.pl check_sensors.sh \ |
| 23 | check_ifstatus.pl check_ifoperstatus.pl check_wave.pl check_mailq.pl check_file_age.pl \ | 23 | check_ifstatus.pl check_ifoperstatus.pl check_wave.pl check_mailq.pl check_file_age.pl \ |
| 24 | utils.sh.in utils.pm.in t | 24 | utils.sh.in utils.pm.in t |
| 25 | 25 | ||
diff --git a/plugins-scripts/check_breeze.pl b/plugins-scripts/check_breeze.pl index 037060c8..917a1c6f 100755 --- a/plugins-scripts/check_breeze.pl +++ b/plugins-scripts/check_breeze.pl | |||
| @@ -4,7 +4,8 @@ | |||
| 4 | use strict; | 4 | use strict; |
| 5 | use Getopt::Long; | 5 | use Getopt::Long; |
| 6 | use vars qw($opt_V $opt_h $opt_w $opt_c $opt_H $opt_C $PROGNAME); | 6 | use vars qw($opt_V $opt_h $opt_w $opt_c $opt_H $opt_C $PROGNAME); |
| 7 | use lib utils.pm ; | 7 | use FindBin; |
| 8 | use lib "$FindBin::Bin"; | ||
| 8 | use utils qw(%ERRORS &print_revision &support &usage); | 9 | use utils qw(%ERRORS &print_revision &support &usage); |
| 9 | 10 | ||
| 10 | $PROGNAME = "check_breeze"; | 11 | $PROGNAME = "check_breeze"; |
diff --git a/plugins-scripts/check_disk_smb.pl b/plugins-scripts/check_disk_smb.pl index 01c560ef..36259d59 100755 --- a/plugins-scripts/check_disk_smb.pl +++ b/plugins-scripts/check_disk_smb.pl | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | # | 3 | # |
| 4 | # check_disk.pl <host> <share> <user> <pass> [warn] [critical] [port] | 4 | # check_disk.pl <host> <share> <user> <pass> [warn] [critical] [port] |
| 5 | # | 5 | # |
| 6 | # Nagios host script to get the disk usage from a SMB share | 6 | # Monitoring host script to get the disk usage from a SMB share |
| 7 | # | 7 | # |
| 8 | # Changes and Modifications | 8 | # Changes and Modifications |
| 9 | # ========================= | 9 | # ========================= |
| @@ -24,7 +24,8 @@ use strict; | |||
| 24 | use Getopt::Long; | 24 | use Getopt::Long; |
| 25 | use vars qw($opt_P $opt_V $opt_h $opt_H $opt_s $opt_W $opt_u $opt_p $opt_w $opt_c $opt_a $verbose); | 25 | use vars qw($opt_P $opt_V $opt_h $opt_H $opt_s $opt_W $opt_u $opt_p $opt_w $opt_c $opt_a $verbose); |
| 26 | use vars qw($PROGNAME); | 26 | use vars qw($PROGNAME); |
| 27 | use lib utils.pm ; | 27 | use FindBin; |
| 28 | use lib "$FindBin::Bin"; | ||
| 28 | use utils qw($TIMEOUT %ERRORS &print_revision &support &usage); | 29 | use utils qw($TIMEOUT %ERRORS &print_revision &support &usage); |
| 29 | 30 | ||
| 30 | sub print_help (); | 31 | sub print_help (); |
| @@ -171,7 +172,7 @@ my $res = undef; | |||
| 171 | my $perfdata = ""; | 172 | my $perfdata = ""; |
| 172 | my @lines = undef; | 173 | my @lines = undef; |
| 173 | 174 | ||
| 174 | # Just in case of problems, let's not hang Nagios | 175 | # Just in case of problems, let's not hang the monitoring system |
| 175 | $SIG{'ALRM'} = sub { | 176 | $SIG{'ALRM'} = sub { |
| 176 | print "No Answer from Client\n"; | 177 | print "No Answer from Client\n"; |
| 177 | exit $ERRORS{"UNKNOWN"}; | 178 | exit $ERRORS{"UNKNOWN"}; |
| @@ -293,7 +294,7 @@ sub print_help () { | |||
| 293 | print_revision($PROGNAME,'@NP_VERSION@'); | 294 | print_revision($PROGNAME,'@NP_VERSION@'); |
| 294 | print "Copyright (c) 2000 Michael Anthon/Karl DeBisschop | 295 | print "Copyright (c) 2000 Michael Anthon/Karl DeBisschop |
| 295 | 296 | ||
| 296 | Perl Check SMB Disk plugin for Nagios | 297 | Perl Check SMB Disk plugin for monitoring |
| 297 | 298 | ||
| 298 | "; | 299 | "; |
| 299 | print_usage(); | 300 | print_usage(); |
diff --git a/plugins-scripts/check_file_age.pl b/plugins-scripts/check_file_age.pl index 37bbe86f..e0280381 100755 --- a/plugins-scripts/check_file_age.pl +++ b/plugins-scripts/check_file_age.pl | |||
| @@ -17,9 +17,8 @@ | |||
| 17 | # GNU General Public License for more details. | 17 | # GNU General Public License for more details. |
| 18 | # | 18 | # |
| 19 | # you should have received a copy of the GNU General Public License | 19 | # you should have received a copy of the GNU General Public License |
| 20 | # along with this program (or with Nagios); if not, write to the | 20 | # along with this program if not, write to the Free Software Foundation, |
| 21 | # Free Software Foundation, Inc., 59 Temple Place - Suite 330, | 21 | # 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA |
| 22 | # Boston, MA 02111-1307, USA | ||
| 23 | 22 | ||
| 24 | use strict; | 23 | use strict; |
| 25 | use English; | 24 | use English; |
| @@ -32,7 +31,7 @@ use utils qw (%ERRORS &print_revision &support); | |||
| 32 | sub print_help (); | 31 | sub print_help (); |
| 33 | sub print_usage (); | 32 | sub print_usage (); |
| 34 | 33 | ||
| 35 | my ($opt_c, $opt_f, $opt_w, $opt_C, $opt_W, $opt_h, $opt_V); | 34 | my ($opt_c, $opt_f, $opt_w, $opt_C, $opt_W, $opt_h, $opt_V, $opt_i); |
| 36 | my ($result, $message, $age, $size, $st); | 35 | my ($result, $message, $age, $size, $st); |
| 37 | 36 | ||
| 38 | $PROGNAME="check_file_age"; | 37 | $PROGNAME="check_file_age"; |
| @@ -51,6 +50,7 @@ Getopt::Long::Configure('bundling'); | |||
| 51 | GetOptions( | 50 | GetOptions( |
| 52 | "V" => \$opt_V, "version" => \$opt_V, | 51 | "V" => \$opt_V, "version" => \$opt_V, |
| 53 | "h" => \$opt_h, "help" => \$opt_h, | 52 | "h" => \$opt_h, "help" => \$opt_h, |
| 53 | "i" => \$opt_i, "ignore-missing" => \$opt_i, | ||
| 54 | "f=s" => \$opt_f, "file" => \$opt_f, | 54 | "f=s" => \$opt_f, "file" => \$opt_f, |
| 55 | "w=f" => \$opt_w, "warning-age=f" => \$opt_w, | 55 | "w=f" => \$opt_w, "warning-age=f" => \$opt_w, |
| 56 | "W=f" => \$opt_W, "warning-size=f" => \$opt_W, | 56 | "W=f" => \$opt_W, "warning-size=f" => \$opt_W, |
| @@ -76,8 +76,15 @@ if (! $opt_f) { | |||
| 76 | 76 | ||
| 77 | # Check that file exists (can be directory or link) | 77 | # Check that file exists (can be directory or link) |
| 78 | unless (-e $opt_f) { | 78 | unless (-e $opt_f) { |
| 79 | print "FILE_AGE CRITICAL: File not found - $opt_f\n"; | 79 | if ($opt_i) { |
| 80 | exit $ERRORS{'CRITICAL'}; | 80 | $result = 'OK'; |
| 81 | print "FILE_AGE $result: $opt_f doesn't exist, but ignore-missing was set\n"; | ||
| 82 | exit $ERRORS{$result}; | ||
| 83 | |||
| 84 | } else { | ||
| 85 | print "FILE_AGE CRITICAL: File not found - $opt_f\n"; | ||
| 86 | exit $ERRORS{'CRITICAL'}; | ||
| 87 | } | ||
| 81 | } | 88 | } |
| 82 | 89 | ||
| 83 | $st = File::stat::stat($opt_f); | 90 | $st = File::stat::stat($opt_f); |
| @@ -99,7 +106,7 @@ exit $ERRORS{$result}; | |||
| 99 | 106 | ||
| 100 | sub print_usage () { | 107 | sub print_usage () { |
| 101 | print "Usage:\n"; | 108 | print "Usage:\n"; |
| 102 | print " $PROGNAME [-w <secs>] [-c <secs>] [-W <size>] [-C <size>] -f <file>\n"; | 109 | print " $PROGNAME [-w <secs>] [-c <secs>] [-W <size>] [-C <size>] [-i] -f <file>\n"; |
| 103 | print " $PROGNAME [-h | --help]\n"; | 110 | print " $PROGNAME [-h | --help]\n"; |
| 104 | print " $PROGNAME [-V | --version]\n"; | 111 | print " $PROGNAME [-V | --version]\n"; |
| 105 | } | 112 | } |
| @@ -109,6 +116,7 @@ sub print_help () { | |||
| 109 | print "Copyright (c) 2003 Steven Grimm\n\n"; | 116 | print "Copyright (c) 2003 Steven Grimm\n\n"; |
| 110 | print_usage(); | 117 | print_usage(); |
| 111 | print "\n"; | 118 | print "\n"; |
| 119 | print " -i | --ignore-missing : return OK if the file does not exist\n"; | ||
| 112 | print " <secs> File must be no more than this many seconds old (default: warn 240 secs, crit 600)\n"; | 120 | print " <secs> File must be no more than this many seconds old (default: warn 240 secs, crit 600)\n"; |
| 113 | print " <size> File must be at least this many bytes long (default: crit 0 bytes)\n"; | 121 | print " <size> File must be at least this many bytes long (default: crit 0 bytes)\n"; |
| 114 | print "\n"; | 122 | print "\n"; |
diff --git a/plugins-scripts/check_flexlm.pl b/plugins-scripts/check_flexlm.pl index 05973777..de63d3ab 100755 --- a/plugins-scripts/check_flexlm.pl +++ b/plugins-scripts/check_flexlm.pl | |||
| @@ -9,7 +9,7 @@ | |||
| 9 | # Check and interpret the output of lmstat | 9 | # Check and interpret the output of lmstat |
| 10 | # and create returncodes and output. | 10 | # and create returncodes and output. |
| 11 | # | 11 | # |
| 12 | # Contrary to the nagios concept, this script takes | 12 | # Contrary to most other plugins, this script takes |
| 13 | # a file, not a hostname as an argument and returns | 13 | # a file, not a hostname as an argument and returns |
| 14 | # the status of hosts and services described in that | 14 | # the status of hosts and services described in that |
| 15 | # file. Use these hosts.cfg entries as an example | 15 | # file. Use these hosts.cfg entries as an example |
| @@ -35,7 +35,8 @@ | |||
| 35 | use strict; | 35 | use strict; |
| 36 | use Getopt::Long; | 36 | use Getopt::Long; |
| 37 | use vars qw($opt_V $opt_h $opt_F $opt_t $verbose $PROGNAME); | 37 | use vars qw($opt_V $opt_h $opt_F $opt_t $verbose $PROGNAME); |
| 38 | use lib utils.pm; | 38 | use FindBin; |
| 39 | use lib "$FindBin::Bin"; | ||
| 39 | use utils qw(%ERRORS &print_revision &support &usage); | 40 | use utils qw(%ERRORS &print_revision &support &usage); |
| 40 | 41 | ||
| 41 | $PROGNAME="check_flexlm"; | 42 | $PROGNAME="check_flexlm"; |
| @@ -72,7 +73,7 @@ unless (defined $opt_F) { | |||
| 72 | print_usage(); | 73 | print_usage(); |
| 73 | exit $ERRORS{'UNKNOWN'}; | 74 | exit $ERRORS{'UNKNOWN'}; |
| 74 | } | 75 | } |
| 75 | # Just in case of problems, let's not hang Nagios | 76 | # Just in case of problems, let's not hang the monitoring system |
| 76 | $SIG{'ALRM'} = sub { | 77 | $SIG{'ALRM'} = sub { |
| 77 | print "Timeout: No Answer from Client\n"; | 78 | print "Timeout: No Answer from Client\n"; |
| 78 | exit $ERRORS{'UNKNOWN'}; | 79 | exit $ERRORS{'UNKNOWN'}; |
diff --git a/plugins-scripts/check_ifoperstatus.pl b/plugins-scripts/check_ifoperstatus.pl index 452911b7..159eb62e 100755 --- a/plugins-scripts/check_ifoperstatus.pl +++ b/plugins-scripts/check_ifoperstatus.pl | |||
| @@ -1,9 +1,9 @@ | |||
| 1 | #!/usr/local/bin/perl -w | 1 | #!/usr/local/bin/perl -w |
| 2 | # | 2 | # |
| 3 | # check_ifoperstatus.pl - nagios plugin | 3 | # check_ifoperstatus.pl - monitoring plugin |
| 4 | # | 4 | # |
| 5 | # Copyright (C) 2000 Christoph Kron, | 5 | # Copyright (C) 2000 Christoph Kron, |
| 6 | # Modified 5/2002 to conform to updated Nagios Plugin Guidelines | 6 | # Modified 5/2002 to conform to updated Monitoring Plugins Guidelines |
| 7 | # Added support for named interfaces per Valdimir Ivaschenko (S. Ghosh) | 7 | # Added support for named interfaces per Valdimir Ivaschenko (S. Ghosh) |
| 8 | # Added SNMPv3 support (10/2003) | 8 | # Added SNMPv3 support (10/2003) |
| 9 | # | 9 | # |
| @@ -19,10 +19,11 @@ | |||
| 19 | # | 19 | # |
| 20 | # You should have received a copy of the GNU General Public License | 20 | # You should have received a copy of the GNU General Public License |
| 21 | # along with this program; if not, write to the Free Software | 21 | # along with this program; if not, write to the Free Software |
| 22 | # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 22 | # Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, |
| 23 | # USA | ||
| 23 | # | 24 | # |
| 24 | # | 25 | # |
| 25 | # Report bugs to: nagiosplug-help@lists.sourceforge.net | 26 | # Report bugs to: help@monitoring-plugins.org |
| 26 | # | 27 | # |
| 27 | # 11.01.2000 Version 1.0 | 28 | # 11.01.2000 Version 1.0 |
| 28 | # | 29 | # |
| @@ -34,7 +35,8 @@ | |||
| 34 | 35 | ||
| 35 | use POSIX; | 36 | use POSIX; |
| 36 | use strict; | 37 | use strict; |
| 37 | use lib utils.pm ; | 38 | use FindBin; |
| 39 | use lib "$FindBin::Bin"; | ||
| 38 | use utils qw($TIMEOUT %ERRORS &print_revision &support); | 40 | use utils qw($TIMEOUT %ERRORS &print_revision &support); |
| 39 | 41 | ||
| 40 | use Net::SNMP; | 42 | use Net::SNMP; |
| @@ -101,7 +103,7 @@ my %session_opts; | |||
| 101 | $status = process_arguments(); | 103 | $status = process_arguments(); |
| 102 | 104 | ||
| 103 | 105 | ||
| 104 | # Just in case of problems, let's not hang Nagios | 106 | # Just in case of problems, let's not hang the monitoring system |
| 105 | $SIG{'ALRM'} = sub { | 107 | $SIG{'ALRM'} = sub { |
| 106 | print ("ERROR: No snmp response from $hostname (alarm)\n"); | 108 | print ("ERROR: No snmp response from $hostname (alarm)\n"); |
| 107 | exit $ERRORS{"UNKNOWN"}; | 109 | exit $ERRORS{"UNKNOWN"}; |
| @@ -292,7 +294,7 @@ sub print_usage() { | |||
| 292 | sub print_help() { | 294 | sub print_help() { |
| 293 | print_revision($PROGNAME, '@NP_VERSION@'); | 295 | print_revision($PROGNAME, '@NP_VERSION@'); |
| 294 | print_usage(); | 296 | print_usage(); |
| 295 | printf "check_ifoperstatus plugin for Nagios monitors operational \n"; | 297 | printf "check_ifoperstatus plugin for monitoring operational \n"; |
| 296 | printf "status of a particular network interface on the target host\n"; | 298 | printf "status of a particular network interface on the target host\n"; |
| 297 | printf "\nUsage:\n"; | 299 | printf "\nUsage:\n"; |
| 298 | printf " -H (--hostname) Hostname to query - (required)\n"; | 300 | printf " -H (--hostname) Hostname to query - (required)\n"; |
diff --git a/plugins-scripts/check_ifstatus.pl b/plugins-scripts/check_ifstatus.pl index 421580ad..4760a281 100755 --- a/plugins-scripts/check_ifstatus.pl +++ b/plugins-scripts/check_ifstatus.pl | |||
| @@ -1,10 +1,10 @@ | |||
| 1 | #!/usr/local/bin/perl -w | 1 | #!/usr/local/bin/perl -w |
| 2 | # | 2 | # |
| 3 | # check_ifstatus.pl - nagios plugin | 3 | # check_ifstatus.pl - monitoring plugin |
| 4 | # | 4 | # |
| 5 | # | 5 | # |
| 6 | # Copyright (C) 2000 Christoph Kron | 6 | # Copyright (C) 2000 Christoph Kron |
| 7 | # Modified 5/2002 to conform to updated Nagios Plugin Guidelines (S. Ghosh) | 7 | # Modified 5/2002 to conform to updated Monitoring Plugins Guidelines (S. Ghosh) |
| 8 | # Added -x option (4/2003) | 8 | # Added -x option (4/2003) |
| 9 | # Added -u option (4/2003) | 9 | # Added -u option (4/2003) |
| 10 | # Added -M option (10/2003) | 10 | # Added -M option (10/2003) |
| @@ -22,17 +22,18 @@ | |||
| 22 | # | 22 | # |
| 23 | # You should have received a copy of the GNU General Public License | 23 | # You should have received a copy of the GNU General Public License |
| 24 | # along with this program; if not, write to the Free Software | 24 | # along with this program; if not, write to the Free Software |
| 25 | # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 25 | # Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA |
| 26 | # | 26 | # |
| 27 | # | 27 | # |
| 28 | # Report bugs to: ck@zet.net, nagiosplug-help@lists.sf.net | 28 | # Report bugs to: ck@zet.net, help@monitoring-plugins.org |
| 29 | # | 29 | # |
| 30 | # 11.01.2000 Version 1.0 | 30 | # 11.01.2000 Version 1.0 |
| 31 | # | 31 | # |
| 32 | 32 | ||
| 33 | use POSIX; | 33 | use POSIX; |
| 34 | use strict; | 34 | use strict; |
| 35 | use lib utils.pm ; | 35 | use FindBin; |
| 36 | use lib "$FindBin::Bin"; | ||
| 36 | use utils qw($TIMEOUT %ERRORS &print_revision &support); | 37 | use utils qw($TIMEOUT %ERRORS &print_revision &support); |
| 37 | 38 | ||
| 38 | use Net::SNMP; | 39 | use Net::SNMP; |
| @@ -102,7 +103,7 @@ my %session_opts; | |||
| 102 | 103 | ||
| 103 | 104 | ||
| 104 | 105 | ||
| 105 | # Just in case of problems, let's not hang Nagios | 106 | # Just in case of problems, let's not hang the monitoring system |
| 106 | $SIG{'ALRM'} = sub { | 107 | $SIG{'ALRM'} = sub { |
| 107 | print ("ERROR: No snmp response from $hostname (alarm timeout)\n"); | 108 | print ("ERROR: No snmp response from $hostname (alarm timeout)\n"); |
| 108 | exit $ERRORS{"UNKNOWN"}; | 109 | exit $ERRORS{"UNKNOWN"}; |
| @@ -242,7 +243,7 @@ sub print_usage() { | |||
| 242 | sub print_help() { | 243 | sub print_help() { |
| 243 | print_revision($PROGNAME, '@NP_VERSION@'); | 244 | print_revision($PROGNAME, '@NP_VERSION@'); |
| 244 | print_usage(); | 245 | print_usage(); |
| 245 | printf "check_ifstatus plugin for Nagios monitors operational \n"; | 246 | printf "check_ifstatus plugin for monitoring operational \n"; |
| 246 | printf "status of each network interface on the target host\n"; | 247 | printf "status of each network interface on the target host\n"; |
| 247 | printf "\nUsage:\n"; | 248 | printf "\nUsage:\n"; |
| 248 | printf " -H (--hostname) Hostname to query - (required)\n"; | 249 | printf " -H (--hostname) Hostname to query - (required)\n"; |
diff --git a/plugins-scripts/check_ircd.pl b/plugins-scripts/check_ircd.pl index f80c5c65..dab65954 100755 --- a/plugins-scripts/check_ircd.pl +++ b/plugins-scripts/check_ircd.pl | |||
| @@ -16,8 +16,6 @@ | |||
| 16 | # ----------------------------------------------------------------------------- | 16 | # ----------------------------------------------------------------------------- |
| 17 | # Copyright 1999 (c) Richard Mayhew | 17 | # Copyright 1999 (c) Richard Mayhew |
| 18 | # | 18 | # |
| 19 | # Credits go to Ethan Galstad for coding Nagios | ||
| 20 | # | ||
| 21 | # If any changes are made to this script, please mail me a copy of the | 19 | # If any changes are made to this script, please mail me a copy of the |
| 22 | # changes :) | 20 | # changes :) |
| 23 | # | 21 | # |
| @@ -51,7 +49,8 @@ use strict; | |||
| 51 | use Getopt::Long; | 49 | use Getopt::Long; |
| 52 | use vars qw($opt_V $opt_h $opt_t $opt_p $opt_H $opt_w $opt_c $verbose); | 50 | use vars qw($opt_V $opt_h $opt_t $opt_p $opt_H $opt_w $opt_c $verbose); |
| 53 | use vars qw($PROGNAME); | 51 | use vars qw($PROGNAME); |
| 54 | use lib utils.pm; | 52 | use FindBin; |
| 53 | use lib "$FindBin::Bin"; | ||
| 55 | use utils qw($TIMEOUT %ERRORS &print_revision &support &usage); | 54 | use utils qw($TIMEOUT %ERRORS &print_revision &support &usage); |
| 56 | 55 | ||
| 57 | # ----------------------------------------------------[ Function Prototypes ]-- | 56 | # ----------------------------------------------------[ Function Prototypes ]-- |
| @@ -121,7 +120,7 @@ sub print_help () | |||
| 121 | print_revision($PROGNAME,'@NP_VERSION@'); | 120 | print_revision($PROGNAME,'@NP_VERSION@'); |
| 122 | print "Copyright (c) 2000 Richard Mayhew/Karl DeBisschop | 121 | print "Copyright (c) 2000 Richard Mayhew/Karl DeBisschop |
| 123 | 122 | ||
| 124 | Perl Check IRCD plugin for Nagios | 123 | Perl Check IRCD plugin for monitoring |
| 125 | 124 | ||
| 126 | "; | 125 | "; |
| 127 | print_usage(); | 126 | print_usage(); |
| @@ -205,7 +204,7 @@ MAIN: | |||
| 205 | 204 | ||
| 206 | if ($opt_t && $opt_t =~ /^([0-9]+)$/) { $TIMEOUT = $1; } | 205 | if ($opt_t && $opt_t =~ /^([0-9]+)$/) { $TIMEOUT = $1; } |
| 207 | 206 | ||
| 208 | # Just in case of problems, let's not hang Nagios | 207 | # Just in case of problems, let's not hang the monitoring system |
| 209 | $SIG{'ALRM'} = sub { | 208 | $SIG{'ALRM'} = sub { |
| 210 | print "Somthing is Taking a Long Time, Increase Your TIMEOUT (Currently Set At $TIMEOUT Seconds)\n"; | 209 | print "Somthing is Taking a Long Time, Increase Your TIMEOUT (Currently Set At $TIMEOUT Seconds)\n"; |
| 211 | exit $ERRORS{"UNKNOWN"}; | 210 | exit $ERRORS{"UNKNOWN"}; |
diff --git a/plugins-scripts/check_log.sh b/plugins-scripts/check_log.sh index a9ff06ad..be4c7be1 100755 --- a/plugins-scripts/check_log.sh +++ b/plugins-scripts/check_log.sh | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | #!/bin/sh | 1 | #!/bin/sh |
| 2 | # | 2 | # |
| 3 | # Log file pattern detector plugin for Nagios | 3 | # Log file pattern detector plugin for monitoring |
| 4 | # Written by Ethan Galstad (nagios@nagios.org) | 4 | # Written by Ethan Galstad (nagios@nagios.org) |
| 5 | # Last Modified: 07-31-1999 | 5 | # Last Modified: 07-31-1999 |
| 6 | # | 6 | # |
| @@ -29,15 +29,15 @@ | |||
| 29 | # | 29 | # |
| 30 | # If you use this plugin make sure to keep the following in mind: | 30 | # If you use this plugin make sure to keep the following in mind: |
| 31 | # | 31 | # |
| 32 | # 1. The "max_attempts" value for the service should be 1, as this | 32 | # 1. The "max_attempts" value for the service should be 1, as this will |
| 33 | # will prevent Nagios from retrying the service check (the | 33 | # prevent the monitoring system from retrying the service check (the |
| 34 | # next time the check is run it will not produce the same results). | 34 | # next time the check is run it will not produce the same results). |
| 35 | # | 35 | # |
| 36 | # 2. The "notify_recovery" value for the service should be 0, so that | 36 | # 2. The "notify_recovery" value for the service should be 0, so that the |
| 37 | # Nagios does not notify you of "recoveries" for the check. Since | 37 | # monitoring system does not notify you of "recoveries" for the check. |
| 38 | # pattern matches in the log file will only be reported once and not | 38 | # Since pattern matches in the log file will only be reported once and |
| 39 | # the next time, there will always be "recoveries" for the service, even | 39 | # not the next time, there will always be "recoveries" for the service, |
| 40 | # though recoveries really don't apply to this type of check. | 40 | # even though recoveries really don't apply to this type of check. |
| 41 | # | 41 | # |
| 42 | # 3. You *must* supply a different <old_file_log> for each service that | 42 | # 3. You *must* supply a different <old_file_log> for each service that |
| 43 | # you define to use this plugin script - even if the different services | 43 | # you define to use this plugin script - even if the different services |
| @@ -58,7 +58,6 @@ | |||
| 58 | # Paths to commands used in this script. These | 58 | # Paths to commands used in this script. These |
| 59 | # may have to be modified to match your system setup. | 59 | # may have to be modified to match your system setup. |
| 60 | 60 | ||
| 61 | ECHO="/bin/echo" | ||
| 62 | GREP="/bin/egrep" | 61 | GREP="/bin/egrep" |
| 63 | DIFF="/bin/diff" | 62 | DIFF="/bin/diff" |
| 64 | TAIL="/bin/tail" | 63 | TAIL="/bin/tail" |
| @@ -85,7 +84,7 @@ print_help() { | |||
| 85 | echo "" | 84 | echo "" |
| 86 | print_usage | 85 | print_usage |
| 87 | echo "" | 86 | echo "" |
| 88 | echo "Log file pattern detector plugin for Nagios" | 87 | echo "Log file pattern detector plugin for monitoring" |
| 89 | echo "" | 88 | echo "" |
| 90 | support | 89 | support |
| 91 | } | 90 | } |
| @@ -166,10 +165,10 @@ done | |||
| 166 | # If the source log file doesn't exist, exit | 165 | # If the source log file doesn't exist, exit |
| 167 | 166 | ||
| 168 | if [ ! -e $logfile ]; then | 167 | if [ ! -e $logfile ]; then |
| 169 | $ECHO "Log check error: Log file $logfile does not exist!\n" | 168 | echo "Log check error: Log file $logfile does not exist!" |
| 170 | exit $STATE_UNKNOWN | 169 | exit $STATE_UNKNOWN |
| 171 | elif [ ! -r $logfile ] ; then | 170 | elif [ ! -r $logfile ] ; then |
| 172 | $ECHO "Log check error: Log file $logfile is not readable!\n" | 171 | echo "Log check error: Log file $logfile is not readable!" |
| 173 | exit $STATE_UNKNOWN | 172 | exit $STATE_UNKNOWN |
| 174 | fi | 173 | fi |
| 175 | 174 | ||
| @@ -179,7 +178,7 @@ fi | |||
| 179 | 178 | ||
| 180 | if [ ! -e $oldlog ]; then | 179 | if [ ! -e $oldlog ]; then |
| 181 | $CAT $logfile > $oldlog | 180 | $CAT $logfile > $oldlog |
| 182 | $ECHO "Log check data initialized...\n" | 181 | echo "Log check data initialized..." |
| 183 | exit $STATE_OK | 182 | exit $STATE_OK |
| 184 | fi | 183 | fi |
| 185 | 184 | ||
| @@ -208,10 +207,10 @@ $RM -f $tempdiff | |||
| 208 | $CAT $logfile > $oldlog | 207 | $CAT $logfile > $oldlog |
| 209 | 208 | ||
| 210 | if [ "$count" = "0" ]; then # no matches, exit with no error | 209 | if [ "$count" = "0" ]; then # no matches, exit with no error |
| 211 | $ECHO "Log check ok - 0 pattern matches found\n" | 210 | echo "Log check ok - 0 pattern matches found" |
| 212 | exitstatus=$STATE_OK | 211 | exitstatus=$STATE_OK |
| 213 | else # Print total matche count and the last entry we found | 212 | else # Print total matche count and the last entry we found |
| 214 | $ECHO "($count) $lastentry" | 213 | echo "($count) $lastentry" |
| 215 | exitstatus=$STATE_CRITICAL | 214 | exitstatus=$STATE_CRITICAL |
| 216 | fi | 215 | fi |
| 217 | 216 | ||
diff --git a/plugins-scripts/check_mailq.pl b/plugins-scripts/check_mailq.pl index 1d0a3ad7..488cf2f1 100755 --- a/plugins-scripts/check_mailq.pl +++ b/plugins-scripts/check_mailq.pl | |||
| @@ -20,8 +20,8 @@ | |||
| 20 | # | 20 | # |
| 21 | # You should have received a copy of the GNU General Public License | 21 | # You should have received a copy of the GNU General Public License |
| 22 | # along with this program; if not, write to the Free Software | 22 | # along with this program; if not, write to the Free Software |
| 23 | # Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 23 | # Foundation, 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 |
| 24 | # | 24 | # USA |
| 25 | # | 25 | # |
| 26 | ############################################################################ | 26 | ############################################################################ |
| 27 | 27 | ||
| @@ -31,7 +31,8 @@ use Getopt::Long; | |||
| 31 | use vars qw($opt_V $opt_h $opt_v $verbose $PROGNAME $opt_w $opt_c $opt_t | 31 | use vars qw($opt_V $opt_h $opt_v $verbose $PROGNAME $opt_w $opt_c $opt_t |
| 32 | $opt_M $mailq $status $state $msg $msg_q $msg_p $opt_W $opt_C $mailq @lines | 32 | $opt_M $mailq $status $state $msg $msg_q $msg_p $opt_W $opt_C $mailq @lines |
| 33 | %srcdomains %dstdomains); | 33 | %srcdomains %dstdomains); |
| 34 | use lib utils.pm; | 34 | use FindBin; |
| 35 | use lib "$FindBin::Bin"; | ||
| 35 | use utils qw(%ERRORS &print_revision &support &usage ); | 36 | use utils qw(%ERRORS &print_revision &support &usage ); |
| 36 | 37 | ||
| 37 | 38 | ||
| @@ -199,20 +200,20 @@ if ($mailq eq "sendmail") { | |||
| 199 | ## now check the queue length(s) | 200 | ## now check the queue length(s) |
| 200 | 201 | ||
| 201 | if ($msg_q == 0) { | 202 | if ($msg_q == 0) { |
| 202 | $msg = "OK: mailq is empty"; | 203 | $msg = "OK: $mailq mailq is empty"; |
| 203 | $state = $ERRORS{'OK'}; | 204 | $state = $ERRORS{'OK'}; |
| 204 | } else { | 205 | } else { |
| 205 | print "msg_q = $msg_q warn=$opt_w crit=$opt_c\n" if $verbose; | 206 | print "msg_q = $msg_q warn=$opt_w crit=$opt_c\n" if $verbose; |
| 206 | 207 | ||
| 207 | # overall queue length | 208 | # overall queue length |
| 208 | if ($msg_q < $opt_w) { | 209 | if ($msg_q < $opt_w) { |
| 209 | $msg = "OK: mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; | 210 | $msg = "OK: $mailq mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; |
| 210 | $state = $ERRORS{'OK'}; | 211 | $state = $ERRORS{'OK'}; |
| 211 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { | 212 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { |
| 212 | $msg = "WARNING: mailq is $msg_q (threshold w = $opt_w)"; | 213 | $msg = "WARNING: $mailq mailq is $msg_q (threshold w = $opt_w)"; |
| 213 | $state = $ERRORS{'WARNING'}; | 214 | $state = $ERRORS{'WARNING'}; |
| 214 | }else { | 215 | }else { |
| 215 | $msg = "CRITICAL: mailq is $msg_q (threshold c = $opt_c)"; | 216 | $msg = "CRITICAL: $mailq mailq is $msg_q (threshold c = $opt_c)"; |
| 216 | $state = $ERRORS{'CRITICAL'}; | 217 | $state = $ERRORS{'CRITICAL'}; |
| 217 | } | 218 | } |
| 218 | 219 | ||
| @@ -344,20 +345,20 @@ elsif ( $mailq eq "postfix" ) { | |||
| 344 | 345 | ||
| 345 | # check queue length(s) | 346 | # check queue length(s) |
| 346 | if ($msg_q == 0){ | 347 | if ($msg_q == 0){ |
| 347 | $msg = "OK: mailq reports queue is empty"; | 348 | $msg = "OK: $mailq mailq reports queue is empty"; |
| 348 | $state = $ERRORS{'OK'}; | 349 | $state = $ERRORS{'OK'}; |
| 349 | } else { | 350 | } else { |
| 350 | print "msg_q = $msg_q warn=$opt_w crit=$opt_c\n" if $verbose; | 351 | print "msg_q = $msg_q warn=$opt_w crit=$opt_c\n" if $verbose; |
| 351 | 352 | ||
| 352 | # overall queue length | 353 | # overall queue length |
| 353 | if ($msg_q < $opt_w) { | 354 | if ($msg_q < $opt_w) { |
| 354 | $msg = "OK: mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; | 355 | $msg = "OK: $mailq mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; |
| 355 | $state = $ERRORS{'OK'}; | 356 | $state = $ERRORS{'OK'}; |
| 356 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { | 357 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { |
| 357 | $msg = "WARNING: mailq is $msg_q (threshold w = $opt_w)"; | 358 | $msg = "WARNING: $mailq mailq is $msg_q (threshold w = $opt_w)"; |
| 358 | $state = $ERRORS{'WARNING'}; | 359 | $state = $ERRORS{'WARNING'}; |
| 359 | }else { | 360 | }else { |
| 360 | $msg = "CRITICAL: mailq is $msg_q (threshold c = $opt_c)"; | 361 | $msg = "CRITICAL: $mailq mailq is $msg_q (threshold c = $opt_c)"; |
| 361 | $state = $ERRORS{'CRITICAL'}; | 362 | $state = $ERRORS{'CRITICAL'}; |
| 362 | } | 363 | } |
| 363 | 364 | ||
| @@ -373,7 +374,7 @@ elsif ( $mailq eq "postfix" ) { | |||
| 373 | # } | 374 | # } |
| 374 | #} | 375 | #} |
| 375 | } | 376 | } |
| 376 | } # end of ($mailq eq "postfixl") | 377 | } # end of ($mailq eq "postfix") |
| 377 | elsif ( $mailq eq "qmail" ) { | 378 | elsif ( $mailq eq "qmail" ) { |
| 378 | 379 | ||
| 379 | # open qmail-qstat | 380 | # open qmail-qstat |
| @@ -431,13 +432,13 @@ elsif ( $mailq eq "qmail" ) { | |||
| 431 | 432 | ||
| 432 | # overall queue length | 433 | # overall queue length |
| 433 | if ($msg_q < $opt_w) { | 434 | if ($msg_q < $opt_w) { |
| 434 | $msg = "OK: mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; | 435 | $msg = "OK: $mailq mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; |
| 435 | $state = $ERRORS{'OK'}; | 436 | $state = $ERRORS{'OK'}; |
| 436 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { | 437 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { |
| 437 | $msg = "WARNING: mailq is $msg_q (threshold w = $opt_w)"; | 438 | $msg = "WARNING: $mailq mailq is $msg_q (threshold w = $opt_w)"; |
| 438 | $state = $ERRORS{'WARNING'}; | 439 | $state = $ERRORS{'WARNING'}; |
| 439 | }else { | 440 | }else { |
| 440 | $msg = "CRITICAL: mailq is $msg_q (threshold c = $opt_c)"; | 441 | $msg = "CRITICAL: $mailq mailq is $msg_q (threshold c = $opt_c)"; |
| 441 | $state = $ERRORS{'CRITICAL'}; | 442 | $state = $ERRORS{'CRITICAL'}; |
| 442 | } | 443 | } |
| 443 | 444 | ||
| @@ -489,17 +490,54 @@ elsif ( $mailq eq "exim" ) { | |||
| 489 | exit $ERRORS{CRITICAL}; | 490 | exit $ERRORS{CRITICAL}; |
| 490 | } | 491 | } |
| 491 | if ($msg_q < $opt_w) { | 492 | if ($msg_q < $opt_w) { |
| 492 | $msg = "OK: mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; | 493 | $msg = "OK: $mailq mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; |
| 493 | $state = $ERRORS{'OK'}; | 494 | $state = $ERRORS{'OK'}; |
| 494 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { | 495 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { |
| 495 | $msg = "WARNING: mailq is $msg_q (threshold w = $opt_w)"; | 496 | $msg = "WARNING: $mailq mailq is $msg_q (threshold w = $opt_w)"; |
| 496 | $state = $ERRORS{'WARNING'}; | 497 | $state = $ERRORS{'WARNING'}; |
| 497 | }else { | 498 | }else { |
| 498 | $msg = "CRITICAL: mailq is $msg_q (threshold c = $opt_c)"; | 499 | $msg = "CRITICAL: $mailq mailq is $msg_q (threshold c = $opt_c)"; |
| 499 | $state = $ERRORS{'CRITICAL'}; | 500 | $state = $ERRORS{'CRITICAL'}; |
| 500 | } | 501 | } |
| 501 | } # end of ($mailq eq "exim") | 502 | } # end of ($mailq eq "exim") |
| 502 | 503 | ||
| 504 | elsif ( $mailq eq "nullmailer" ) { | ||
| 505 | ## open mailq | ||
| 506 | if ( defined $utils::PATH_TO_MAILQ && -x $utils::PATH_TO_MAILQ ) { | ||
| 507 | if (! open (MAILQ, "$utils::PATH_TO_MAILQ | " ) ) { | ||
| 508 | print "ERROR: could not open $utils::PATH_TO_MAILQ \n"; | ||
| 509 | exit $ERRORS{'UNKNOWN'}; | ||
| 510 | } | ||
| 511 | }elsif( defined $utils::PATH_TO_MAILQ){ | ||
| 512 | unless (-x $utils::PATH_TO_MAILQ) { | ||
| 513 | print "ERROR: $utils::PATH_TO_MAILQ is not executable by (uid $>:gid($)))\n"; | ||
| 514 | exit $ERRORS{'UNKNOWN'}; | ||
| 515 | } | ||
| 516 | } else { | ||
| 517 | print "ERROR: \$utils::PATH_TO_MAILQ is not defined\n"; | ||
| 518 | exit $ERRORS{'UNKNOWN'}; | ||
| 519 | } | ||
| 520 | |||
| 521 | while (<MAILQ>) { | ||
| 522 | #2006-06-22 16:00:00 282 bytes | ||
| 523 | |||
| 524 | if (/^[1-9][0-9]*-[01][0-9]-[0-3][0-9]\s[0-2][0-9]\:[0-2][0-9]\:[0-2][0-9]\s{2}[0-9]+\sbytes$/) { | ||
| 525 | $msg_q++ ; | ||
| 526 | } | ||
| 527 | } | ||
| 528 | close(MAILQ) ; | ||
| 529 | if ($msg_q < $opt_w) { | ||
| 530 | $msg = "OK: $mailq mailq ($msg_q) is below threshold ($opt_w/$opt_c)"; | ||
| 531 | $state = $ERRORS{'OK'}; | ||
| 532 | }elsif ($msg_q >= $opt_w && $msg_q < $opt_c) { | ||
| 533 | $msg = "WARNING: $mailq mailq is $msg_q (threshold w = $opt_w)"; | ||
| 534 | $state = $ERRORS{'WARNING'}; | ||
| 535 | }else { | ||
| 536 | $msg = "CRITICAL: $mailq mailq is $msg_q (threshold c = $opt_c)"; | ||
| 537 | $state = $ERRORS{'CRITICAL'}; | ||
| 538 | } | ||
| 539 | } # end of ($mailq eq "nullmailer") | ||
| 540 | |||
| 503 | # Perfdata support | 541 | # Perfdata support |
| 504 | print "$msg|unsent=$msg_q;$opt_w;$opt_c;0\n"; | 542 | print "$msg|unsent=$msg_q;$opt_w;$opt_c;0\n"; |
| 505 | exit $state; | 543 | exit $state; |
| @@ -559,7 +597,7 @@ sub process_arguments(){ | |||
| 559 | } | 597 | } |
| 560 | 598 | ||
| 561 | if (defined $opt_M) { | 599 | if (defined $opt_M) { |
| 562 | if ($opt_M =~ /^(sendmail|qmail|postfix|exim)$/) { | 600 | if ($opt_M =~ /^(sendmail|qmail|postfix|exim|nullmailer)$/) { |
| 563 | $mailq = $opt_M ; | 601 | $mailq = $opt_M ; |
| 564 | }elsif( $opt_M eq ''){ | 602 | }elsif( $opt_M eq ''){ |
| 565 | $mailq = 'sendmail'; | 603 | $mailq = 'sendmail'; |
| @@ -568,7 +606,30 @@ sub process_arguments(){ | |||
| 568 | exit $ERRORS{'UNKNOWN'}; | 606 | exit $ERRORS{'UNKNOWN'}; |
| 569 | } | 607 | } |
| 570 | }else{ | 608 | }else{ |
| 571 | $mailq = 'sendmail' ; | 609 | if (defined $utils::PATH_TO_QMAIL_QSTAT |
| 610 | && -x $utils::PATH_TO_QMAIL_QSTAT) | ||
| 611 | { | ||
| 612 | $mailq = 'qmail'; | ||
| 613 | } | ||
| 614 | elsif (-d '/var/lib/postfix' || -d '/var/local/lib/postfix' | ||
| 615 | || -e '/usr/sbin/postfix' || -e '/usr/local/sbin/postfix') | ||
| 616 | { | ||
| 617 | $mailq = 'postfix'; | ||
| 618 | } | ||
| 619 | elsif (-d '/usr/lib/exim4' || -d '/usr/local/lib/exim4' | ||
| 620 | || -e '/usr/sbin/exim' || -e '/usr/local/sbin/exim') | ||
| 621 | { | ||
| 622 | $mailq = 'exim'; | ||
| 623 | } | ||
| 624 | elsif (-d '/usr/lib/nullmailer' || -d '/usr/local/lib/nullmailer' | ||
| 625 | || -e '/usr/sbin/nullmailer-send' | ||
| 626 | || -e '/usr/local/sbin/nullmailer-send') | ||
| 627 | { | ||
| 628 | $mailq = 'nullmailer'; | ||
| 629 | } | ||
| 630 | else { | ||
| 631 | $mailq = 'sendmail'; | ||
| 632 | } | ||
| 572 | } | 633 | } |
| 573 | 634 | ||
| 574 | return $ERRORS{'OK'}; | 635 | return $ERRORS{'OK'}; |
| @@ -591,7 +652,7 @@ sub print_help () { | |||
| 591 | print "-W (--Warning) = Min. number of messages for same domain in queue to generate warning\n"; | 652 | print "-W (--Warning) = Min. number of messages for same domain in queue to generate warning\n"; |
| 592 | print "-C (--Critical) = Min. number of messages for same domain in queue to generate critical alert ( W < C )\n"; | 653 | print "-C (--Critical) = Min. number of messages for same domain in queue to generate critical alert ( W < C )\n"; |
| 593 | print "-t (--timeout) = Plugin timeout in seconds (default = $utils::TIMEOUT)\n"; | 654 | print "-t (--timeout) = Plugin timeout in seconds (default = $utils::TIMEOUT)\n"; |
| 594 | print "-M (--mailserver) = [ sendmail | qmail | postfix | exim ] (default = sendmail)\n"; | 655 | print "-M (--mailserver) = [ sendmail | qmail | postfix | exim | nullmailer ] (default = autodetect)\n"; |
| 595 | print "-h (--help)\n"; | 656 | print "-h (--help)\n"; |
| 596 | print "-V (--version)\n"; | 657 | print "-V (--version)\n"; |
| 597 | print "-v (--verbose) = debugging output\n"; | 658 | print "-v (--verbose) = debugging output\n"; |
| @@ -599,6 +660,8 @@ sub print_help () { | |||
| 599 | print "Note: -w and -c are required arguments. -W and -C are optional.\n"; | 660 | print "Note: -w and -c are required arguments. -W and -C are optional.\n"; |
| 600 | print " -W and -C are applied to domains listed on the queues - both FROM and TO. (sendmail)\n"; | 661 | print " -W and -C are applied to domains listed on the queues - both FROM and TO. (sendmail)\n"; |
| 601 | print " -W and -C are applied message not yet preproccessed. (qmail)\n"; | 662 | print " -W and -C are applied message not yet preproccessed. (qmail)\n"; |
| 663 | print " This plugin tries to autodetect which mailserver you are running,\n"; | ||
| 664 | print " you can override the autodetection with -M.\n"; | ||
| 602 | print " This plugin uses the system mailq command (sendmail) or qmail-stat (qmail)\n"; | 665 | print " This plugin uses the system mailq command (sendmail) or qmail-stat (qmail)\n"; |
| 603 | print " to look at the queues. Mailq can usually only be accessed by root or \n"; | 666 | print " to look at the queues. Mailq can usually only be accessed by root or \n"; |
| 604 | print " a TrustedUser. You will have to set appropriate permissions for the plugin to work.\n"; | 667 | print " a TrustedUser. You will have to set appropriate permissions for the plugin to work.\n"; |
diff --git a/plugins-scripts/check_mssql.pl b/plugins-scripts/check_mssql.pl index 4486149d..cf23ae82 100755 --- a/plugins-scripts/check_mssql.pl +++ b/plugins-scripts/check_mssql.pl | |||
| @@ -21,7 +21,7 @@ | |||
| 21 | # along with this program; if not, write to the Free Software | 21 | # along with this program; if not, write to the Free Software |
| 22 | # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. | 22 | # Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. |
| 23 | # | 23 | # |
| 24 | # Report bugs to: nagiosplug-help@lists.sourceforge.net | 24 | # Report bugs to: help@monitoring-plugins.org |
| 25 | # | 25 | # |
| 26 | # | 26 | # |
| 27 | 27 | ||
| @@ -48,7 +48,7 @@ my $exitcode = $ERRORS{'OK'}; | |||
| 48 | 48 | ||
| 49 | process_arguments(); | 49 | process_arguments(); |
| 50 | 50 | ||
| 51 | # Just in case of problems, let's not hang Nagios | 51 | # Just in case of problems, let's not hang the monitoring system |
| 52 | $SIG{'ALRM'} = sub { | 52 | $SIG{'ALRM'} = sub { |
| 53 | print ("SQL UNKNOWN: ERROR connection $server (alarm timeout)\n"); | 53 | print ("SQL UNKNOWN: ERROR connection $server (alarm timeout)\n"); |
| 54 | exit $ERRORS{"UNKNOWN"}; | 54 | exit $ERRORS{"UNKNOWN"}; |
diff --git a/plugins-scripts/check_netdns.pl b/plugins-scripts/check_netdns.pl index 9871a9a5..6e0d02d1 100755 --- a/plugins-scripts/check_netdns.pl +++ b/plugins-scripts/check_netdns.pl | |||
| @@ -27,7 +27,8 @@ | |||
| 27 | 27 | ||
| 28 | use Getopt::Long; | 28 | use Getopt::Long; |
| 29 | use Net::DNS; | 29 | use Net::DNS; |
| 30 | use lib utils.pm; | 30 | use FindBin; |
| 31 | use lib "$FindBin::Bin"; | ||
| 31 | use utils ; | 32 | use utils ; |
| 32 | 33 | ||
| 33 | my $PROGNAME = "check_netdns"; | 34 | my $PROGNAME = "check_netdns"; |
diff --git a/plugins-scripts/check_oracle.sh b/plugins-scripts/check_oracle.sh index f5302e3b..efa1df19 100755 --- a/plugins-scripts/check_oracle.sh +++ b/plugins-scripts/check_oracle.sh | |||
| @@ -3,7 +3,7 @@ | |||
| 3 | # latigid010@yahoo.com | 3 | # latigid010@yahoo.com |
| 4 | # 01/06/2000 | 4 | # 01/06/2000 |
| 5 | # | 5 | # |
| 6 | # This Nagios plugin was created to check Oracle status | 6 | # This Monitoring plugin was created to check Oracle status |
| 7 | # | 7 | # |
| 8 | 8 | ||
| 9 | PROGNAME=`basename $0` | 9 | PROGNAME=`basename $0` |
| @@ -164,7 +164,7 @@ case "$cmd" in | |||
| 164 | }' | 164 | }' |
| 165 | ;; | 165 | ;; |
| 166 | --db) | 166 | --db) |
| 167 | pmonchk=`ps -ef | grep -v grep | grep -c "ora_pmon_${2}$"` | 167 | pmonchk=`ps -ef | grep -v grep | grep -E -c "(asm|ora)_pmon_${2}$"` |
| 168 | if [ ${pmonchk} -ge 1 ] ; then | 168 | if [ ${pmonchk} -ge 1 ] ; then |
| 169 | echo "${2} OK - ${pmonchk} PMON process(es) running" | 169 | echo "${2} OK - ${pmonchk} PMON process(es) running" |
| 170 | exit $STATE_OK | 170 | exit $STATE_OK |
diff --git a/plugins-scripts/check_rpc.pl b/plugins-scripts/check_rpc.pl index e09754dd..f7fe0321 100755 --- a/plugins-scripts/check_rpc.pl +++ b/plugins-scripts/check_rpc.pl | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | #!/usr/local/bin/perl -w | 1 | #!/usr/local/bin/perl -w |
| 2 | # | 2 | # |
| 3 | # check_rpc plugin for nagios | 3 | # check_rpc plugin for monitoring |
| 4 | # | 4 | # |
| 5 | # usage: | 5 | # usage: |
| 6 | # check_rpc host service | 6 | # check_rpc host service |
| @@ -20,7 +20,8 @@ | |||
| 20 | # | 20 | # |
| 21 | 21 | ||
| 22 | use strict; | 22 | use strict; |
| 23 | use lib utils.pm; | 23 | use FindBin; |
| 24 | use lib "$FindBin::Bin"; | ||
| 24 | use utils qw($TIMEOUT %ERRORS &print_revision &support); | 25 | use utils qw($TIMEOUT %ERRORS &print_revision &support); |
| 25 | use vars qw($PROGNAME); | 26 | use vars qw($PROGNAME); |
| 26 | my ($verbose,@proto,%prognum,$host,$response,$prognum,$port,$cmd,$progver,$state); | 27 | my ($verbose,@proto,%prognum,$host,$response,$prognum,$port,$cmd,$progver,$state); |
| @@ -254,7 +255,7 @@ $proto = 't' if ($opt_t); | |||
| 254 | $proto = 'u' if ($opt_u); | 255 | $proto = 'u' if ($opt_u); |
| 255 | 256 | ||
| 256 | 257 | ||
| 257 | # Just in case of problems, let's not hang Nagios | 258 | # Just in case of problems, let's not hang the monitoring system |
| 258 | $SIG{'ALRM'} = sub { | 259 | $SIG{'ALRM'} = sub { |
| 259 | print ("ERROR: No response from RPC server (alarm)\n"); | 260 | print ("ERROR: No response from RPC server (alarm)\n"); |
| 260 | exit $ERRORS{"UNKNOWN"}; | 261 | exit $ERRORS{"UNKNOWN"}; |
diff --git a/plugins-scripts/check_wave.pl b/plugins-scripts/check_wave.pl index 8f9a4da3..51927534 100755 --- a/plugins-scripts/check_wave.pl +++ b/plugins-scripts/check_wave.pl | |||
| @@ -3,7 +3,8 @@ | |||
| 3 | 3 | ||
| 4 | 4 | ||
| 5 | use strict; | 5 | use strict; |
| 6 | use lib utils.pm; | 6 | use FindBin; |
| 7 | use lib "$FindBin::Bin"; | ||
| 7 | use utils qw($TIMEOUT %ERRORS &print_revision &support); | 8 | use utils qw($TIMEOUT %ERRORS &print_revision &support); |
| 8 | use vars qw($PROGNAME); | 9 | use vars qw($PROGNAME); |
| 9 | use Getopt::Long; | 10 | use Getopt::Long; |
diff --git a/plugins-scripts/subst.in b/plugins-scripts/subst.in index 49a95ca1..c730b770 100644 --- a/plugins-scripts/subst.in +++ b/plugins-scripts/subst.in | |||
| @@ -19,19 +19,6 @@ function which(c,path) { | |||
| 19 | return c; | 19 | return c; |
| 20 | } | 20 | } |
| 21 | 21 | ||
| 22 | # used to replace "use lib utils.pm" with "use lib @libexecdir" | ||
| 23 | # | ||
| 24 | function led() { | ||
| 25 | led1 = "@libexecdir@"; | ||
| 26 | led2 = "@exec_prefix@"; | ||
| 27 | led3 = "@prefix@"; | ||
| 28 | if ( match(led1, /^\$\{exec_prefix\}/ ) != 0 ) { | ||
| 29 | return "\"" led3 "/libexec\" " ; | ||
| 30 | |||
| 31 | } | ||
| 32 | return "\"" led1 "\"" ; | ||
| 33 | } | ||
| 34 | |||
| 35 | BEGIN { | 22 | BEGIN { |
| 36 | split(ENVIRON["PATH"] ":/sbin:/usr/sbin",path,/:/); | 23 | split(ENVIRON["PATH"] ":/sbin:/usr/sbin",path,/:/); |
| 37 | 24 | ||
| @@ -58,9 +45,6 @@ BEGIN { | |||
| 58 | sub(c,which(c,path)); | 45 | sub(c,which(c,path)); |
| 59 | } | 46 | } |
| 60 | 47 | ||
| 61 | # add to libexecdir to INC for perl utils.pm | ||
| 62 | /^use/ { if (/lib/) { if (/utils.pm|"."/ ) {sub(/utils.pm|"."/,led() )} } } | ||
| 63 | |||
| 64 | # Trusted path mechanism | 48 | # Trusted path mechanism |
| 65 | /@trusted_path@/ {sub(/@trusted_path@/,"@with_trusted_path@");} | 49 | /@trusted_path@/ {sub(/@trusted_path@/,"@with_trusted_path@");} |
| 66 | 50 | ||
diff --git a/plugins-scripts/t/check_file_age.t b/plugins-scripts/t/check_file_age.t index 384c276b..a5156491 100644 --- a/plugins-scripts/t/check_file_age.t +++ b/plugins-scripts/t/check_file_age.t | |||
| @@ -5,7 +5,7 @@ | |||
| 5 | # | 5 | # |
| 6 | 6 | ||
| 7 | use strict; | 7 | use strict; |
| 8 | use Test::More tests => 15; | 8 | use Test::More tests => 16; |
| 9 | use NPTest; | 9 | use NPTest; |
| 10 | 10 | ||
| 11 | my $successOutput = '/^FILE_AGE OK: /'; | 11 | my $successOutput = '/^FILE_AGE OK: /'; |
| @@ -58,6 +58,11 @@ $result = NPTest->testCmd( | |||
| 58 | cmp_ok( $result->return_code, '==', 0, "Checking file size" ); | 58 | cmp_ok( $result->return_code, '==', 0, "Checking file size" ); |
| 59 | 59 | ||
| 60 | $result = NPTest->testCmd( | 60 | $result = NPTest->testCmd( |
| 61 | "./check_file_age -f /non/existent --ignore-missing" | ||
| 62 | ); | ||
| 63 | cmp_ok( $result->return_code, '==', 0, "Honours --ignore-missing" ); | ||
| 64 | |||
| 65 | $result = NPTest->testCmd( | ||
| 61 | "./check_file_age -f $temp_file -c 1000 -W 101" | 66 | "./check_file_age -f $temp_file -c 1000 -W 101" |
| 62 | ); | 67 | ); |
| 63 | cmp_ok( $result->return_code, '==', 1, "One byte too short" ); | 68 | cmp_ok( $result->return_code, '==', 1, "One byte too short" ); |
diff --git a/plugins-scripts/utils.pm.in b/plugins-scripts/utils.pm.in index 37cd62c3..0f53243c 100644 --- a/plugins-scripts/utils.pm.in +++ b/plugins-scripts/utils.pm.in | |||
| @@ -1,6 +1,6 @@ | |||
| 1 | # Utility drawer for Nagios plugins. | 1 | # Utility drawer for Monitoring Plugins. |
| 2 | # | 2 | # |
| 3 | # This will be deprecated soon. Please use Nagios::Plugin from CPAN | 3 | # This will be deprecated soon. Please use Monitoring::Plugin from CPAN |
| 4 | # for new plugins | 4 | # for new plugins |
| 5 | 5 | ||
| 6 | package utils; | 6 | package utils; |
diff --git a/plugins-scripts/utils.sh.in b/plugins-scripts/utils.sh.in index 4a07df89..031c0357 100644 --- a/plugins-scripts/utils.sh.in +++ b/plugins-scripts/utils.sh.in | |||
| @@ -6,19 +6,13 @@ STATE_CRITICAL=2 | |||
| 6 | STATE_UNKNOWN=3 | 6 | STATE_UNKNOWN=3 |
| 7 | STATE_DEPENDENT=4 | 7 | STATE_DEPENDENT=4 |
| 8 | 8 | ||
| 9 | if test -x /usr/bin/printf; then | ||
| 10 | ECHO=/usr/bin/printf | ||
| 11 | else | ||
| 12 | ECHO=echo | ||
| 13 | fi | ||
| 14 | |||
| 15 | print_revision() { | 9 | print_revision() { |
| 16 | echo "$1 v$2 (@PACKAGE@ @VERSION@)" | 10 | echo "$1 v$2 (@PACKAGE@ @VERSION@)" |
| 17 | $ECHO "@WARRANTY@" | sed -e 's/\n/ /g' | 11 | printf '%b' "@WARRANTY@" |
| 18 | } | 12 | } |
| 19 | 13 | ||
| 20 | support() { | 14 | support() { |
| 21 | $ECHO "@SUPPORT@" | sed -e 's/\n/ /g' | 15 | printf '%b' "@SUPPORT@" |
| 22 | } | 16 | } |
| 23 | 17 | ||
| 24 | # | 18 | # |
