Code

Remove unnecessary getopt references and link in lib directory
[nagiosplug.git] / plugins / check_ping.c
index b61b41b503cc4ff6fd032293cd57504e2b49c91e..0c0f2e44f2872e0d4601e683c9b733dd596ecc3c 100644 (file)
@@ -10,7 +10,7 @@
 *
 *****************************************************************************/
 
-#define PROGNAME "check_pgsql"
+const char *progname = "check_ping";
 #define REVISION "$Revision$"
 #define COPYRIGHT "1999-2001"
 #define AUTHOR "Ethan Galstad/Karl DeBisschop"
@@ -56,7 +56,6 @@ the contrib area of the downloads section at http://www.nagios.org\n\n"
 #define WARN_DUPLICATES "DUPLICATES FOUND! "
 
 int process_arguments (int, char **);
-int call_getopt (int, char **);
 int get_threshold (char *, float *, int *);
 int validate_arguments (void);
 int run_ping (char *);
@@ -85,14 +84,13 @@ main (int argc, char **argv)
 
        if (process_arguments (argc, argv) == ERROR)
                usage ("Could not parse arguments");
+       exit;
 
        /* does the host address of number of packets argument come first? */
 #ifdef PING_PACKETS_FIRST
-       command_line =
-               ssprintf (command_line, PING_COMMAND, max_packets, server_address);
+       asprintf (&command_line, PING_COMMAND, max_packets, server_address);
 #else
-       command_line =
-               ssprintf (command_line, PING_COMMAND, server_address, max_packets);
+       asprintf (&command_line, PING_COMMAND, server_address, max_packets);
 #endif
 
        /* Set signal handling and alarm */
@@ -121,8 +119,12 @@ main (int argc, char **argv)
        else if (pl >= wpl || rta >= wrta)
                result = STATE_WARNING;
        else if (pl < wpl && rta < wrta && pl >= 0 && rta >= 0)
-               result = max (result, STATE_OK);
-
+               /* cannot use the max function because STATE_UNKNOWN is now 3 gt STATE_OK                       
+               result = max (result, STATE_OK);  */
+               if( !( (result == STATE_WARNING) || (result == STATE_CRITICAL) )  ) {
+                       result = STATE_OK;      
+               }
+       
        if (display_html == TRUE)
                printf ("<A HREF='%s/traceroute.cgi?%s'>", CGIURL, server_address);
        if (pl == 100)
@@ -146,7 +148,20 @@ main (int argc, char **argv)
 int
 process_arguments (int argc, char **argv)
 {
-       int c;
+       int c = 1;
+
+#ifdef HAVE_GETOPT_H
+       int option_index = 0;
+       static struct option long_options[] = {
+               STD_LONG_OPTS,
+               {"packets", required_argument, 0, 'p'},
+               {"nohtml", no_argument, 0, 'n'},
+               {"link", no_argument, 0, 'L'},
+               {0, 0, 0, 0}
+       };
+#endif
+
+#define OPTCHARS "Vvht:c:w:H:p:nL"
 
        if (argc < 2)
                return ERROR;
@@ -158,138 +173,45 @@ process_arguments (int argc, char **argv)
                        strcpy (argv[c], "-n");
        }
 
