Code

had been grandfathered ibto core, finally use normal getopts, add options for player...
[nagiosplug.git] / plugins / utils.c
index 474206b93638bded27106ec8efbdfb7e1d40c15b..bf36039e520d87a7d3730839b552dc25d9d5ecb8 100644 (file)
 
 #include "config.h"
 #include "common.h"
-#include "version.h"
 #include <stdarg.h>
 #include <limits.h>
 
+#include <arpa/inet.h>
+
 extern int timeout_interval;
 extern const char *progname;
 
 void support (void);
 char *clean_revstring (const char *);
 void print_revision (const char *, const char *);
-void terminate (int, const char *fmt, ...);
+void die (int result, const char *fmt, ...);
+void terminate (int result, const char *fmt, ...);
 RETSIGTYPE timeout_alarm_handler (int);
 
-int is_host (char *);
-int is_dotted_quad (char *);
-int is_hostname (char *);
-
 int is_integer (char *);
 int is_intpos (char *);
 int is_intneg (char *);
@@ -53,18 +51,22 @@ char *strnl (char *str);
 char *strpcpy (char *dest, const char *src, const char *str);
 char *strpcat (char *dest, const char *src, const char *str);
 
+char *state_text (int result);
+
 #define LABELLEN 63
 #define STRLEN 64
 #define TXTBLK 128
 
 /* **************************************************************************
- * max_state(STATE_x, STATE_y)
/* max_state(STATE_x, STATE_y)
  * compares STATE_x to  STATE_y and returns result based on the following
  * STATE_UNKNOWN < STATE_OK < STATE_WARNING < STATE_CRITICAL
  *
  * Note that numerically the above does not hold
  ****************************************************************************/
 
+#define max(a,b) (((a)>(b))?(a):(b))
+
 int
 max_state (int a, int b)
 {
@@ -141,6 +143,33 @@ print_revision (const char *command_name, const char *revision_string)
 
 }
 
+char *
+state_text (int result)
+{
+       switch (result) {
+       case STATE_OK:
+               return "OK";
+       case STATE_WARNING:
+               return "WARNING";
+       case STATE_CRITICAL:
+               return "CRITICAL";
+       case STATE_DEPENDENT:
+               return "DEPENDENT";
+       default:
+               return "UNKNOWN";
+       }
+}
+
+void
+die (int result, const char *fmt, ...)
+{
+       va_list ap;
+       printf ("%s %s: ", sizeof (char) + index(progname, '_'), state_text(result));
+       va_start (ap, fmt);
+       vprintf (fmt, ap);
+       va_end (ap);
+       exit (result);
+}
 
 void
 terminate (int result, const char *fmt, ...)
@@ -162,61 +191,6 @@ timeout_alarm_handler (int signo)
        }
 }
 
-int
-is_host (char *address)
-{
-       if (is_dotted_quad (address) || is_hostname (address))
-               return (TRUE);
-       return (FALSE);
-}
-
-int
-is_dotted_quad (char *address)
-{
-       int o1, o2, o3, o4;
-       char c[1];
-
-       if (!address)
-               return FALSE;
-
-       if (sscanf (address, "%d.%d.%d.%d%c", &o1, &o2, &o3, &o4, c) != 4)
-               return FALSE;
-       else if (o1 > 255 || o2 > 255 || o3 > 255 || o4 > 255)
-               return FALSE;
-       else if (o1 < 0 || o2 < 0 || o3 < 0 || o4 < 0)
-               return FALSE;
-       else
-               return TRUE;
-}
-
-/* from RFC-1035
- * 
- * The labels must follow the rules for ARPANET host names.  They must
- * start with a letter, end with a letter or digit, and have as interior
- * characters only letters, digits, and hyphen.  There are also some
- * restrictions on the length.  Labels must be 63 characters or less. */
-
-int
-is_hostname (char *s1)
-{
-       if (!s1 || strlen (s1) > 63) {
-               return FALSE;
-       }
-       if (strcspn (s1, "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLMNOPQRSTUWVXYZ0123456789-.") != 0) {
-               return FALSE;
-       }
-       if (strspn (s1, "0123456789-.") == 1) {
-               return FALSE;
-       }
-       while ((s1 = index (s1, '.'))) {
-               s1++;
-               if (strspn (s1, "0123456789-.") == 1) {
-                       return FALSE;
-               }
-       }
-       return TRUE;
-}
-
 int
 is_numeric (char *number)
 {