diff options
Diffstat (limited to 'plugins/check_ups.c')
-rw-r--r-- | plugins/check_ups.c | 50 |
1 files changed, 42 insertions, 8 deletions
diff --git a/plugins/check_ups.c b/plugins/check_ups.c index d1ded620..2fb04eef 100644 --- a/plugins/check_ups.c +++ b/plugins/check_ups.c | |||
@@ -46,12 +46,13 @@ enum { | |||
46 | 46 | ||
47 | #define CHECK_NONE 0 | 47 | #define CHECK_NONE 0 |
48 | 48 | ||
49 | #define UPS_NONE 0 /* no supported options */ | 49 | #define UPS_NONE 0 /* no supported options */ |
50 | #define UPS_UTILITY 1 /* supports utility line voltage */ | 50 | #define UPS_UTILITY 1 /* supports utility line */ |
51 | #define UPS_BATTPCT 2 /* supports percent battery remaining */ | 51 | #define UPS_BATTPCT 2 /* supports percent battery remaining */ |
52 | #define UPS_STATUS 4 /* supports UPS status */ | 52 | #define UPS_STATUS 4 /* supports UPS status */ |
53 | #define UPS_TEMP 8 /* supports UPS temperature */ | 53 | #define UPS_TEMP 8 /* supports UPS temperature */ |
54 | #define UPS_LOADPCT 16 /* supports load percent */ | 54 | #define UPS_LOADPCT 16 /* supports load percent */ |
55 | #define UPS_REALPOWER 32 /* supports real power */ | ||
55 | 56 | ||
56 | #define UPSSTATUS_NONE 0 | 57 | #define UPSSTATUS_NONE 0 |
57 | #define UPSSTATUS_OFF 1 | 58 | #define UPSSTATUS_OFF 1 |
@@ -85,6 +86,7 @@ double ups_utility_voltage = 0.0; | |||
85 | double ups_battery_percent = 0.0; | 86 | double ups_battery_percent = 0.0; |
86 | double ups_load_percent = 0.0; | 87 | double ups_load_percent = 0.0; |
87 | double ups_temperature = 0.0; | 88 | double ups_temperature = 0.0; |
89 | double ups_realpower = 0.0; | ||
88 | char *ups_status; | 90 | char *ups_status; |
89 | bool temp_output_c = false; | 91 | bool temp_output_c = false; |
90 | 92 | ||
@@ -318,6 +320,35 @@ main (int argc, char **argv) | |||
318 | } | 320 | } |
319 | } | 321 | } |
320 | 322 | ||
323 | /* get the ups real power if possible */ | ||
324 | res=get_ups_variable ("ups.realpower", temp_buffer); | ||
325 | if ( res == NOSUCHVAR ) supported_options &= ~UPS_REALPOWER; | ||
326 | else if ( res != OK) | ||
327 | return STATE_CRITICAL; | ||
328 | else { | ||
329 | supported_options |= UPS_REALPOWER; | ||
330 | ups_realpower = atof (temp_buffer); | ||
331 | xasprintf (&message, "%sReal power=%3.1fW ", message, ups_realpower); | ||
332 | |||
333 | if (check_variable == UPS_REALPOWER) { | ||
334 | if (check_crit && ups_realpower>=critical_value) { | ||
335 | result = STATE_CRITICAL; | ||
336 | } | ||
337 | else if (check_warn && ups_realpower>=warning_value) { | ||
338 | result = max_state (result, STATE_WARNING); | ||
339 | } | ||
340 | xasprintf (&data, "%s %s", data, | ||
341 | perfdata ("realpower", (long)ups_realpower, "W", | ||
342 | check_warn, (long)(warning_value), | ||
343 | check_crit, (long)(critical_value), | ||
344 | true, 0, false, 0)); | ||
345 | } else { | ||
346 | xasprintf (&data, "%s %s", data, | ||
347 | perfdata ("realpower", (long)ups_realpower, "W", | ||
348 | false, 0, false, 0, true, 0, false, 0)); | ||
349 | } | ||
350 | } | ||
351 | |||
321 | /* if the UPS does not support any options we are looking for, report an error */ | 352 | /* if the UPS does not support any options we are looking for, report an error */ |
322 | if (supported_options == UPS_NONE) { | 353 | if (supported_options == UPS_NONE) { |
323 | result = STATE_CRITICAL; | 354 | result = STATE_CRITICAL; |
@@ -402,7 +433,8 @@ get_ups_variable (const char *varname, char *buf) | |||
402 | 433 | ||
403 | /* create the command string to send to the UPS daemon */ | 434 | /* create the command string to send to the UPS daemon */ |
404 | /* Add LOGOUT to avoid read failure logs */ | 435 | /* Add LOGOUT to avoid read failure logs */ |
405 | if (snprintf (send_buffer, sizeof(send_buffer), "GET VAR %s %s\nLOGOUT\n", ups_name, varname) >= sizeof(send_buffer)) { | 436 | int res = snprintf (send_buffer, sizeof(send_buffer), "GET VAR %s %s\nLOGOUT\n", ups_name, varname); |
437 | if ( (res > 0) && ((size_t)res >= sizeof(send_buffer))) { | ||
406 | printf("%s\n", _("UPS name to long for buffer")); | 438 | printf("%s\n", _("UPS name to long for buffer")); |
407 | return ERROR; | 439 | return ERROR; |
408 | } | 440 | } |
@@ -548,6 +580,8 @@ process_arguments (int argc, char **argv) | |||
548 | check_variable = UPS_BATTPCT; | 580 | check_variable = UPS_BATTPCT; |
549 | else if (!strcmp (optarg, "LOADPCT")) | 581 | else if (!strcmp (optarg, "LOADPCT")) |
550 | check_variable = UPS_LOADPCT; | 582 | check_variable = UPS_LOADPCT; |
583 | else if (!strcmp (optarg, "REALPOWER")) | ||
584 | check_variable = UPS_REALPOWER; | ||
551 | else | 585 | else |
552 | usage2 (_("Unrecognized UPS variable"), optarg); | 586 | usage2 (_("Unrecognized UPS variable"), optarg); |
553 | break; | 587 | break; |
@@ -624,7 +658,7 @@ print_help (void) | |||
624 | printf (" %s\n", "-T, --temperature"); | 658 | printf (" %s\n", "-T, --temperature"); |
625 | printf (" %s\n", _("Output of temperatures in Celsius")); | 659 | printf (" %s\n", _("Output of temperatures in Celsius")); |
626 | printf (" %s\n", "-v, --variable=STRING"); | 660 | printf (" %s\n", "-v, --variable=STRING"); |
627 | printf (" %s %s\n", _("Valid values for STRING are"), "LINE, TEMP, BATTPCT or LOADPCT"); | 661 | printf (" %s %s\n", _("Valid values for STRING are"), "LINE, TEMP, BATTPCT, LOADPCT or REALPOWER"); |
628 | 662 | ||
629 | printf (UT_WARN_CRIT); | 663 | printf (UT_WARN_CRIT); |
630 | 664 | ||