-       c = 0;
-       while ((c += call_getopt (argc - c, &argv[c])) < argc) {
-
-               if (is_option (argv[c]))
-                       continue;
-
-               if (server_address == NULL) {
-                       if (is_host (argv[c]) == FALSE) {
-                               printf ("Invalid host name/address: %s\n\n", argv[c]);
-                               return ERROR;
-                       }
-                       server_address = argv[c];
-               }
-               else if (wpl == UNKNOWN_PACKET_LOSS) {
-                       if (is_intpercent (argv[c]) == FALSE) {
-                               printf ("<wpl> (%s) must be an integer percentage\n", argv[c]);
-                               return ERROR;
-                       }
-                       wpl = atoi (argv[c]);
-               }
-               else if (cpl == UNKNOWN_PACKET_LOSS) {
-                       if (is_intpercent (argv[c]) == FALSE) {
-                               printf ("<cpl> (%s) must be an integer percentage\n", argv[c]);
-                               return ERROR;
-                       }
-                       cpl = atoi (argv[c]);
-               }
-               else if (wrta == UNKNOWN_TRIP_TIME) {
-                       if (is_negative (argv[c])) {
-                               printf ("<wrta> (%s) must be a non-negative number\n", argv[c]);
-                               return ERROR;
-                       }
-                       wrta = atof (argv[c]);
-               }
-               else if (crta == UNKNOWN_TRIP_TIME) {
-                       if (is_negative (argv[c])) {
-                               printf ("<crta> (%s) must be a non-negative number\n", argv[c]);
-                               return ERROR;
-                       }
-                       crta = atof (argv[c]);
-               }
-               else if (max_packets == -1) {
-                       if (is_intnonneg (argv[c])) {
-                               max_packets = atoi (argv[c]);
-                       }
-                       else {
-                               printf ("<max_packets> (%s) must be a non-negative number\n",
-                                                               argv[c]);
-                               return ERROR;
-                       }
-               }
-
-       }
-
-       return validate_arguments ();
-}
-
-int
-call_getopt (int argc, char **argv)
-{
-       int c, i = 0;
-
-#ifdef HAVE_GETOPT_H
-       int option_index = 0;
-       static struct option long_options[] = {
-               {"help", no_argument, 0, 'h'},
-               {"version", no_argument, 0, 'V'},
-               {"verbose", no_argument, 0, 'v'},
-               {"nohtml", no_argument, 0, 'n'},
-               {"link", no_argument, 0, 'L'},
-               {"timeout", required_argument, 0, 't'},
-               {"critical", required_argument, 0, 'c'},
-               {"warning", required_argument, 0, 'w'},
-               {"hostname", required_argument, 0, 'H'},
-               {"packets", required_argument, 0, 'p'},
-               {0, 0, 0, 0}
-       };
-#endif
-
        while (1) {
 #ifdef HAVE_GETOPT_H
-               c =
-                       getopt_long (argc, argv, "+hVvt:c:w:H:p:nL", long_options,
-                                                                        &option_index);
+               c = getopt_long (argc, argv, OPTCHARS, long_options, &option_index);
 #else
-               c = getopt (argc, argv, "+hVvt:c:w:H:p:nL");
+               c = getopt (argc, argv, OPTCHARS);
 #endif
-
-               i++;
-
-               if (c == -1 || c == EOF || c == 1)
+               if (c == -1 || c == EOF)
                        break;
 
                switch (c) {
-               case 't':
-               case 'c':
-               case 'w':
-               case 'H':
-               case 'p':
-                       i++;
-               }
-
-               switch (c) {
-               case '?':                                                                       /* print short usage statement if args not parsable */
-                       usage2 ("Unknown argument", optarg);
-               case 'h':                                                                       /* help */
+               case '?':       /* usage */
+                       usage3 ("Unknown argument", optopt);
+               case 'h':       /* help */
                        print_help ();
                        exit (STATE_OK);
-               case 'V':                                                                       /* version */
-                       print_revision (PROGNAME, REVISION);
+               case 'V':       /* version */
+                       print_revision (progname, REVISION);
                        exit (STATE_OK);
-               case 't':                                                                       /* timeout period */
+               case 't':       /* timeout period */
                        timeout_interval = atoi (optarg);
                        break;
-               case 'v':                                                                       /* verbose mode */
+               case 'v':       /* verbose mode */
                        verbose = TRUE;
                        break;
-               case 'H':                                                                       /* hostname */
+               case 'H':       /* hostname */
                        if (is_host (optarg) == FALSE)
                                usage2 ("Invalid host name/address", optarg);
                        server_address = optarg;
                        break;
-               case 'p':                                                                       /* number of packets to send */
+               case 'p':       /* number of packets to send */
                        if (is_intnonneg (optarg))
                                max_packets = atoi (optarg);
                        else
                                usage2 ("<max_packets> (%s) must be a non-negative number\n", optarg);
                        break;
-               case 'n':                                                                       /* no HTML */
+               case 'n':       /* no HTML */
                        display_html = FALSE;
                        break;
-               case 'L':                                                                       /* show HTML */
+               case 'L':       /* show HTML */
                        display_html = TRUE;
                        break;
                case 'c':
@@ -301,7 +223,75 @@ call_getopt (int argc, char **argv)
                }
        }
 
-       return i;
+       c = optind;
+       if (c == argc)
+               return validate_arguments ();
+
+       if (server_address == NULL) {
+               if (is_host (argv[c]) == FALSE) {
+                       printf ("Invalid host name/address: %s\n\n", argv[c]);
+                       return ERROR;
+               } else {
+                       server_address = argv[c++];
+                       if (c == argc)
+                               return validate_arguments ();
+               }
+       }
+
+       if (wpl == UNKNOWN_PACKET_LOSS) {
+               if (is_intpercent (argv[c]) == FALSE) {
+                       printf ("<wpl> (%s) must be an integer percentage\n", argv[c]);
+                       return ERROR;
+               } else {
+                       wpl = atoi (argv[c++]);
+                       if (c == argc)
+                               return validate_arguments ();
+               }
+       }
+
+       if (cpl == UNKNOWN_PACKET_LOSS) {
+               if (is_intpercent (argv[c]) == FALSE) {
+                       printf ("<cpl> (%s) must be an integer percentage\n", argv[c]);
+                       return ERROR;
+               } else {
+                       cpl = atoi (argv[c++]);
+                       if (c == argc)
+                               return validate_arguments ();
+               }
+       }
+
+       if (wrta == UNKNOWN_TRIP_TIME) {
+               if (is_negative (argv[c])) {
+                       printf ("<wrta> (%s) must be a non-negative number\n", argv[c]);
+                       return ERROR;
+               } else {
+                       wrta = atof (argv[c++]);
+                       if (c == argc)
+                               return validate_arguments ();
+               }
+       }
+
+       if (crta == UNKNOWN_TRIP_TIME) {
+               if (is_negative (argv[c])) {
+                       printf ("<crta> (%s) must be a non-negative number\n", argv[c]);
+                       return ERROR;
+               } else {
+                       crta = atof (argv[c++]);
+                       if (c == argc)
+                               return validate_arguments ();
+               }
+       }
+
+       if (max_packets == -1) {
+               if (is_intnonneg (argv[c])) {
+                       max_packets = atoi (argv[c++]);
+               }       else {
+                       printf ("<max_packets> (%s) must be a non-negative number\n", argv[c]);
+                       return ERROR;
+               }
+       }
+
+       return validate_arguments ();
 }
 
 int
