diff --git a/plugins/utils.c b/plugins/utils.c
index 474206b93638bded27106ec8efbdfb7e1d40c15b..bf36039e520d87a7d3730839b552dc25d9d5ecb8 100644 (file)
--- a/plugins/utils.c
+++ b/plugins/utils.c
#include "config.h"
#include "common.h"
#include "config.h"
#include "common.h"
-#include "version.h"
#include <stdarg.h>
#include <limits.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 *);
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);
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 *);
int is_integer (char *);
int is_intpos (char *);
int is_intneg (char *);
char *strpcpy (char *dest, const char *src, const char *str);
char *strpcat (char *dest, const char *src, const 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
/* **************************************************************************
#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
****************************************************************************/
* 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)
{
int
max_state (int a, int b)
{
}
}
+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, ...)
void
terminate (int result, const char *fmt, ...)
}
}
}
}
-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)
{
int
is_numeric (char *number)
{