pkg-monitoring-plugins/lib/utils_base.h

120 lines
3.1 KiB
C
Raw Permalink Normal View History

2013-11-26 22:53:19 +00:00
#ifndef _UTILS_BASE_
#define _UTILS_BASE_
2014-07-11 19:01:00 +00:00
/* Header file for Monitoring Plugins utils_base.c */
2013-11-26 22:53:19 +00:00
2023-10-18 07:29:37 +00:00
#ifndef USE_OPENSSL
# include "sha256.h"
#endif
2013-11-26 22:57:29 +00:00
2023-10-18 07:29:37 +00:00
/* This file holds header information for thresholds - use this in preference to
2013-11-26 22:53:19 +00:00
individual plugin logic */
/* This has not been merged with utils.h because of problems with
timeout_interval when other utils_*.h files use utils.h */
/* Long term, add new functions to utils_base.h for common routines
and utils_*.h for specific to plugin routines. If routines are
placed in utils_*.h, then these can be tested with libtap */
#define OUTSIDE 0
#define INSIDE 1
typedef struct range_struct {
double start;
2023-10-18 07:29:37 +00:00
bool start_infinity;
2013-11-26 22:53:19 +00:00
double end;
int end_infinity;
int alert_on; /* OUTSIDE (default) or INSIDE */
2022-10-19 15:24:24 +00:00
char* text; /* original unparsed text input */
2013-11-26 22:53:19 +00:00
} range;
typedef struct thresholds_struct {
range *warning;
range *critical;
} thresholds;
2013-11-26 22:57:29 +00:00
#define NP_STATE_FORMAT_VERSION 1
typedef struct state_data_struct {
time_t time;
void *data;
int length; /* Of binary data */
} state_data;
typedef struct state_key_struct {
char *name;
char *plugin_name;
int data_version;
char *_filename;
state_data *state_data;
} state_key;
typedef struct np_struct {
char *plugin_name;
state_key *state;
int argc;
char **argv;
2014-07-11 19:01:00 +00:00
} monitoring_plugin;
2013-11-26 22:57:29 +00:00
2013-11-26 22:53:19 +00:00
range *parse_range_string (char *);
int _set_thresholds(thresholds **, char *, char *);
void set_thresholds(thresholds **, char *, char *);
2013-11-26 22:54:42 +00:00
void print_thresholds(const char *, thresholds *);
2023-10-18 07:29:37 +00:00
bool check_range(double, range *);
2013-11-26 22:53:19 +00:00
int get_status(double, thresholds *);
2020-12-10 20:00:09 +00:00
/* Handle timeouts */
extern unsigned int timeout_state;
extern unsigned int timeout_interval;
/* All possible characters in a threshold range */
2014-07-11 19:01:00 +00:00
#define NP_THRESHOLDS_CHARS "-0123456789.:@~"
2013-11-26 22:53:19 +00:00
char *np_escaped_string (const char *);
void die (int, const char *, ...) __attribute__((noreturn,format(printf, 2, 3)));
/* Return codes for _set_thresholds */
#define NP_RANGE_UNPARSEABLE 1
#define NP_WARN_WITHIN_CRIT 2
2023-10-18 07:29:37 +00:00
/* a simple check to see if we're running as root.
2013-11-26 22:54:42 +00:00
* returns zero on failure, nonzero on success */
int np_check_if_root(void);
2014-07-11 19:01:00 +00:00
/* mp_suid() returns true if the real and effective uids differs, such as when
* running a suid plugin */
#define mp_suid() (getuid() != geteuid())
2013-11-26 22:54:42 +00:00
/*
* Extract the value from key/value pairs, or return NULL. The value returned
* can be free()ed.
* This function can be used to parse NTP control packet data and performance
* data strings.
*/
char *np_extract_value(const char*, const char*, char);
/*
* Same as np_extract_value with separator suitable for NTP control packet
* payloads (comma)
*/
#define np_extract_ntpvar(l, n) np_extract_value(l, n, ',')
2014-07-11 19:01:00 +00:00
/*
* Read a string representing a state (ok, warning... or numeric: 0, 1) and
* return the corresponding NP_STATE or ERROR)
*/
int mp_translate_state (char *);
2013-11-26 22:57:29 +00:00
void np_enable_state(char *, int);
state_data *np_state_read();
void np_state_write_string(time_t, char *);
void np_init(char *, int argc, char **argv);
void np_set_args(int argc, char **argv);
void np_cleanup();
2020-12-10 20:00:09 +00:00
const char *state_text (int);
2013-11-26 22:57:29 +00:00
2013-11-26 22:53:19 +00:00
#endif /* _UTILS_BASE_ */