diff options
author | Lorenz Kästle <lorenz.kaestle@netways.de> | 2024-10-30 17:07:04 +0100 |
---|---|---|
committer | Lorenz Kästle <lorenz.kaestle@netways.de> | 2024-10-30 17:07:04 +0100 |
commit | 3f1db8dc3a0a5233d338fd6bd5e80971bfb21545 (patch) | |
tree | 4d5d29d32b4d66a9371c4c19eb5b225a5e7a692e /plugins/check_ups.c | |
parent | aa1f9c50118d63f7229523655a1fab28fd0eab24 (diff) | |
parent | 6b20391ff3cfe0e69539238ade2c62dfce209fc0 (diff) | |
download | monitoring-plugins-3f1db8d.tar.gz |
Merge branch 'master' into cleanup/check_icmp
Diffstat (limited to 'plugins/check_ups.c')
-rw-r--r-- | plugins/check_ups.c | 106 |
1 files changed, 33 insertions, 73 deletions
diff --git a/plugins/check_ups.c b/plugins/check_ups.c index 380ff3bc..f60c0e9e 100644 --- a/plugins/check_ups.c +++ b/plugins/check_ups.c | |||
@@ -6,7 +6,7 @@ | |||
6 | * Copyright (c) 2000 Tom Shields | 6 | * Copyright (c) 2000 Tom Shields |
7 | * 2004 Alain Richard <alain.richard@equation.fr> | 7 | * 2004 Alain Richard <alain.richard@equation.fr> |
8 | * 2004 Arnaud Quette <arnaud.quette@mgeups.com> | 8 | * 2004 Arnaud Quette <arnaud.quette@mgeups.com> |
9 | * Copyright (c) 2002-2023 Monitoring Plugins Development Team | 9 | * Copyright (c) 2002-2024 Monitoring Plugins Development Team |
10 | * | 10 | * |
11 | * Description: | 11 | * Description: |
12 | * | 12 | * |
@@ -33,7 +33,7 @@ | |||
33 | *****************************************************************************/ | 33 | *****************************************************************************/ |
34 | 34 | ||
35 | const char *progname = "check_ups"; | 35 | const char *progname = "check_ups"; |
36 | const char *copyright = "2000-2023"; | 36 | const char *copyright = "2000-2024"; |
37 | const char *email = "devel@monitoring-plugins.org"; | 37 | const char *email = "devel@monitoring-plugins.org"; |
38 | 38 | ||
39 | #include "common.h" | 39 | #include "common.h" |
@@ -141,7 +141,6 @@ int main(int argc, char **argv) { | |||
141 | return STATE_CRITICAL; | 141 | return STATE_CRITICAL; |
142 | } | 142 | } |
143 | 143 | ||
144 | |||
145 | if (supported_options & UPS_STATUS) { | 144 | if (supported_options & UPS_STATUS) { |
146 | 145 | ||
147 | ups_status = strdup(""); | 146 | ups_status = strdup(""); |
@@ -151,8 +150,7 @@ int main(int argc, char **argv) { | |||
151 | if (config.status & UPSSTATUS_OFF) { | 150 | if (config.status & UPSSTATUS_OFF) { |
152 | xasprintf(&ups_status, "Off"); | 151 | xasprintf(&ups_status, "Off"); |
153 | result = STATE_CRITICAL; | 152 | result = STATE_CRITICAL; |
154 | } else if ((config.status & (UPSSTATUS_OB | UPSSTATUS_LB)) == | 153 | } else if ((config.status & (UPSSTATUS_OB | UPSSTATUS_LB)) == (UPSSTATUS_OB | UPSSTATUS_LB)) { |
155 | (UPSSTATUS_OB | UPSSTATUS_LB)) { | ||
156 | xasprintf(&ups_status, _("On Battery, Low Battery")); | 154 | xasprintf(&ups_status, _("On Battery, Low Battery")); |
157 | result = STATE_CRITICAL; | 155 | result = STATE_CRITICAL; |
158 | } else { | 156 | } else { |
@@ -171,8 +169,7 @@ int main(int argc, char **argv) { | |||
171 | xasprintf(&ups_status, "%s%s", ups_status, _(", Calibrating")); | 169 | xasprintf(&ups_status, "%s%s", ups_status, _(", Calibrating")); |
172 | } | 170 | } |
173 | if (config.status & UPSSTATUS_RB) { | 171 | if (config.status & UPSSTATUS_RB) { |
174 | xasprintf(&ups_status, "%s%s", ups_status, | 172 | xasprintf(&ups_status, "%s%s", ups_status, _(", Replace Battery")); |
175 | _(", Replace Battery")); | ||
176 | result = max_state(result, STATE_WARNING); | 173 | result = max_state(result, STATE_WARNING); |
177 | } | 174 | } |
178 | if (config.status & UPSSTATUS_BYPASS) { | 175 | if (config.status & UPSSTATUS_BYPASS) { |
@@ -233,24 +230,16 @@ int main(int argc, char **argv) { | |||
233 | } | 230 | } |
234 | 231 | ||
235 | if (config.check_variable == UPS_UTILITY) { | 232 | if (config.check_variable == UPS_UTILITY) { |
236 | if (config.check_crit && | 233 | if (config.check_crit && ups_utility_deviation >= config.critical_value) { |
237 | ups_utility_deviation >= config.critical_value) { | ||
238 | result = STATE_CRITICAL; | 234 | result = STATE_CRITICAL; |
239 | } else if (config.check_warn && | 235 | } else if (config.check_warn && ups_utility_deviation >= config.warning_value) { |
240 | ups_utility_deviation >= config.warning_value) { | ||
241 | result = max_state(result, STATE_WARNING); | 236 | result = max_state(result, STATE_WARNING); |
242 | } | 237 | } |
243 | xasprintf(&data, "%s", | 238 | xasprintf(&data, "%s", |
244 | perfdata("voltage", (long)(1000 * ups_utility_voltage), | 239 | perfdata("voltage", (long)(1000 * ups_utility_voltage), "mV", config.check_warn, (long)(1000 * config.warning_value), |
245 | "mV", config.check_warn, | 240 | config.check_crit, (long)(1000 * config.critical_value), true, 0, false, 0)); |
246 | (long)(1000 * config.warning_value), | ||
247 | config.check_crit, | ||
248 | (long)(1000 * config.critical_value), true, 0, | ||
249 | false, 0)); | ||
250 | } else { | 241 | } else { |
251 | xasprintf(&data, "%s", | 242 | xasprintf(&data, "%s", perfdata("voltage", (long)(1000 * ups_utility_voltage), "mV", false, 0, false, 0, true, 0, false, 0)); |
252 | perfdata("voltage", (long)(1000 * ups_utility_voltage), | ||
253 | "mV", false, 0, false, 0, true, 0, false, 0)); | ||
254 | } | 243 | } |
255 | } | 244 | } |
256 | 245 | ||
@@ -268,22 +257,16 @@ int main(int argc, char **argv) { | |||
268 | xasprintf(&message, "%sBatt=%3.1f%% ", message, ups_battery_percent); | 257 | xasprintf(&message, "%sBatt=%3.1f%% ", message, ups_battery_percent); |
269 | 258 | ||
270 | if (config.check_variable == UPS_BATTPCT) { | 259 | if (config.check_variable == UPS_BATTPCT) { |
271 | if (config.check_crit && | 260 | if (config.check_crit && ups_battery_percent <= config.critical_value) { |
272 | ups_battery_percent <= config.critical_value) { | ||
273 | result = STATE_CRITICAL; | 261 | result = STATE_CRITICAL; |
274 | } else if (config.check_warn && | 262 | } else if (config.check_warn && ups_battery_percent <= config.warning_value) { |
275 | ups_battery_percent <= config.warning_value) { | ||
276 | result = max_state(result, STATE_WARNING); | 263 | result = max_state(result, STATE_WARNING); |
277 | } | 264 | } |
278 | xasprintf(&data, "%s %s", data, | 265 | xasprintf(&data, "%s %s", data, |
279 | perfdata("battery", (long)ups_battery_percent, "%", | 266 | perfdata("battery", (long)ups_battery_percent, "%", config.check_warn, (long)(config.warning_value), |
280 | config.check_warn, (long)(config.warning_value), | 267 | config.check_crit, (long)(config.critical_value), true, 0, true, 100)); |
281 | config.check_crit, (long)(config.critical_value), | ||
282 | true, 0, true, 100)); | ||
283 | } else { | 268 | } else { |
284 | xasprintf(&data, "%s %s", data, | 269 | xasprintf(&data, "%s %s", data, perfdata("battery", (long)ups_battery_percent, "%", false, 0, false, 0, true, 0, true, 100)); |
285 | perfdata("battery", (long)ups_battery_percent, "%", false, | ||
286 | 0, false, 0, true, 0, true, 100)); | ||
287 | } | 270 | } |
288 | } | 271 | } |
289 | 272 | ||
@@ -301,22 +284,16 @@ int main(int argc, char **argv) { | |||
301 | xasprintf(&message, "%sLoad=%3.1f%% ", message, ups_load_percent); | 284 | xasprintf(&message, "%sLoad=%3.1f%% ", message, ups_load_percent); |
302 | 285 | ||
303 | if (config.check_variable == UPS_LOADPCT) { | 286 | if (config.check_variable == UPS_LOADPCT) { |
304 | if (config.check_crit && | 287 | if (config.check_crit && ups_load_percent >= config.critical_value) { |
305 | ups_load_percent >= config.critical_value) { | ||
306 | result = STATE_CRITICAL; | 288 | result = STATE_CRITICAL; |
307 | } else if (config.check_warn && | 289 | } else if (config.check_warn && ups_load_percent >= config.warning_value) { |
308 | ups_load_percent >= config.warning_value) { | ||
309 | result = max_state(result, STATE_WARNING); | 290 | result = max_state(result, STATE_WARNING); |
310 | } | 291 | } |
311 | xasprintf(&data, "%s %s", data, | 292 | xasprintf(&data, "%s %s", data, |
312 | perfdata("load", (long)ups_load_percent, "%", | 293 | perfdata("load", (long)ups_load_percent, "%", config.check_warn, (long)(config.warning_value), config.check_crit, |
313 | config.check_warn, (long)(config.warning_value), | 294 | (long)(config.critical_value), true, 0, true, 100)); |
314 | config.check_crit, (long)(config.critical_value), | ||
315 | true, 0, true, 100)); | ||
316 | } else { | 295 | } else { |
317 | xasprintf(&data, "%s %s", data, | 296 | xasprintf(&data, "%s %s", data, perfdata("load", (long)ups_load_percent, "%", false, 0, false, 0, true, 0, true, 100)); |
318 | perfdata("load", (long)ups_load_percent, "%", false, 0, | ||
319 | false, 0, true, 0, true, 100)); | ||
320 | } | 297 | } |
321 | } | 298 | } |
322 | 299 | ||
@@ -345,19 +322,14 @@ int main(int argc, char **argv) { | |||
345 | if (config.check_variable == UPS_TEMP) { | 322 | if (config.check_variable == UPS_TEMP) { |
346 | if (config.check_crit && ups_temperature >= config.critical_value) { | 323 | if (config.check_crit && ups_temperature >= config.critical_value) { |
347 | result = STATE_CRITICAL; | 324 | result = STATE_CRITICAL; |
348 | } else if (config.check_warn && | 325 | } else if (config.check_warn && ups_temperature >= config.warning_value) { |
349 | ups_temperature >= config.warning_value) { | ||
350 | result = max_state(result, STATE_WARNING); | 326 | result = max_state(result, STATE_WARNING); |
351 | } | 327 | } |
352 | xasprintf(&data, "%s %s", data, | 328 | xasprintf(&data, "%s %s", data, |
353 | perfdata("temp", (long)ups_temperature, tunits, | 329 | perfdata("temp", (long)ups_temperature, tunits, config.check_warn, (long)(config.warning_value), config.check_crit, |
354 | config.check_warn, (long)(config.warning_value), | 330 | (long)(config.critical_value), true, 0, false, 0)); |
355 | config.check_crit, (long)(config.critical_value), | ||
356 | true, 0, false, 0)); | ||
357 | } else { | 331 | } else { |
358 | xasprintf(&data, "%s %s", data, | 332 | xasprintf(&data, "%s %s", data, perfdata("temp", (long)ups_temperature, tunits, false, 0, false, 0, true, 0, false, 0)); |
359 | perfdata("temp", (long)ups_temperature, tunits, false, 0, | ||
360 | false, 0, true, 0, false, 0)); | ||
361 | } | 333 | } |
362 | } | 334 | } |
363 | 335 | ||
@@ -376,19 +348,14 @@ int main(int argc, char **argv) { | |||
376 | if (config.check_variable == UPS_REALPOWER) { | 348 | if (config.check_variable == UPS_REALPOWER) { |
377 | if (config.check_crit && ups_realpower >= config.critical_value) { | 349 | if (config.check_crit && ups_realpower >= config.critical_value) { |
378 | result = STATE_CRITICAL; | 350 | result = STATE_CRITICAL; |
379 | } else if (config.check_warn && | 351 | } else if (config.check_warn && ups_realpower >= config.warning_value) { |
380 | ups_realpower >= config.warning_value) { | ||
381 | result = max_state(result, STATE_WARNING); | 352 | result = max_state(result, STATE_WARNING); |
382 | } | 353 | } |
383 | xasprintf(&data, "%s %s", data, | 354 | xasprintf(&data, "%s %s", data, |
384 | perfdata("realpower", (long)ups_realpower, "W", | 355 | perfdata("realpower", (long)ups_realpower, "W", config.check_warn, (long)(config.warning_value), config.check_crit, |
385 | config.check_warn, (long)(config.warning_value), | 356 | (long)(config.critical_value), true, 0, false, 0)); |
386 | config.check_crit, (long)(config.critical_value), | ||
387 | true, 0, false, 0)); | ||
388 | } else { | 357 | } else { |
389 | xasprintf(&data, "%s %s", data, | 358 | xasprintf(&data, "%s %s", data, perfdata("realpower", (long)ups_realpower, "W", false, 0, false, 0, true, 0, false, 0)); |
390 | perfdata("realpower", (long)ups_realpower, "W", false, 0, | ||
391 | false, 0, true, 0, false, 0)); | ||
392 | } | 359 | } |
393 | } | 360 | } |
394 | 361 | ||
@@ -425,8 +392,7 @@ int determine_status(ups_config *config, int *supported_options) { | |||
425 | char temp_buffer[MAX_INPUT_BUFFER]; | 392 | char temp_buffer[MAX_INPUT_BUFFER]; |
426 | 393 | ||
427 | strcpy(temp_buffer, recv_buffer); | 394 | strcpy(temp_buffer, recv_buffer); |
428 | for (char *ptr = (char *)strtok(temp_buffer, " "); ptr != NULL; | 395 | for (char *ptr = (char *)strtok(temp_buffer, " "); ptr != NULL; ptr = (char *)strtok(NULL, " ")) { |
429 | ptr = (char *)strtok(NULL, " ")) { | ||
430 | if (!strcmp(ptr, "OFF")) { | 396 | if (!strcmp(ptr, "OFF")) { |
431 | config->status |= UPSSTATUS_OFF; | 397 | config->status |= UPSSTATUS_OFF; |
432 | } else if (!strcmp(ptr, "OL")) { | 398 | } else if (!strcmp(ptr, "OL")) { |
@@ -467,8 +433,7 @@ int get_ups_variable(const char *varname, char *buf, const ups_config config) { | |||
467 | 433 | ||
468 | /* create the command string to send to the UPS daemon */ | 434 | /* create the command string to send to the UPS daemon */ |
469 | /* Add LOGOUT to avoid read failure logs */ | 435 | /* Add LOGOUT to avoid read failure logs */ |
470 | int res = snprintf(send_buffer, sizeof(send_buffer), | 436 | int res = snprintf(send_buffer, sizeof(send_buffer), "GET VAR %s %s\nLOGOUT\n", config.ups_name, varname); |
471 | "GET VAR %s %s\nLOGOUT\n", config.ups_name, varname); | ||
472 | if ((res > 0) && ((size_t)res >= sizeof(send_buffer))) { | 437 | if ((res > 0) && ((size_t)res >= sizeof(send_buffer))) { |
473 | printf("%s\n", _("UPS name to long for buffer")); | 438 | printf("%s\n", _("UPS name to long for buffer")); |
474 | return ERROR; | 439 | return ERROR; |
@@ -477,9 +442,7 @@ int get_ups_variable(const char *varname, char *buf, const ups_config config) { | |||
477 | char temp_buffer[MAX_INPUT_BUFFER]; | 442 | char temp_buffer[MAX_INPUT_BUFFER]; |
478 | 443 | ||
479 | /* send the command to the daemon and get a response back */ | 444 | /* send the command to the daemon and get a response back */ |
480 | if (process_tcp_request(config.server_address, config.server_port, | 445 | if (process_tcp_request(config.server_address, config.server_port, send_buffer, temp_buffer, sizeof(temp_buffer)) != STATE_OK) { |
481 | send_buffer, temp_buffer, | ||
482 | sizeof(temp_buffer)) != STATE_OK) { | ||
483 | printf("%s\n", _("Invalid response received from host")); | 446 | printf("%s\n", _("Invalid response received from host")); |
484 | return ERROR; | 447 | return ERROR; |
485 | } | 448 | } |
@@ -496,8 +459,7 @@ int get_ups_variable(const char *varname, char *buf, const ups_config config) { | |||
496 | ptr[len - 1] = 0; | 459 | ptr[len - 1] = 0; |
497 | } | 460 | } |
498 | if (strcmp(ptr, "ERR UNKNOWN-UPS") == 0) { | 461 | if (strcmp(ptr, "ERR UNKNOWN-UPS") == 0) { |
499 | printf(_("CRITICAL - no such UPS '%s' on that host\n"), | 462 | printf(_("CRITICAL - no such UPS '%s' on that host\n"), config.ups_name); |
500 | config.ups_name); | ||
501 | return ERROR; | 463 | return ERROR; |
502 | } | 464 | } |
503 | 465 | ||
@@ -694,8 +656,7 @@ void print_help(void) { | |||
694 | printf(" %s\n", "-T, --temperature"); | 656 | printf(" %s\n", "-T, --temperature"); |
695 | printf(" %s\n", _("Output of temperatures in Celsius")); | 657 | printf(" %s\n", _("Output of temperatures in Celsius")); |
696 | printf(" %s\n", "-v, --variable=STRING"); | 658 | printf(" %s\n", "-v, --variable=STRING"); |
697 | printf(" %s %s\n", _("Valid values for STRING are"), | 659 | printf(" %s %s\n", _("Valid values for STRING are"), "LINE, TEMP, BATTPCT, LOADPCT or REALPOWER"); |
698 | "LINE, TEMP, BATTPCT, LOADPCT or REALPOWER"); | ||
699 | 660 | ||
700 | printf(UT_WARN_CRIT); | 661 | printf(UT_WARN_CRIT); |
701 | 662 | ||
@@ -731,8 +692,7 @@ void print_help(void) { | |||
731 | "with Russell Kroll's")); | 692 | "with Russell Kroll's")); |
732 | printf(" %s\n", _("Network UPS Tools be installed on the remote host. If " | 693 | printf(" %s\n", _("Network UPS Tools be installed on the remote host. If " |
733 | "you do not have the")); | 694 | "you do not have the")); |
734 | printf(" %s\n", | 695 | printf(" %s\n", _("package installed on your system, you can download it from")); |
735 | _("package installed on your system, you can download it from")); | ||
736 | printf(" %s\n", _("http://www.networkupstools.org")); | 696 | printf(" %s\n", _("http://www.networkupstools.org")); |
737 | 697 | ||
738 | printf(UT_SUPPORT); | 698 | printf(UT_SUPPORT); |