@@ -315,7 +305,6 @@ get_threshold (char *arg, float *trta, int *tpl)
                return OK;
        else
                usage2 ("%s: Warning threshold must be integer or percentage!\n\n", arg);
-
 }
 
 int
@@ -381,7 +370,12 @@ run_ping (char *command_line)
        while (fgets (input_buffer, MAX_INPUT_BUFFER - 1, child_process)) {
 
                if (strstr (input_buffer, "(DUP!)")) {
-                       result = max (result, STATE_WARNING);
+                       /* cannot use the max function since STATE_UNKNOWN is max
+                       result = max (result, STATE_WARNING); */
+                       if( !(result == STATE_CRITICAL) ){
+                               result = STATE_WARNING;
+                       }
+                       
                        warn_text = realloc (warn_text, strlen (WARN_DUPLICATES) + 1);
                        if (warn_text == NULL)
                                terminate (STATE_UNKNOWN, "unable to realloc warn_text");
@@ -390,12 +384,17 @@ run_ping (char *command_line)
 
                /* get the percent loss statistics */
                if (sscanf
-                               (input_buffer,
-                                "%*d packets transmitted, %*d packets received, +%*d errors, %d%% packet loss",
-                                &pl) == 1
-                               || sscanf (input_buffer,
-                                                                        "%*d packets transmitted, %*d packets received, %d%% packet loss",
-                                                                        &pl) == 1)
+                                       (input_buffer, "%*d packets transmitted, %*d packets received, +%*d errors, %d%% packet loss",
+                                                &pl) == 1
+                               || sscanf 
+                                       (input_buffer, "%*d packets transmitted, %*d packets received, %d%% packet loss",
+                                               &pl) == 1
+                               || sscanf 
+                                       (input_buffer, "%*d packets transmitted, %*d packets received, %d%% loss, time", &pl) == 1
+                               || sscanf
+                                       (input_buffer, "%*d packets transmitted, %*d received, %d%% loss, time", &pl) == 1
+                                       /* Suse 8.0 as reported by Richard * Brodie */
+                               )
                        continue;
 
                /* get the round trip average */
@@ -415,7 +414,10 @@ run_ping (char *command_line)
                                                                                 "round-trip min/avg/max/std-dev = %*f/%f/%*f/%*f",
                                                                                 &rta) == 1
                                        || sscanf (input_buffer, "round-trip (ms) min/avg/max = %*f/%f/%*f",
-                                                                                &rta) == 1)
+                                                                                &rta) == 1
+                                       || sscanf (input_buffer, "rtt min/avg/max/mdev = %*f/%f/%*f/%*f ms",
+                                                                                &rta) == 1
+                                                                               )
                        continue;
        }
 
