diff options
| author | John C. Frickson <jfrickson@nagios.com> | 2016-11-07 13:06:05 -0600 |
|---|---|---|
| committer | Sven Nierlein <sven@nierlein.de> | 2016-11-07 21:36:25 +0100 |
| commit | a5983eda69b442a90495909803724901669b50fb (patch) | |
| tree | fa3442fe3bc20309245188d88d77c6cdd15c17d9 /plugins/check_users.c | |
| parent | 3a12034805caf6c4ad21a8f86c8e4a43ff62576c (diff) | |
| download | monitoring-plugins-a5983eda69b442a90495909803724901669b50fb.tar.gz | |
check_users not correctly detecting thresholds
Fix for issue https://github.com/nagios-plugins/nagios-plugins/issues/81
check_users now uses the standard warning and critical ranges parser and
a standard perdata output routine.
Diffstat (limited to 'plugins/check_users.c')
| -rw-r--r-- | plugins/check_users.c | 60 |
1 files changed, 22 insertions, 38 deletions
diff --git a/plugins/check_users.c b/plugins/check_users.c index 54415a48..a10249c4 100644 --- a/plugins/check_users.c +++ b/plugins/check_users.c | |||
| @@ -54,15 +54,15 @@ int process_arguments (int, char **); | |||
| 54 | void print_help (void); | 54 | void print_help (void); |
| 55 | void print_usage (void); | 55 | void print_usage (void); |
| 56 | 56 | ||
| 57 | int wusers = -1; | 57 | char *warning_range = NULL; |
| 58 | int cusers = -1; | 58 | char *critical_range = NULL; |
| 59 | thresholds *thlds = NULL; | ||
| 59 | 60 | ||
| 60 | int | 61 | int |
| 61 | main (int argc, char **argv) | 62 | main (int argc, char **argv) |
| 62 | { | 63 | { |
| 63 | int users = -1; | 64 | int users = -1; |
| 64 | int result = STATE_UNKNOWN; | 65 | int result = STATE_UNKNOWN; |
| 65 | char *perf; | ||
| 66 | #if HAVE_WTSAPI32_H | 66 | #if HAVE_WTSAPI32_H |
| 67 | WTS_SESSION_INFO *wtsinfo; | 67 | WTS_SESSION_INFO *wtsinfo; |
| 68 | DWORD wtscount; | 68 | DWORD wtscount; |
| @@ -77,8 +77,6 @@ main (int argc, char **argv) | |||
| 77 | bindtextdomain (PACKAGE, LOCALEDIR); | 77 | bindtextdomain (PACKAGE, LOCALEDIR); |
| 78 | textdomain (PACKAGE); | 78 | textdomain (PACKAGE); |
| 79 | 79 | ||
| 80 | perf = strdup (""); | ||
| 81 | |||
| 82 | /* Parse extra opts if any */ | 80 | /* Parse extra opts if any */ |
| 83 | argv = np_extra_opts (&argc, argv, progname); | 81 | argv = np_extra_opts (&argc, argv, progname); |
| 84 | 82 | ||
| @@ -160,23 +158,15 @@ main (int argc, char **argv) | |||
| 160 | #endif | 158 | #endif |
| 161 | 159 | ||
| 162 | /* check the user count against warning and critical thresholds */ | 160 | /* check the user count against warning and critical thresholds */ |
| 163 | if (users > cusers) | 161 | result = get_status((double)users, thlds); |
| 164 | result = STATE_CRITICAL; | ||
| 165 | else if (users > wusers) | ||
| 166 | result = STATE_WARNING; | ||
| 167 | else if (users >= 0) | ||
| 168 | result = STATE_OK; | ||
| 169 | 162 | ||
| 170 | if (result == STATE_UNKNOWN) | 163 | if (result == STATE_UNKNOWN) |
| 171 | printf ("%s\n", _("Unable to read output")); | 164 | printf ("%s\n", _("Unable to read output")); |
| 172 | else { | 165 | else { |
| 173 | xasprintf (&perf, "%s", perfdata ("users", users, "", | 166 | printf (_("USERS %s - %d users currently logged in |%s\n"), |
| 174 | TRUE, wusers, | 167 | state_text(result), users, |
| 175 | TRUE, cusers, | 168 | sperfdata_int("users", users, "", warning_range, |
| 176 | TRUE, 0, | 169 | critical_range, TRUE, 0, FALSE, 0)); |
| 177 | FALSE, 0)); | ||
| 178 | printf (_("USERS %s - %d users currently logged in |%s\n"), state_text (result), | ||
| 179 | users, perf); | ||
| 180 | } | 170 | } |
| 181 | 171 | ||
| 182 | return result; | 172 | return result; |
| @@ -215,33 +205,27 @@ process_arguments (int argc, char **argv) | |||
| 215 | print_revision (progname, NP_VERSION); | 205 | print_revision (progname, NP_VERSION); |
| 216 | exit (STATE_UNKNOWN); | 206 | exit (STATE_UNKNOWN); |
| 217 | case 'c': /* critical */ | 207 | case 'c': /* critical */ |
| 218 | if (!is_intnonneg (optarg)) | 208 | critical_range = optarg; |
| 219 | usage4 (_("Critical threshold must be a positive integer")); | ||
| 220 | else | ||
| 221 | cusers = atoi (optarg); | ||
| 222 | break; | 209 | break; |
| 223 | case 'w': /* warning */ | 210 | case 'w': /* warning */ |
| 224 | if (!is_intnonneg (optarg)) | 211 | warning_range = optarg; |
| 225 | usage4 (_("Warning threshold must be a positive integer")); | ||
| 226 | else | ||
| 227 | wusers = atoi (optarg); | ||
| 228 | break; | 212 | break; |
| 229 | } | 213 | } |
| 230 | } | 214 | } |
| 231 | 215 | ||
| 232 | c = optind; | 216 | c = optind; |
| 233 | if (wusers == -1 && argc > c) { | 217 | if (warning_range == NULL && argc > c) |
| 234 | if (is_intnonneg (argv[c]) == FALSE) | 218 | warning_range = argv[c++]; |
| 235 | usage4 (_("Warning threshold must be a positive integer")); | 219 | if (critical_range == NULL && argc > c) |
| 236 | else | 220 | critical_range = argv[c++]; |
| 237 | wusers = atoi (argv[c++]); | 221 | |
| 238 | } | 222 | /* this will abort in case of invalid ranges */ |
| 239 | if (cusers == -1 && argc > c) { | 223 | set_thresholds (&thlds, warning_range, critical_range); |
| 240 | if (is_intnonneg (argv[c]) == FALSE) | 224 | |
| 241 | usage4 (_("Warning threshold must be a positive integer")); | 225 | if (thlds->warning->end <= 0) |
| 242 | else | 226 | usage4 (_("Warning threshold must be a positive integer")); |
| 243 | cusers = atoi (argv[c]); | 227 | if (thlds->critical->end <= 0) |
| 244 | } | 228 | usage4 (_("Critical threshold must be a positive integer")); |
| 245 | 229 | ||
| 246 | return OK; | 230 | return OK; |
| 247 | } | 231 | } |
