summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--plugins/check_nt.c148
1 files changed, 111 insertions, 37 deletions
diff --git a/plugins/check_nt.c b/plugins/check_nt.c
index ef0a66b5..25645eaa 100644
--- a/plugins/check_nt.c
+++ b/plugins/check_nt.c
@@ -81,7 +81,8 @@ int main(int argc, char **argv){
81 char *perfdata=NULL; 81 char *perfdata=NULL;
82 char *temp_string=NULL; 82 char *temp_string=NULL;
83 char *temp_string_perf=NULL; 83 char *temp_string_perf=NULL;
84 char *description=NULL; 84 char *description=NULL,*counter_unit = NULL;
85 char *minval = NULL, *maxval = NULL, *errcvt = NULL;
85 86
86 double total_disk_space=0; 87 double total_disk_space=0;
87 double free_disk_space=0; 88 double free_disk_space=0;
@@ -90,6 +91,7 @@ int main(int argc, char **argv){
90 double critical_used_space=0; 91 double critical_used_space=0;
91 double mem_commitLimit=0; 92 double mem_commitLimit=0;
92 double mem_commitByte=0; 93 double mem_commitByte=0;
94 double fminval = 0, fmaxval = 0;
93 unsigned long utilization; 95 unsigned long utilization;
94 unsigned long uptime; 96 unsigned long uptime;
95 unsigned long age_in_minutes; 97 unsigned long age_in_minutes;
@@ -99,6 +101,9 @@ int main(int argc, char **argv){
99 int uphours=0; 101 int uphours=0;
100 int upminutes=0; 102 int upminutes=0;
101 103
104 int isPercent = FALSE;
105 int allRight = FALSE;
106
102 setlocale (LC_ALL, ""); 107 setlocale (LC_ALL, "");
103 bindtextdomain (PACKAGE, LOCALEDIR); 108 bindtextdomain (PACKAGE, LOCALEDIR);
104 textdomain (PACKAGE); 109 textdomain (PACKAGE);
@@ -252,12 +257,13 @@ int main(int argc, char **argv){
252 warning_used_space = ((float)warning_value / 100) * mem_commitLimit; 257 warning_used_space = ((float)warning_value / 100) * mem_commitLimit;
253 critical_used_space = ((float)critical_value / 100) * mem_commitLimit; 258 critical_used_space = ((float)critical_value / 100) * mem_commitLimit;
254 259
255 // Changed divisor in following line from 1048567 to 3044515 to accurately reflect memory size 260 /* Divisor should be 1048567, not 3044515, as we are measuring "Commit Charge" here,
261 which equals RAM + Pagefiles. */
256 asprintf(&output_message,_("Memory usage: total:%.2f Mb - used: %.2f Mb (%.0f%%) - free: %.2f Mb (%.0f%%)"), 262 asprintf(&output_message,_("Memory usage: total:%.2f Mb - used: %.2f Mb (%.0f%%) - free: %.2f Mb (%.0f%%)"),
257 mem_commitLimit / 3044515, mem_commitByte / 3044515, percent_used_space, 263 mem_commitLimit / 1048567, mem_commitByte / 1048567, percent_used_space,
258 (mem_commitLimit - mem_commitByte) / 3044515, (mem_commitLimit - mem_commitByte) / mem_commitLimit * 100); 264 (mem_commitLimit - mem_commitByte) / 1048567, (mem_commitLimit - mem_commitByte) / mem_commitLimit * 100);
259 asprintf(&perfdata,_("'Memory usage'=%.2fMb;%.2f;%.2f;0.00;%.2f"), mem_commitByte / 3044515, 265 asprintf(&perfdata,_("'Memory usage'=%.2fMb;%.2f;%.2f;0.00;%.2f"), mem_commitByte / 1048567,
260 warning_used_space / 3044515, critical_used_space / 3044515, mem_commitLimit / 3044515); 266 warning_used_space / 1048567, critical_used_space / 1048567, mem_commitLimit / 1048567);
261 267
262 return_code=STATE_OK; 268 return_code=STATE_OK;
263 if(check_critical_value==TRUE && percent_used_space >= critical_value) 269 if(check_critical_value==TRUE && percent_used_space >= critical_value)
@@ -269,40 +275,108 @@ int main(int argc, char **argv){
269 275
270 case CHECK_COUNTER: 276 case CHECK_COUNTER:
271 277
272 if (value_list==NULL)
273 output_message = strdup (_("No counter specified"));
274 else {
275 preparelist(value_list); /* replace , between services with & to send the request */
276 asprintf(&send_buffer,"%s&8&%s", req_password,value_list);
277 fetch_data (server_address, server_port, send_buffer);
278 strtok(value_list,"&"); /* burn the first parameters */
279 description = strtok(NULL,"&");
280 counter_value = atof(recv_buffer);
281 278
282 if (description == NULL) 279 /*
283 asprintf(&output_message, "%.f", counter_value); 280 CHECK_COUNTER has been modified to provide extensive perfdata information.
284 else 281 In order to do this, some modifications have been done to the code
285 asprintf(&output_message,"%s = %.f", description, counter_value); 282 and some constraints have been introduced.
286 asprintf(&perfdata,"'%s'=%.f", description, counter_value); 283
287 284 1) For the sake of simplicity of the code, perfdata information will only be
288 if (critical_value > warning_value) { /* Normal thresholds */ 285 provided when the "description" field is added.
289 if(check_critical_value==TRUE && counter_value >= critical_value) 286
290 return_code=STATE_CRITICAL; 287 2) If the counter you're going to measure is percent-based, the code will detect
291 else if (check_warning_value==TRUE && counter_value >= warning_value) 288 the percent sign in its name and will attribute minimum (0%) and maximum (100%)
292 return_code=STATE_WARNING; 289 values automagically, as well the �%" sign to graph units.
293 else 290
294 return_code=STATE_OK; 291 3) OTOH, if the counter is "absolute", you'll have to provide the following
295 } 292 the counter unit - that is, the dimensions of the counter you're getting. Examples:
296 else { /* inverse thresholds */ 293 pages/s, packets transferred, etc.
297 return_code=STATE_OK; 294
298 if(check_critical_value==TRUE && counter_value <= critical_value) 295 4) If you want, you may provide the minimum and maximum values to expect. They aren't mandatory,
299 return_code=STATE_CRITICAL; 296 but once specified they MUST have the same order of magnitude and units of -w and -c; otherwise.
300 else if (check_warning_value==TRUE && counter_value <= warning_value) 297 strange things will happen when you make graphs of your data.
301 return_code=STATE_WARNING; 298 */
302 } 299
300 if (value_list == NULL)
301 output_message = strdup (_("No counter specified"));
302 else
303 {
304 preparelist (value_list); /* replace , between services with & to send the request */
305 isPercent = (strchr (value_list, '%') != NULL);
306
307 strtok (value_list, "&"); /* burn the first parameters */
308 description = strtok (NULL, "&");
309 counter_unit = strtok (NULL, "&");
310 asprintf (&send_buffer, "%s&8&%s", req_password, value_list);
311 fetch_data (server_address, server_port, send_buffer);
312 counter_value = atof (recv_buffer);
313
314
315 if (description == NULL)
316 asprintf (&output_message, "%.f", counter_value);
317 else if (isPercent)
318 {
319 counter_unit = strdup (_("%"));
320 allRight = TRUE;
321 }
322
323 if ((counter_unit != NULL) && (!allRight))
324 {
325 minval = strtok (NULL, "&");
326 maxval = strtok (NULL, "&");
327
328 /* All parameters specified. Let's check the numbers */
329
330 fminval = (minval != NULL) ? strtod (minval, &errcvt) : -1;
331 fmaxval = (minval != NULL) ? strtod (maxval, &errcvt) : -1;
332
333 if ((fminval == 0) && (minval == errcvt))
334 output_message = strdup (_("Minimum value contains non-numbers"));
335 else
336 {
337 if ((fmaxval == 0) && (maxval == errcvt))
338 output_message = strdup (_("Maximum value contains non-numbers"));
339 else
340 allRight = TRUE; /* Everything is OK. */
341
342 }
343 }
344 else if ((counter_unit == NULL) && (description != NULL))
345 output_message = strdup (_("No unit counter specified"));
346
347 if (allRight)
348 {
349 /* Let's format the output string, finally... */
350
351 asprintf (&output_message, "%s = %.2f %s", description, counter_value, counter_unit);
352 output_message = strcat (output_message, "|");
353 output_message = strcat (output_message,
354 fperfdata (description, counter_value, counter_unit,
355 1, warning_value, 1, critical_value,
356 (!(isPercent) && (minval != NULL)), fminval,
357 (!(isPercent) && (minval != NULL)), fmaxval));
358 }
303 } 359 }
304 break;
305 360
361 if (critical_value > warning_value)
362 { /* Normal thresholds */
363 if (check_critical_value == TRUE && counter_value >= critical_value)
364 return_code = STATE_CRITICAL;
365 else if (check_warning_value == TRUE && counter_value >= warning_value)
366 return_code = STATE_WARNING;
367 else
368 return_code = STATE_OK;
369 }
370 else
371 { /* inverse thresholds */
372 return_code = STATE_OK;
373 if (check_critical_value == TRUE && counter_value <= critical_value)
374 return_code = STATE_CRITICAL;
375 else if (check_warning_value == TRUE && counter_value <= warning_value)
376 return_code = STATE_WARNING;
377 }
378 break;
379
306 case CHECK_FILEAGE: 380 case CHECK_FILEAGE:
307 381
308 if (value_list==NULL) 382 if (value_list==NULL)