diff options
-rw-r--r-- | plugins/check_tcp.c | 62 |
1 files changed, 29 insertions, 33 deletions
diff --git a/plugins/check_tcp.c b/plugins/check_tcp.c index af318853..c13ac767 100644 --- a/plugins/check_tcp.c +++ b/plugins/check_tcp.c | |||
@@ -51,8 +51,8 @@ static int days_till_exp_warn, days_till_exp_crit; | |||
51 | #endif | 51 | #endif |
52 | 52 | ||
53 | /* int my_recv(char *, size_t); */ | 53 | /* int my_recv(char *, size_t); */ |
54 | static int process_arguments(int, char **); | 54 | static int process_arguments(int /*argc*/, char ** /*argv*/); |
55 | void print_help(void); | 55 | static void print_help(void); |
56 | void print_usage(void); | 56 | void print_usage(void); |
57 | 57 | ||
58 | #define EXPECT server_expect[0] | 58 | #define EXPECT server_expect[0] |
@@ -99,15 +99,6 @@ static bool sni_specified = false; | |||
99 | static size_t flags; | 99 | static size_t flags; |
100 | 100 | ||
101 | int main(int argc, char **argv) { | 101 | int main(int argc, char **argv) { |
102 | int result = STATE_UNKNOWN; | ||
103 | char *status = NULL; | ||
104 | struct timeval tv; | ||
105 | struct timeval timeout; | ||
106 | int match = -1; | ||
107 | fd_set rfds; | ||
108 | |||
109 | FD_ZERO(&rfds); | ||
110 | |||
111 | setlocale(LC_ALL, ""); | 102 | setlocale(LC_ALL, ""); |
112 | bindtextdomain(PACKAGE, LOCALEDIR); | 103 | bindtextdomain(PACKAGE, LOCALEDIR); |
113 | textdomain(PACKAGE); | 104 | textdomain(PACKAGE); |
@@ -202,7 +193,7 @@ int main(int argc, char **argv) { | |||
202 | server_port = PORT; | 193 | server_port = PORT; |
203 | server_send = SEND; | 194 | server_send = SEND; |
204 | server_quit = QUIT; | 195 | server_quit = QUIT; |
205 | status = NULL; | 196 | char *status = NULL; |
206 | 197 | ||
207 | /* Parse extra opts if any */ | 198 | /* Parse extra opts if any */ |
208 | argv = np_extra_opts(&argc, argv, progname); | 199 | argv = np_extra_opts(&argc, argv, progname); |
@@ -228,8 +219,10 @@ int main(int argc, char **argv) { | |||
228 | alarm(socket_timeout); | 219 | alarm(socket_timeout); |
229 | 220 | ||
230 | /* try to connect to the host at the given port number */ | 221 | /* try to connect to the host at the given port number */ |
222 | struct timeval tv; | ||
231 | gettimeofday(&tv, NULL); | 223 | gettimeofday(&tv, NULL); |
232 | 224 | ||
225 | int result = STATE_UNKNOWN; | ||
233 | result = np_net_connect(server_address, server_port, &sd, PROTOCOL); | 226 | result = np_net_connect(server_address, server_port, &sd, PROTOCOL); |
234 | if (result == STATE_CRITICAL) | 227 | if (result == STATE_CRITICAL) |
235 | return econn_refuse_state; | 228 | return econn_refuse_state; |
@@ -273,6 +266,10 @@ int main(int argc, char **argv) { | |||
273 | /* if(len) later on, we know we have a non-NULL response */ | 266 | /* if(len) later on, we know we have a non-NULL response */ |
274 | ssize_t len = 0; | 267 | ssize_t len = 0; |
275 | 268 | ||
269 | int match = -1; | ||
270 | struct timeval timeout; | ||
271 | fd_set rfds; | ||
272 | FD_ZERO(&rfds); | ||
276 | if (server_expect_count) { | 273 | if (server_expect_count) { |
277 | ssize_t received = 0; | 274 | ssize_t received = 0; |
278 | 275 | ||
@@ -377,15 +374,10 @@ int main(int argc, char **argv) { | |||
377 | 374 | ||
378 | /* process command-line arguments */ | 375 | /* process command-line arguments */ |
379 | static int process_arguments(int argc, char **argv) { | 376 | static int process_arguments(int argc, char **argv) { |
380 | int c; | ||
381 | bool escape = false; | ||
382 | char *temp; | ||
383 | |||
384 | enum { | 377 | enum { |
385 | SNI_OPTION = CHAR_MAX + 1 | 378 | SNI_OPTION = CHAR_MAX + 1 |
386 | }; | 379 | }; |
387 | 380 | ||
388 | int option = 0; | ||
389 | static struct option longopts[] = {{"hostname", required_argument, 0, 'H'}, | 381 | static struct option longopts[] = {{"hostname", required_argument, 0, 'H'}, |
390 | {"critical", required_argument, 0, 'c'}, | 382 | {"critical", required_argument, 0, 'c'}, |
391 | {"warning", required_argument, 0, 'w'}, | 383 | {"warning", required_argument, 0, 'w'}, |
@@ -418,13 +410,13 @@ static int process_arguments(int argc, char **argv) { | |||
418 | usage4(_("No arguments found")); | 410 | usage4(_("No arguments found")); |
419 | 411 | ||
420 | /* backwards compatibility */ | 412 | /* backwards compatibility */ |
421 | for (c = 1; c < argc; c++) { | 413 | for (int i = 1; i < argc; i++) { |
422 | if (strcmp("-to", argv[c]) == 0) | 414 | if (strcmp("-to", argv[i]) == 0) |
423 | strcpy(argv[c], "-t"); | 415 | strcpy(argv[i], "-t"); |
424 | else if (strcmp("-wt", argv[c]) == 0) | 416 | else if (strcmp("-wt", argv[i]) == 0) |
425 | strcpy(argv[c], "-w"); | 417 | strcpy(argv[i], "-w"); |
426 | else if (strcmp("-ct", argv[c]) == 0) | 418 | else if (strcmp("-ct", argv[i]) == 0) |
427 | strcpy(argv[c], "-c"); | 419 | strcpy(argv[i], "-c"); |
428 | } | 420 | } |
429 | 421 | ||
430 | if (!is_option(argv[1])) { | 422 | if (!is_option(argv[1])) { |
@@ -434,13 +426,16 @@ static int process_arguments(int argc, char **argv) { | |||
434 | argc--; | 426 | argc--; |
435 | } | 427 | } |
436 | 428 | ||
437 | while (1) { | 429 | int option_char; |
438 | c = getopt_long(argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", longopts, &option); | 430 | bool escape = false; |
431 | while (true) { | ||
432 | int option = 0; | ||
433 | option_char = getopt_long(argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", longopts, &option); | ||
439 | 434 | ||
440 | if (c == -1 || c == EOF || c == 1) | 435 | if (option_char == -1 || option_char == EOF || option_char == 1) |
441 | break; | 436 | break; |
442 | 437 | ||
443 | switch (c) { | 438 | switch (option_char) { |
444 | case '?': /* print short usage statement if args not parsable */ | 439 | case '?': /* print short usage statement if args not parsable */ |
445 | usage5(); | 440 | usage5(); |
446 | case 'h': /* help */ | 441 | case 'h': /* help */ |
@@ -553,9 +548,10 @@ static int process_arguments(int argc, char **argv) { | |||
553 | else | 548 | else |
554 | usage4(_("Delay must be a positive integer")); | 549 | usage4(_("Delay must be a positive integer")); |
555 | break; | 550 | break; |
556 | case 'D': /* Check SSL cert validity - days 'til certificate expiration */ | 551 | case 'D': { /* Check SSL cert validity - days 'til certificate expiration */ |
557 | #ifdef HAVE_SSL | 552 | #ifdef HAVE_SSL |
558 | # ifdef USE_OPENSSL /* XXX */ | 553 | # ifdef USE_OPENSSL /* XXX */ |
554 | char *temp; | ||
559 | if ((temp = strchr(optarg, ',')) != NULL) { | 555 | if ((temp = strchr(optarg, ',')) != NULL) { |
560 | *temp = '\0'; | 556 | *temp = '\0'; |
561 | if (!is_intnonneg(optarg)) | 557 | if (!is_intnonneg(optarg)) |
@@ -574,7 +570,7 @@ static int process_arguments(int argc, char **argv) { | |||
574 | } | 570 | } |
575 | check_cert = true; | 571 | check_cert = true; |
576 | flags |= FLAG_SSL; | 572 | flags |= FLAG_SSL; |
577 | break; | 573 | } break; |
578 | # endif /* USE_OPENSSL */ | 574 | # endif /* USE_OPENSSL */ |
579 | #endif | 575 | #endif |
580 | /* fallthrough if we don't have ssl */ | 576 | /* fallthrough if we don't have ssl */ |
@@ -600,9 +596,9 @@ static int process_arguments(int argc, char **argv) { | |||
600 | } | 596 | } |
601 | } | 597 | } |
602 | 598 | ||
603 | c = optind; | 599 | option_char = optind; |
604 | if (!host_specified && c < argc) | 600 | if (!host_specified && option_char < argc) |
605 | server_address = strdup(argv[c++]); | 601 | server_address = strdup(argv[option_char++]); |
606 | 602 | ||
607 | if (server_address == NULL) | 603 | if (server_address == NULL) |
608 | usage4(_("You must provide a server address")); | 604 | usage4(_("You must provide a server address")); |