Code

fix for (tracker id 1420741)
[nagiosplug.git] / plugins / check_ups.c
index e974b7534576799b3e1c7045b84359ba35843ca9..786cedcc1bc2ef02a5fa12b707efd8e6bbc340d8 100644 (file)
 
 const char *progname = "check_ups";
 const char *revision = "$Revision$";
-const char *copyright = "2000-2002";
+const char *copyright = "2000-2004";
 const char *email = "nagiosplug-devel@lists.sourceforge.net";
 
-#include <locale.h>
 #include "common.h"
 #include "netutils.h"
 #include "utils.h"
@@ -96,9 +95,10 @@ void print_usage (void);
 int
 main (int argc, char **argv)
 {
-       int result = STATE_OK;
+       int result = STATE_UNKNOWN;
        char *message;
        char *data;
+       char *tunits;
        char temp_buffer[MAX_INPUT_BUFFER];
        double ups_utility_deviation = 0.0;
        int res;
@@ -111,7 +111,7 @@ main (int argc, char **argv)
        data = strdup ("");
        message = strdup ("");
 
-       if (process_arguments (argc, argv) != TRUE)
+       if (process_arguments (argc, argv) == ERROR)
                usage4 (_("Could not parse arguments"));
 
        /* initialize alarm signal handling */
@@ -134,48 +134,48 @@ main (int argc, char **argv)
                }
                else if ((status & (UPSSTATUS_OB | UPSSTATUS_LB)) ==
                                                 (UPSSTATUS_OB | UPSSTATUS_LB)) {
-                       asprintf (&ups_status, "On Battery, Low Battery");
+                       asprintf (&ups_status, _("On Battery, Low Battery"));
                        result = STATE_CRITICAL;
                }
                else {
                        if (status & UPSSTATUS_OL) {
-                               asprintf (&ups_status, "%s%s", ups_status, "Online");
+                               asprintf (&ups_status, "%s%s", ups_status, _("Online"));
                        }
                        if (status & UPSSTATUS_OB) {
-                               asprintf (&ups_status, "%s%s", ups_status, "On Battery");
+                               asprintf (&ups_status, "%s%s", ups_status, _("On Battery"));
                                result = STATE_WARNING;
                        }
                        if (status & UPSSTATUS_LB) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Low Battery");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Low Battery"));
                                result = STATE_WARNING;
                        }
                        if (status & UPSSTATUS_CAL) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Calibrating");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Calibrating"));
                        }
                        if (status & UPSSTATUS_RB) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Replace Battery");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Replace Battery"));
                                result = STATE_WARNING;
                        }
                        if (status & UPSSTATUS_BYPASS) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", On Bypass");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", On Bypass"));
                        }
                        if (status & UPSSTATUS_OVER) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Overload");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Overload"));
                        }
                        if (status & UPSSTATUS_TRIM) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Trimming");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Trimming"));
                        }
                        if (status & UPSSTATUS_BOOST) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Boosting");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Boosting"));
                        }
                        if (status & UPSSTATUS_CHRG) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Charging");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Charging"));
                        }
                        if (status & UPSSTATUS_DISCHRG) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Discharging");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Discharging"));
                        }
                        if (status & UPSSTATUS_UNKOWN) {
-                               asprintf (&ups_status, "%s%s", ups_status, ", Unknown");
+                               asprintf (&ups_status, "%s%s", ups_status, _(", Unknown"));
                        }
                }
                asprintf (&message, "%sStatus=%s ", message, ups_status);
@@ -282,10 +282,12 @@ main (int argc, char **argv)
        else {
                supported_options |= UPS_TEMP;
                if (temp_output_c) {
+                 tunits="degC";
                  ups_temperature = atof (temp_buffer);
                  asprintf (&message, "%sTemp=%3.1fC", message, ups_temperature);
                }
                else {
+                 tunits="degF";
                  ups_temperature = (atof (temp_buffer) * 1.8) + 32;
                  asprintf (&message, "%sTemp=%3.1fF", message, ups_temperature);
                }
@@ -298,13 +300,13 @@ main (int argc, char **argv)
                                result = max_state (result, STATE_WARNING);
                        }
                        asprintf (&data, "%s %s", data,
-                                 perfdata ("temp", (long)ups_temperature, "degF",
+                                 perfdata ("temp", (long)ups_temperature, tunits,
                                            check_warn, (long)(1000*warning_value),
                                            check_crit, (long)(1000*critical_value),
                                            TRUE, 0, FALSE, 0));
                } else {
                        asprintf (&data, "%s %s", data,
-                                 perfdata ("temp", (long)ups_temperature, "degF",
+                                 perfdata ("temp", (long)ups_temperature, tunits,
                                            FALSE, 0, FALSE, 0, TRUE, 0, FALSE, 0));
                }
        }
@@ -312,7 +314,7 @@ main (int argc, char **argv)
        /* if the UPS does not support any options we are looking for, report an error */
        if (supported_options == UPS_NONE) {
                result = STATE_CRITICAL;
-               asprintf (&message, "UPS does not support any available options\n");
+               asprintf (&message, _("UPS does not support any available options\n"));
        }
 
        /* reset timeout */
@@ -336,7 +338,7 @@ determine_status (void)
        res=get_ups_variable ("ups.status", recv_buffer, sizeof (recv_buffer));
        if (res == NOSUCHVAR) return OK;
        if (res != STATE_OK) {
-               printf ("Invalid response received from host\n");
+               printf (_("Invalid response received from host\n"));
                return ERROR;
        }
 
