diff options
| -rw-r--r-- | plugins/check_nt.c | 170 | ||||
| -rw-r--r-- | plugins/check_smtp.c | 188 | 
2 files changed, 186 insertions, 172 deletions
| diff --git a/plugins/check_nt.c b/plugins/check_nt.c index 85c67531..91022bac 100644 --- a/plugins/check_nt.c +++ b/plugins/check_nt.c | |||
| @@ -64,9 +64,10 @@ int show_all=FALSE; | |||
| 64 | const char *progname = "check_nt"; | 64 | const char *progname = "check_nt"; | 
| 65 | 65 | ||
| 66 | int process_arguments(int, char **); | 66 | int process_arguments(int, char **); | 
| 67 | void print_usage(void); | ||
| 68 | void print_help(void); | ||
| 69 | void preparelist(char *string); | 67 | void preparelist(char *string); | 
| 68 | int strtoularray(unsigned long *array, char *string, char *delim); | ||
| 69 | void print_help(void); | ||
| 70 | void print_usage(void); | ||
| 70 | 71 | ||
| 71 | int main(int argc, char **argv){ | 72 | int main(int argc, char **argv){ | 
| 72 | int result; | 73 | int result; | 
| @@ -91,10 +92,10 @@ int main(int argc, char **argv){ | |||
| 91 | int uphours=0; | 92 | int uphours=0; | 
| 92 | int upminutes=0; | 93 | int upminutes=0; | 
| 93 | 94 | ||
| 94 | asprintf(&req_password,"None"); | 95 | asprintf(&req_password, _("None")); | 
| 95 | 96 | ||
| 96 | if(process_arguments(argc,argv)==ERROR) | 97 | if(process_arguments(argc,argv)==ERROR) | 
| 97 | usage("Could not parse arguments\n"); | 98 | usage(_("Could not parse arguments\n")); | 
| 98 | 99 | ||
| 99 | /* initialize alarm signal handling */ | 100 | /* initialize alarm signal handling */ | 
| 100 | signal(SIGALRM,socket_timeout_alarm_handler); | 101 | signal(SIGALRM,socket_timeout_alarm_handler); | 
| @@ -116,15 +117,15 @@ int main(int argc, char **argv){ | |||
| 116 | else if(vars_to_check==CHECK_CPULOAD){ | 117 | else if(vars_to_check==CHECK_CPULOAD){ | 
| 117 | 118 | ||
| 118 | if (check_value_list==TRUE) { | 119 | if (check_value_list==TRUE) { | 
| 119 | if (strtolarray(&lvalue_list,value_list,",")==TRUE) { | 120 | if (strtoularray(&lvalue_list,value_list,",")==TRUE) { | 
| 120 | /* -l parameters is present with only integers */ | 121 | /* -l parameters is present with only integers */ | 
| 121 | return_code=STATE_OK; | 122 | return_code=STATE_OK; | 
| 122 | asprintf(&temp_string,"CPU Load"); | 123 | asprintf(&temp_string,_("CPU Load")); | 
| 123 | while (lvalue_list[0+offset]>(unsigned long)0 && | 124 | while (lvalue_list[0+offset]> (unsigned long)0 && | 
| 124 | lvalue_list[0+offset]<=(unsigned long)17280 && | 125 | lvalue_list[0+offset]<=(unsigned long)17280 && | 
| 125 | lvalue_list[1+offset]>=(unsigned long)0 && | 126 | lvalue_list[1+offset]> (unsigned long)0 && | 
| 126 | lvalue_list[1+offset]<=(unsigned long)100 && | 127 | lvalue_list[1+offset]<=(unsigned long)100 && | 
| 127 | lvalue_list[2+offset]>=(unsigned long)0 && | 128 | lvalue_list[2+offset]> (unsigned long)0 && | 
| 128 | lvalue_list[2+offset]<=(unsigned long)100) { | 129 | lvalue_list[2+offset]<=(unsigned long)100) { | 
| 129 | /* loop until one of the parameters is wrong or not present */ | 130 | /* loop until one of the parameters is wrong or not present */ | 
| 130 | 131 | ||
| @@ -147,7 +148,7 @@ int main(int argc, char **argv){ | |||
| 147 | else if(utilization >= lvalue_list[1+offset] && return_code<STATE_WARNING) | 148 | else if(utilization >= lvalue_list[1+offset] && return_code<STATE_WARNING) | 
| 148 | return_code=STATE_WARNING; | 149 | return_code=STATE_WARNING; | 
| 149 | 150 | ||
| 150 | asprintf(&output_message," %lu%% (%lu min average)", utilization, lvalue_list[0+offset]); | 151 | asprintf(&output_message,_(" %lu%% (%lu min average)"), utilization, lvalue_list[0+offset]); | 
| 151 | asprintf(&temp_string,"%s%s",temp_string,output_message); | 152 | asprintf(&temp_string,"%s%s",temp_string,output_message); | 
| 152 | offset+=3; /* move across the array */ | 153 | offset+=3; /* move across the array */ | 
| 153 | } | 154 | } | 
| @@ -156,13 +157,13 @@ int main(int argc, char **argv){ | |||
| 156 | asprintf(&output_message,"%s",temp_string); | 157 | asprintf(&output_message,"%s",temp_string); | 
| 157 | } | 158 | } | 
| 158 | else | 159 | else | 
| 159 | asprintf(&output_message,"%s","not enough values for -l parameters"); | 160 | asprintf(&output_message,"%s",_("not enough values for -l parameters")); | 
| 160 | 161 | ||
| 161 | } else | 162 | } else | 
| 162 | asprintf(&output_message,"wrong -l parameter."); | 163 | asprintf(&output_message,_("wrong -l parameter.")); | 
| 163 | 164 | ||
| 164 | } else | 165 | } else | 
| 165 | asprintf(&output_message,"missing -l parameters"); | 166 | asprintf(&output_message,_("missing -l parameters")); | 
| 166 | } | 167 | } | 
| 167 | 168 | ||
| 168 | else if(vars_to_check==CHECK_UPTIME){ | 169 | else if(vars_to_check==CHECK_UPTIME){ | 
| @@ -181,7 +182,7 @@ int main(int argc, char **argv){ | |||
| 181 | updays = uptime / 86400; | 182 | updays = uptime / 86400; | 
| 182 | uphours = (uptime % 86400) / 3600; | 183 | uphours = (uptime % 86400) / 3600; | 
| 183 | upminutes = ((uptime % 86400) % 3600) / 60; | 184 | upminutes = ((uptime % 86400) % 3600) / 60; | 
| 184 | asprintf(&output_message,"System Uptime : %u day(s) %u hour(s) %u minute(s)",updays,uphours, upminutes); | 185 | asprintf(&output_message,_("System Uptime : %u day(s) %u hour(s) %u minute(s)"),updays,uphours, upminutes); | 
| 185 | return_code=STATE_OK; | 186 | return_code=STATE_OK; | 
| 186 | } | 187 | } | 
| 187 | 188 | ||
| @@ -205,7 +206,7 @@ int main(int argc, char **argv){ | |||
| 205 | percent_used_space = ((total_disk_space - free_disk_space) / total_disk_space) * 100; | 206 | percent_used_space = ((total_disk_space - free_disk_space) / total_disk_space) * 100; | 
| 206 | 207 | ||
| 207 | if (free_disk_space>=0) { | 208 | if (free_disk_space>=0) { | 
| 208 | asprintf(&temp_string,"%s:\\ - total: %.2f Gb - used: %.2f Gb (%.0f%%) - free %.2f Gb (%.0f%%)", | 209 | asprintf(&temp_string,_("%s:\\ - total: %.2f Gb - used: %.2f Gb (%.0f%%) - free %.2f Gb (%.0f%%)"), | 
| 209 | value_list, total_disk_space / 1073741824, (total_disk_space - free_disk_space) / 1073741824, percent_used_space, | 210 | value_list, total_disk_space / 1073741824, (total_disk_space - free_disk_space) / 1073741824, percent_used_space, | 
| 210 | free_disk_space / 1073741824, (free_disk_space / total_disk_space)*100); | 211 | free_disk_space / 1073741824, (free_disk_space / total_disk_space)*100); | 
| 211 | 212 | ||
| @@ -221,14 +222,14 @@ int main(int argc, char **argv){ | |||
| 221 | 222 | ||
| 222 | } | 223 | } | 
| 223 | else { | 224 | else { | 
| 224 | asprintf(&output_message,"Free disk space : Invalid drive "); | 225 | asprintf(&output_message,_("Free disk space : Invalid drive ")); | 
| 225 | return_code=STATE_UNKNOWN; | 226 | return_code=STATE_UNKNOWN; | 
| 226 | } | 227 | } | 
| 227 | } | 228 | } | 
| 228 | else | 229 | else | 
| 229 | asprintf(&output_message,"wrong -l argument"); | 230 | asprintf(&output_message,_("wrong -l argument")); | 
| 230 | } else | 231 | } else | 
| 231 | asprintf(&output_message,"missing -l parameters"); | 232 | asprintf(&output_message,_("missing -l parameters")); | 
| 232 | 233 | ||
| 233 | } | 234 | } | 
| 234 | 235 | ||
| @@ -237,7 +238,7 @@ int main(int argc, char **argv){ | |||
| 237 | if (check_value_list==TRUE) { | 238 | if (check_value_list==TRUE) { | 
| 238 | preparelist(value_list); /* replace , between services with & to send the request */ | 239 | preparelist(value_list); /* replace , between services with & to send the request */ | 
| 239 | asprintf(&send_buffer,"%s&%u&%s&%s", req_password,(vars_to_check==CHECK_SERVICESTATE)?5:6, | 240 | asprintf(&send_buffer,"%s&%u&%s&%s", req_password,(vars_to_check==CHECK_SERVICESTATE)?5:6, | 
| 240 | (show_all==TRUE)?"ShowAll":"ShowFail",value_list); | 241 | (show_all==TRUE)?_("ShowAll"):_("ShowFail"),value_list); | 
| 241 | result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer)); | 242 | result=process_tcp_request(server_address,server_port,send_buffer,recv_buffer,sizeof(recv_buffer)); | 
| 242 | if(result!=STATE_OK) | 243 | if(result!=STATE_OK) | 
| 243 | return result; | 244 | return result; | 
| @@ -251,7 +252,7 @@ int main(int argc, char **argv){ | |||
| 251 | asprintf(&output_message, "%s",temp_string); | 252 | asprintf(&output_message, "%s",temp_string); | 
| 252 | } | 253 | } | 
| 253 | else | 254 | else | 
| 254 | asprintf(&output_message,"No service/process specified"); | 255 | asprintf(&output_message,_("No service/process specified")); | 
| 255 | } | 256 | } | 
| 256 | 257 | ||
| 257 | else if(vars_to_check==CHECK_MEMUSE) { | 258 | else if(vars_to_check==CHECK_MEMUSE) { | 
| @@ -269,7 +270,7 @@ int main(int argc, char **argv){ | |||
| 269 | mem_commitLimit=atof(strtok(recv_buffer,"&")); | 270 | mem_commitLimit=atof(strtok(recv_buffer,"&")); | 
| 270 | mem_commitByte=atof(strtok(NULL,"&")); | 271 | mem_commitByte=atof(strtok(NULL,"&")); | 
| 271 | percent_used_space = (mem_commitByte / mem_commitLimit) * 100; | 272 | percent_used_space = (mem_commitByte / mem_commitLimit) * 100; | 
| 272 | asprintf(&output_message,"Memory usage: total:%.2f Mb - used: %.2f Mb (%.0f%%) - free: %.2f Mb (%.0f%%)", | 273 | asprintf(&output_message,_("Memory usage: total:%.2f Mb - used: %.2f Mb (%.0f%%) - free: %.2f Mb (%.0f%%)"), | 
| 273 | mem_commitLimit / 1048576, mem_commitByte / 1048567, percent_used_space, | 274 | mem_commitLimit / 1048576, mem_commitByte / 1048567, percent_used_space, | 
| 274 | (mem_commitLimit - mem_commitByte) / 1048576, (mem_commitLimit - mem_commitByte) / mem_commitLimit * 100); | 275 | (mem_commitLimit - mem_commitByte) / 1048576, (mem_commitLimit - mem_commitByte) / mem_commitLimit * 100); | 
| 275 | 276 | ||
| @@ -325,7 +326,7 @@ int main(int argc, char **argv){ | |||
| 325 | 326 | ||
| 326 | } | 327 | } | 
| 327 | else { | 328 | else { | 
| 328 | asprintf(&output_message,"No counter specified"); | 329 | asprintf(&output_message,_("No counter specified")); | 
| 329 | result=STATE_UNKNOWN; | 330 | result=STATE_UNKNOWN; | 
| 330 | } | 331 | } | 
| 331 | } | 332 | } | 
| @@ -368,7 +369,7 @@ int main(int argc, char **argv){ | |||
| 368 | 369 | ||
| 369 | } | 370 | } | 
| 370 | else { | 371 | else { | 
| 371 | asprintf(&output_message,"No file specified"); | 372 | asprintf(&output_message,_("No file specified")); | 
| 372 | result=STATE_UNKNOWN; | 373 | result=STATE_UNKNOWN; | 
| 373 | } | 374 | } | 
| 374 | } | 375 | } | 
| @@ -382,6 +383,10 @@ int main(int argc, char **argv){ | |||
| 382 | } | 383 | } | 
| 383 | 384 | ||
| 384 | 385 | ||
| 386 | |||
| 387 | |||
| 388 | |||
| 389 | |||
| 385 | /* process command-line arguments */ | 390 | /* process command-line arguments */ | 
| 386 | int process_arguments(int argc, char **argv){ | 391 | int process_arguments(int argc, char **argv){ | 
| 387 | int c; | 392 | int c; | 
| @@ -448,7 +453,7 @@ int process_arguments(int argc, char **argv){ | |||
| 448 | if (is_intnonneg(optarg)) | 453 | if (is_intnonneg(optarg)) | 
| 449 | server_port=atoi(optarg); | 454 | server_port=atoi(optarg); | 
| 450 | else | 455 | else | 
| 451 | die(STATE_UNKNOWN,"Server port an integer (seconds)\nType '%s -h' for additional help\n",progname); | 456 | die(STATE_UNKNOWN,_("Server port an integer (seconds)\nType '%s -h' for additional help\n"),progname); | 
| 452 | break; | 457 | break; | 
| 453 | case 'v': | 458 | case 'v': | 
| 454 | if(strlen(optarg)<4) | 459 | if(strlen(optarg)<4) | 
| @@ -505,21 +510,53 @@ int process_arguments(int argc, char **argv){ | |||
| 505 | } | 510 | } | 
| 506 | 511 | ||
| 507 | 512 | ||
| 508 | void print_usage(void) | 513 | |
| 509 | { | 514 | |
| 510 | printf("Usage: %s -H host -v variable [-p port] [-w warning] [-c critical] [-l params] [-d SHOWALL] [-t timeout]\n",progname); | 515 | |
| 516 | |||
| 517 | int strtoularray(unsigned long *array, char *string, char *delim) { | ||
| 518 | /* split a <delim> delimited string into a long array */ | ||
| 519 | int idx=0; | ||
| 520 | char *t1; | ||
| 521 | |||
| 522 | for (idx=0;idx<MAX_VALUE_LIST;idx++) | ||
| 523 | array[idx]=0; | ||
| 524 | |||
| 525 | idx=0; | ||
| 526 | for(t1 = strtok(string,delim);t1 != NULL; t1 = strtok(NULL, delim)) { | ||
| 527 | if (is_numeric(t1) && idx<MAX_VALUE_LIST) { | ||
| 528 | array[idx]=strtoul(t1,NULL,10); | ||
| 529 | idx++; | ||
| 530 | } else | ||
| 531 | return FALSE; | ||
| 532 | } | ||
| 533 | return TRUE; | ||
| 511 | } | 534 | } | 
| 512 | 535 | ||
| 536 | void preparelist(char *string) { | ||
| 537 | /* Replace all , with & which is the delimiter for the request */ | ||
| 538 | int i; | ||
| 513 | 539 | ||
| 540 | for (i = 0; (size_t)i < strlen(string); i++) | ||
| 541 | if (string[i] == ',') { | ||
| 542 | string[i]='&'; | ||
| 543 | } | ||
| 544 | } | ||
| 545 | |||
| 546 | |||
| 547 | |||
| 548 | |||
| 549 | |||
| 550 | |||
| 514 | void print_help(void) | 551 | void print_help(void) | 
| 515 | { | 552 | { | 
| 516 | print_revision(progname,"$Revision$"); | 553 | print_revision(progname,"$Revision$"); | 
| 517 | printf ("\ | 554 | printf (_("\ | 
| 518 | Copyright (c) 2000 Yves Rubin (rubiyz@yahoo.com)\n\n\ | 555 | Copyright (c) 2000 Yves Rubin (rubiyz@yahoo.com)\n\n\ | 
| 519 | This plugin collects data from the NSClient service running on a\n\ | 556 | This plugin collects data from the NSClient service running on a\n\ | 
| 520 | Windows NT/2000/XP server.\n\n"); | 557 | Windows NT/2000/XP server.\n\n")); | 
| 521 | print_usage(); | 558 | print_usage(); | 
| 522 | printf ("\nOptions:\n\ | 559 | printf (_("\nOptions:\n\ | 
| 523 | -H, --hostname=HOST\n\ | 560 | -H, --hostname=HOST\n\ | 
| 524 | Name of the host to check\n\ | 561 | Name of the host to check\n\ | 
| 525 | -p, --port=INTEGER\n\ | 562 | -p, --port=INTEGER\n\ | 
| @@ -535,40 +572,40 @@ Windows NT/2000/XP server.\n\n"); | |||
| 535 | -h, --help\n\ | 572 | -h, --help\n\ | 
| 536 | Print this help screen\n\ | 573 | Print this help screen\n\ | 
| 537 | -V, --version\n\ | 574 | -V, --version\n\ | 
| 538 | Print version information\n", | 575 | Print version information\n"), | 
| 539 | PORT, DEFAULT_SOCKET_TIMEOUT); | 576 | PORT, DEFAULT_SOCKET_TIMEOUT); | 
| 540 | printf ("\ | 577 | printf (_("\ | 
| 541 | -v, --variable=STRING\n\ | 578 | -v, --variable=STRING\n\ | 
| 542 | Variable to check. Valid variables are:\n"); | 579 | Variable to check. Valid variables are:\n")); | 
| 543 | printf ("\ | 580 | printf (_("\ | 
| 544 | CLIENTVERSION = Get the NSClient version\n"); | 581 | CLIENTVERSION = Get the NSClient version\n")); | 
| 545 | printf ("\ | 582 | printf (_("\ | 
| 546 | CPULOAD = Average CPU load on last x minutes.\n\ | 583 | CPULOAD = Average CPU load on last x minutes.\n\ | 
| 547 | Request a -l parameter with the following syntax:\n\ | 584 | Request a -l parameter with the following syntax:\n\ | 
| 548 | -l <minutes range>,<warning threshold>,<critical threshold>.\n\ | 585 | -l <minutes range>,<warning threshold>,<critical threshold>.\n\ | 
| 549 | <minute range> should be less than 24*60.\n\ | 586 | <minute range> should be less than 24*60.\n\ | 
| 550 | Thresholds are percentage and up to 10 requests can be done in one shot.\n\ | 587 | Thresholds are percentage and up to 10 requests can be done in one shot.\n\ | 
| 551 | ie: -l 60,90,95,120,90,95\n"); | 588 | ie: -l 60,90,95,120,90,95\n")); | 
| 552 | printf ("\ | 589 | printf (_("\ | 
| 553 | UPTIME = Get the uptime of the machine.\n\ | 590 | UPTIME = Get the uptime of the machine.\n\ | 
| 554 | No specific parameters. No warning or critical threshold\n"); | 591 | No specific parameters. No warning or critical threshold\n")); | 
| 555 | printf ("\ | 592 | printf (_("\ | 
| 556 | USEDDISKSPACE = Size and percentage of disk use.\n\ | 593 | USEDDISKSPACE = Size and percentage of disk use.\n\ | 
| 557 | Request a -l parameter containing the drive letter only.\n\ | 594 | Request a -l parameter containing the drive letter only.\n\ | 
| 558 | Warning and critical thresholds can be specified with -w and -c.\n"); | 595 | Warning and critical thresholds can be specified with -w and -c.\n")); | 
| 559 | printf ("\ | 596 | printf (_("\ | 
| 560 | MEMUSE = Memory use.\n\ | 597 | MEMUSE = Memory use.\n\ | 
| 561 | Warning and critical thresholds can be specified with -w and -c.\n"); | 598 | Warning and critical thresholds can be specified with -w and -c.\n")); | 
| 562 | printf ("\ | 599 | printf (_("\ | 
| 563 | SERVICESTATE = Check the state of one or several services.\n\ | 600 | SERVICESTATE = Check the state of one or several services.\n\ | 
| 564 | Request a -l parameters with the following syntax:\n\ | 601 | Request a -l parameters with the following syntax:\n\ | 
| 565 | -l <service1>,<service2>,<service3>,...\n\ | 602 | -l <service1>,<service2>,<service3>,...\n\ | 
| 566 | You can specify -d SHOWALL in case you want to see working services\n\ | 603 | You can specify -d SHOWALL in case you want to see working services\n\ | 
| 567 | in the returned string.\n"); | 604 | in the returned string.\n")); | 
| 568 | printf ("\ | 605 | printf (_("\ | 
| 569 | PROCSTATE = Check if one or several process are running.\n\ | 606 | PROCSTATE = Check if one or several process are running.\n\ | 
| 570 | Same syntax as SERVICESTATE.\n"); | 607 | Same syntax as SERVICESTATE.\n")); | 
| 571 | printf ("\ | 608 | printf (_("\ | 
| 572 | COUNTER = Check any performance counter of Windows NT/2000.\n\ | 609 | COUNTER = Check any performance counter of Windows NT/2000.\n\ | 
| 573 | Request a -l parameters with the following syntax:\n\ | 610 | Request a -l parameters with the following syntax:\n\ | 
| 574 | -l \"\\\\<performance object>\\\\counter\",\"<description>\n\ | 611 | -l \"\\\\<performance object>\\\\counter\",\"<description>\n\ | 
| @@ -576,39 +613,20 @@ Windows NT/2000/XP server.\n\n"); | |||
| 576 | is given to a printf output command which require a float parameters.\n\ | 613 | is given to a printf output command which require a float parameters.\n\ | 
| 577 | Some examples:\n\ | 614 | Some examples:\n\ | 
| 578 | \"Paging file usage is %%.2f %%%%\"\n\ | 615 | \"Paging file usage is %%.2f %%%%\"\n\ | 
| 579 | \"%%.f %%%% paging file used.\"\n"); | 616 | \"%%.f %%%% paging file used.\"\n")); | 
| 580 | printf ("Notes:\n\ | 617 | printf (_("Notes:\n\ | 
| 581 | - The NSClient service should be running on the server to get any information\n\ | 618 | - The NSClient service should be running on the server to get any information\n\ | 
| 582 | (http://nsclient.ready2run.nl).\n\ | 619 | (http://nsclient.ready2run.nl).\n\ | 
| 583 | - Critical thresholds should be lower than warning thresholds\n"); | 620 | - Critical thresholds should be lower than warning thresholds\n")); | 
| 584 | } | 621 | } | 
| 585 | 622 | ||
| 586 | int strtolarray(unsigned long *array, char *string, char *delim) { | ||
| 587 | /* split a <delim> delimited string into a long array */ | ||
| 588 | int idx=0; | ||
| 589 | char *t1; | ||
| 590 | 623 | ||
| 591 | for (idx=0;idx<MAX_VALUE_LIST;idx++) | ||
| 592 | array[idx]=-1; | ||
| 593 | |||
| 594 | idx=0; | ||
| 595 | for(t1 = strtok(string,delim);t1 != NULL; t1 = strtok(NULL, delim)) { | ||
| 596 | if (is_numeric(t1) && idx<MAX_VALUE_LIST) { | ||
| 597 | array[idx]=strtoul(t1,NULL,10); | ||
| 598 | idx++; | ||
| 599 | } else | ||
| 600 | return FALSE; | ||
| 601 | } | ||
| 602 | return TRUE; | ||
| 603 | } | ||
| 604 | 624 | ||
| 605 | void preparelist(char *string) { | ||
| 606 | /* Replace all , with & which is the delimiter for the request */ | ||
| 607 | int i; | ||
| 608 | 625 | ||
| 609 | for (i = 0; (size_t)i < strlen(string); i++) | 626 | void print_usage(void) | 
| 610 | if (string[i] == ',') { | 627 | { | 
| 611 | string[i]='&'; | 628 | printf(_("\ | 
| 612 | } | 629 | Usage: %s -H host -v variable [-p port] [-w warning] [-c critical]\n\ | 
| 630 | [-l params] [-d SHOWALL] [-t timeout]\n"), progname); | ||
| 631 | printf (_(UT_HLP_VRS), progname, progname); | ||
| 613 | } | 632 | } | 
| 614 | |||
| diff --git a/plugins/check_smtp.c b/plugins/check_smtp.c index 7562c4c6..f7c826b2 100644 --- a/plugins/check_smtp.c +++ b/plugins/check_smtp.c | |||
| @@ -1,70 +1,29 @@ | |||
| 1 | /****************************************************************************** | 1 | /****************************************************************************** | 
| 2 | * | 2 | |
| 3 | * This program is free software; you can redistribute it and/or modify | 3 | This program is free software; you can redistribute it and/or modify | 
| 4 | * it under the terms of the GNU General Public License as published by | 4 | it under the terms of the GNU General Public License as published by | 
| 5 | * the Free Software Foundation; either version 2 of the License, or | 5 | the Free Software Foundation; either version 2 of the License, or | 
| 6 | * (at your option) any later version. | 6 | (at your option) any later version. | 
| 7 | * | 7 | |
| 8 | * This program is distributed in the hope that it will be useful, | 8 | This program is distributed in the hope that it will be useful, | 
| 9 | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 9 | but WITHOUT ANY WARRANTY; without even the implied warranty of | 
| 10 | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 10 | MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the | 
| 11 | * GNU General Public License for more details. | 11 | GNU General Public License for more details. | 
| 12 | * | 12 | |
| 13 | * You should have received a copy of the GNU General Public License | 13 | You should have received a copy of the GNU General Public License | 
| 14 | * along with this program; if not, write to the Free Software | 14 | along with this program; if not, write to the Free Software | 
| 15 | * Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 15 | Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. | 
| 16 | * | 16 | |
| 17 | *****************************************************************************/ | 17 | ******************************************************************************/ | 
| 18 | 18 | ||
| 19 | const char *progname = "check_smtp"; | 19 | const char *progname = "check_smtp"; | 
| 20 | const char *revision = "$Revision$"; | 20 | const char *revision = "$Revision$"; | 
| 21 | const char *copyright = "1999-2003"; | 21 | const char *copyright = "2000-2003"; | 
| 22 | const char *authors = "Nagios Plugin Development Team"; | ||
| 23 | const char *email = "nagiosplug-devel@lists.sourceforge.net"; | 22 | const char *email = "nagiosplug-devel@lists.sourceforge.net"; | 
| 24 | 23 | ||
| 25 | const char *summary = "\ | 24 | #include "common.h" | 
| 26 | This plugin will attempt to open an SMTP connection with the host.\n"; | 25 | #include "netutils.h" | 
| 27 | 26 | #include "utils.h" | |
| 28 | const char *description = "\ | ||
| 29 | Successul connects return STATE_OK, refusals and timeouts return\n\ | ||
| 30 | STATE_CRITICAL, other errors return STATE_UNKNOWN. Successful\n\ | ||
| 31 | connects, but incorrect reponse messages from the host result in\n\ | ||
| 32 | STATE_WARNING return values.\n"; | ||
| 33 | |||
| 34 | const char *option_summary = "\ | ||
| 35 | -H host [-p port] [-e expect] [-C command] [-f from addr]\n\ | ||
| 36 | [-w warn] [-c crit] [-t timeout] [-n] [-v] [-4|-6]"; | ||
| 37 | |||
| 38 | const char *options = "\ | ||
| 39 | -H, --hostname=STRING or IPADDRESS\n\ | ||
| 40 | Check server on the indicated host\n\ | ||
| 41 | -4, --use-ipv4\n\ | ||
| 42 | Use IPv4 protocol\n\ | ||
| 43 | -6, --use-ipv6\n\ | ||
| 44 | Use IPv6 protocol\n\ | ||
| 45 | -p, --port=INTEGER\n\ | ||
| 46 | Make connection on the indicated port (default: %d)\n\ | ||
| 47 | -e, --expect=STRING\n\ | ||
| 48 | String to expect in first line of server response (default: '%s')\n\ | ||
| 49 | -n, nocommand\n\ | ||
| 50 | Suppress SMTP command\n\ | ||
| 51 | -C, --command=STRING\n\ | ||
| 52 | SMTP command (default: '%s')\n\ | ||
| 53 | -f, --from=STRING\n\ | ||
| 54 | FROM-address to include in MAIL command, required by Exchange 2000\n\ | ||
| 55 | (default: '%s')\n\ | ||
| 56 | -w, --warning=INTEGER\n\ | ||
| 57 | Seconds necessary to result in a warning status\n\ | ||
| 58 | -c, --critical=INTEGER\n\ | ||
| 59 | Seconds necessary to result in a critical status\n\ | ||
| 60 | -t, --timeout=INTEGER\n\ | ||
| 61 | Seconds before connection attempt times out (default: %d)\n\ | ||
| 62 | -v, --verbose\n\ | ||
| 63 | Print extra information (command-line use only)\n\ | ||
| 64 | -h, --help\n\ | ||
| 65 | Print detailed help screen\n\ | ||
| 66 | -V, --version\n\ | ||
| 67 | Print version information\n\n"; | ||
| 68 | 27 | ||
| 69 | enum { | 28 | enum { | 
| 70 | SMTP_PORT = 25 | 29 | SMTP_PORT = 25 | 
| @@ -73,11 +32,6 @@ const char *SMTP_EXPECT = "220"; | |||
| 73 | const char *SMTP_HELO = "HELO "; | 32 | const char *SMTP_HELO = "HELO "; | 
| 74 | const char *SMTP_QUIT = "QUIT\r\n"; | 33 | const char *SMTP_QUIT = "QUIT\r\n"; | 
| 75 | 34 | ||
| 76 | #include "config.h" | ||
| 77 | #include "common.h" | ||
| 78 | #include "netutils.h" | ||
| 79 | #include "utils.h" | ||
| 80 | |||
| 81 | int process_arguments (int, char **); | 35 | int process_arguments (int, char **); | 
| 82 | int validate_arguments (void); | 36 | int validate_arguments (void); | 
| 83 | void print_help (void); | 37 | void print_help (void); | 
| @@ -95,6 +49,11 @@ int critical_time = 0; | |||
| 95 | int check_critical_time = FALSE; | 49 | int check_critical_time = FALSE; | 
| 96 | int verbose = 0; | 50 | int verbose = 0; | 
| 97 | 51 | ||
| 52 | |||
| 53 | |||
| 54 | |||
| 55 | |||
| 56 | |||
| 98 | int | 57 | int | 
| 99 | main (int argc, char **argv) | 58 | main (int argc, char **argv) | 
| 100 | { | 59 | { | 
| @@ -107,7 +66,7 @@ main (int argc, char **argv) | |||
| 107 | struct timeval tv; | 66 | struct timeval tv; | 
| 108 | 67 | ||
| 109 | if (process_arguments (argc, argv) != OK) | 68 | if (process_arguments (argc, argv) != OK) | 
| 110 | usage ("Invalid command arguments supplied\n"); | 69 | usage (_("Invalid command arguments supplied\n")); | 
| 111 | 70 | ||
| 112 | /* initialize the HELO command with the localhostname */ | 71 | /* initialize the HELO command with the localhostname */ | 
| 113 | #ifndef HOST_MAX_BYTES | 72 | #ifndef HOST_MAX_BYTES | 
| @@ -141,7 +100,7 @@ main (int argc, char **argv) | |||
| 141 | /* watch for the SMTP connection string and */ | 100 | /* watch for the SMTP connection string and */ | 
| 142 | /* return a WARNING status if we couldn't read any data */ | 101 | /* return a WARNING status if we couldn't read any data */ | 
| 143 | if (recv (sd, buffer, MAX_INPUT_BUFFER - 1, 0) == -1) { | 102 | if (recv (sd, buffer, MAX_INPUT_BUFFER - 1, 0) == -1) { | 
| 144 | printf ("recv() failed\n"); | 103 | printf (_("recv() failed\n")); | 
| 145 | result = STATE_WARNING; | 104 | result = STATE_WARNING; | 
| 146 | } | 105 | } | 
| 147 | else { | 106 | else { | 
| @@ -150,9 +109,9 @@ main (int argc, char **argv) | |||
| 150 | /* make sure we find the response we are looking for */ | 109 | /* make sure we find the response we are looking for */ | 
| 151 | if (!strstr (buffer, server_expect)) { | 110 | if (!strstr (buffer, server_expect)) { | 
| 152 | if (server_port == SMTP_PORT) | 111 | if (server_port == SMTP_PORT) | 
| 153 | printf ("Invalid SMTP response received from host\n"); | 112 | printf (_("Invalid SMTP response received from host\n")); | 
| 154 | else | 113 | else | 
| 155 | printf ("Invalid SMTP response received from host on port %d\n", | 114 | printf (_("Invalid SMTP response received from host on port %d\n"), | 
| 156 | server_port); | 115 | server_port); | 
| 157 | result = STATE_WARNING; | 116 | result = STATE_WARNING; | 
| 158 | } | 117 | } | 
| @@ -182,7 +141,7 @@ main (int argc, char **argv) | |||
| 182 | recv(sd, buffer, MAX_INPUT_BUFFER-1, 0); | 141 | recv(sd, buffer, MAX_INPUT_BUFFER-1, 0); | 
| 183 | 142 | ||
| 184 | if (verbose) | 143 | if (verbose) | 
| 185 | printf("DUMMYCMD: %s\n%s\n",from_str,buffer); | 144 | printf(_("DUMMYCMD: %s\n%s\n"),from_str,buffer); | 
| 186 | 145 | ||
| 187 | } /* smtp_use_dummycmd */ | 146 | } /* smtp_use_dummycmd */ | 
| 188 | 147 | ||
| @@ -204,10 +163,10 @@ main (int argc, char **argv) | |||
| 204 | result = STATE_WARNING; | 163 | result = STATE_WARNING; | 
| 205 | 164 | ||
| 206 | if (verbose) | 165 | if (verbose) | 
| 207 | printf ("SMTP %s - %.3f sec. response time, %s|time=%.3f\n", | 166 | printf (_("SMTP %s - %.3f sec. response time, %s|time=%.3f\n"), | 
| 208 | state_text (result), elapsed_time, buffer, elapsed_time); | 167 | state_text (result), elapsed_time, buffer, elapsed_time); | 
| 209 | else | 168 | else | 
| 210 | printf ("SMTP %s - %.3f second response time|time=%.3f\n", | 169 | printf (_("SMTP %s - %.3f second response time|time=%.3f\n"), | 
| 211 | state_text (result), elapsed_time, elapsed_time); | 170 | state_text (result), elapsed_time, elapsed_time); | 
| 212 | 171 | ||
| 213 | return result; | 172 | return result; | 
| @@ -217,7 +176,7 @@ main (int argc, char **argv) | |||
| 217 | 176 | ||
| 218 | 177 | ||
| 219 | 178 | ||
| 220 | 179 | ||
| 221 | /* process command-line arguments */ | 180 | /* process command-line arguments */ | 
| 222 | int | 181 | int | 
| 223 | process_arguments (int argc, char **argv) | 182 | process_arguments (int argc, char **argv) | 
| @@ -268,16 +227,14 @@ process_arguments (int argc, char **argv) | |||
| 268 | server_address = optarg; | 227 | server_address = optarg; | 
| 269 | } | 228 | } | 
| 270 | else { | 229 | else { | 
| 271 | usage ("Invalid host name\n"); | 230 | usage (_("Invalid host name\n")); | 
| 272 | } | 231 | } | 
| 273 | break; | 232 | break; | 
| 274 | case 'p': /* port */ | 233 | case 'p': /* port */ | 
| 275 | if (is_intpos (optarg)) { | 234 | if (is_intpos (optarg)) | 
| 276 | server_port = atoi (optarg); | 235 | server_port = atoi (optarg); | 
| 277 | } | 236 | else | 
| 278 | else { | 237 | usage (_("Server port must be a positive integer\n")); | 
| 279 | usage ("Server port must be a positive integer\n"); | ||
| 280 | } | ||
| 281 | break; | 238 | break; | 
| 282 | case 'f': /* from argument */ | 239 | case 'f': /* from argument */ | 
| 283 | from_arg = optarg; | 240 | from_arg = optarg; | 
| @@ -298,7 +255,7 @@ process_arguments (int argc, char **argv) | |||
| 298 | check_critical_time = TRUE; | 255 | check_critical_time = TRUE; | 
| 299 | } | 256 | } | 
| 300 | else { | 257 | else { | 
| 301 | usage ("Critical time must be a nonnegative integer\n"); | 258 | usage (_("Critical time must be a nonnegative integer\n")); | 
| 302 | } | 259 | } | 
| 303 | break; | 260 | break; | 
| 304 | case 'w': /* warning time threshold */ | 261 | case 'w': /* warning time threshold */ | 
| @@ -307,7 +264,7 @@ process_arguments (int argc, char **argv) | |||
| 307 | check_warning_time = TRUE; | 264 | check_warning_time = TRUE; | 
| 308 | } | 265 | } | 
| 309 | else { | 266 | else { | 
| 310 | usage ("Warning time must be a nonnegative integer\n"); | 267 | usage (_("Warning time must be a nonnegative integer\n")); | 
| 311 | } | 268 | } | 
| 312 | break; | 269 | break; | 
| 313 | case 'v': /* verbose */ | 270 | case 'v': /* verbose */ | 
| @@ -318,7 +275,7 @@ process_arguments (int argc, char **argv) | |||
| 318 | socket_timeout = atoi (optarg); | 275 | socket_timeout = atoi (optarg); | 
| 319 | } | 276 | } | 
| 320 | else { | 277 | else { | 
| 321 | usage ("Time interval must be a nonnegative integer\n"); | 278 | usage (_("Time interval must be a nonnegative integer\n")); | 
| 322 | } | 279 | } | 
| 323 | break; | 280 | break; | 
| 324 | case '4': | 281 | case '4': | 
| @@ -328,7 +285,7 @@ process_arguments (int argc, char **argv) | |||
| 328 | #ifdef USE_IPV6 | 285 | #ifdef USE_IPV6 | 
| 329 | address_family = AF_INET6; | 286 | address_family = AF_INET6; | 
| 330 | #else | 287 | #else | 
| 331 | usage ("IPv6 support not available\n"); | 288 | usage (_("IPv6 support not available\n")); | 
| 332 | #endif | 289 | #endif | 
| 333 | break; | 290 | break; | 
| 334 | case 'V': /* version */ | 291 | case 'V': /* version */ | 
| @@ -338,7 +295,7 @@ process_arguments (int argc, char **argv) | |||
| 338 | print_help (); | 295 | print_help (); | 
| 339 | exit (STATE_OK); | 296 | exit (STATE_OK); | 
| 340 | case '?': /* help */ | 297 | case '?': /* help */ | 
| 341 | usage ("Invalid argument\n"); | 298 | usage (_("Invalid argument\n")); | 
| 342 | } | 299 | } | 
| 343 | } | 300 | } | 
| 344 | 301 | ||
| @@ -348,7 +305,7 @@ process_arguments (int argc, char **argv) | |||
| 348 | if (is_host (argv[c])) | 305 | if (is_host (argv[c])) | 
| 349 | server_address = argv[c]; | 306 | server_address = argv[c]; | 
| 350 | else | 307 | else | 
| 351 | usage ("Invalid host name"); | 308 | usage (_("Invalid host name")); | 
| 352 | } | 309 | } | 
| 353 | else { | 310 | else { | 
| 354 | asprintf (&server_address, "127.0.0.1"); | 311 | asprintf (&server_address, "127.0.0.1"); | 
| @@ -375,17 +332,53 @@ validate_arguments (void) | |||
| 375 | 332 | ||
| 376 | 333 | ||
| 377 | 334 | ||
| 335 | |||
| 378 | void | 336 | void | 
| 379 | print_help (void) | 337 | print_help (void) | 
| 380 | { | 338 | { | 
| 339 | char *myport; | ||
| 340 | asprintf (&myport, "%d", SMTP_PORT); | ||
| 341 | |||
| 381 | print_revision (progname, revision); | 342 | print_revision (progname, revision); | 
| 382 | printf ("Copyright (c) %s %s\n\t<%s>\n\n%s\n", | 343 | |
| 383 | copyright, authors, email, summary); | 344 | printf (_("Copyright (c) 1999-2001 Ethan Galstad <nagios@nagios.org>\n")); | 
| 345 | printf (_(COPYRIGHT), copyright, email); | ||
| 346 | |||
| 347 | printf(_("\ | ||
| 348 | This plugin will attempt to open an SMTP connection with the host.\n\n")); | ||
| 349 | |||
| 384 | print_usage (); | 350 | print_usage (); | 
| 385 | printf ("\nOptions:\n"); | 351 | |
| 386 | printf (options, SMTP_PORT, SMTP_EXPECT, mail_command, from_arg, | 352 | printf (_(UT_HELP_VRSN)); | 
| 387 | DEFAULT_SOCKET_TIMEOUT); | 353 | |
| 388 | support (); | 354 | printf (_(UT_HOST_PORT), 'p', myport); | 
| 355 | |||
| 356 | printf (_(UT_IPv46)); | ||
| 357 | |||
| 358 | printf (_("\ | ||
| 359 | -e, --expect=STRING\n\ | ||
| 360 | String to expect in first line of server response (default: '%s')\n\ | ||
| 361 | -n, nocommand\n\ | ||
| 362 | Suppress SMTP command\n\ | ||
| 363 | -C, --command=STRING\n\ | ||
| 364 | SMTP command (default: '%s')\n\ | ||
| 365 | -f, --from=STRING\n\ | ||
| 366 | FROM-address to include in MAIL command, required by Exchange 2000\n\ | ||
| 367 | (default: '%s')\n"), SMTP_EXPECT, mail_command, from_arg); | ||
| 368 | |||
| 369 | printf (_(UT_WARN_CRIT)); | ||
| 370 | |||
| 371 | printf (_(UT_TIMEOUT), DEFAULT_SOCKET_TIMEOUT); | ||
| 372 | |||
| 373 | printf (_(UT_VERBOSE)); | ||
| 374 | |||
| 375 | printf(_("\n\ | ||
| 376 | Successul connects return STATE_OK, refusals and timeouts return\n\ | ||
| 377 | STATE_CRITICAL, other errors return STATE_UNKNOWN. Successful\n\ | ||
| 378 | connects, but incorrect reponse messages from the host result in\n\ | ||
| 379 | STATE_WARNING return values.\n")); | ||
| 380 | |||
| 381 | printf (_(UT_SUPPORT)); | ||
| 389 | } | 382 | } | 
| 390 | 383 | ||
| 391 | 384 | ||
| @@ -395,8 +388,11 @@ print_help (void) | |||
| 395 | void | 388 | void | 
| 396 | print_usage (void) | 389 | print_usage (void) | 
| 397 | { | 390 | { | 
| 398 | printf ("Usage: %s %s\n" | 391 | printf ("\ | 
| 399 | " %s --help\n" | 392 | Usage: %s -H host [-p port] [-e expect] [-C command] [-f from addr]\n\ | 
| 400 | " %s --version\n", | 393 | [-w warn] [-c crit] [-t timeout] [-n] [-v] [-4|-6]\n", progname); | 
| 401 | progname, option_summary, progname, progname); | 394 | printf (_(UT_HLP_VRS), progname, progname); | 
| 402 | } | 395 | } | 
| 396 | |||
| 397 | |||
| 398 | |||
