diff options
| author | Ton Voon <tonvoon@users.sourceforge.net> | 2006-07-13 23:58:00 +0000 |
|---|---|---|
| committer | Ton Voon <tonvoon@users.sourceforge.net> | 2006-07-13 23:58:00 +0000 |
| commit | 5912398b9723545ecd061650667cbb238be85743 (patch) | |
| tree | e5d8353cc8d8c278bfc22bd926f613da63f5e83f | |
| parent | 548083b2ea865474915fc8a9ddd361e997585a02 (diff) | |
| download | monitoring-plugins-5912398b9723545ecd061650667cbb238be85743.tar.gz | |
Major fixes to check_disk. Now should return same data as df
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1452 f882894a-f735-0410-b71e-b25c423dba1c
| -rw-r--r-- | CHANGES | 2 | ||||
| -rw-r--r-- | lib/tests/test_utils.c | 15 | ||||
| -rw-r--r-- | lib/utils_base.c | 225 | ||||
| -rw-r--r-- | lib/utils_base.h | 37 | ||||
| -rw-r--r-- | lib/utils_disk.c | 140 | ||||
| -rw-r--r-- | lib/utils_disk.h | 32 | ||||
| -rw-r--r-- | plugins/check_disk.c | 329 | ||||
| -rw-r--r-- | plugins/t/check_disk.t | 51 |
8 files changed, 649 insertions, 182 deletions
| @@ -5,6 +5,8 @@ This file documents the major additions and syntax changes between releases. | |||
| 5 | New check_apt plugin | 5 | New check_apt plugin |
| 6 | Notice: plugins in contrib/ will start to be removed from this distribution. | 6 | Notice: plugins in contrib/ will start to be removed from this distribution. |
| 7 | Please check at http://www.nagiosexchange.org for contributed plugins | 7 | Please check at http://www.nagiosexchange.org for contributed plugins |
| 8 | Major bug fixes to check_disk where values were incorrectly calculated and alerted on. | ||
| 9 | Perf data for warn/crit/max/min have been removed, to be readded soon. | ||
| 8 | 10 | ||
| 9 | 1.4.3 | 11 | 1.4.3 |
| 10 | Setuid plugins (check_dhcp, check_icmp) separated into plugins-root/. Run make install as root to install | 12 | Setuid plugins (check_dhcp, check_icmp) separated into plugins-root/. Run make install as root to install |
diff --git a/lib/tests/test_utils.c b/lib/tests/test_utils.c index aedc2a58..96b5333d 100644 --- a/lib/tests/test_utils.c +++ b/lib/tests/test_utils.c | |||
| @@ -31,7 +31,7 @@ main (int argc, char **argv) | |||
| 31 | thresholds *thresholds = NULL; | 31 | thresholds *thresholds = NULL; |
| 32 | int rc; | 32 | int rc; |
| 33 | 33 | ||
| 34 | plan_tests(74); | 34 | plan_tests(82); |
| 35 | 35 | ||
| 36 | range = parse_range_string("6"); | 36 | range = parse_range_string("6"); |
| 37 | ok( range != NULL, "'6' is valid range"); | 37 | ok( range != NULL, "'6' is valid range"); |
| @@ -41,6 +41,14 @@ main (int argc, char **argv) | |||
| 41 | ok( range->end_infinity == FALSE, "Not using infinity"); | 41 | ok( range->end_infinity == FALSE, "Not using infinity"); |
| 42 | free(range); | 42 | free(range); |
| 43 | 43 | ||
| 44 | range = parse_range_string("1:12%%"); | ||
| 45 | ok( range != NULL, "'1:12%%' is valid - percentages are ignored"); | ||
| 46 | ok( range->start == 1, "Start correct"); | ||
| 47 | ok( range->start_infinity == FALSE, "Not using negative infinity"); | ||
| 48 | ok( range->end == 12, "End correct"); | ||
| 49 | ok( range->end_infinity == FALSE, "Not using infinity"); | ||
| 50 | free(range); | ||
| 51 | |||
| 44 | range = parse_range_string("-7:23"); | 52 | range = parse_range_string("-7:23"); |
| 45 | ok( range != NULL, "'-7:23' is valid range"); | 53 | ok( range != NULL, "'-7:23' is valid range"); |
| 46 | ok( range->start == -7, "Start correct"); | 54 | ok( range->start == -7, "Start correct"); |
| @@ -114,6 +122,11 @@ main (int argc, char **argv) | |||
| 114 | range = parse_range_string("2:1"); | 122 | range = parse_range_string("2:1"); |
| 115 | ok( range == NULL, "'2:1' rejected"); | 123 | ok( range == NULL, "'2:1' rejected"); |
| 116 | 124 | ||
| 125 | rc = _set_thresholds(&thresholds, NULL, NULL); | ||
| 126 | ok( rc == 0, "Thresholds (NULL, NULL) set"); | ||
| 127 | ok( thresholds->warning == NULL, "Warning not set"); | ||
| 128 | ok( thresholds->critical == NULL, "Critical not set"); | ||
| 129 | |||
| 117 | rc = _set_thresholds(&thresholds, NULL, "80"); | 130 | rc = _set_thresholds(&thresholds, NULL, "80"); |
| 118 | ok( rc == 0, "Thresholds (NULL, '80') set"); | 131 | ok( rc == 0, "Thresholds (NULL, '80') set"); |
| 119 | ok( thresholds->warning == NULL, "Warning not set"); | 132 | ok( thresholds->warning == NULL, "Warning not set"); |
diff --git a/lib/utils_base.c b/lib/utils_base.c new file mode 100644 index 00000000..5a45f84a --- /dev/null +++ b/lib/utils_base.c | |||
| @@ -0,0 +1,225 @@ | |||
| 1 | /***************************************************************************** | ||
| 2 | * | ||
| 3 | * utils_base.c | ||
| 4 | * | ||
| 5 | * Library of useful functions for plugins | ||
| 6 | * These functions are tested with libtap. See tests/ directory | ||
| 7 | * | ||
| 8 | * Copyright (c) 2006 Nagios Plugin Development Team | ||
| 9 | * License: GPL | ||
| 10 | * | ||
| 11 | * $Revision$ | ||
| 12 | * $Date$ | ||
| 13 | ****************************************************************************/ | ||
| 14 | |||
| 15 | #include "common.h" | ||
| 16 | #include "utils_base.h" | ||
| 17 | |||
| 18 | void | ||
| 19 | die (int result, const char *fmt, ...) | ||
| 20 | { | ||
| 21 | va_list ap; | ||
| 22 | va_start (ap, fmt); | ||
| 23 | vprintf (fmt, ap); | ||
| 24 | va_end (ap); | ||
| 25 | exit (result); | ||
| 26 | } | ||
| 27 | |||
| 28 | void set_range_start (range *this, double value) { | ||
| 29 | this->start = value; | ||
| 30 | this->start_infinity = FALSE; | ||
| 31 | } | ||
| 32 | |||
| 33 | void set_range_end (range *this, double value) { | ||
| 34 | this->end = value; | ||
| 35 | this->end_infinity = FALSE; | ||
| 36 | } | ||
| 37 | |||
| 38 | range | ||
| 39 | *parse_range_string (char *str) { | ||
| 40 | range *temp_range; | ||
| 41 | double start; | ||
| 42 | double end; | ||
| 43 | char *end_str; | ||
| 44 | |||
| 45 | temp_range = (range *) malloc(sizeof(range)); | ||
| 46 | |||
| 47 | /* Set defaults */ | ||
| 48 | temp_range->start = 0; | ||
| 49 | temp_range->start_infinity = FALSE; | ||
| 50 | temp_range->end = 0; | ||
| 51 | temp_range->end_infinity = TRUE; | ||
| 52 | temp_range->alert_on = OUTSIDE; | ||
| 53 | |||
| 54 | if (str[0] == '@') { | ||
| 55 | temp_range->alert_on = INSIDE; | ||
| 56 | str++; | ||
| 57 | } | ||
| 58 | |||
| 59 | end_str = index(str, ':'); | ||
| 60 | if (end_str != NULL) { | ||
| 61 | if (str[0] == '~') { | ||
| 62 | temp_range->start_infinity = TRUE; | ||
| 63 | } else { | ||
| 64 | start = strtod(str, NULL); /* Will stop at the ':' */ | ||
| 65 | set_range_start(temp_range, start); | ||
| 66 | } | ||
| 67 | end_str++; /* Move past the ':' */ | ||
| 68 | } else { | ||
| 69 | end_str = str; | ||
| 70 | } | ||
| 71 | end = strtod(end_str, NULL); | ||
| 72 | if (strcmp(end_str, "") != 0) { | ||
| 73 | set_range_end(temp_range, end); | ||
| 74 | } | ||
| 75 | |||
| 76 | if (temp_range->start_infinity == TRUE || | ||
| 77 | temp_range->end_infinity == TRUE || | ||
| 78 | temp_range->start <= temp_range->end) { | ||
| 79 | return temp_range; | ||
| 80 | } | ||
| 81 | free(temp_range); | ||
| 82 | return NULL; | ||
| 83 | } | ||
| 84 | |||
| 85 | /* returns 0 if okay, otherwise 1 */ | ||
| 86 | int | ||
| 87 | _set_thresholds(thresholds **my_thresholds, char *warn_string, char *critical_string) | ||
| 88 | { | ||
| 89 | thresholds *temp_thresholds = NULL; | ||
| 90 | |||
| 91 | temp_thresholds = malloc(sizeof(temp_thresholds)); | ||
| 92 | |||
| 93 | temp_thresholds->warning = NULL; | ||
| 94 | temp_thresholds->critical = NULL; | ||
| 95 | |||
| 96 | if (warn_string != NULL) { | ||
| 97 | if ((temp_thresholds->warning = parse_range_string(warn_string)) == NULL) { | ||
| 98 | return 1; | ||
| 99 | } | ||
| 100 | } | ||
| 101 | if (critical_string != NULL) { | ||
| 102 | if ((temp_thresholds->critical = parse_range_string(critical_string)) == NULL) { | ||
| 103 | return 1; | ||
| 104 | } | ||
| 105 | } | ||
| 106 | |||
| 107 | if (*my_thresholds > 0) { /* Not sure why, but sometimes could be -1 */ | ||
| 108 | /* printf("Freeing here: %d\n", *my_thresholds); */ | ||
| 109 | free(*my_thresholds); | ||
| 110 | } | ||
| 111 | *my_thresholds = temp_thresholds; | ||
| 112 | |||
| 113 | return 0; | ||
| 114 | } | ||
| 115 | |||
| 116 | void | ||
| 117 | set_thresholds(thresholds **my_thresholds, char *warn_string, char *critical_string) | ||
| 118 | { | ||
| 119 | if (_set_thresholds(my_thresholds, warn_string, critical_string) == 0) { | ||
| 120 | return; | ||
| 121 | } else { | ||
| 122 | die(STATE_UNKNOWN, _("Range format incorrect")); | ||
| 123 | } | ||
| 124 | } | ||
| 125 | |||
| 126 | void print_thresholds(const char *threshold_name, thresholds *my_threshold) { | ||
| 127 | printf("%s - ", threshold_name); | ||
| 128 | if (! my_threshold) { | ||
| 129 | printf("Threshold not set"); | ||
| 130 | } else { | ||
| 131 | if (my_threshold->warning) { | ||
| 132 | printf("Warning: start=%g end=%g; ", my_threshold->warning->start, my_threshold->warning->end); | ||
| 133 | } else { | ||
| 134 | printf("Warning not set; "); | ||
| 135 | } | ||
| 136 | if (my_threshold->critical) { | ||
| 137 | printf("Critical: start=%g end=%g", my_threshold->critical->start, my_threshold->critical->end); | ||
| 138 | } else { | ||
| 139 | printf("Critical not set"); | ||
| 140 | } | ||
| 141 | } | ||
| 142 | printf("\n"); | ||
| 143 | } | ||
| 144 | |||
| 145 | /* Returns TRUE if alert should be raised based on the range */ | ||
| 146 | int | ||
| 147 | check_range(double value, range *my_range) | ||
| 148 | { | ||
| 149 | int false = FALSE; | ||
| 150 | int true = TRUE; | ||
| 151 | |||
| 152 | if (my_range->alert_on == INSIDE) { | ||
| 153 | false = TRUE; | ||
| 154 | true = FALSE; | ||
| 155 | } | ||
| 156 | |||
| 157 | if (my_range->end_infinity == FALSE && my_range->start_infinity == FALSE) { | ||
| 158 | if ((my_range->start <= value) && (value <= my_range->end)) { | ||
| 159 | return false; | ||
| 160 | } else { | ||
| 161 | return true; | ||
| 162 | } | ||
| 163 | } else if (my_range->start_infinity == FALSE && my_range->end_infinity == TRUE) { | ||
| 164 | if (my_range->start <= value) { | ||
| 165 | return false; | ||
| 166 | } else { | ||
| 167 | return true; | ||
| 168 | } | ||
| 169 | } else if (my_range->start_infinity == TRUE && my_range->end_infinity == FALSE) { | ||
| 170 | if (value <= my_range->end) { | ||
| 171 | return false; | ||
| 172 | } else { | ||
| 173 | return true; | ||
| 174 | } | ||
| 175 | } else { | ||
| 176 | return false; | ||
| 177 | } | ||
| 178 | } | ||
| 179 | |||
| 180 | /* Returns status */ | ||
| 181 | int | ||
| 182 | get_status(double value, thresholds *my_thresholds) | ||
| 183 | { | ||
| 184 | if (my_thresholds->critical != NULL) { | ||
| 185 | if (check_range(value, my_thresholds->critical) == TRUE) { | ||
| 186 | return STATE_CRITICAL; | ||
| 187 | } | ||
| 188 | } | ||
| 189 | if (my_thresholds->warning != NULL) { | ||
| 190 | if (check_range(value, my_thresholds->warning) == TRUE) { | ||
| 191 | return STATE_WARNING; | ||
| 192 | } | ||
| 193 | } | ||
| 194 | return STATE_OK; | ||
| 195 | } | ||
| 196 | |||
| 197 | char *np_escaped_string (const char *string) { | ||
| 198 | char *data; | ||
| 199 | int i, j=0; | ||
| 200 | data = strdup(string); | ||
| 201 | for (i=0; data[i]; i++) { | ||
| 202 | if (data[i] == '\\') { | ||
| 203 | switch(data[++i]) { | ||
| 204 | case 'n': | ||
| 205 | data[j++] = '\n'; | ||
| 206 | break; | ||
| 207 | case 'r': | ||
| 208 | data[j++] = '\r'; | ||
| 209 | break; | ||
| 210 | case 't': | ||
| 211 | data[j++] = '\t'; | ||
| 212 | break; | ||
| 213 | case '\\': | ||
| 214 | data[j++] = '\\'; | ||
| 215 | break; | ||
| 216 | default: | ||
| 217 | data[j++] = data[i]; | ||
| 218 | } | ||
| 219 | } else { | ||
| 220 | data[j++] = data[i]; | ||
| 221 | } | ||
| 222 | } | ||
| 223 | data[j] = '\0'; | ||
| 224 | return data; | ||
| 225 | } | ||
diff --git a/lib/utils_base.h b/lib/utils_base.h new file mode 100644 index 00000000..ca27f169 --- /dev/null +++ b/lib/utils_base.h | |||
| @@ -0,0 +1,37 @@ | |||
| 1 | /* Header file for nagios plugins utils_base.c */ | ||
| 2 | |||
| 3 | /* This file holds header information for thresholds - use this in preference to | ||
| 4 | individual plugin logic */ | ||
| 5 | |||
| 6 | /* This has not been merged with utils.h because of problems with | ||
| 7 | timeout_interval when other utils_*.h files use utils.h */ | ||
| 8 | |||
| 9 | /* Long term, add new functions to utils_base.h for common routines | ||
| 10 | and utils_*.h for specific to plugin routines. If routines are | ||
| 11 | placed in utils_*.h, then these can be tested with libtap */ | ||
| 12 | |||
| 13 | #define OUTSIDE 0 | ||
| 14 | #define INSIDE 1 | ||
| 15 | |||
| 16 | typedef struct range_struct { | ||
| 17 | double start; | ||
| 18 | int start_infinity; /* FALSE (default) or TRUE */ | ||
| 19 | double end; | ||
| 20 | int end_infinity; | ||
| 21 | int alert_on; /* OUTSIDE (default) or INSIDE */ | ||
| 22 | } range; | ||
| 23 | |||
| 24 | typedef struct thresholds_struct { | ||
| 25 | range *warning; | ||
| 26 | range *critical; | ||
| 27 | } thresholds; | ||
| 28 | |||
| 29 | range *parse_range_string (char *); | ||
| 30 | int _set_thresholds(thresholds **, char *, char *); | ||
| 31 | void set_thresholds(thresholds **, char *, char *); | ||
| 32 | int check_range(double, range *); | ||
| 33 | int get_status(double, thresholds *); | ||
| 34 | |||
| 35 | char *np_escaped_string (const char *); | ||
| 36 | |||
| 37 | void die (int, const char *, ...) __attribute__((noreturn,format(printf, 2, 3))); | ||
diff --git a/lib/utils_disk.c b/lib/utils_disk.c new file mode 100644 index 00000000..fdbeaf1e --- /dev/null +++ b/lib/utils_disk.c | |||
| @@ -0,0 +1,140 @@ | |||
| 1 | /**************************************************************************** | ||
| 2 | * Utils for check_disk | ||
| 3 | * | ||
| 4 | * License: GPL | ||
| 5 | * Copyright (c) 1999-2006 nagios-plugins team | ||
| 6 | * | ||
| 7 | * Last Modified: $Date$ | ||
| 8 | * | ||
| 9 | * Description: | ||
| 10 | * | ||
| 11 | * This file contains utilities for check_disk. These are tested by libtap | ||
| 12 | * | ||
| 13 | * License Information: | ||
| 14 | * | ||
| 15 | * This program is free software; you can redistribute it and/or modify | ||
| 16 | * it under the terms of the GNU General Public License as published by | ||
| 17 | * the Free Software Foundation; either version 2 of the License, or | ||
| 18 | * (at your option) any later version. | ||
| 19 | * | ||
| 20 | * This program is distributed in the hope that it will be useful, | ||
| 21 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | ||
| 22 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | ||
| 23 | * GNU General Public License for more details. | ||
| 24 | * | ||
| 25 | * You should have received a copy of the GNU General Public License | ||
| 26 | * along with this program; if not, write to the Free Software | ||
| 27 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | ||
| 28 | * | ||
| 29 | * $Id$ | ||
| 30 | * | ||
| 31 | *****************************************************************************/ | ||
| 32 | |||
| 33 | #include "common.h" | ||
| 34 | #include "utils_disk.h" | ||
| 35 | |||
| 36 | void | ||
| 37 | np_add_name (struct name_list **list, const char *name) | ||
| 38 | { | ||
| 39 | struct name_list *new_entry; | ||
| 40 | new_entry = (struct name_list *) malloc (sizeof *new_entry); | ||
| 41 | new_entry->name = (char *) name; | ||
| 42 | new_entry->next = *list; | ||
| 43 | *list = new_entry; | ||
| 44 | } | ||
| 45 | |||
| 46 | /* Initialises a new parameter at the end of list */ | ||
| 47 | struct parameter_list * | ||
| 48 | np_add_parameter(struct parameter_list **list, const char *name) | ||
| 49 | { | ||
| 50 | struct parameter_list *current = *list; | ||
| 51 | struct parameter_list *new_path; | ||
| 52 | new_path = (struct parameter_list *) malloc (sizeof *new_path); | ||
| 53 | new_path->name = (char *) name; | ||
| 54 | new_path->best_match = NULL; | ||
| 55 | new_path->name_next = NULL; | ||
| 56 | new_path->freespace_bytes = NULL; | ||
| 57 | new_path->freespace_units = NULL; | ||
| 58 | new_path->freespace_percent = NULL; | ||
| 59 | new_path->usedspace_bytes = NULL; | ||
| 60 | new_path->usedspace_units = NULL; | ||
| 61 | new_path->usedspace_percent = NULL; | ||
| 62 | new_path->usedinodes_percent = NULL; | ||
| 63 | |||
| 64 | if (current == NULL) { | ||
| 65 | *list = new_path; | ||
| 66 | } else { | ||
| 67 | while (current->name_next) { | ||
| 68 | current = current->name_next; | ||
| 69 | } | ||
| 70 | current->name_next = new_path; | ||
| 71 | } | ||
| 72 | return new_path; | ||
| 73 | } | ||
| 74 | |||
| 75 | void | ||
| 76 | np_set_best_match(struct parameter_list *desired, struct mount_entry *mount_list, int exact) | ||
| 77 | { | ||
| 78 | struct parameter_list *d; | ||
| 79 | for (d = desired; d; d= d->name_next) { | ||
| 80 | struct mount_entry *me; | ||
| 81 | size_t name_len = strlen(d->name); | ||
| 82 | size_t best_match_len = 0; | ||
| 83 | struct mount_entry *best_match = NULL; | ||
| 84 | |||
| 85 | for (me = mount_list; me; me = me->me_next) { | ||
| 86 | size_t len = strlen (me->me_mountdir); | ||
| 87 | if ((exact == FALSE && (best_match_len <= len && len <= name_len && | ||
| 88 | (len == 1 || strncmp (me->me_mountdir, d->name, len) == 0))) | ||
| 89 | || (exact == TRUE && strcmp(me->me_mountdir, d->name)==0)) | ||
| 90 | { | ||
| 91 | best_match = me; | ||
| 92 | best_match_len = len; | ||
| 93 | } else { | ||
| 94 | len = strlen (me->me_devname); | ||
| 95 | if ((exact == FALSE && (best_match_len <= len && len <= name_len && | ||
| 96 | (len == 1 || strncmp (me->me_devname, d->name, len) == 0))) | ||
| 97 | || (exact == TRUE && strcmp(me->me_devname, d->name)==0)) | ||
| 98 | { | ||
| 99 | best_match = me; | ||
| 100 | best_match_len = len; | ||
| 101 | } | ||
| 102 | } | ||
| 103 | } | ||
| 104 | if (best_match) { | ||
| 105 | d->best_match = best_match; | ||
| 106 | } else { | ||
| 107 | d->best_match = NULL; /* Not sure why this is needed as it should be null on initialisation */ | ||
| 108 | } | ||
| 109 | } | ||
| 110 | } | ||
| 111 | |||
| 112 | /* Returns TRUE if name is in list */ | ||
| 113 | int | ||
| 114 | np_find_name (struct name_list *list, const char *name) | ||
| 115 | { | ||
| 116 | const struct name_list *n; | ||
| 117 | |||
| 118 | if (list == NULL || name == NULL) { | ||
| 119 | return FALSE; | ||
| 120 | } | ||
| 121 | for (n = list; n; n = n->next) { | ||
| 122 | if (!strcmp(name, n->name)) { | ||
| 123 | return TRUE; | ||
| 124 | } | ||
| 125 | } | ||
| 126 | return FALSE; | ||
| 127 | } | ||
| 128 | |||
| 129 | int | ||
| 130 | np_seen_name(struct name_list *list, const char *name) | ||
| 131 | { | ||
| 132 | const struct name_list *s; | ||
| 133 | for (s = list; s; s=s->next) { | ||
| 134 | if (!strcmp(s->name, name)) { | ||
| 135 | return TRUE; | ||
| 136 | } | ||
| 137 | } | ||
| 138 | return FALSE; | ||
| 139 | } | ||
| 140 | |||
diff --git a/lib/utils_disk.h b/lib/utils_disk.h new file mode 100644 index 00000000..928fdbe5 --- /dev/null +++ b/lib/utils_disk.h | |||
| @@ -0,0 +1,32 @@ | |||
| 1 | /* Header file for utils_disk */ | ||
| 2 | |||
| 3 | #include "mountlist.h" | ||
| 4 | #include "utils_base.h" | ||
| 5 | |||
| 6 | struct name_list | ||
| 7 | { | ||
| 8 | char *name; | ||
| 9 | struct name_list *next; | ||
| 10 | }; | ||
| 11 | |||
| 12 | struct parameter_list | ||
| 13 | { | ||
| 14 | char *name; | ||
| 15 | int found; | ||
| 16 | thresholds *freespace_bytes; | ||
| 17 | thresholds *freespace_units; | ||
| 18 | thresholds *freespace_percent; | ||
| 19 | thresholds *usedspace_bytes; | ||
| 20 | thresholds *usedspace_units; | ||
| 21 | thresholds *usedspace_percent; | ||
| 22 | thresholds *usedinodes_percent; | ||
| 23 | struct mount_entry *best_match; | ||
| 24 | struct parameter_list *name_next; | ||
| 25 | }; | ||
| 26 | |||
| 27 | void np_add_name (struct name_list **list, const char *name); | ||
| 28 | int np_find_name (struct name_list *list, const char *name); | ||
| 29 | int np_seen_name (struct name_list *list, const char *name); | ||
| 30 | struct parameter_list *np_add_parameter(struct parameter_list **list, const char *name); | ||
| 31 | int search_parameter_list (struct parameter_list *list, const char *name); | ||
| 32 | void np_set_best_match(struct parameter_list *desired, struct mount_entry *mount_list, int exact); | ||
diff --git a/plugins/check_disk.c b/plugins/check_disk.c index 6beaf861..b966fabe 100644 --- a/plugins/check_disk.c +++ b/plugins/check_disk.c | |||
| @@ -49,13 +49,14 @@ const char *email = "nagiosplug-devel@lists.sourceforge.net"; | |||
| 49 | #include <stdarg.h> | 49 | #include <stdarg.h> |
| 50 | #include "fsusage.h" | 50 | #include "fsusage.h" |
| 51 | #include "mountlist.h" | 51 | #include "mountlist.h" |
| 52 | #include "intprops.h" /* necessary for TYPE_MAXIMUM */ | ||
| 52 | #if HAVE_LIMITS_H | 53 | #if HAVE_LIMITS_H |
| 53 | # include <limits.h> | 54 | # include <limits.h> |
| 54 | #endif | 55 | #endif |
| 55 | 56 | ||
| 56 | 57 | ||
| 57 | /* If nonzero, show inode information. */ | 58 | /* If nonzero, show inode information. */ |
| 58 | static int inode_format; | 59 | static int inode_format = 1; |
| 59 | 60 | ||
| 60 | /* If nonzero, show even filesystems with zero size or | 61 | /* If nonzero, show even filesystems with zero size or |
| 61 | uninteresting types. */ | 62 | uninteresting types. */ |
| @@ -118,16 +119,11 @@ static struct mount_entry *mount_list; | |||
| 118 | int process_arguments (int, char **); | 119 | int process_arguments (int, char **); |
| 119 | void print_path (const char *mypath); | 120 | void print_path (const char *mypath); |
| 120 | int validate_arguments (uintmax_t, uintmax_t, double, double, double, double, char *); | 121 | int validate_arguments (uintmax_t, uintmax_t, double, double, double, double, char *); |
| 121 | int check_disk (double usp, uintmax_t free_disk, double uisp); | ||
| 122 | void print_help (void); | 122 | void print_help (void); |
| 123 | void print_usage (void); | 123 | void print_usage (void); |
| 124 | 124 | ||
| 125 | uintmax_t w_df = 0; | ||
| 126 | uintmax_t c_df = 0; | ||
| 127 | double w_dfp = -1.0; | 125 | double w_dfp = -1.0; |
| 128 | double c_dfp = -1.0; | 126 | double c_dfp = -1.0; |
| 129 | double w_idfp = -1.0; | ||
| 130 | double c_idfp = -1.0; | ||
| 131 | char *path; | 127 | char *path; |
| 132 | char *exclude_device; | 128 | char *exclude_device; |
| 133 | char *units; | 129 | char *units; |
| @@ -136,20 +132,32 @@ int verbose = 0; | |||
| 136 | int erronly = FALSE; | 132 | int erronly = FALSE; |
| 137 | int display_mntp = FALSE; | 133 | int display_mntp = FALSE; |
| 138 | int exact_match = FALSE; | 134 | int exact_match = FALSE; |
| 135 | char *warn_freespace_units = NULL; | ||
| 136 | char *crit_freespace_units = NULL; | ||
| 137 | char *warn_freespace_percent = NULL; | ||
| 138 | char *crit_freespace_percent = NULL; | ||
| 139 | char *warn_usedspace_units = NULL; | ||
| 140 | char *crit_usedspace_units = NULL; | ||
| 141 | char *warn_usedspace_percent = NULL; | ||
| 142 | char *crit_usedspace_percent = NULL; | ||
| 143 | char *warn_usedinodes_percent = NULL; | ||
| 144 | char *crit_usedinodes_percent = NULL; | ||
| 139 | 145 | ||
| 140 | 146 | ||
| 141 | int | 147 | int |
| 142 | main (int argc, char **argv) | 148 | main (int argc, char **argv) |
| 143 | { | 149 | { |
| 144 | double usp = -1.0, uisp = -1.0; | ||
| 145 | int result = STATE_UNKNOWN; | 150 | int result = STATE_UNKNOWN; |
| 146 | int disk_result = STATE_UNKNOWN; | 151 | int disk_result = STATE_UNKNOWN; |
| 147 | char file_system[MAX_INPUT_BUFFER]; | ||
| 148 | char *output; | 152 | char *output; |
| 149 | char *details; | 153 | char *details; |
| 150 | char *perf; | 154 | char *perf; |
| 151 | uintmax_t psize; | 155 | float inode_space_pct; |
| 152 | float free_space, free_space_pct, total_space, inode_space_pct; | 156 | uintmax_t total, available, available_to_root, used; |
| 157 | double dfree_pct = -1, dused_pct = -1; | ||
| 158 | double dused_units, dfree_units, dtotal_units; | ||
| 159 | double dused_inodes_percent; | ||
| 160 | int temp_result; | ||
| 153 | 161 | ||
| 154 | struct mount_entry *me; | 162 | struct mount_entry *me; |
| 155 | struct fs_usage fsp; | 163 | struct fs_usage fsp; |
| @@ -175,13 +183,12 @@ main (int argc, char **argv) | |||
| 175 | if (! path_select_list) { | 183 | if (! path_select_list) { |
| 176 | for (me = mount_list; me; me = me->me_next) { | 184 | for (me = mount_list; me; me = me->me_next) { |
| 177 | path = np_add_parameter(&path_select_list, me->me_mountdir); | 185 | path = np_add_parameter(&path_select_list, me->me_mountdir); |
| 178 | path->w_df = w_df; | ||
| 179 | path->c_df = c_df; | ||
| 180 | path->w_dfp = w_dfp; | ||
| 181 | path->c_dfp = c_dfp; | ||
| 182 | path->w_idfp = w_idfp; | ||
| 183 | path->c_idfp = c_idfp; | ||
| 184 | path->best_match = me; | 186 | path->best_match = me; |
| 187 | set_thresholds(&path->freespace_units, warn_freespace_units, crit_freespace_units); | ||
| 188 | set_thresholds(&path->freespace_percent, warn_freespace_percent, crit_freespace_percent); | ||
| 189 | set_thresholds(&path->usedspace_units, warn_usedspace_units, crit_usedspace_units); | ||
| 190 | set_thresholds(&path->usedspace_percent, warn_usedspace_percent, crit_usedspace_percent); | ||
| 191 | set_thresholds(&path->usedinodes_percent, warn_usedinodes_percent, crit_usedinodes_percent); | ||
| 185 | } | 192 | } |
| 186 | } else { | 193 | } else { |
| 187 | np_set_best_match(path_select_list, mount_list, exact_match); | 194 | np_set_best_match(path_select_list, mount_list, exact_match); |
| @@ -199,12 +206,6 @@ main (int argc, char **argv) | |||
| 199 | /* Process for every path in list */ | 206 | /* Process for every path in list */ |
| 200 | for (path = path_select_list; path; path=path->name_next) { | 207 | for (path = path_select_list; path; path=path->name_next) { |
| 201 | me = path->best_match; | 208 | me = path->best_match; |
| 202 | w_df = path->w_df; | ||
| 203 | c_df = path->c_df; | ||
| 204 | w_dfp = path->w_dfp; | ||
| 205 | c_dfp = path->c_dfp; | ||
| 206 | w_idfp = path->w_idfp; | ||
| 207 | c_idfp = path->c_idfp; | ||
| 208 | 209 | ||
| 209 | /* Filters */ | 210 | /* Filters */ |
| 210 | 211 | ||
| @@ -233,13 +234,67 @@ main (int argc, char **argv) | |||
| 233 | get_fs_usage (me->me_mountdir, me->me_devname, &fsp); | 234 | get_fs_usage (me->me_mountdir, me->me_devname, &fsp); |
| 234 | 235 | ||
| 235 | if (fsp.fsu_blocks && strcmp ("none", me->me_mountdir)) { | 236 | if (fsp.fsu_blocks && strcmp ("none", me->me_mountdir)) { |
| 236 | usp = (double)(fsp.fsu_blocks - fsp.fsu_bavail) * 100 / fsp.fsu_blocks; | 237 | total = fsp.fsu_blocks; |
| 237 | uisp = (double)(fsp.fsu_files - fsp.fsu_ffree) * 100 / fsp.fsu_files; | 238 | available = fsp.fsu_bavail; |
| 238 | disk_result = check_disk (usp, fsp.fsu_bavail, uisp); | 239 | available_to_root = fsp.fsu_bfree; |
| 240 | used = total - available_to_root; | ||
| 241 | |||
| 242 | /* I don't understand the below, but it is taken from coreutils' df */ | ||
| 243 | /* Is setting dused_pct, in the best possible way */ | ||
| 244 | if (used <= TYPE_MAXIMUM(uintmax_t) / 100) { | ||
| 245 | uintmax_t u100 = used * 100; | ||
| 246 | uintmax_t nonroot_total = used + available; | ||
| 247 | dused_pct = u100 / nonroot_total + (u100 % nonroot_total != 0); | ||
| 248 | } else { | ||
| 249 | /* Possible rounding errors - see coreutils' df for more explanation */ | ||
| 250 | double u = used; | ||
| 251 | double a = available; | ||
| 252 | double nonroot_total = u + a; | ||
| 253 | if (nonroot_total) { | ||
| 254 | long int lipct = dused_pct = u * 100 / nonroot_total; | ||
| 255 | double ipct = lipct; | ||
| 256 | |||
| 257 | /* Like 'pct = ceil (dpct);', but without ceil - from coreutils again */ | ||
| 258 | if (ipct - 1 < dused_pct && dused_pct <= ipct + 1) | ||
| 259 | dused_pct = ipct + (ipct < dused_pct); | ||
| 260 | } | ||
| 261 | } | ||
| 262 | |||
| 263 | dfree_pct = 100 - dused_pct; | ||
| 264 | dused_units = used*fsp.fsu_blocksize/mult; | ||
| 265 | dfree_units = available*fsp.fsu_blocksize/mult; | ||
| 266 | dtotal_units = total*fsp.fsu_blocksize/mult; | ||
| 267 | dused_inodes_percent = (fsp.fsu_files - fsp.fsu_ffree) * 100 / fsp.fsu_files; | ||
| 268 | |||
| 269 | if (verbose >= 3) { | ||
| 270 | printf ("For %s, used_pct=%g free_pct=%g used_units=%g free_units=%g total_units=%g used_inodes_pct=%g\n", | ||
| 271 | me->me_mountdir, dused_pct, dfree_pct, dused_units, dfree_units, dtotal_units, dused_inodes_percent); | ||
| 272 | } | ||
| 273 | |||
| 274 | /* Threshold comparisons */ | ||
| 275 | |||
| 276 | temp_result = get_status(dfree_units, path->freespace_units); | ||
| 277 | if (verbose >=3) printf("Freespace_units result=%d\n", temp_result); | ||
| 278 | result = max_state( result, temp_result ); | ||
| 239 | 279 | ||
| 280 | temp_result = get_status(dfree_pct, path->freespace_percent); | ||
| 281 | if (verbose >=3) printf("Freespace%% result=%d\n", temp_result); | ||
| 282 | result = max_state( result, temp_result ); | ||
| 283 | |||
| 284 | temp_result = get_status(dused_units, path->usedspace_units); | ||
| 285 | if (verbose >=3) printf("Usedspace_units result=%d\n", temp_result); | ||
| 286 | result = max_state( result, temp_result ); | ||
| 287 | |||
| 288 | temp_result = get_status(dused_pct, path->usedspace_percent); | ||
| 289 | if (verbose >=3) printf("Usedspace_percent result=%d\n", temp_result); | ||
| 290 | result = max_state( result, temp_result ); | ||
| 291 | |||
| 292 | temp_result = get_status(dused_inodes_percent, path->usedinodes_percent); | ||
| 293 | if (verbose >=3) printf("Usedinodes_percent result=%d\n", temp_result); | ||
| 294 | result = max_state( result, temp_result ); | ||
| 295 | |||
| 296 | |||
| 240 | 297 | ||
| 241 | result = max_state (disk_result, result); | ||
| 242 | psize = fsp.fsu_blocks*fsp.fsu_blocksize/mult; | ||
| 243 | 298 | ||
| 244 | 299 | ||
| 245 | /* Moved this computation up here so we can add it | 300 | /* Moved this computation up here so we can add it |
| @@ -248,33 +303,33 @@ main (int argc, char **argv) | |||
| 248 | 303 | ||
| 249 | 304 | ||
| 250 | asprintf (&perf, "%s %s", perf, | 305 | asprintf (&perf, "%s %s", perf, |
| 251 | perfdata ((!strcmp(file_system, "none") || display_mntp) ? me->me_devname : me->me_mountdir, | 306 | perfdata ((!strcmp(me->me_mountdir, "none") || display_mntp) ? me->me_devname : me->me_mountdir, |
| 252 | psize-(fsp.fsu_bavail*fsp.fsu_blocksize/mult), units, | 307 | dused_units, units, |
| 253 | TRUE, min ((uintmax_t)psize-(uintmax_t)w_df, (uintmax_t)((1.0-w_dfp/100.0)*psize)), | 308 | FALSE, 0, /* min ((uintmax_t)dtotal_units-(uintmax_t)w_df, (uintmax_t)((1.0-w_dfp/100.0)*dtotal_units)), */ |
| 254 | TRUE, min ((uintmax_t)psize-(uintmax_t)c_df, (uintmax_t)((1.0-c_dfp/100.0)*psize)), | 309 | FALSE, 0, /* min ((uintmax_t)dtotal_units-(uintmax_t)c_df, (uintmax_t)((1.0-c_dfp/100.0)*dtotal_units)), */ |
| 255 | TRUE, inode_space_pct, | 310 | FALSE, 0, /* inode_space_pct, */ |
| 311 | FALSE, 0));; /* dtotal_units)); */ | ||
| 256 | 312 | ||
| 257 | TRUE, psize)); | ||
| 258 | if (disk_result==STATE_OK && erronly && !verbose) | 313 | if (disk_result==STATE_OK && erronly && !verbose) |
| 259 | continue; | 314 | continue; |
| 260 | 315 | ||
| 261 | free_space = (float)fsp.fsu_bavail*fsp.fsu_blocksize/mult; | 316 | if (disk_result!=STATE_OK || verbose>=0) { |
| 262 | free_space_pct = (float)fsp.fsu_bavail*100/fsp.fsu_blocks; | ||
| 263 | total_space = (float)fsp.fsu_blocks*fsp.fsu_blocksize/mult; | ||
| 264 | if (disk_result!=STATE_OK || verbose>=0) | ||
| 265 | asprintf (&output, ("%s %s %.0f %s (%.0f%% inode=%.0f%%);"), | 317 | asprintf (&output, ("%s %s %.0f %s (%.0f%% inode=%.0f%%);"), |
| 266 | output, | 318 | output, |
| 267 | (!strcmp(file_system, "none") || display_mntp) ? me->me_devname : me->me_mountdir, | 319 | (!strcmp(me->me_mountdir, "none") || display_mntp) ? me->me_devname : me->me_mountdir, |
| 268 | free_space, | 320 | dfree_units, |
| 269 | units, | 321 | units, |
| 270 | free_space_pct, | 322 | dfree_pct, |
| 271 | inode_space_pct); | 323 | inode_space_pct); |
| 324 | } | ||
| 272 | 325 | ||
| 326 | /* Need to do a similar one | ||
| 273 | asprintf (&details, _("%s\n\ | 327 | asprintf (&details, _("%s\n\ |
| 274 | %.0f of %.0f %s (%.0f%% inode=%.0f%%) free on %s (type %s mounted on %s) warn:%lu crit:%lu warn%%:%.0f%% crit%%:%.0f%%"), | 328 | %.0f of %.0f %s (%.0f%% inode=%.0f%%) free on %s (type %s mounted on %s) warn:%lu crit:%lu warn%%:%.0f%% crit%%:%.0f%%"), |
| 275 | details, free_space, total_space, units, free_space_pct, inode_space_pct, | 329 | details, dfree_units, dtotal_units, units, dfree_pct, inode_space_pct, |
| 276 | me->me_devname, me->me_type, me->me_mountdir, | 330 | me->me_devname, me->me_type, me->me_mountdir, |
| 277 | (unsigned long)w_df, (unsigned long)c_df, w_dfp, c_dfp); | 331 | (unsigned long)w_df, (unsigned long)c_df, w_dfp, c_dfp); |
| 332 | */ | ||
| 278 | 333 | ||
| 279 | } | 334 | } |
| 280 | 335 | ||
| @@ -299,14 +354,6 @@ process_arguments (int argc, char **argv) | |||
| 299 | struct parameter_list *temp_list; | 354 | struct parameter_list *temp_list; |
| 300 | int result = OK; | 355 | int result = OK; |
| 301 | struct stat *stat_buf; | 356 | struct stat *stat_buf; |
| 302 | char *warn_freespace = NULL; | ||
| 303 | char *crit_freespace = NULL; | ||
| 304 | char *warn_freespace_percent = NULL; | ||
| 305 | char *crit_freespace_percent = NULL; | ||
| 306 | char temp_string[MAX_INPUT_BUFFER]; | ||
| 307 | |||
| 308 | unsigned long l; | ||
| 309 | double f; | ||
| 310 | 357 | ||
| 311 | int option = 0; | 358 | int option = 0; |
| 312 | static struct option longopts[] = { | 359 | static struct option longopts[] = { |
| @@ -359,65 +406,51 @@ process_arguments (int argc, char **argv) | |||
| 359 | else { | 406 | else { |
| 360 | usage2 (_("Timeout interval must be a positive integer"), optarg); | 407 | usage2 (_("Timeout interval must be a positive integer"), optarg); |
| 361 | } | 408 | } |
| 409 | |||
| 410 | /* See comments for 'c' */ | ||
| 362 | case 'w': /* warning threshold */ | 411 | case 'w': /* warning threshold */ |
| 363 | /* | ||
| 364 | if (strstr(optarg, "%")) { | 412 | if (strstr(optarg, "%")) { |
| 365 | printf("Got percent with optarg=%s\n", optarg); | 413 | if (*optarg == '@') { |
| 366 | warn_freespace_percent = optarg; | 414 | warn_freespace_percent = optarg; |
| 415 | } else { | ||
| 416 | asprintf(&warn_freespace_percent, "@%s", optarg); | ||
| 417 | } | ||
| 367 | } else { | 418 | } else { |
| 368 | warn_freespace = optarg; | 419 | if (*optarg == '@') { |
| 420 | warn_freespace_units = optarg; | ||
| 421 | } else { | ||
| 422 | asprintf(&warn_freespace_units, "@%s", optarg); | ||
| 423 | } | ||
| 369 | } | 424 | } |
| 370 | break; | 425 | break; |
| 371 | */ | 426 | |
| 372 | if (is_intnonneg (optarg)) { | 427 | /* Awful mistake where the range values do not make sense. Normally, |
| 373 | w_df = atoi (optarg); | 428 | you alert if the value is within the range, but since we are using |
| 374 | break; | 429 | freespace, we have to alert if outside the range. Thus we artifically |
| 375 | } | 430 | force @ at the beginning of the range, so that it is backwards compatible |
| 376 | else if (strpbrk (optarg, ",:") && | 431 | */ |
| 377 | strstr (optarg, "%") && | ||
| 378 | sscanf (optarg, "%lu%*[:,]%lf%%", &l, &w_dfp) == 2) { | ||
| 379 | w_df = (uintmax_t)l; | ||
| 380 | break; | ||
| 381 | } | ||
| 382 | else if (strstr (optarg, "%") && sscanf (optarg, "%lf%%", &w_dfp) == 1) { | ||
| 383 | break; | ||
| 384 | } | ||
| 385 | else { | ||
| 386 | usage4 (_("Warning threshold must be integer or percentage!")); | ||
| 387 | } | ||
| 388 | case 'c': /* critical threshold */ | 432 | case 'c': /* critical threshold */ |
| 389 | if (is_intnonneg (optarg)) { | 433 | if (strstr(optarg, "%")) { |
| 390 | c_df = atoi (optarg); | 434 | if (*optarg == '@') { |
| 391 | break; | 435 | crit_freespace_percent = optarg; |
| 392 | } | 436 | } else { |
| 393 | else if (strpbrk (optarg, ",:") && | 437 | asprintf(&crit_freespace_percent, "@%s", optarg); |
| 394 | strstr (optarg, "%") && | 438 | } |
| 395 | sscanf (optarg, "%lu%*[,:]%lf%%", &l, &c_dfp) == 2) { | 439 | } else { |
| 396 | c_df = (uintmax_t)l; | 440 | if (*optarg == '@') { |
| 397 | break; | 441 | crit_freespace_units = optarg; |
| 398 | } | 442 | } else { |
| 399 | else if (strstr (optarg, "%") && sscanf (optarg, "%lf%%", &c_dfp) == 1) { | 443 | asprintf(&crit_freespace_units, "@%s", optarg); |
| 400 | break; | 444 | } |
| 401 | } | ||
| 402 | else { | ||
| 403 | usage4 (_("Critical threshold must be integer or percentage!")); | ||
| 404 | } | 445 | } |
| 446 | break; | ||
| 405 | 447 | ||
| 406 | 448 | case 'W': /* warning inode threshold */ | |
| 407 | case 'W': /* warning inode threshold */ | 449 | warn_usedinodes_percent = optarg; |
| 408 | if (strstr (optarg, "%") && sscanf (optarg, "%lf%%", &w_idfp) == 1) { | 450 | break; |
| 409 | break; | 451 | case 'K': /* critical inode threshold */ |
| 410 | } | 452 | crit_usedinodes_percent = optarg; |
| 411 | else { | 453 | break; |
| 412 | usage (_("Warning inode threshold must be percentage!\n")); | ||
| 413 | } | ||
| 414 | case 'K': /* kritical inode threshold */ | ||
| 415 | if (strstr (optarg, "%") && sscanf (optarg, "%lf%%", &c_idfp) == 1) { | ||
| 416 | break; | ||
| 417 | } | ||
| 418 | else { | ||
| 419 | usage (_("Critical inode threshold must be percentage!\n")); | ||
| 420 | } | ||
| 421 | case 'u': | 454 | case 'u': |
| 422 | if (units) | 455 | if (units) |
| 423 | free(units); | 456 | free(units); |
| @@ -458,13 +491,18 @@ process_arguments (int argc, char **argv) | |||
| 458 | show_local_fs = 1; | 491 | show_local_fs = 1; |
| 459 | break; | 492 | break; |
| 460 | case 'p': /* select path */ | 493 | case 'p': /* select path */ |
| 494 | if (! (warn_freespace_units || crit_freespace_units || warn_freespace_percent || | ||
| 495 | crit_freespace_percent || warn_usedspace_units || crit_usedspace_units || | ||
| 496 | warn_usedspace_percent || crit_usedspace_percent || warn_usedinodes_percent || | ||
| 497 | crit_usedinodes_percent)) { | ||
| 498 | die (STATE_UNKNOWN, "DISK %s: %s", _("UNKNOWN"), _("Must set a threshold value before using -p\n")); | ||
| 499 | } | ||
| 461 | se = np_add_parameter(&path_select_list, optarg); | 500 | se = np_add_parameter(&path_select_list, optarg); |
| 462 | se->w_df = w_df; | 501 | set_thresholds(&se->freespace_units, warn_freespace_units, crit_freespace_units); |
| 463 | se->c_df = c_df; | 502 | set_thresholds(&se->freespace_percent, warn_freespace_percent, crit_freespace_percent); |
| 464 | se->w_dfp = w_dfp; | 503 | set_thresholds(&se->usedspace_units, warn_usedspace_units, crit_usedspace_units); |
| 465 | se->c_dfp = c_dfp; | 504 | set_thresholds(&se->usedspace_percent, warn_usedspace_percent, crit_usedspace_percent); |
| 466 | se->w_idfp = w_idfp; | 505 | set_thresholds(&se->usedinodes_percent, warn_usedinodes_percent, crit_usedinodes_percent); |
| 467 | se->c_idfp = c_idfp; | ||
| 468 | break; | 506 | break; |
| 469 | case 'x': /* exclude path or partition */ | 507 | case 'x': /* exclude path or partition */ |
| 470 | np_add_name(&dp_exclude_list, optarg); | 508 | np_add_name(&dp_exclude_list, optarg); |
| @@ -488,12 +526,16 @@ process_arguments (int argc, char **argv) | |||
| 488 | display_mntp = TRUE; | 526 | display_mntp = TRUE; |
| 489 | break; | 527 | break; |
| 490 | case 'C': | 528 | case 'C': |
| 491 | w_df = 0; | 529 | warn_freespace_units = NULL; |
| 492 | c_df = 0; | 530 | crit_freespace_units = NULL; |
| 493 | w_dfp = -1.0; | 531 | warn_usedspace_units = NULL; |
| 494 | c_dfp = -1.0; | 532 | crit_usedspace_units = NULL; |
| 495 | w_idfp = -1.0; | 533 | warn_freespace_percent = NULL; |
| 496 | c_idfp = -1.0; | 534 | crit_freespace_percent = NULL; |
| 535 | warn_usedspace_percent = NULL; | ||
| 536 | crit_usedspace_percent = NULL; | ||
| 537 | warn_usedinodes_percent = NULL; | ||
| 538 | crit_usedinodes_percent = NULL; | ||
| 497 | break; | 539 | break; |
| 498 | case 'V': /* version */ | 540 | case 'V': /* version */ |
| 499 | print_revision (progname, revision); | 541 | print_revision (progname, revision); |
| @@ -506,22 +548,26 @@ process_arguments (int argc, char **argv) | |||
| 506 | } | 548 | } |
| 507 | } | 549 | } |
| 508 | 550 | ||
| 509 | /* Support for "check_disk warn crit [fs]" with thresholds at used level */ | 551 | /* Support for "check_disk warn crit [fs]" with thresholds at used% level */ |
| 510 | c = optind; | 552 | c = optind; |
| 511 | if (w_dfp < 0 && argc > c && is_intnonneg (argv[c])) | 553 | if (warn_usedspace_percent == NULL && argc > c && is_intnonneg (argv[c])) |
| 512 | w_dfp = (100.0 - atof (argv[c++])); | 554 | warn_usedspace_percent = argv[c++]; |
| 513 | 555 | ||
| 514 | if (c_dfp < 0 && argc > c && is_intnonneg (argv[c])) | 556 | if (crit_usedspace_percent == NULL && argc > c && is_intnonneg (argv[c])) |
| 515 | c_dfp = (100.0 - atof (argv[c++])); | 557 | crit_usedspace_percent = argv[c++]; |
| 516 | 558 | ||
| 517 | if (argc > c && path == NULL) { | 559 | if (argc > c && path == NULL) { |
| 518 | se = np_add_parameter(&path_select_list, strdup(argv[c++])); | 560 | se = np_add_parameter(&path_select_list, strdup(argv[c++])); |
| 519 | se->w_df = w_df; | 561 | set_thresholds(&se->freespace_units, warn_freespace_units, crit_freespace_units); |
| 520 | se->c_df = c_df; | 562 | set_thresholds(&se->freespace_percent, warn_freespace_percent, crit_freespace_percent); |
| 521 | se->w_dfp = w_dfp; | 563 | set_thresholds(&se->usedspace_units, warn_usedspace_units, crit_usedspace_units); |
| 522 | se->c_dfp = c_dfp; | 564 | set_thresholds(&se->usedspace_percent, warn_usedspace_percent, crit_usedspace_percent); |
| 523 | se->w_idfp = w_idfp; | 565 | set_thresholds(&se->usedinodes_percent, warn_usedinodes_percent, crit_usedinodes_percent); |
| 524 | se->c_idfp = c_idfp; | 566 | } |
| 567 | |||
| 568 | if (units == NULL) { | ||
| 569 | units = strdup ("MB"); | ||
| 570 | mult = (uintmax_t)1024 * 1024; | ||
| 525 | } | 571 | } |
| 526 | 572 | ||
| 527 | if (path_select_list) { | 573 | if (path_select_list) { |
| @@ -533,7 +579,7 @@ process_arguments (int argc, char **argv) | |||
| 533 | printf("DISK %s - ", _("CRITICAL")); | 579 | printf("DISK %s - ", _("CRITICAL")); |
| 534 | die (STATE_CRITICAL, _("%s does not exist\n"), temp_list->name); | 580 | die (STATE_CRITICAL, _("%s does not exist\n"), temp_list->name); |
| 535 | } | 581 | } |
| 536 | if (validate_arguments (temp_list->w_df, | 582 | /* if (validate_arguments (temp_list->w_df, |
| 537 | temp_list->c_df, | 583 | temp_list->c_df, |
| 538 | temp_list->w_dfp, | 584 | temp_list->w_dfp, |
| 539 | temp_list->c_dfp, | 585 | temp_list->c_dfp, |
| @@ -541,12 +587,14 @@ process_arguments (int argc, char **argv) | |||
| 541 | temp_list->c_idfp, | 587 | temp_list->c_idfp, |
| 542 | temp_list->name) == ERROR) | 588 | temp_list->name) == ERROR) |
| 543 | result = ERROR; | 589 | result = ERROR; |
| 590 | */ | ||
| 544 | temp_list = temp_list->name_next; | 591 | temp_list = temp_list->name_next; |
| 545 | } | 592 | } |
| 546 | free(stat_buf); | 593 | free(stat_buf); |
| 547 | return result; | 594 | return result; |
| 548 | } else { | 595 | } else { |
| 549 | return validate_arguments (w_df, c_df, w_dfp, c_dfp, w_idfp, c_idfp, NULL); | 596 | return TRUE; |
| 597 | /* return validate_arguments (w_df, c_df, w_dfp, c_dfp, w_idfp, c_idfp, NULL); */ | ||
| 550 | } | 598 | } |
| 551 | } | 599 | } |
| 552 | 600 | ||
| @@ -560,11 +608,13 @@ print_path (const char *mypath) | |||
| 560 | else | 608 | else |
| 561 | printf (_(" for %s\n"), mypath); | 609 | printf (_(" for %s\n"), mypath); |
| 562 | 610 | ||
| 563 | return; | 611 | //return; |
| 564 | } | 612 | } |
| 565 | 613 | ||
| 566 | 614 | ||
| 567 | 615 | ||
| 616 | /* TODO: Remove? | ||
| 617 | |||
| 568 | int | 618 | int |
| 569 | validate_arguments (uintmax_t w, uintmax_t c, double wp, double cp, double iwp, double icp, char *mypath) | 619 | validate_arguments (uintmax_t w, uintmax_t c, double wp, double cp, double iwp, double icp, char *mypath) |
| 570 | { | 620 | { |
| @@ -597,37 +647,12 @@ INPUT ERROR: C_DF (%lu) should be less than W_DF (%lu) and both should be greate | |||
| 597 | return ERROR; | 647 | return ERROR; |
| 598 | } | 648 | } |
| 599 | 649 | ||
| 600 | if (units == NULL) { | ||
| 601 | units = strdup ("MB"); | ||
| 602 | mult = (uintmax_t)1024 * 1024; | ||
| 603 | } | ||
| 604 | return OK; | 650 | return OK; |
| 605 | } | 651 | } |
| 606 | 652 | ||
| 653 | */ | ||
| 607 | 654 | ||
| 608 | 655 | ||
| 609 | int | ||
| 610 | check_disk (double usp, uintmax_t free_disk, double uisp) | ||
| 611 | { | ||
| 612 | int result = STATE_UNKNOWN; | ||
| 613 | /* check the percent used space against thresholds */ | ||
| 614 | if (usp >= 0.0 && c_dfp >=0.0 && usp >= (100.0 - c_dfp)) | ||
| 615 | result = STATE_CRITICAL; | ||
| 616 | else if (uisp >= 0.0 && c_idfp >=0.0 && uisp >= (100.0 - c_idfp)) | ||
| 617 | result = STATE_CRITICAL; | ||
| 618 | else if (c_df > 0 && free_disk <= c_df) | ||
| 619 | result = STATE_CRITICAL; | ||
| 620 | else if (usp >= 0.0 && w_dfp >=0.0 && usp >= (100.0 - w_dfp)) | ||
| 621 | result = STATE_WARNING; | ||
| 622 | else if (uisp >= 0.0 && w_idfp >=0.0 && uisp >= (100.0 - w_idfp)) | ||
| 623 | result = STATE_WARNING; | ||
| 624 | else if (w_df > 0 && free_disk <= w_df) | ||
| 625 | result = STATE_WARNING; | ||
| 626 | else if (usp >= 0.0) | ||
| 627 | result = STATE_OK; | ||
| 628 | return result; | ||
| 629 | } | ||
| 630 | |||
| 631 | 656 | ||
| 632 | 657 | ||
| 633 | 658 | ||
diff --git a/plugins/t/check_disk.t b/plugins/t/check_disk.t index 70d8415c..66344927 100644 --- a/plugins/t/check_disk.t +++ b/plugins/t/check_disk.t | |||
| @@ -52,8 +52,8 @@ if ($free_on_mp1 > $free_on_mp2) { | |||
| 52 | } | 52 | } |
| 53 | 53 | ||
| 54 | 54 | ||
| 55 | $result = NPTest->testCmd( "./check_disk -w 100 -c 100 -p $more_free" ); | 55 | $result = NPTest->testCmd( "./check_disk -w 1 -c 1 -p $more_free" ); |
| 56 | cmp_ok( $result->return_code, '==', 0, "At least 100 bytes available on $more_free"); | 56 | cmp_ok( $result->return_code, '==', 0, "At least 1 MB available on $more_free"); |
| 57 | like ( $result->output, $successOutput, "OK output" ); | 57 | like ( $result->output, $successOutput, "OK output" ); |
| 58 | 58 | ||
| 59 | $result = NPTest->testCmd( "./check_disk 100 100 $more_free" ); | 59 | $result = NPTest->testCmd( "./check_disk 100 100 $more_free" ); |
| @@ -110,35 +110,28 @@ cmp_ok( $result->return_code, '==', 2, "And reversing arguments should not make | |||
| 110 | 110 | ||
| 111 | 111 | ||
| 112 | 112 | ||
| 113 | |||
| 114 | $result = NPTest->testCmd( | ||
| 115 | "./check_disk -w 10% -c 15% -p $mountpoint_valid" | ||
| 116 | ); | ||
| 117 | cmp_ok( $result->return_code, '==', 3, "Invalid command line options" ); | ||
| 118 | |||
| 119 | TODO: { | 113 | TODO: { |
| 120 | local $TODO = "-p must come after -w and -c"; | 114 | local $TODO = "Invalid percent figures"; |
| 121 | $result = NPTest->testCmd( | 115 | $result = NPTest->testCmd( |
| 116 | "./check_disk -w 10% -c 15% -p $mountpoint_valid" | ||
| 117 | ); | ||
| 118 | cmp_ok( $result->return_code, '==', 3, "Invalid command line options" ); | ||
| 119 | } | ||
| 120 | |||
| 121 | $result = NPTest->testCmd( | ||
| 122 | "./check_disk -p $mountpoint_valid -w 10% -c 15%" | 122 | "./check_disk -p $mountpoint_valid -w 10% -c 15%" |
| 123 | ); | 123 | ); |
| 124 | cmp_ok( $result->return_code, "==", 3, "Invalid options - order unimportant" ); | 124 | cmp_ok( $result->return_code, "==", 3, "Invalid options: -p must come after thresholds" ); |
| 125 | } | ||
| 126 | 125 | ||
| 127 | $result = NPTest->testCmd( "./check_disk -w 100% -c 100% ".${mountpoint_valid} ); # 100% empty | 126 | $result = NPTest->testCmd( "./check_disk -w 100% -c 100% ".${mountpoint_valid} ); # 100% empty |
| 128 | cmp_ok( $result->return_code, "==", 2, "100% empty" ); | 127 | cmp_ok( $result->return_code, "==", 2, "100% empty" ); |
| 129 | like( $result->output, $failureOutput, "Right output" ); | 128 | like( $result->output, $failureOutput, "Right output" ); |
| 130 | 129 | ||
| 131 | TODO: { | 130 | $result = NPTest->testCmd( "./check_disk -w 100000 -c 100000 $mountpoint_valid" ); |
| 132 | local $TODO = "Requesting 100GB free is should be critical"; | 131 | cmp_ok( $result->return_code, '==', 2, "Check for 100GB free" ); |
| 133 | $result = NPTest->testCmd( "./check_disk -w 100000 -c 100000 $mountpoint_valid" ); | ||
| 134 | cmp_ok( $result->return_code, '==', 2, "Check for 100GB free" ); | ||
| 135 | } | ||
| 136 | 132 | ||
| 137 | TODO: { | 133 | $result = NPTest->testCmd( "./check_disk -w 100 -c 100 -u GB ".${mountpoint_valid} ); # 100 GB empty |
| 138 | local $TODO = "-u GB does not work"; | 134 | cmp_ok( $result->return_code, "==", 2, "100 GB empty" ); |
| 139 | $result = NPTest->testCmd( "./check_disk -w 100 -c 100 -u GB ".${mountpoint_valid} ); # 100 GB empty | ||
| 140 | cmp_ok( $result->return_code, "==", 2, "100 GB empty" ); | ||
| 141 | } | ||
| 142 | 135 | ||
| 143 | 136 | ||
| 144 | # Checking old syntax of check_disk warn crit [fs], with warn/crit at USED% thresholds | 137 | # Checking old syntax of check_disk warn crit [fs], with warn/crit at USED% thresholds |
| @@ -151,17 +144,17 @@ cmp_ok( $result->return_code, '==', 0, "Old syntax: 100% used" ); | |||
| 151 | $result = NPTest->testCmd( "./check_disk 0 100 $mountpoint_valid" ); | 144 | $result = NPTest->testCmd( "./check_disk 0 100 $mountpoint_valid" ); |
| 152 | cmp_ok( $result->return_code, '==', 1, "Old syntax: warn 0% used" ); | 145 | cmp_ok( $result->return_code, '==', 1, "Old syntax: warn 0% used" ); |
| 153 | 146 | ||
| 154 | $result = NPTest->testCmd( "./check_disk 0 200 $mountpoint_valid" ); | ||
| 155 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); | ||
| 156 | |||
| 157 | TODO: { | 147 | TODO: { |
| 158 | local $TODO = "Need to properly check input"; | 148 | local $TODO = "Invalid values"; |
| 149 | $result = NPTest->testCmd( "./check_disk 0 200 $mountpoint_valid" ); | ||
| 150 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); | ||
| 151 | |||
| 159 | $result = NPTest->testCmd( "./check_disk 200 200 $mountpoint_valid" ); | 152 | $result = NPTest->testCmd( "./check_disk 200 200 $mountpoint_valid" ); |
| 160 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); | 153 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); |
| 161 | } | ||
| 162 | 154 | ||
| 163 | $result = NPTest->testCmd( "./check_disk 200 0 $mountpoint_valid" ); | 155 | $result = NPTest->testCmd( "./check_disk 200 0 $mountpoint_valid" ); |
| 164 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); | 156 | cmp_ok( $result->return_code, '==', 3, "Old syntax: Error with values outside percent range" ); |
| 157 | } | ||
| 165 | 158 | ||
| 166 | $result = NPTest->testCmd( "./check_disk -w 0% -c 0% -p /bob" ); | 159 | $result = NPTest->testCmd( "./check_disk -w 0% -c 0% -p /bob" ); |
| 167 | cmp_ok( $result->return_code, '==', 2, "Checking /bob - return error because /bob does not exist" ); | 160 | cmp_ok( $result->return_code, '==', 2, "Checking /bob - return error because /bob does not exist" ); |