@@ -396,7 +398,7 @@ get_ups_variable (const char *varname, char *buf, size_t buflen)
        if (process_tcp_request
                        (server_address, server_port, send_buffer, temp_buffer,
                         sizeof (temp_buffer)) != STATE_OK) {
-               printf ("Invalid response received from host\n");
+               printf (_("Invalid response received from host\n"));
                return ERROR;
        }
 
@@ -404,29 +406,29 @@ get_ups_variable (const char *varname, char *buf, size_t buflen)
        len = strlen(ptr);
        if (len > 0 && ptr[len-1] == '\n') ptr[len-1]=0;
        if (strcmp (ptr, "ERR UNKNOWN-UPS") == 0) {
-               printf ("CRITICAL - no such ups '%s' on that host\n", ups_name);
+               printf (_("CRITICAL - no such ups '%s' on that host\n"), ups_name);
                return ERROR;
        }
 
        if (strcmp (ptr, "ERR VAR-NOT-SUPPORTED") == 0) {
-               //printf ("Error: Variable '%s' is not supported\n", varname);
+               /*printf ("Error: Variable '%s' is not supported\n", varname);*/
                return NOSUCHVAR;
        }
 
        if (strcmp (ptr, "ERR DATA-STALE") == 0) {
-               printf ("CRITICAL - UPS data is stale\n");
+               printf (_("CRITICAL - UPS data is stale\n"));
                return ERROR;
        }
 
        if (strncmp (ptr, "ERR", 3) == 0) {
-               printf ("Unknown error: %s\n", ptr);
+               printf (_("Unknown error: %s\n"), ptr);
                return ERROR;
        }
 
        ptr = temp_buffer + strlen (varname) + strlen (ups_name) + 6;
        len = strlen(ptr);
        if (len < 2 || ptr[0] != '"' || ptr[len-1] != '"') {
-               printf ("Error: unable to parse variable\n");
+               printf (_("Error: unable to parse variable\n"));
                return ERROR;
        }
        strncpy (buf, ptr+1, len - 2);
@@ -482,9 +484,7 @@ process_arguments (int argc, char **argv)
 
                switch (c) {
                case '?':                                                                       /* help */
-                       printf (_("%s: Unknown argument: %s\n\n"), progname, optarg);
-                       print_usage ();
-                       exit (STATE_UNKNOWN);
+                       usage2 (_("Unknown argument"), optarg);
                case 'H':                                                                       /* hostname */
                        if (is_host (optarg)) {
                                server_address = optarg;
@@ -504,7 +504,7 @@ process_arguments (int argc, char **argv)
                                server_port = atoi (optarg);
                        }
                        else {
-                               usage2 ("Port must be a positive integer", optarg);
+                               usage2 (_("Port must be a positive integer"), optarg);
                        }
                        break;
                case 'c':                                                                       /* critical time threshold */
@@ -513,7 +513,7 @@ process_arguments (int argc, char **argv)
                                check_crit = TRUE;
                        }
                        else {
-                               usage2 ("Critical time must be a positive integer", optarg);
+                               usage2 (_("Critical time must be a positive integer"), optarg);
                        }
                        break;
                case 'w':                                                                       /* warning time threshold */
@@ -522,7 +522,7 @@ process_arguments (int argc, char **argv)
                                check_warn = TRUE;
                        }
                        else {
-                               usage2 ("Warning time must be a positive integer", optarg);
+                               usage2 (_("Warning time must be a positive integer"), optarg);
                        }
                        break;
                case 'v':                                                                       /* variable */
@@ -535,14 +535,14 @@ process_arguments (int argc, char **argv)
                        else if (!strcmp (optarg, "LOADPCT"))
                                check_variable = UPS_LOADPCT;
                        else
-                               usage2 ("Unrecognized UPS variable", optarg);
+                               usage2 (_("Unrecognized UPS variable"), optarg);
                        break;
                case 't':                                                                       /* timeout */
                        if (is_intnonneg (optarg)) {
                                socket_timeout = atoi (optarg);
                        }
                        else {
-                               usage ("Time interval must be a positive integer\n");
+                               usage4 (_("Timeout interval must be a positive integer"));
                        }
                        break;
                case 'V':                                                                       /* version */
@@ -569,19 +569,17 @@ process_arguments (int argc, char **argv)
 }
 
 
-
 int
 validate_arguments (void)
 {
        if (! ups_name) {
-               printf ("Error : no ups indicated\n");
+               printf (_("Error : no ups indicated\n"));
                return ERROR;
        }
        return OK;
 }
 
 
-
 void
 print_help (void)
 {
@@ -593,7 +591,6 @@ print_help (void)
        printf ("Copyright (c) 2000 Tom Shields");
        printf ("Copyright (c) 2004 Alain Richard <alain.richard@equation.fr>\n");
        printf ("Copyright (c) 2004 Arnaud Quette <arnaud.quette@mgeups.com>\n");
-
        printf (COPYRIGHT, copyright, email);
 
        printf (_("This plugin tests the UPS service on the specified host.\n\
@@ -643,12 +640,10 @@ http://www.networkupstools.org\n\n"));
 }
 
 
-
 void
 print_usage (void)
 {
-       printf (_("\
+       printf ("\
 Usage: %s -H host -u ups [-p port] [-v variable]\n\
-  [-wv warn_value] [-cv crit_value] [-to to_sec] [-T]\n"), progname);
-       printf (_(UT_HLP_VRS), progname, progname);
+                  [-wv warn_value] [-cv crit_value] [-to to_sec] [-T]\n", progname);
 }