From 0be4dede6e546234684b807618d930c1aa50fe31 Mon Sep 17 00:00:00 2001 From: RincewindsHat <12514511+RincewindsHat@users.noreply.github.com> Date: Thu, 31 Oct 2024 14:02:13 +0100 Subject: check_tcp: clang-format --- plugins/check_tcp.c | 556 ++++++++++++++++++++++++---------------------------- 1 file changed, 261 insertions(+), 295 deletions(-) (limited to 'plugins/check_tcp.c') diff --git a/plugins/check_tcp.c b/plugins/check_tcp.c index 01dd35eb..78dcbd43 100644 --- a/plugins/check_tcp.c +++ b/plugins/check_tcp.c @@ -1,31 +1,31 @@ /***************************************************************************** -* -* Monitoring check_tcp plugin -* -* License: GPL -* Copyright (c) 1999-2013 Monitoring Plugins Development Team -* -* Description: -* -* This file contains the check_tcp plugin -* -* -* This program is free software: you can redistribute it and/or modify -* it under the terms of the GNU General Public License as published by -* the Free Software Foundation, either version 3 of the License, or -* (at your option) any later version. -* -* This program is distributed in the hope that it will be useful, -* but WITHOUT ANY WARRANTY; without even the implied warranty of -* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -* GNU General Public License for more details. -* -* You should have received a copy of the GNU General Public License -* along with this program. If not, see . -* -* $Id$ -* -*****************************************************************************/ + * + * Monitoring check_tcp plugin + * + * License: GPL + * Copyright (c) 1999-2013 Monitoring Plugins Development Team + * + * Description: + * + * This file contains the check_tcp plugin + * + * + * This program is free software: you can redistribute it and/or modify + * it under the terms of the GNU General Public License as published by + * the Free Software Foundation, either version 3 of the License, or + * (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program. If not, see . + * + * $Id$ + * + *****************************************************************************/ /* progname "check_tcp" changes depending on symlink called */ char *progname; @@ -43,17 +43,17 @@ const char *email = "devel@monitoring-plugins.org"; #ifdef HAVE_SSL static bool check_cert = false; static int days_till_exp_warn, days_till_exp_crit; -# define my_recv(buf, len) ((flags & FLAG_SSL) ? np_net_ssl_read(buf, len) : read(sd, buf, len)) -# define my_send(buf, len) ((flags & FLAG_SSL) ? np_net_ssl_write(buf, len) : send(sd, buf, len, 0)) +# define my_recv(buf, len) ((flags & FLAG_SSL) ? np_net_ssl_read(buf, len) : read(sd, buf, len)) +# define my_send(buf, len) ((flags & FLAG_SSL) ? np_net_ssl_write(buf, len) : send(sd, buf, len, 0)) #else -# define my_recv(buf, len) read(sd, buf, len) -# define my_send(buf, len) send(sd, buf, len, 0) +# define my_recv(buf, len) read(sd, buf, len) +# define my_send(buf, len) send(sd, buf, len, 0) #endif /* int my_recv(char *, size_t); */ -static int process_arguments (int, char **); -void print_help (void); -void print_usage (void); +static int process_arguments(int, char **); +void print_help(void); +void print_usage(void); #define EXPECT server_expect[0] static char *SERVICE = "TCP"; @@ -91,16 +91,14 @@ static char *sni = NULL; static bool sni_specified = false; #endif -#define FLAG_SSL 0x01 -#define FLAG_VERBOSE 0x02 -#define FLAG_TIME_WARN 0x04 -#define FLAG_TIME_CRIT 0x08 +#define FLAG_SSL 0x01 +#define FLAG_VERBOSE 0x02 +#define FLAG_TIME_WARN 0x04 +#define FLAG_TIME_CRIT 0x08 #define FLAG_HIDE_OUTPUT 0x10 static size_t flags; -int -main (int argc, char **argv) -{ +int main(int argc, char **argv) { int result = STATE_UNKNOWN; char *status = NULL; struct timeval tv; @@ -110,19 +108,21 @@ main (int argc, char **argv) FD_ZERO(&rfds); - setlocale (LC_ALL, ""); - bindtextdomain (PACKAGE, LOCALEDIR); - textdomain (PACKAGE); + setlocale(LC_ALL, ""); + bindtextdomain(PACKAGE, LOCALEDIR); + textdomain(PACKAGE); /* determine program- and service-name quickly */ progname = strrchr(argv[0], '/'); - if(progname != NULL) progname++; - else progname = argv[0]; + if (progname != NULL) + progname++; + else + progname = argv[0]; size_t prog_name_len = strlen(progname); - if(prog_name_len > 6 && !memcmp(progname, "check_", 6)) { + if (prog_name_len > 6 && !memcmp(progname, "check_", 6)) { SERVICE = strdup(progname + 6); - for(size_t i = 0; i < prog_name_len - 6; i++) + for (size_t i = 0; i < prog_name_len - 6; i++) SERVICE[i] = toupper(SERVICE[i]); } @@ -133,23 +133,19 @@ main (int argc, char **argv) /* determine defaults for this service's protocol */ if (!strncmp(SERVICE, "UDP", 3)) { PROTOCOL = IPPROTO_UDP; - } - else if (!strncmp(SERVICE, "FTP", 3)) { + } else if (!strncmp(SERVICE, "FTP", 3)) { EXPECT = "220"; QUIT = "QUIT\r\n"; PORT = 21; - } - else if (!strncmp(SERVICE, "POP", 3) || !strncmp(SERVICE, "POP3", 4)) { + } else if (!strncmp(SERVICE, "POP", 3) || !strncmp(SERVICE, "POP3", 4)) { EXPECT = "+OK"; QUIT = "QUIT\r\n"; PORT = 110; - } - else if (!strncmp(SERVICE, "SMTP", 4)) { + } else if (!strncmp(SERVICE, "SMTP", 4)) { EXPECT = "220"; QUIT = "QUIT\r\n"; PORT = 25; - } - else if (!strncmp(SERVICE, "IMAP", 4)) { + } else if (!strncmp(SERVICE, "IMAP", 4)) { EXPECT = "* OK"; QUIT = "a1 LOGOUT\r\n"; PORT = 143; @@ -160,27 +156,23 @@ main (int argc, char **argv) QUIT = "a1 LOGOUT\r\n"; flags |= FLAG_SSL; PORT = 993; - } - else if (!strncmp(SERVICE, "SPOP", 4)) { + } else if (!strncmp(SERVICE, "SPOP", 4)) { EXPECT = "+OK"; QUIT = "QUIT\r\n"; flags |= FLAG_SSL; PORT = 995; - } - else if (!strncmp(SERVICE, "SSMTP", 5)) { + } else if (!strncmp(SERVICE, "SSMTP", 5)) { EXPECT = "220"; QUIT = "QUIT\r\n"; flags |= FLAG_SSL; PORT = 465; - } - else if (!strncmp(SERVICE, "JABBER", 6)) { + } else if (!strncmp(SERVICE, "JABBER", 6)) { SEND = "\n"; EXPECT = "\n"; flags |= FLAG_HIDE_OUTPUT; PORT = 5222; - } - else if (!strncmp (SERVICE, "NNTPS", 5)) { + } else if (!strncmp(SERVICE, "NNTPS", 5)) { server_expect_count = 2; server_expect[0] = "200"; server_expect[1] = "201"; @@ -189,23 +181,22 @@ main (int argc, char **argv) PORT = 563; } #endif - else if (!strncmp (SERVICE, "NNTP", 4)) { + else if (!strncmp(SERVICE, "NNTP", 4)) { server_expect_count = 2; server_expect = malloc(sizeof(char *) * server_expect_count); server_expect[0] = strdup("200"); server_expect[1] = strdup("201"); QUIT = "QUIT\r\n"; PORT = 119; - } - else if (!strncmp(SERVICE, "CLAMD", 5)) { + } else if (!strncmp(SERVICE, "CLAMD", 5)) { SEND = "PING"; EXPECT = "PONG"; QUIT = NULL; PORT = 3310; } /* fallthrough check, so it's supposed to use reverse matching */ - else if (strcmp (SERVICE, "TCP")) - usage (_("CRITICAL - Generic check_tcp called with unknown service\n")); + else if (strcmp(SERVICE, "TCP")) + usage(_("CRITICAL - Generic check_tcp called with unknown service\n")); server_address = "127.0.0.1"; server_port = PORT; @@ -214,58 +205,60 @@ main (int argc, char **argv) status = NULL; /* Parse extra opts if any */ - argv=np_extra_opts (&argc, argv, progname); + argv = np_extra_opts(&argc, argv, progname); - if (process_arguments (argc, argv) == ERROR) - usage4 (_("Could not parse arguments")); + if (process_arguments(argc, argv) == ERROR) + usage4(_("Could not parse arguments")); - if(flags & FLAG_VERBOSE) { + if (flags & FLAG_VERBOSE) { printf("Using service %s\n", SERVICE); printf("Port: %d\n", server_port); printf("flags: 0x%x\n", (int)flags); } - if(EXPECT && !server_expect_count) + if (EXPECT && !server_expect_count) server_expect_count++; - if(PROTOCOL==IPPROTO_UDP && !(server_expect_count && server_send)){ + if (PROTOCOL == IPPROTO_UDP && !(server_expect_count && server_send)) { usage(_("With UDP checks, a send/expect string must be specified.")); } /* set up the timer */ - signal (SIGALRM, socket_timeout_alarm_handler); - alarm (socket_timeout); + signal(SIGALRM, socket_timeout_alarm_handler); + alarm(socket_timeout); /* try to connect to the host at the given port number */ - gettimeofday (&tv, NULL); + gettimeofday(&tv, NULL); - result = np_net_connect (server_address, server_port, &sd, PROTOCOL); - if (result == STATE_CRITICAL) return econn_refuse_state; + result = np_net_connect(server_address, server_port, &sd, PROTOCOL); + if (result == STATE_CRITICAL) + return econn_refuse_state; #ifdef HAVE_SSL - if (flags & FLAG_SSL){ + if (flags & FLAG_SSL) { result = np_net_ssl_init_with_hostname(sd, (sni_specified ? sni : NULL)); if (result == STATE_OK && check_cert) { result = np_net_ssl_check_cert(days_till_exp_warn, days_till_exp_crit); } } - if(result != STATE_OK){ - if(sd) close(sd); + if (result != STATE_OK) { + if (sd) + close(sd); np_net_ssl_cleanup(); return result; } #endif /* HAVE_SSL */ - if (server_send != NULL) { /* Something to send? */ + if (server_send != NULL) { /* Something to send? */ my_send(server_send, strlen(server_send)); } if (delay > 0) { tv.tv_sec += delay; - sleep (delay); + sleep(delay); } - if(flags & FLAG_VERBOSE) { + if (flags & FLAG_VERBOSE) { if (server_send) { printf("Send string: %s\n", server_send); } @@ -273,7 +266,7 @@ main (int argc, char **argv) printf("Quit string: %s\n", server_quit); } printf("server_expect_count: %d\n", (int)server_expect_count); - for(size_t i = 0; i < server_expect_count; i++) + for (size_t i = 0; i < server_expect_count; i++) printf("\t%zd: %s\n", i, server_expect[i]); } @@ -294,17 +287,14 @@ main (int argc, char **argv) if (maxbytes && len >= maxbytes) break; - if ((match = np_expect_match(status, - server_expect, - server_expect_count, - match_flags)) != NP_MATCH_RETRY) + if ((match = np_expect_match(status, server_expect, server_expect_count, match_flags)) != NP_MATCH_RETRY) break; /* some protocols wait for further input, so make sure we don't wait forever */ FD_SET(sd, &rfds); - timeout.tv_sec = READ_TIMEOUT; + timeout.tv_sec = READ_TIMEOUT; timeout.tv_usec = 0; - if(select(sd + 1, &rfds, NULL, NULL, &timeout) <= 0) + if (select(sd + 1, &rfds, NULL, NULL, &timeout) <= 0) break; } @@ -313,26 +303,26 @@ main (int argc, char **argv) /* no data when expected, so return critical */ if (len == 0) - die (STATE_CRITICAL, _("No data received from host\n")); + die(STATE_CRITICAL, _("No data received from host\n")); /* print raw output if we're debugging */ - if(flags & FLAG_VERBOSE) - printf("received %d bytes from host\n#-raw-recv-------#\n%s\n#-raw-recv-------#\n", - (int)len + 1, status); + if (flags & FLAG_VERBOSE) + printf("received %d bytes from host\n#-raw-recv-------#\n%s\n#-raw-recv-------#\n", (int)len + 1, status); /* strip whitespace from end of output */ - while(--len > 0 && isspace(status[len])) + while (--len > 0 && isspace(status[len])) status[len] = '\0'; } if (server_quit != NULL) { my_send(server_quit, strlen(server_quit)); } - if (sd) close (sd); + if (sd) + close(sd); #ifdef HAVE_SSL np_net_ssl_cleanup(); #endif - microsec = deltime (tv); + microsec = deltime(tv); elapsed_time = (double)microsec / 1.0e6; if (flags & FLAG_TIME_CRIT && elapsed_time > critical_time) @@ -341,66 +331,52 @@ main (int argc, char **argv) result = STATE_WARNING; /* did we get the response we hoped? */ - if(match == NP_MATCH_FAILURE && result != STATE_CRITICAL) + if (match == NP_MATCH_FAILURE && result != STATE_CRITICAL) result = expect_mismatch_state; /* reset the alarm */ - alarm (0); + alarm(0); /* this is a bit stupid, because we don't want to print the * response time (which can look ok to the user) if we didn't get * the response we were looking for. if-else */ printf("%s %s - ", SERVICE, state_text(result)); - if(match == NP_MATCH_FAILURE && len && !(flags & FLAG_HIDE_OUTPUT)) + if (match == NP_MATCH_FAILURE && len && !(flags & FLAG_HIDE_OUTPUT)) printf("Unexpected response from host/socket: %s", status); else { - if(match == NP_MATCH_FAILURE) + if (match == NP_MATCH_FAILURE) printf("Unexpected response from host/socket on "); else printf("%.3f second response time on ", elapsed_time); - if(server_address[0] != '/') { + if (server_address[0] != '/') { if (host_specified) - printf("%s port %d", - server_address, server_port); + printf("%s port %d", server_address, server_port); else printf("port %d", server_port); - } - else + } else printf("socket %s", server_address); } if (match != NP_MATCH_FAILURE && !(flags & FLAG_HIDE_OUTPUT) && len) - printf (" [%s]", status); + printf(" [%s]", status); /* perf-data doesn't apply when server doesn't talk properly, * so print all zeroes on warn and crit. Use fperfdata since * localisation settings can make different outputs */ - if(match == NP_MATCH_FAILURE) - printf ("|%s", - fperfdata ("time", elapsed_time, "s", - (flags & FLAG_TIME_WARN ? true : false), 0, - (flags & FLAG_TIME_CRIT ? true : false), 0, - true, 0, - true, socket_timeout) - ); + if (match == NP_MATCH_FAILURE) + printf("|%s", fperfdata("time", elapsed_time, "s", (flags & FLAG_TIME_WARN ? true : false), 0, + (flags & FLAG_TIME_CRIT ? true : false), 0, true, 0, true, socket_timeout)); else - printf("|%s", - fperfdata ("time", elapsed_time, "s", - (flags & FLAG_TIME_WARN ? true : false), warning_time, - (flags & FLAG_TIME_CRIT ? true : false), critical_time, - true, 0, - true, socket_timeout) - ); + printf("|%s", fperfdata("time", elapsed_time, "s", (flags & FLAG_TIME_WARN ? true : false), warning_time, + (flags & FLAG_TIME_CRIT ? true : false), critical_time, true, 0, true, socket_timeout)); putchar('\n'); return result; } - - /* process command-line arguments */ -static int process_arguments (int argc, char **argv) { +static int process_arguments(int argc, char **argv) { int c; bool escape = false; char *temp; @@ -410,50 +386,48 @@ static int process_arguments (int argc, char **argv) { }; int option = 0; - static struct option longopts[] = { - {"hostname", required_argument, 0, 'H'}, - {"critical", required_argument, 0, 'c'}, - {"warning", required_argument, 0, 'w'}, - {"critical-codes", required_argument, 0, 'C'}, - {"warning-codes", required_argument, 0, 'W'}, - {"timeout", required_argument, 0, 't'}, - {"protocol", required_argument, 0, 'P'}, /* FIXME: Unhandled */ - {"port", required_argument, 0, 'p'}, - {"escape", no_argument, 0, 'E'}, - {"all", no_argument, 0, 'A'}, - {"send", required_argument, 0, 's'}, - {"expect", required_argument, 0, 'e'}, - {"maxbytes", required_argument, 0, 'm'}, - {"quit", required_argument, 0, 'q'}, - {"jail", no_argument, 0, 'j'}, - {"delay", required_argument, 0, 'd'}, - {"refuse", required_argument, 0, 'r'}, - {"mismatch", required_argument, 0, 'M'}, - {"use-ipv4", no_argument, 0, '4'}, - {"use-ipv6", no_argument, 0, '6'}, - {"verbose", no_argument, 0, 'v'}, - {"version", no_argument, 0, 'V'}, - {"help", no_argument, 0, 'h'}, - {"ssl", no_argument, 0, 'S'}, - {"sni", required_argument, 0, SNI_OPTION}, - {"certificate", required_argument, 0, 'D'}, - {0, 0, 0, 0} - }; + static struct option longopts[] = {{"hostname", required_argument, 0, 'H'}, + {"critical", required_argument, 0, 'c'}, + {"warning", required_argument, 0, 'w'}, + {"critical-codes", required_argument, 0, 'C'}, + {"warning-codes", required_argument, 0, 'W'}, + {"timeout", required_argument, 0, 't'}, + {"protocol", required_argument, 0, 'P'}, /* FIXME: Unhandled */ + {"port", required_argument, 0, 'p'}, + {"escape", no_argument, 0, 'E'}, + {"all", no_argument, 0, 'A'}, + {"send", required_argument, 0, 's'}, + {"expect", required_argument, 0, 'e'}, + {"maxbytes", required_argument, 0, 'm'}, + {"quit", required_argument, 0, 'q'}, + {"jail", no_argument, 0, 'j'}, + {"delay", required_argument, 0, 'd'}, + {"refuse", required_argument, 0, 'r'}, + {"mismatch", required_argument, 0, 'M'}, + {"use-ipv4", no_argument, 0, '4'}, + {"use-ipv6", no_argument, 0, '6'}, + {"verbose", no_argument, 0, 'v'}, + {"version", no_argument, 0, 'V'}, + {"help", no_argument, 0, 'h'}, + {"ssl", no_argument, 0, 'S'}, + {"sni", required_argument, 0, SNI_OPTION}, + {"certificate", required_argument, 0, 'D'}, + {0, 0, 0, 0}}; if (argc < 2) - usage4 (_("No arguments found")); + usage4(_("No arguments found")); /* backwards compatibility */ for (c = 1; c < argc; c++) { - if (strcmp ("-to", argv[c]) == 0) - strcpy (argv[c], "-t"); - else if (strcmp ("-wt", argv[c]) == 0) - strcpy (argv[c], "-w"); - else if (strcmp ("-ct", argv[c]) == 0) - strcpy (argv[c], "-c"); + if (strcmp("-to", argv[c]) == 0) + strcpy(argv[c], "-t"); + else if (strcmp("-wt", argv[c]) == 0) + strcpy(argv[c], "-w"); + else if (strcmp("-ct", argv[c]) == 0) + strcpy(argv[c], "-c"); } - if (!is_option (argv[1])) { + if (!is_option(argv[1])) { server_address = argv[1]; argv[1] = argv[0]; argv = &argv[1]; @@ -461,22 +435,21 @@ static int process_arguments (int argc, char **argv) { } while (1) { - c = getopt_long (argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", - longopts, &option); + c = getopt_long(argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", longopts, &option); if (c == -1 || c == EOF || c == 1) break; switch (c) { - case '?': /* print short usage statement if args not parsable */ - usage5 (); - case 'h': /* help */ - print_help (); - exit (STATE_UNKNOWN); - case 'V': /* version */ - print_revision (progname, NP_VERSION); - exit (STATE_UNKNOWN); - case 'v': /* verbose mode */ + case '?': /* print short usage statement if args not parsable */ + usage5(); + case 'h': /* help */ + print_help(); + exit(STATE_UNKNOWN); + case 'V': /* version */ + print_revision(progname, NP_VERSION); + exit(STATE_UNKNOWN); + case 'v': /* verbose mode */ flags |= FLAG_VERBOSE; match_flags |= NP_MATCH_VERBOSE; break; @@ -487,43 +460,43 @@ static int process_arguments (int argc, char **argv) { #ifdef USE_IPV6 address_family = AF_INET6; #else - usage4 (_("IPv6 support not available")); + usage4(_("IPv6 support not available")); #endif break; - case 'H': /* hostname */ + case 'H': /* hostname */ host_specified = true; server_address = optarg; break; - case 'c': /* critical */ - critical_time = strtod (optarg, NULL); + case 'c': /* critical */ + critical_time = strtod(optarg, NULL); flags |= FLAG_TIME_CRIT; break; - case 'j': /* hide output */ + case 'j': /* hide output */ flags |= FLAG_HIDE_OUTPUT; break; - case 'w': /* warning */ - warning_time = strtod (optarg, NULL); + case 'w': /* warning */ + warning_time = strtod(optarg, NULL); flags |= FLAG_TIME_WARN; break; case 'C': - crit_codes = realloc (crit_codes, ++crit_codes_count); + crit_codes = realloc(crit_codes, ++crit_codes_count); crit_codes[crit_codes_count - 1] = optarg; break; case 'W': - warn_codes = realloc (warn_codes, ++warn_codes_count); + warn_codes = realloc(warn_codes, ++warn_codes_count); warn_codes[warn_codes_count - 1] = optarg; break; - case 't': /* timeout */ - if (!is_intpos (optarg)) - usage4 (_("Timeout interval must be a positive integer")); + case 't': /* timeout */ + if (!is_intpos(optarg)) + usage4(_("Timeout interval must be a positive integer")); else - socket_timeout = atoi (optarg); + socket_timeout = atoi(optarg); break; - case 'p': /* port */ - if (!is_intpos (optarg)) - usage4 (_("Port must be a positive integer")); + case 'p': /* port */ + if (!is_intpos(optarg)) + usage4(_("Port must be a positive integer")); else - server_port = atoi (optarg); + server_port = atoi(optarg); break; case 'E': escape = true; @@ -537,16 +510,16 @@ static int process_arguments (int argc, char **argv) { case 'e': /* expect string (may be repeated) */ match_flags &= ~NP_MATCH_EXACT; if (server_expect_count == 0) - server_expect = malloc (sizeof (char *) * (++server_expect_count)); + server_expect = malloc(sizeof(char *) * (++server_expect_count)); else - server_expect = realloc (server_expect, sizeof (char *) * (++server_expect_count)); + server_expect = realloc(server_expect, sizeof(char *) * (++server_expect_count)); server_expect[server_expect_count - 1] = optarg; break; case 'm': - if (!is_intpos (optarg)) - usage4 (_("Maxbytes must be a positive integer")); + if (!is_intpos(optarg)) + usage4(_("Maxbytes must be a positive integer")); else - maxbytes = strtol (optarg, NULL, 0); + maxbytes = strtol(optarg, NULL, 0); break; case 'q': if (escape) @@ -555,62 +528,61 @@ static int process_arguments (int argc, char **argv) { xasprintf(&server_quit, "%s\r\n", optarg); break; case 'r': - if (!strncmp(optarg,"ok",2)) + if (!strncmp(optarg, "ok", 2)) econn_refuse_state = STATE_OK; - else if (!strncmp(optarg,"warn",4)) + else if (!strncmp(optarg, "warn", 4)) econn_refuse_state = STATE_WARNING; - else if (!strncmp(optarg,"crit",4)) + else if (!strncmp(optarg, "crit", 4)) econn_refuse_state = STATE_CRITICAL; else - usage4 (_("Refuse must be one of ok, warn, crit")); + usage4(_("Refuse must be one of ok, warn, crit")); break; case 'M': - if (!strncmp(optarg,"ok",2)) + if (!strncmp(optarg, "ok", 2)) expect_mismatch_state = STATE_OK; - else if (!strncmp(optarg,"warn",4)) + else if (!strncmp(optarg, "warn", 4)) expect_mismatch_state = STATE_WARNING; - else if (!strncmp(optarg,"crit",4)) + else if (!strncmp(optarg, "crit", 4)) expect_mismatch_state = STATE_CRITICAL; else - usage4 (_("Mismatch must be one of ok, warn, crit")); + usage4(_("Mismatch must be one of ok, warn, crit")); break; case 'd': - if (is_intpos (optarg)) - delay = atoi (optarg); + if (is_intpos(optarg)) + delay = atoi(optarg); else - usage4 (_("Delay must be a positive integer")); + usage4(_("Delay must be a positive integer")); break; case 'D': /* Check SSL cert validity - days 'til certificate expiration */ #ifdef HAVE_SSL -# ifdef USE_OPENSSL /* XXX */ - if ((temp=strchr(optarg,','))!=NULL) { - *temp='\0'; - if (!is_intnonneg (optarg)) - usage2 (_("Invalid certificate expiration period"), optarg); - days_till_exp_warn = atoi (optarg); - *temp=','; - temp++; - if (!is_intnonneg (temp)) - usage2 (_("Invalid certificate expiration period"), temp); - days_till_exp_crit = atoi (temp); - } - else { - days_till_exp_crit=0; - if (!is_intnonneg (optarg)) - usage2 (_("Invalid certificate expiration period"), optarg); - days_till_exp_warn = atoi (optarg); +# ifdef USE_OPENSSL /* XXX */ + if ((temp = strchr(optarg, ',')) != NULL) { + *temp = '\0'; + if (!is_intnonneg(optarg)) + usage2(_("Invalid certificate expiration period"), optarg); + days_till_exp_warn = atoi(optarg); + *temp = ','; + temp++; + if (!is_intnonneg(temp)) + usage2(_("Invalid certificate expiration period"), temp); + days_till_exp_crit = atoi(temp); + } else { + days_till_exp_crit = 0; + if (!is_intnonneg(optarg)) + usage2(_("Invalid certificate expiration period"), optarg); + days_till_exp_warn = atoi(optarg); } check_cert = true; flags |= FLAG_SSL; break; -# endif /* USE_OPENSSL */ +# endif /* USE_OPENSSL */ #endif /* fallthrough if we don't have ssl */ case 'S': #ifdef HAVE_SSL flags |= FLAG_SSL; #else - die (STATE_UNKNOWN, _("Invalid option - SSL is not available")); + die(STATE_UNKNOWN, _("Invalid option - SSL is not available")); #endif break; case SNI_OPTION: @@ -619,7 +591,7 @@ static int process_arguments (int argc, char **argv) { sni_specified = true; sni = optarg; #else - die (STATE_UNKNOWN, _("Invalid option - SSL is not available")); + die(STATE_UNKNOWN, _("Invalid option - SSL is not available")); #endif break; case 'A': @@ -629,86 +601,80 @@ static int process_arguments (int argc, char **argv) { } c = optind; - if(!host_specified && c < argc) - server_address = strdup (argv[c++]); + if (!host_specified && c < argc) + server_address = strdup(argv[c++]); if (server_address == NULL) - usage4 (_("You must provide a server address")); + usage4(_("You must provide a server address")); else if (server_address[0] != '/' && !is_host(server_address)) - die (STATE_CRITICAL, "%s %s - %s: %s\n", SERVICE, state_text(STATE_CRITICAL), _("Invalid hostname, address or socket"), server_address); + die(STATE_CRITICAL, "%s %s - %s: %s\n", SERVICE, state_text(STATE_CRITICAL), _("Invalid hostname, address or socket"), + server_address); return OK; } - -void -print_help (void) -{ - print_revision (progname, NP_VERSION); - - printf ("Copyright (c) 1999 Ethan Galstad \n"); - printf (COPYRIGHT, copyright, email); - - printf (_("This plugin tests %s connections with the specified host (or unix socket).\n\n"), - SERVICE); - - print_usage (); - - printf (UT_HELP_VRSN); - printf (UT_EXTRA_OPTS); - - printf (UT_HOST_PORT, 'p', "none"); - - printf (UT_IPv46); - - printf (" %s\n", "-E, --escape"); - printf (" %s\n", _("Can use \\n, \\r, \\t or \\\\ in send or quit string. Must come before send or quit option")); - printf (" %s\n", _("Default: nothing added to send, \\r\\n added to end of quit")); - printf (" %s\n", "-s, --send=STRING"); - printf (" %s\n", _("String to send to the server")); - printf (" %s\n", "-e, --expect=STRING"); - printf (" %s %s\n", _("String to expect in server response"), _("(may be repeated)")); - printf (" %s\n", "-A, --all"); - printf (" %s\n", _("All expect strings need to occur in server response. Default is any")); - printf (" %s\n", "-q, --quit=STRING"); - printf (" %s\n", _("String to send server to initiate a clean close of the connection")); - printf (" %s\n", "-r, --refuse=ok|warn|crit"); - printf (" %s\n", _("Accept TCP refusals with states ok, warn, crit (default: crit)")); - printf (" %s\n", "-M, --mismatch=ok|warn|crit"); - printf (" %s\n", _("Accept expected string mismatches with states ok, warn, crit (default: warn)")); - printf (" %s\n", "-j, --jail"); - printf (" %s\n", _("Hide output from TCP socket")); - printf (" %s\n", "-m, --maxbytes=INTEGER"); - printf (" %s\n", _("Close connection once more than this number of bytes are received")); - printf (" %s\n", "-d, --delay=INTEGER"); - printf (" %s\n", _("Seconds to wait between sending string and polling for response")); +void print_help(void) { + print_revision(progname, NP_VERSION); + + printf("Copyright (c) 1999 Ethan Galstad \n"); + printf(COPYRIGHT, copyright, email); + + printf(_("This plugin tests %s connections with the specified host (or unix socket).\n\n"), SERVICE); + + print_usage(); + + printf(UT_HELP_VRSN); + printf(UT_EXTRA_OPTS); + + printf(UT_HOST_PORT, 'p', "none"); + + printf(UT_IPv46); + + printf(" %s\n", "-E, --escape"); + printf(" %s\n", _("Can use \\n, \\r, \\t or \\\\ in send or quit string. Must come before send or quit option")); + printf(" %s\n", _("Default: nothing added to send, \\r\\n added to end of quit")); + printf(" %s\n", "-s, --send=STRING"); + printf(" %s\n", _("String to send to the server")); + printf(" %s\n", "-e, --expect=STRING"); + printf(" %s %s\n", _("String to expect in server response"), _("(may be repeated)")); + printf(" %s\n", "-A, --all"); + printf(" %s\n", _("All expect strings need to occur in server response. Default is any")); + printf(" %s\n", "-q, --quit=STRING"); + printf(" %s\n", _("String to send server to initiate a clean close of the connection")); + printf(" %s\n", "-r, --refuse=ok|warn|crit"); + printf(" %s\n", _("Accept TCP refusals with states ok, warn, crit (default: crit)")); + printf(" %s\n", "-M, --mismatch=ok|warn|crit"); + printf(" %s\n", _("Accept expected string mismatches with states ok, warn, crit (default: warn)")); + printf(" %s\n", "-j, --jail"); + printf(" %s\n", _("Hide output from TCP socket")); + printf(" %s\n", "-m, --maxbytes=INTEGER"); + printf(" %s\n", _("Close connection once more than this number of bytes are received")); + printf(" %s\n", "-d, --delay=INTEGER"); + printf(" %s\n", _("Seconds to wait between sending string and polling for response")); #ifdef HAVE_SSL - printf (" %s\n", "-D, --certificate=INTEGER[,INTEGER]"); - printf (" %s\n", _("Minimum number of days a certificate has to be valid.")); - printf (" %s\n", _("1st is #days for warning, 2nd is critical (if not specified - 0).")); - printf (" %s\n", "-S, --ssl"); - printf (" %s\n", _("Use SSL for the connection.")); - printf (" %s\n", "--sni=STRING"); - printf (" %s\n", _("SSL server_name")); + printf(" %s\n", "-D, --certificate=INTEGER[,INTEGER]"); + printf(" %s\n", _("Minimum number of days a certificate has to be valid.")); + printf(" %s\n", _("1st is #days for warning, 2nd is critical (if not specified - 0).")); + printf(" %s\n", "-S, --ssl"); + printf(" %s\n", _("Use SSL for the connection.")); + printf(" %s\n", "--sni=STRING"); + printf(" %s\n", _("SSL server_name")); #endif - printf (UT_WARN_CRIT); + printf(UT_WARN_CRIT); - printf (UT_CONN_TIMEOUT, DEFAULT_SOCKET_TIMEOUT); + printf(UT_CONN_TIMEOUT, DEFAULT_SOCKET_TIMEOUT); - printf (UT_VERBOSE); + printf(UT_VERBOSE); - printf (UT_SUPPORT); + printf(UT_SUPPORT); } - -void -print_usage (void) -{ - printf ("%s\n", _("Usage:")); - printf ("%s -H host -p port [-w ] [-c ] [-s ]\n",progname); - printf ("[-e ] [-q ][-m ] [-d ]\n"); - printf ("[-t ] [-r ] [-M ] [-v] [-4|-6] [-j]\n"); - printf ("[-D [,]] [-S ] [-E]\n"); +void print_usage(void) { + printf("%s\n", _("Usage:")); + printf("%s -H host -p port [-w ] [-c ] [-s ]\n", progname); + printf("[-e ] [-q ][-m ] [-d ]\n"); + printf("[-t ] [-r ] [-M ] [-v] [-4|-6] [-j]\n"); + printf("[-D [,]] [-S ] [-E]\n"); } -- cgit v1.2.3-74-g34f1 From ec70b396727570c21465f8d94fb64105a80ae958 Mon Sep 17 00:00:00 2001 From: RincewindsHat <12514511+RincewindsHat@users.noreply.github.com> Date: Thu, 31 Oct 2024 14:02:57 +0100 Subject: check_tcp: update_copyright --- plugins/check_tcp.c | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) (limited to 'plugins/check_tcp.c') diff --git a/plugins/check_tcp.c b/plugins/check_tcp.c index 78dcbd43..af318853 100644 --- a/plugins/check_tcp.c +++ b/plugins/check_tcp.c @@ -3,7 +3,7 @@ * Monitoring check_tcp plugin * * License: GPL - * Copyright (c) 1999-2013 Monitoring Plugins Development Team + * Copyright (c) 1999-2024 Monitoring Plugins Development Team * * Description: * @@ -29,7 +29,7 @@ /* progname "check_tcp" changes depending on symlink called */ char *progname; -const char *copyright = "1999-2008"; +const char *copyright = "1999-2024"; const char *email = "devel@monitoring-plugins.org"; #include "common.h" -- cgit v1.2.3-74-g34f1 From c1f337c6537110d87b4cf2e63454889f910c3fa2 Mon Sep 17 00:00:00 2001 From: RincewindsHat <12514511+RincewindsHat@users.noreply.github.com> Date: Thu, 31 Oct 2024 14:07:54 +0100 Subject: check_tcp: style + linter fixes --- plugins/check_tcp.c | 62 +++++++++++++++++++++++++---------------------------- 1 file changed, 29 insertions(+), 33 deletions(-) (limited to 'plugins/check_tcp.c') 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; #endif /* int my_recv(char *, size_t); */ -static int process_arguments(int, char **); -void print_help(void); +static int process_arguments(int /*argc*/, char ** /*argv*/); +static void print_help(void); void print_usage(void); #define EXPECT server_expect[0] @@ -99,15 +99,6 @@ static bool sni_specified = false; static size_t flags; int main(int argc, char **argv) { - int result = STATE_UNKNOWN; - char *status = NULL; - struct timeval tv; - struct timeval timeout; - int match = -1; - fd_set rfds; - - FD_ZERO(&rfds); - setlocale(LC_ALL, ""); bindtextdomain(PACKAGE, LOCALEDIR); textdomain(PACKAGE); @@ -202,7 +193,7 @@ int main(int argc, char **argv) { server_port = PORT; server_send = SEND; server_quit = QUIT; - status = NULL; + char *status = NULL; /* Parse extra opts if any */ argv = np_extra_opts(&argc, argv, progname); @@ -228,8 +219,10 @@ int main(int argc, char **argv) { alarm(socket_timeout); /* try to connect to the host at the given port number */ + struct timeval tv; gettimeofday(&tv, NULL); + int result = STATE_UNKNOWN; result = np_net_connect(server_address, server_port, &sd, PROTOCOL); if (result == STATE_CRITICAL) return econn_refuse_state; @@ -273,6 +266,10 @@ int main(int argc, char **argv) { /* if(len) later on, we know we have a non-NULL response */ ssize_t len = 0; + int match = -1; + struct timeval timeout; + fd_set rfds; + FD_ZERO(&rfds); if (server_expect_count) { ssize_t received = 0; @@ -377,15 +374,10 @@ int main(int argc, char **argv) { /* process command-line arguments */ static int process_arguments(int argc, char **argv) { - int c; - bool escape = false; - char *temp; - enum { SNI_OPTION = CHAR_MAX + 1 }; - int option = 0; static struct option longopts[] = {{"hostname", required_argument, 0, 'H'}, {"critical", required_argument, 0, 'c'}, {"warning", required_argument, 0, 'w'}, @@ -418,13 +410,13 @@ static int process_arguments(int argc, char **argv) { usage4(_("No arguments found")); /* backwards compatibility */ - for (c = 1; c < argc; c++) { - if (strcmp("-to", argv[c]) == 0) - strcpy(argv[c], "-t"); - else if (strcmp("-wt", argv[c]) == 0) - strcpy(argv[c], "-w"); - else if (strcmp("-ct", argv[c]) == 0) - strcpy(argv[c], "-c"); + for (int i = 1; i < argc; i++) { + if (strcmp("-to", argv[i]) == 0) + strcpy(argv[i], "-t"); + else if (strcmp("-wt", argv[i]) == 0) + strcpy(argv[i], "-w"); + else if (strcmp("-ct", argv[i]) == 0) + strcpy(argv[i], "-c"); } if (!is_option(argv[1])) { @@ -434,13 +426,16 @@ static int process_arguments(int argc, char **argv) { argc--; } - while (1) { - c = getopt_long(argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", longopts, &option); + int option_char; + bool escape = false; + while (true) { + int option = 0; + option_char = getopt_long(argc, argv, "+hVv46EAH:s:e:q:m:c:w:t:p:C:W:d:Sr:jD:M:", longopts, &option); - if (c == -1 || c == EOF || c == 1) + if (option_char == -1 || option_char == EOF || option_char == 1) break; - switch (c) { + switch (option_char) { case '?': /* print short usage statement if args not parsable */ usage5(); case 'h': /* help */ @@ -553,9 +548,10 @@ static int process_arguments(int argc, char **argv) { else usage4(_("Delay must be a positive integer")); break; - case 'D': /* Check SSL cert validity - days 'til certificate expiration */ + case 'D': { /* Check SSL cert validity - days 'til certificate expiration */ #ifdef HAVE_SSL # ifdef USE_OPENSSL /* XXX */ + char *temp; if ((temp = strchr(optarg, ',')) != NULL) { *temp = '\0'; if (!is_intnonneg(optarg)) @@ -574,7 +570,7 @@ static int process_arguments(int argc, char **argv) { } check_cert = true; flags |= FLAG_SSL; - break; + } break; # endif /* USE_OPENSSL */ #endif /* fallthrough if we don't have ssl */ @@ -600,9 +596,9 @@ static int process_arguments(int argc, char **argv) { } } - c = optind; - if (!host_specified && c < argc) - server_address = strdup(argv[c++]); + option_char = optind; + if (!host_specified && option_char < argc) + server_address = strdup(argv[option_char++]); if (server_address == NULL) usage4(_("You must provide a server address")); -- cgit v1.2.3-74-g34f1