@@ -437,6 +439,9 @@ run_ping (char *command_line)
                else if (strstr (input_buffer, "Destination Host Unreachable"))
                        terminate (STATE_CRITICAL, "PING CRITICAL - Host Unreachable (%s)",
                                                                 server_address);
+               else if (strstr (input_buffer, "unknown host" ) )
+                       terminate (STATE_CRITICAL, "PING CRITICAL - Host not found (%s)",
+                                                               server_address);
 
                warn_text =
                        realloc (warn_text, strlen (warn_text) + strlen (input_buffer) + 2);
@@ -447,21 +452,24 @@ run_ping (char *command_line)
                else
                        sprintf (warn_text, "%s %s", warn_text, input_buffer);
 
-               if (strstr (input_buffer, "DUPLICATES FOUND"))
-                       result = max (result, STATE_WARNING);
+               if (strstr (input_buffer, "DUPLICATES FOUND")) {
+                       if( !(result == STATE_CRITICAL) ){
+                               result = STATE_WARNING;
+                       }
+               }
                else
-                       result = max (result, STATE_CRITICAL);
+                       result = STATE_CRITICAL ;
        }
        (void) fclose (child_stderr);
 
 
        /* close the pipe - WARNING if status is set */
        if (spclose (child_process))
-               result = max (result, STATE_WARNING);
+               result = max_state (result, STATE_WARNING);
 
        return result;
 }
-\f
+
 
 void
 print_usage (void)
@@ -474,13 +482,13 @@ print_usage (void)
                                        " %s -h for detailed help\n"
                                        " %s -V for version information\n",
 #endif
-                                       PROGNAME, OPTIONS, PROGNAME, PROGNAME);
+                                       progname, OPTIONS, progname, progname);
 }
 
 void
 print_help (void)
 {
-       print_revision (PROGNAME, REVISION);
+       print_revision (progname, REVISION);
        printf
                ("Copyright (c) %s %s <%s>\n\n%s\n",
                 COPYRIGHT, AUTHOR, EMAIL, SUMMARY);