From 8de299308c52d083b893a87e6924405b652f1f7b Mon Sep 17 00:00:00 2001 From: Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> Date: Wed, 27 Nov 2024 14:22:02 +0100 Subject: check_curl: update TLS notification notes --- plugins/check_curl.c | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/plugins/check_curl.c b/plugins/check_curl.c index 8ea73ce1..ef7d4ee4 100644 --- a/plugins/check_curl.c +++ b/plugins/check_curl.c @@ -1912,7 +1912,7 @@ void print_help(void) { printf(" %s\n", _("Connect via SSL. Port defaults to 443. VERSION is optional, and prevents")); printf(" %s\n", _("auto-negotiation (2 = SSLv2, 3 = SSLv3, 1 = TLSv1, 1.1 = TLSv1.1,")); printf(" %s\n", _("1.2 = TLSv1.2, 1.3 = TLSv1.3). With a '+' suffix, newer versions are also accepted.")); - printf(" %s\n", _("Note: SSLv2 and SSLv3 are deprecated and are usually disabled in libcurl")); + printf(" %s\n", _("Note: SSLv2, SSLv3, TLSv1.0 and TLSv1.1 are deprecated and are usually disabled in libcurl")); printf(" %s\n", "--sni"); printf(" %s\n", _("Enable SSL/TLS hostname extension support (SNI)")); # if LIBCURL_VERSION_NUM >= 0x071801 -- cgit v1.2.3-74-g34f1 From eb9f9cf8c47fc37553cc17d349a47c9dab0a5e8b Mon Sep 17 00:00:00 2001 From: Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:19:21 +0100 Subject: check_icmp: clang-format --- plugins-root/check_icmp.c | 294 +++++++++++++++++++++++++++++----------------- 1 file changed, 188 insertions(+), 106 deletions(-) diff --git a/plugins-root/check_icmp.c b/plugins-root/check_icmp.c index 960ab8f1..ea17b3a8 100644 --- a/plugins-root/check_icmp.c +++ b/plugins-root/check_icmp.c @@ -272,8 +272,9 @@ static void crash(const char *fmt, ...) { vprintf(fmt, ap); va_end(ap); - if (errno) + if (errno) { printf(": %s", strerror(errno)); + } puts(""); exit(3); @@ -282,8 +283,9 @@ static void crash(const char *fmt, ...) { static const char *get_icmp_error_msg(unsigned char icmp_type, unsigned char icmp_code) { const char *msg = "unreachable"; - if (debug > 1) + if (debug > 1) { printf("get_icmp_error_msg(%u, %u)\n", icmp_type, icmp_code); + } switch (icmp_type) { case ICMP_UNREACH: switch (icmp_code) { @@ -392,8 +394,9 @@ static int handle_random_icmp(unsigned char *packet, struct sockaddr_storage *ad return 0; } - if (debug) + if (debug) { printf("handle_random_icmp(%p, %p)\n", (void *)&p, (void *)addr); + } /* only handle a few types, since others can't possibly be replies to * us in a sane network (if it is anyway, it will be counted as lost @@ -413,8 +416,9 @@ static int handle_random_icmp(unsigned char *packet, struct sockaddr_storage *ad * to RFC 792). If it isn't, just ignore it */ memcpy(&sent_icmp, packet + 28, sizeof(sent_icmp)); if (sent_icmp.icmp_type != ICMP_ECHO || ntohs(sent_icmp.icmp_id) != pid || ntohs(sent_icmp.icmp_seq) >= targets * packets) { - if (debug) + if (debug) { printf("Packet is no response to a packet we sent\n"); + } return 0; } @@ -429,8 +433,9 @@ static int handle_random_icmp(unsigned char *packet, struct sockaddr_storage *ad icmp_lost++; host->icmp_lost++; /* don't spend time on lost hosts any more */ - if (host->flags & FLAG_LOST_CAUSE) + if (host->flags & FLAG_LOST_CAUSE) { return 0; + } /* source quench means we're sending too fast, so increase the * interval and mark this packet lost */ @@ -488,10 +493,11 @@ int main(int argc, char **argv) { /* get calling name the old-fashioned way for portability instead * of relying on the glibc-ism __progname */ ptr = strrchr(argv[0], '/'); - if (ptr) + if (ptr) { progname = &ptr[1]; - else + } else { progname = argv[0]; + } /* now set defaults. Use progname to set them initially (allows for * superfast check_host program when target host is up */ @@ -534,10 +540,12 @@ int main(int argc, char **argv) { /* support "--help" and "--version" */ if (argc == 2) { - if (!strcmp(argv[1], "--help")) + if (!strcmp(argv[1], "--help")) { strcpy(argv[1], "-h"); - if (!strcmp(argv[1], "--version")) + } + if (!strcmp(argv[1], "--version")) { strcpy(argv[1], "-V"); + } } /* Parse protocol arguments first */ @@ -545,14 +553,16 @@ int main(int argc, char **argv) { while ((arg = getopt(argc, argv, opts_str)) != EOF) { switch (arg) { case '4': - if (address_family != -1) + if (address_family != -1) { crash("Multiple protocol versions not supported"); + } address_family = AF_INET; break; case '6': #ifdef USE_IPV6 - if (address_family != -1) + if (address_family != -1) { crash("Multiple protocol versions not supported"); + } address_family = AF_INET6; #else usage(_("IPv6 support not available\n")); @@ -579,9 +589,10 @@ int main(int argc, char **argv) { if (size >= (sizeof(struct icmp) + sizeof(struct icmp_ping_data)) && size < MAX_PING_DATA) { icmp_data_size = size; icmp_pkt_size = size + ICMP_MINLEN; - } else + } else { usage_va("ICMP data length must be between: %lu and %lu", sizeof(struct icmp) + sizeof(struct icmp_ping_data), MAX_PING_DATA - 1); + } break; case 'i': pkt_interval = get_timevar(optarg); @@ -601,8 +612,9 @@ int main(int argc, char **argv) { break; case 't': timeout = strtoul(optarg, NULL, 0); - if (!timeout) + if (!timeout) { timeout = 10; + } break; case 'H': add_target(optarg); @@ -709,18 +721,22 @@ int main(int argc, char **argv) { default: crash("Address family not supported"); } - if ((icmp_sock = socket(address_family, SOCK_RAW, icmp_proto)) != -1) + if ((icmp_sock = socket(address_family, SOCK_RAW, icmp_proto)) != -1) { sockets |= HAVE_ICMP; - else + } else { icmp_sockerrno = errno; + } - if (source_ip) + if (source_ip) { set_source_ip(source_ip); + } #ifdef SO_TIMESTAMP - if (setsockopt(icmp_sock, SOL_SOCKET, SO_TIMESTAMP, &on, sizeof(on))) - if (debug) + if (setsockopt(icmp_sock, SOL_SOCKET, SO_TIMESTAMP, &on, sizeof(on))) { + if (debug) { printf("Warning: no SO_TIMESTAMP support\n"); + } + } #endif // SO_TIMESTAMP /* now drop privileges (no effect if not setsuid or geteuid() == 0) */ @@ -746,16 +762,18 @@ int main(int argc, char **argv) { /* return -1; */ /* } */ } - if (!ttl) + if (!ttl) { ttl = 64; + } if (icmp_sock) { result = setsockopt(icmp_sock, SOL_IP, IP_TTL, &ttl, sizeof(ttl)); if (debug) { - if (result == -1) + if (result == -1) { printf("setsockopt failed\n"); - else + } else { printf("ttl set to %u\n", ttl); + } } } @@ -763,18 +781,24 @@ int main(int argc, char **argv) { * (nothing will break if they do), but some anal plugin maintainer * will probably add some printf() thing here later, so it might be * best to at least show them where to do it. ;) */ - if (warn.pl > crit.pl) + if (warn.pl > crit.pl) { warn.pl = crit.pl; - if (warn.rta > crit.rta) + } + if (warn.rta > crit.rta) { warn.rta = crit.rta; - if (warn_down > crit_down) + } + if (warn_down > crit_down) { crit_down = warn_down; - if (warn.jitter > crit.jitter) + } + if (warn.jitter > crit.jitter) { crit.jitter = warn.jitter; - if (warn.mos < crit.mos) + } + if (warn.mos < crit.mos) { warn.mos = crit.mos; - if (warn.score < crit.score) + } + if (warn.score < crit.score) { warn.score = crit.score; + } #ifdef HAVE_SIGACTION sig_action.sa_sigaction = NULL; @@ -791,8 +815,9 @@ int main(int argc, char **argv) { signal(SIGTERM, finish); signal(SIGALRM, finish); #endif /* HAVE_SIGACTION */ - if (debug) + if (debug) { printf("Setting alarm timeout to %u seconds\n", timeout); + } alarm(timeout); /* make sure we don't wait any longer than necessary */ @@ -863,11 +888,13 @@ static void run_checks(void) { for (i = 0; i < packets; i++) { for (t = 0; t < targets; t++) { /* don't send useless packets */ - if (!targets_alive) + if (!targets_alive) { finish(0); + } if (table[t]->flags & FLAG_LOST_CAUSE) { - if (debug) + if (debug) { printf("%s is a lost cause. not sending any more\n", table[t]->name); + } continue; } @@ -886,15 +913,17 @@ static void run_checks(void) { printf("time_passed: %u final_wait: %u max_completion_time: %llu\n", time_passed, final_wait, max_completion_time); } if (time_passed > max_completion_time) { - if (debug) + if (debug) { printf("Time passed. Finishing up\n"); + } finish(0); } /* catch the packets that might come in within the timeframe, but * haven't yet */ - if (debug) + if (debug) { printf("Waiting for %u micro-seconds (%0.3f msecs)\n", final_wait, (float)final_wait / 1000); + } wait_for_reply(icmp_sock, final_wait); } } @@ -955,8 +984,9 @@ static int wait_for_reply(int sock, u_int t) { continue; /* timeout for this one, so keep trying */ } if (n < 0) { - if (debug) + if (debug) { printf("recvfrom_wto() returned errors\n"); + } free(packet.buf); return n; } @@ -1003,8 +1033,9 @@ static int wait_for_reply(int sock, u_int t) { ntohs(packet.icp->icmp_seq) >= targets * packets)) || (address_family == PF_INET6 && (ntohs(packet.icp6->icmp6_id) != pid || packet.icp6->icmp6_type != ICMP6_ECHO_REPLY || ntohs(packet.icp6->icmp6_seq) >= targets * packets))) { - if (debug > 2) + if (debug > 2) { printf("not a proper ICMP_ECHOREPLY\n"); + } handle_random_icmp(buf + hlen, &resp_addr); continue; } @@ -1012,15 +1043,17 @@ static int wait_for_reply(int sock, u_int t) { /* this is indeed a valid response */ if (address_family == PF_INET) { memcpy(&data, packet.icp->icmp_data, sizeof(data)); - if (debug > 2) + if (debug > 2) { printf("ICMP echo-reply of len %lu, id %u, seq %u, cksum 0x%X\n", (unsigned long)sizeof(data), ntohs(packet.icp->icmp_id), ntohs(packet.icp->icmp_seq), packet.icp->icmp_cksum); + } host = table[ntohs(packet.icp->icmp_seq) / packets]; } else { memcpy(&data, &packet.icp6->icmp6_dataun.icmp6_un_data8[4], sizeof(data)); - if (debug > 2) + if (debug > 2) { printf("ICMP echo-reply of len %lu, id %u, seq %u, cksum 0x%X\n", (unsigned long)sizeof(data), ntohs(packet.icp6->icmp6_id), ntohs(packet.icp6->icmp6_seq), packet.icp6->icmp6_cksum); + } host = table[ntohs(packet.icp6->icmp6_seq) / packets]; } @@ -1051,8 +1084,9 @@ static int wait_for_reply(int sock, u_int t) { } /* Check if packets in order */ - if (host->last_icmp_seq >= packet.icp->icmp_seq) + if (host->last_icmp_seq >= packet.icp->icmp_seq) { host->order_status = STATE_CRITICAL; + } } host->last_tdiff = tdiff; @@ -1061,10 +1095,12 @@ static int wait_for_reply(int sock, u_int t) { host->time_waited += tdiff; host->icmp_recv++; icmp_recv++; - if (tdiff > (unsigned int)host->rtmax) + if (tdiff > (unsigned int)host->rtmax) { host->rtmax = tdiff; - if (tdiff < (unsigned int)host->rtmin) + } + if (tdiff < (unsigned int)host->rtmin) { host->rtmin = tdiff; + } if (debug) { char address[INET6_ADDRSTRLEN]; @@ -1142,9 +1178,10 @@ static int send_icmp_ping(int sock, struct rta_host *host) { icp->icmp_seq = htons(host->id++); icp->icmp_cksum = icmp_checksum((uint16_t *)buf, (size_t)icmp_pkt_size); - if (debug > 2) + if (debug > 2) { printf("Sending ICMP echo-request of len %lu, id %u, seq %u, cksum 0x%X to host %s\n", (unsigned long)sizeof(data), ntohs(icp->icmp_id), ntohs(icp->icmp_seq), icp->icmp_cksum, host->name); + } } else { struct icmp6_hdr *icp6 = (struct icmp6_hdr *)buf; addrlen = sizeof(struct sockaddr_in6); @@ -1216,8 +1253,9 @@ static int recvfrom_wto(int sock, void *buf, unsigned int len, struct sockaddr * #endif if (!*timo) { - if (debug) + if (debug) { printf("*timo is not\n"); + } return 0; } @@ -1230,13 +1268,15 @@ static int recvfrom_wto(int sock, void *buf, unsigned int len, struct sockaddr * errno = 0; gettimeofday(&then, &tz); n = select(sock + 1, &rd, &wr, NULL, &to); - if (n < 0) + if (n < 0) { crash("select() in recvfrom_wto"); + } gettimeofday(&now, &tz); *timo = get_timevaldiff(&then, &now); - if (!n) + if (!n) { return 0; /* timeout */ + } slen = sizeof(struct sockaddr_storage); @@ -1281,15 +1321,19 @@ static void finish(int sig) { double R; alarm(0); - if (debug > 1) + if (debug > 1) { printf("finish(%d) called\n", sig); + } - if (icmp_sock != -1) + if (icmp_sock != -1) { close(icmp_sock); - if (udp_sock != -1) + } + if (udp_sock != -1) { close(udp_sock); - if (tcp_sock != -1) + } + if (tcp_sock != -1) { close(tcp_sock); + } if (debug) { printf("icmp_sent: %u icmp_recv: %u icmp_lost: %u\n", icmp_sent, icmp_recv, icmp_lost); @@ -1310,8 +1354,9 @@ static void finish(int sig) { rta = 0; status = STATE_CRITICAL; /* up the down counter if not already counted */ - if (!(host->flags & FLAG_LOST_CAUSE) && targets_alive) + if (!(host->flags & FLAG_LOST_CAUSE) && targets_alive) { targets_down++; + } } else { pl = ((host->icmp_sent - host->icmp_recv) * 100) / host->icmp_sent; rta = (double)host->time_waited / host->icmp_recv; @@ -1444,26 +1489,30 @@ static void finish(int sig) { } /* this is inevitable */ - if (!targets_alive) + if (!targets_alive) { status = STATE_CRITICAL; + } if (min_hosts_alive > -1) { - if (hosts_ok >= min_hosts_alive) + if (hosts_ok >= min_hosts_alive) { status = STATE_OK; - else if ((hosts_ok + hosts_warn) >= min_hosts_alive) + } else if ((hosts_ok + hosts_warn) >= min_hosts_alive) { status = STATE_WARNING; + } } printf("%s - ", status_string[status]); host = list; while (host) { - if (debug) + if (debug) { puts(""); + } if (i) { - if (i < targets) + if (i < targets) { printf(" :: "); - else + } else { printf("\n"); + } } i++; if (!host->icmp_recv) { @@ -1481,55 +1530,61 @@ static void finish(int sig) { printf("%s", host->name); /* rta text output */ if (rta_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" rta %0.3fms", host->rta / 1000); - else if (status == STATE_WARNING && host->rta_status == status) + } else if (status == STATE_WARNING && host->rta_status == status) { printf(" rta %0.3fms > %0.3fms", (float)host->rta / 1000, (float)warn.rta / 1000); - else if (status == STATE_CRITICAL && host->rta_status == status) + } else if (status == STATE_CRITICAL && host->rta_status == status) { printf(" rta %0.3fms > %0.3fms", (float)host->rta / 1000, (float)crit.rta / 1000); + } } /* pl text output */ if (pl_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" lost %u%%", host->pl); - else if (status == STATE_WARNING && host->pl_status == status) + } else if (status == STATE_WARNING && host->pl_status == status) { printf(" lost %u%% > %u%%", host->pl, warn.pl); - else if (status == STATE_CRITICAL && host->pl_status == status) + } else if (status == STATE_CRITICAL && host->pl_status == status) { printf(" lost %u%% > %u%%", host->pl, crit.pl); + } } /* jitter text output */ if (jitter_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" jitter %0.3fms", (float)host->jitter); - else if (status == STATE_WARNING && host->jitter_status == status) + } else if (status == STATE_WARNING && host->jitter_status == status) { printf(" jitter %0.3fms > %0.3fms", (float)host->jitter, warn.jitter); - else if (status == STATE_CRITICAL && host->jitter_status == status) + } else if (status == STATE_CRITICAL && host->jitter_status == status) { printf(" jitter %0.3fms > %0.3fms", (float)host->jitter, crit.jitter); + } } /* mos text output */ if (mos_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" MOS %0.1f", (float)host->mos); - else if (status == STATE_WARNING && host->mos_status == status) + } else if (status == STATE_WARNING && host->mos_status == status) { printf(" MOS %0.1f < %0.1f", (float)host->mos, (float)warn.mos); - else if (status == STATE_CRITICAL && host->mos_status == status) + } else if (status == STATE_CRITICAL && host->mos_status == status) { printf(" MOS %0.1f < %0.1f", (float)host->mos, (float)crit.mos); + } } /* score text output */ if (score_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" Score %u", (int)host->score); - else if (status == STATE_WARNING && host->score_status == status) + } else if (status == STATE_WARNING && host->score_status == status) { printf(" Score %u < %u", (int)host->score, (int)warn.score); - else if (status == STATE_CRITICAL && host->score_status == status) + } else if (status == STATE_CRITICAL && host->score_status == status) { printf(" Score %u < %u", (int)host->score, (int)crit.score); + } } /* order statis text output */ if (order_mode) { - if (status == STATE_OK) + if (status == STATE_OK) { printf(" Packets in order"); - else if (status == STATE_CRITICAL && host->order_status == status) + } else if (status == STATE_CRITICAL && host->order_status == status) { printf(" Packets out of order"); + } } } host = host->next; @@ -1542,8 +1597,9 @@ static void finish(int sig) { i = 0; host = list; while (host) { - if (debug) + if (debug) { puts(""); + } if (rta_mode) { if (host->pl < 100) { @@ -1593,17 +1649,19 @@ static void finish(int sig) { } if (min_hosts_alive > -1) { - if (hosts_ok >= min_hosts_alive) + if (hosts_ok >= min_hosts_alive) { status = STATE_OK; - else if ((hosts_ok + hosts_warn) >= min_hosts_alive) + } else if ((hosts_ok + hosts_warn) >= min_hosts_alive) { status = STATE_WARNING; + } } /* finish with an empty line */ puts(""); - if (debug) + if (debug) { printf("targets: %u, targets_alive: %u, hosts_ok: %u, hosts_warn: %u, min_hosts_alive: %i\n", targets, targets_alive, hosts_ok, hosts_warn, min_hosts_alive); + } exit(status); } @@ -1616,8 +1674,9 @@ static u_int get_timevaldiff(struct timeval *early, struct timeval *later) { gettimeofday(&now, &tz); later = &now; } - if (!early) + if (!early) { early = &prog_start; + } /* if early > later we return 0 so as to indicate a timeout */ if (early->tv_sec > later->tv_sec || (early->tv_sec == later->tv_sec && early->tv_usec > later->tv_usec)) { @@ -1634,10 +1693,11 @@ static int add_target_ip(char *arg, struct sockaddr_storage *in) { struct sockaddr_in *sin, *host_sin; struct sockaddr_in6 *sin6, *host_sin6; - if (address_family == AF_INET) + if (address_family == AF_INET) { sin = (struct sockaddr_in *)in; - else + } else { sin6 = (struct sockaddr_in6 *)in; + } /* disregard obviously stupid addresses * (I didn't find an ipv6 equivalent to INADDR_NONE) */ @@ -1654,8 +1714,9 @@ static int add_target_ip(char *arg, struct sockaddr_storage *in) { if ((address_family == AF_INET && host_sin->sin_addr.s_addr == sin->sin_addr.s_addr) || (address_family == AF_INET6 && host_sin6->sin6_addr.s6_addr == sin6->sin6_addr.s6_addr)) { - if (debug) + if (debug) { printf("Identical IP already exists. Not adding %s\n", arg); + } return -1; } host = host->next; @@ -1700,10 +1761,11 @@ static int add_target_ip(char *arg, struct sockaddr_storage *in) { host->score_status = 0; host->pl_status = 0; - if (!list) + if (!list) { list = cursor = host; - else + } else { cursor->next = host; + } cursor = host; targets++; @@ -1777,8 +1839,9 @@ static int add_target(char *arg) { /* this is silly, but it works */ if (mode == MODE_HOSTCHECK || mode == MODE_ALL) { - if (debug > 2) + if (debug > 2) { printf("mode: %d\n", mode); + } continue; } break; @@ -1793,10 +1856,12 @@ static void set_source_ip(char *arg) { memset(&src, 0, sizeof(src)); src.sin_family = address_family; - if ((src.sin_addr.s_addr = inet_addr(arg)) == INADDR_NONE) + if ((src.sin_addr.s_addr = inet_addr(arg)) == INADDR_NONE) { src.sin_addr.s_addr = get_ip_address(arg); - if (bind(icmp_sock, (struct sockaddr *)&src, sizeof(src)) == -1) + } + if (bind(icmp_sock, (struct sockaddr *)&src, sizeof(src)) == -1) { crash("Cannot bind to IP address %s", arg); + } } /* TODO: Move this to netutils.c and also change check_dhcp to use that. */ @@ -1811,8 +1876,9 @@ static in_addr_t get_ip_address(const char *ifname) { ifr.ifr_name[sizeof(ifr.ifr_name) - 1] = '\0'; - if (ioctl(icmp_sock, SIOCGIFADDR, &ifr) == -1) + if (ioctl(icmp_sock, SIOCGIFADDR, &ifr) == -1) { crash("Cannot determine IP address of interface %s", ifname); + } memcpy(&ip, &ifr.ifr_addr, sizeof(ip)); #else @@ -1835,47 +1901,57 @@ static u_int get_timevar(const char *str) { u_int i, d; /* integer and decimal, respectively */ u_int factor = 1000; /* default to milliseconds */ - if (!str) + if (!str) { return 0; + } len = strlen(str); - if (!len) + if (!len) { return 0; + } /* unit might be given as ms|m (millisec), * us|u (microsec) or just plain s, for seconds */ p = '\0'; u = str[len - 1]; - if (len >= 2 && !isdigit((int)str[len - 2])) + if (len >= 2 && !isdigit((int)str[len - 2])) { p = str[len - 2]; - if (p && u == 's') + } + if (p && u == 's') { u = p; - else if (!p) + } else if (!p) { p = u; - if (debug > 2) + } + if (debug > 2) { printf("evaluating %s, u: %c, p: %c\n", str, u, p); + } - if (u == 'u') + if (u == 'u') { factor = 1; /* microseconds */ - else if (u == 'm') + } else if (u == 'm') { factor = 1000; /* milliseconds */ - else if (u == 's') + } else if (u == 's') { factor = 1000000; /* seconds */ - if (debug > 2) + } + if (debug > 2) { printf("factor is %u\n", factor); + } i = strtoul(str, &ptr, 0); - if (!ptr || *ptr != '.' || strlen(ptr) < 2 || factor == 1) + if (!ptr || *ptr != '.' || strlen(ptr) < 2 || factor == 1) { return i * factor; + } /* time specified in usecs can't have decimal points, so ignore them */ - if (factor == 1) + if (factor == 1) { return i; + } d = strtoul(ptr + 1, NULL, 0); /* d is decimal, so get rid of excess digits */ - while (d >= factor) + while (d >= factor) { d /= 10; + } /* the last parenthesis avoids floating point exceptions. */ return ((i * factor) + (d * (factor / 10))); @@ -1885,15 +1961,16 @@ static u_int get_timevar(const char *str) { static int get_threshold(char *str, threshold *th) { char *p = NULL, i = 0; - if (!str || !strlen(str) || !th) + if (!str || !strlen(str) || !th) { return -1; + } /* pointer magic slims code by 10 lines. i is bof-stop on stupid libc's */ p = &str[strlen(str) - 1]; while (p != &str[1]) { - if (*p == '%') + if (*p == '%') { *p = '\0'; - else if (*p == ',' && i) { + } else if (*p == ',' && i) { *p = '\0'; /* reset it so get_timevar(str) works nicely later */ th->pl = (unsigned char)strtoul(p + 1, NULL, 0); break; @@ -1903,13 +1980,16 @@ static int get_threshold(char *str, threshold *th) { } th->rta = get_timevar(str); - if (!th->rta) + if (!th->rta) { return -1; + } - if (th->rta > MAXTTL * 1000000) + if (th->rta > MAXTTL * 1000000) { th->rta = MAXTTL * 1000000; - if (th->pl > 100) + } + if (th->pl > 100) { th->pl = 100; + } return 0; } @@ -1925,8 +2005,9 @@ static int get_threshold(char *str, threshold *th) { * @param[in] mode Determines whether this a threshold for rta, packet_loss, jitter, mos or score (exclusively) */ static bool get_threshold2(char *str, size_t length, threshold *warn, threshold *crit, threshold_mode mode) { - if (!str || !length || !warn || !crit) + if (!str || !length || !warn || !crit) { return false; + } // p points to the last char in str char *p = &str[length - 1]; @@ -1999,8 +2080,9 @@ unsigned short icmp_checksum(uint16_t *p, size_t n) { } /* mop up the occasional odd byte */ - if (n == 1) + if (n == 1) { sum += *((uint8_t *)p - 1); + } sum = (sum >> 16) + (sum & 0xffff); /* add hi 16 to low 16 */ sum += (sum >> 16); /* add carry */ -- cgit v1.2.3-74-g34f1 From 714fd1aceb22014eae64be288fa148bbbf835e33 Mon Sep 17 00:00:00 2001 From: Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:28:53 +0100 Subject: check_icmp: Add some lines to introduce some readability --- plugins-root/check_icmp.c | 11 ++++++++++- 1 file changed, 10 insertions(+), 1 deletion(-) diff --git a/plugins-root/check_icmp.c b/plugins-root/check_icmp.c index ea17b3a8..e6a00960 100644 --- a/plugins-root/check_icmp.c +++ b/plugins-root/check_icmp.c @@ -1095,6 +1095,7 @@ static int wait_for_reply(int sock, u_int t) { host->time_waited += tdiff; host->icmp_recv++; icmp_recv++; + if (tdiff > (unsigned int)host->rtmax) { host->rtmax = tdiff; } @@ -1503,10 +1504,10 @@ static void finish(int sig) { host = list; while (host) { - if (debug) { puts(""); } + if (i) { if (i < targets) { printf(" :: "); @@ -1514,11 +1515,14 @@ static void finish(int sig) { printf("\n"); } } + i++; + if (!host->icmp_recv) { status = STATE_CRITICAL; host->rtmin = 0; host->jitter_min = 0; + if (host->flags & FLAG_LOST_CAUSE) { char address[INET6_ADDRSTRLEN]; parse_address(&host->error_addr, address, sizeof(address)); @@ -1538,6 +1542,7 @@ static void finish(int sig) { printf(" rta %0.3fms > %0.3fms", (float)host->rta / 1000, (float)crit.rta / 1000); } } + /* pl text output */ if (pl_mode) { if (status == STATE_OK) { @@ -1548,6 +1553,7 @@ static void finish(int sig) { printf(" lost %u%% > %u%%", host->pl, crit.pl); } } + /* jitter text output */ if (jitter_mode) { if (status == STATE_OK) { @@ -1558,6 +1564,7 @@ static void finish(int sig) { printf(" jitter %0.3fms > %0.3fms", (float)host->jitter, crit.jitter); } } + /* mos text output */ if (mos_mode) { if (status == STATE_OK) { @@ -1568,6 +1575,7 @@ static void finish(int sig) { printf(" MOS %0.1f < %0.1f", (float)host->mos, (float)crit.mos); } } + /* score text output */ if (score_mode) { if (status == STATE_OK) { @@ -1578,6 +1586,7 @@ static void finish(int sig) { printf(" Score %u < %u", (int)host->score, (int)crit.score); } } + /* order statis text output */ if (order_mode) { if (status == STATE_OK) { -- cgit v1.2.3-74-g34f1 From 89f79cf2d216fed07de554ef01e230de7e2a5c56 Mon Sep 17 00:00:00 2001 From: Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> Date: Wed, 27 Nov 2024 15:29:19 +0100 Subject: check_icmp: set rtmin initially --- plugins-root/check_icmp.c | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/plugins-root/check_icmp.c b/plugins-root/check_icmp.c index e6a00960..dcaceddb 100644 --- a/plugins-root/check_icmp.c +++ b/plugins-root/check_icmp.c @@ -64,6 +64,7 @@ const char *email = "devel@monitoring-plugins.org"; #include #include #include +#include /** sometimes undefined system macros (quite a few, actually) **/ #ifndef MAXTTL @@ -1099,7 +1100,8 @@ static int wait_for_reply(int sock, u_int t) { if (tdiff > (unsigned int)host->rtmax) { host->rtmax = tdiff; } - if (tdiff < (unsigned int)host->rtmin) { + + if ((host->rtmin == INFINITY) || (tdiff < (unsigned int)host->rtmin)) { host->rtmin = tdiff; } -- cgit v1.2.3-74-g34f1 From 28e7fe33729a42c6338fcdced65acbb62cf99065 Mon Sep 17 00:00:00 2001 From: Andre Klaerner Date: Thu, 28 Nov 2024 22:52:41 +0100 Subject: fix typo in SUPPORT --- SUPPORT | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/SUPPORT b/SUPPORT index d2a2b7de..d98c6c16 100644 --- a/SUPPORT +++ b/SUPPORT @@ -8,7 +8,7 @@ support offerings. There are two mailing lists associated with Monitoring Plugins development: 'help' (mailto:help@monitoring-plugins.org), and 'devel' -(mailto:help@monitoring-plugins.org). Unless you are fairly +(mailto:devel@monitoring-plugins.org). Unless you are fairly certain you have found a bug or that you are requesting a new feature, please direct support requests to 'help'. -- cgit v1.2.3-74-g34f1 From e7dbfd42231754b0258f2f92088caba7de3ee9d8 Mon Sep 17 00:00:00 2001 From: Andre Klärner Date: Fri, 29 Nov 2024 10:34:16 +0100 Subject: check_curl: enable internal cookie handling This enables us to enable curl cookie engine by specifying an empty filename as the cookie jar file. This works, since curl's CURLOPT_COOKIEFILE option allows passing an empty string as filename, which it interprets as a request to enable the cookie processing. But since CURLOPT_COOKIEJAR would now attempt to write to a file named by an empty filename, it would break again (or at least produce a warning in verbose output). Overall this is allows to handle checking URLs with cookie based sessions without persisting the cookies to disk, by using the curl-internal redirect following. --- plugins/check_curl.c | 8 +++++++- 1 file changed, 7 insertions(+), 1 deletion(-) diff --git a/plugins/check_curl.c b/plugins/check_curl.c index ef7d4ee4..748201e8 100644 --- a/plugins/check_curl.c +++ b/plugins/check_curl.c @@ -818,8 +818,11 @@ int check_http(void) { /* cookie handling */ if (cookie_jar_file != NULL) { - handle_curl_option_return_code(curl_easy_setopt(curl, CURLOPT_COOKIEJAR, cookie_jar_file), "CURLOPT_COOKIEJAR"); + /* enable reading cookies from a file, and if the filename is an empty string, only enable the curl cookie engine */ handle_curl_option_return_code(curl_easy_setopt(curl, CURLOPT_COOKIEFILE, cookie_jar_file), "CURLOPT_COOKIEFILE"); + /* now enable saving cookies to a file, but only if the filename is not an empty string, since writing it would fail */ + if (*cookie_jar_file) + handle_curl_option_return_code(curl_easy_setopt(curl, CURLOPT_COOKIEJAR, cookie_jar_file), "CURLOPT_COOKIEJAR"); } /* do the request */ @@ -2011,6 +2014,9 @@ void print_help(void) { printf(" %s\n", _("Send HAProxy proxy protocol v1 header (CURLOPT_HAPROXYPROTOCOL).")); printf(" %s\n", "--cookie-jar=FILE"); printf(" %s\n", _("Store cookies in the cookie jar and send them out when requested.")); + printf(" %s\n", _("Specify an empty string as FILE to enable curl's cookie engine without saving")); + printf(" %s\n", _("the cookies to disk. Only enabling the engine without saving to disk requires")); + printf(" %s\n", _("handling multiple requests internally to curl, so use it with --onredirect=curl")); printf("\n"); printf(UT_WARN_CRIT); -- cgit v1.2.3-74-g34f1 From 908c2e7b24cf60e82cedf99f1eda6a2c369c4c2e Mon Sep 17 00:00:00 2001 From: Lorenz Kästle <12514511+RincewindsHat@users.noreply.github.com> Date: Sun, 29 Dec 2024 19:34:17 +0100 Subject: Fix breakage in rpm build test due to changes in mock --- .github/mock.sh | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/mock.sh b/.github/mock.sh index ea4f7f3d..8f84756c 100755 --- a/.github/mock.sh +++ b/.github/mock.sh @@ -59,7 +59,7 @@ mkdir -p "${SRCRPM_DIR}" "${RPM_DIR}" dnf -y --setopt="tsflags=nodocs" install rpmdevtools && \ spectool -g -C ${SOURCE_DIR} ${SPEC_FILE} && \ mock --init && \ - { mock --no-clean --spec ${SPEC_FILE} --sources=${SOURCE_DIR} --result=${SRCRPM_DIR} --build || \ + { mock --no-clean --spec ${SPEC_FILE} --sources=${SOURCE_DIR} --result=${SRCRPM_DIR} --buildsrpm || \ { cat ${SRCRPM_DIR}/{root,build}.log; exit 1; } } && \ { mock --no-clean --sources=${SOURCE_DIR} --result=${RPM_DIR} --rebuild "${SRCRPM_DIR}"/${SRC_RPM} || \ { cat ${RPM_DIR}/{root,build}.log; exit 1; } } -- cgit v1.2.3-74-g34f1