From 96ec686004b13a76eac081db5d0883db6ae08963 Mon Sep 17 00:00:00 2001 From: Steve Weinreich Date: Sun, 18 Aug 2013 19:40:42 +0200 Subject: check_fping error handling enhanced, generates UNKNOWN on fping parameter error (i.e. wrong interface, missing perms ..) --- plugins/check_fping.c | 21 ++++++++++++++++++++- 1 file changed, 20 insertions(+), 1 deletion(-) (limited to 'plugins') diff --git a/plugins/check_fping.c b/plugins/check_fping.c index fde1d798..c7cce97d 100644 --- a/plugins/check_fping.c +++ b/plugins/check_fping.c @@ -74,6 +74,7 @@ main (int argc, char **argv) /* normaly should be int result = STATE_UNKNOWN; */ int status = STATE_UNKNOWN; + int result = 0; char *fping_prog = NULL; char *server = NULL; char *command_line = NULL; @@ -146,10 +147,24 @@ main (int argc, char **argv) (void) fclose (child_stderr); /* close the pipe */ - if (spclose (child_process)) + if (result = spclose (child_process)) /* need to use max_state not max */ status = max_state (status, STATE_WARNING); + if (result > 1 ) { + status = max_state (status, STATE_UNKNOWN); + if (result == 2) { + die (STATE_UNKNOWN, _("FPING UNKNOWN - IP address not found\n")); + } + if (result == 3) { + die (STATE_UNKNOWN, _("FPING UNKNOWN - invalid commandline argument\n")); + } + if (result == 4) { + die (STATE_UNKNOWN, _("FPING UNKNOWN - failed system call\n")); + } + + } + printf ("FPING %s - %s\n", state_text (status), server_name); return status; @@ -175,6 +190,10 @@ textscan (char *buf) "host"); } + else if (strstr (buf, "Operation not permitted") || strstr (buf, "No such device") ) { + die (STATE_UNKNOWN, _("FPING UNKNOWN - %s parameter error\n"), + "host"); + } else if (strstr (buf, "is down")) { die (STATE_CRITICAL, _("FPING CRITICAL - %s is down\n"), server_name); -- cgit v1.2.3-74-g34f1