diff options
-rw-r--r-- | .github/os_detect.sh | 7 | ||||
-rw-r--r-- | .github/workflows/test-next.yml | 2 | ||||
-rw-r--r-- | .github/workflows/test.yml | 2 | ||||
-rw-r--r-- | configure.ac | 44 | ||||
-rw-r--r-- | lib/utils_cmd.c | 2 | ||||
-rw-r--r-- | lib/utils_cmd.h | 2 | ||||
-rw-r--r-- | plugins/check_fping.c | 114 | ||||
-rw-r--r-- | plugins/check_fping.d/config.h | 24 | ||||
-rw-r--r-- | plugins/check_http.c | 10 | ||||
-rw-r--r-- | plugins/sslutils.c | 2 |
10 files changed, 173 insertions, 36 deletions
diff --git a/.github/os_detect.sh b/.github/os_detect.sh index ee9c145d..47c762d3 100644 --- a/.github/os_detect.sh +++ b/.github/os_detect.sh | |||
@@ -1,10 +1,17 @@ | |||
1 | #!/bin/sh -e | 1 | #!/bin/sh -e |
2 | |||
3 | . /etc/os-release | ||
4 | |||
2 | # workaround for really bare-bones Archlinux containers: | 5 | # workaround for really bare-bones Archlinux containers: |
3 | if [ -x "$(command -v pacman)" ]; then | 6 | if [ -x "$(command -v pacman)" ]; then |
4 | pacman --noconfirm -Sy | 7 | pacman --noconfirm -Sy |
5 | pacman --noconfirm -S grep gawk sed | 8 | pacman --noconfirm -S grep gawk sed |
6 | fi | 9 | fi |
7 | 10 | ||
11 | if [ ${ID} == "fedora" -a ${VERSION_ID} -gt 41 ]; then | ||
12 | dnf install -y gawk | ||
13 | fi | ||
14 | |||
8 | os_release_file= | 15 | os_release_file= |
9 | if [ -s "/etc/os-release" ]; then | 16 | if [ -s "/etc/os-release" ]; then |
10 | os_release_file="/etc/os-release" | 17 | os_release_file="/etc/os-release" |
diff --git a/.github/workflows/test-next.yml b/.github/workflows/test-next.yml index 81240759..fd59e85d 100644 --- a/.github/workflows/test-next.yml +++ b/.github/workflows/test-next.yml | |||
@@ -38,7 +38,7 @@ jobs: | |||
38 | ${{ matrix.distro }} \ | 38 | ${{ matrix.distro }} \ |
39 | /bin/sh -c '${{ matrix.prepare }} && \ | 39 | /bin/sh -c '${{ matrix.prepare }} && \ |
40 | tools/setup && \ | 40 | tools/setup && \ |
41 | ./configure --enable-libtap --with-ipv6=no && \ | 41 | ./configure --enable-libtap && \ |
42 | make && \ | 42 | make && \ |
43 | make test && \ | 43 | make test && \ |
44 | make dist && \ | 44 | make dist && \ |
diff --git a/.github/workflows/test.yml b/.github/workflows/test.yml index 77ca6585..ce0ec547 100644 --- a/.github/workflows/test.yml +++ b/.github/workflows/test.yml | |||
@@ -35,7 +35,7 @@ jobs: | |||
35 | ${{ matrix.distro }} \ | 35 | ${{ matrix.distro }} \ |
36 | /bin/sh -c '${{ matrix.prepare }} && \ | 36 | /bin/sh -c '${{ matrix.prepare }} && \ |
37 | tools/setup && \ | 37 | tools/setup && \ |
38 | ./configure --enable-libtap --with-ipv6=no && \ | 38 | ./configure --enable-libtap && \ |
39 | make && \ | 39 | make && \ |
40 | make test && \ | 40 | make test && \ |
41 | make dist && \ | 41 | make dist && \ |
diff --git a/configure.ac b/configure.ac index fdc9b699..bec50cb4 100644 --- a/configure.ac +++ b/configure.ac | |||
@@ -1519,21 +1519,47 @@ then | |||
1519 | fi | 1519 | fi |
1520 | 1520 | ||
1521 | AC_PATH_PROG(PATH_TO_FPING,fping) | 1521 | AC_PATH_PROG(PATH_TO_FPING,fping) |
1522 | AC_PATH_PROG(PATH_TO_FPING6,fping6) | ||
1523 | 1522 | ||
1524 | AC_ARG_WITH(fping_command, | 1523 | AC_ARG_WITH(fping_command, |
1525 | ACX_HELP_STRING([--with-fping-command=PATH], | 1524 | ACX_HELP_STRING([--with-fping-command=PATH], |
1526 | [Path to fping command]), PATH_TO_FPING=$withval) | 1525 | [Path to fping command]), PATH_TO_FPING=$withval) |
1527 | AC_ARG_WITH(fping6_command, | 1526 | if test -n "$PATH_TO_FPING"; then |
1528 | ACX_HELP_STRING([--with-fping6-command=PATH], | ||
1529 | [Path to fping6 command]), PATH_TO_FPING6=$withval) | ||
1530 | |||
1531 | if test -n "$PATH_TO_FPING" | ||
1532 | then | ||
1533 | AC_DEFINE_UNQUOTED(PATH_TO_FPING,"$PATH_TO_FPING",[path to fping]) | 1527 | AC_DEFINE_UNQUOTED(PATH_TO_FPING,"$PATH_TO_FPING",[path to fping]) |
1534 | EXTRAS="$EXTRAS check_fping\$(EXEEXT)" | 1528 | EXTRAS="$EXTRAS check_fping\$(EXEEXT)" |
1535 | if test x"$with_ipv6" != xno && test -n "$PATH_TO_FPING6"; then | 1529 | |
1536 | AC_DEFINE_UNQUOTED(PATH_TO_FPING6,"$PATH_TO_FPING6",[path to fping6]) | 1530 | if test -z "$($PATH_TO_FPING --version)" ; then |
1531 | AC_MSG_NOTICE([failed to get version of fping]) | ||
1532 | else | ||
1533 | FPING_MAJOR_VERSION="$($PATH_TO_FPING --version | sed 's/.*fping: Version //' | sed 's/\..*//')" | ||
1534 | FPING_MINOR_VERSION="$($PATH_TO_FPING --version | sed 's/.*fping: Version //' | sed 's/.*\.//')" | ||
1535 | |||
1536 | if test $FPING_MAJOR_VERSION -eq 5 ; then | ||
1537 | if test $FPING_MINOR_VERSION -ge 3 ; then | ||
1538 | AC_DEFINE(FPING_VERSION_5_3_OR_HIGHER, "true", [fping is of version 5.3 or higher]) | ||
1539 | AC_MSG_NOTICE([fping is of version 5.3 or higher]) | ||
1540 | AC_DEFINE(FPING_VERSION_5_2_OR_HIGHER, "true", [fping is of version 5.2 or higher]) | ||
1541 | AC_MSG_NOTICE([fping is of version 5.2 or higher]) | ||
1542 | elif test $FPING_MINOR_VERSION -ge 2 ; then | ||
1543 | AC_DEFINE(FPING_VERSION_5_2_OR_HIGHER, "true", [fping is of version 5.2 or higher]) | ||
1544 | AC_MSG_NOTICE([fping is of version 5.2 or higher]) | ||
1545 | else | ||
1546 | AC_MSG_NOTICE([fping is of a version lower then 5.2]) | ||
1547 | fi | ||
1548 | |||
1549 | elif $FPING_MAJOR_VERSION > 5 ; then | ||
1550 | AC_DEFINE(FPING_VERSION_5_2_OR_HIGHER, "true", [fping is of version 5.2 or higher]) | ||
1551 | AC_MSG_NOTICE([fping is of version 5.2 or higher]) | ||
1552 | AC_DEFINE(FPING_VERSION_5_3_OR_HIGHER, "true", [fping is of version 5.2 or higher]) | ||
1553 | AC_MSG_NOTICE([fping is of version 5.3 or higher]) | ||
1554 | fi | ||
1555 | |||
1556 | if test "`fping --version | sed 's/.*fping: Version //'`" = "5.2" ; then | ||
1557 | AC_DEFINE(FPING_VERSION, "5.2", [the version of fping available]) | ||
1558 | AC_MSG_NOTICE([fping version: 5.2]) | ||
1559 | elif test "`fping --version | sed 's/.*fping: Version //'`" = "5.3"; then | ||
1560 | AC_DEFINE(FPING_VERSION, "5.3", [the version of fping available]) | ||
1561 | AC_MSG_NOTICE([fping version: 5.3]) | ||
1562 | fi | ||
1537 | fi | 1563 | fi |
1538 | else | 1564 | else |
1539 | AC_MSG_WARN([Get fping from http://www.fping.com in order to make check_fping plugin]) | 1565 | AC_MSG_WARN([Get fping from http://www.fping.com in order to make check_fping plugin]) |
diff --git a/lib/utils_cmd.c b/lib/utils_cmd.c index 18350ac0..9b222409 100644 --- a/lib/utils_cmd.c +++ b/lib/utils_cmd.c | |||
@@ -346,7 +346,7 @@ int cmd_run_array(char *const *argv, output *out, output *err, int flags) { | |||
346 | return _cmd_close(fd); | 346 | return _cmd_close(fd); |
347 | } | 347 | } |
348 | 348 | ||
349 | int cmd_file_read(char *filename, output *out, int flags) { | 349 | int cmd_file_read(const char *filename, output *out, int flags) { |
350 | int fd; | 350 | int fd; |
351 | if (out) | 351 | if (out) |
352 | memset(out, 0, sizeof(output)); | 352 | memset(out, 0, sizeof(output)); |
diff --git a/lib/utils_cmd.h b/lib/utils_cmd.h index d00069c9..728ece23 100644 --- a/lib/utils_cmd.h +++ b/lib/utils_cmd.h | |||
@@ -20,7 +20,7 @@ typedef struct output output; | |||
20 | /** prototypes **/ | 20 | /** prototypes **/ |
21 | int cmd_run(const char *, output *, output *, int); | 21 | int cmd_run(const char *, output *, output *, int); |
22 | int cmd_run_array(char *const *, output *, output *, int); | 22 | int cmd_run_array(char *const *, output *, output *, int); |
23 | int cmd_file_read(char *, output *, int); | 23 | int cmd_file_read(const char *, output *, int); |
24 | 24 | ||
25 | /* only multi-threaded plugins need to bother with this */ | 25 | /* only multi-threaded plugins need to bother with this */ |
26 | void cmd_init(void); | 26 | void cmd_init(void); |
diff --git a/plugins/check_fping.c b/plugins/check_fping.c index ec7abb67..8018e06d 100644 --- a/plugins/check_fping.c +++ b/plugins/check_fping.c | |||
@@ -79,6 +79,24 @@ int main(int argc, char **argv) { | |||
79 | server = strscpy(server, config.server_name); | 79 | server = strscpy(server, config.server_name); |
80 | 80 | ||
81 | char *option_string = ""; | 81 | char *option_string = ""; |
82 | char *fping_prog = NULL; | ||
83 | |||
84 | /* First determine if the target is dualstack or ipv6 only. */ | ||
85 | bool server_is_inet6_addr = is_inet6_addr(server); | ||
86 | |||
87 | /* | ||
88 | * If the user requested -6 OR the user made no assertion and the address is v6 or dualstack | ||
89 | * -> we use ipv6 | ||
90 | * If the user requested -4 OR the user made no assertion and the address is v4 ONLY | ||
91 | * -> we use ipv4 | ||
92 | */ | ||
93 | if (address_family == AF_INET6 || (address_family == AF_UNSPEC && server_is_inet6_addr)) { | ||
94 | xasprintf(&option_string, "%s-6 ", option_string); | ||
95 | } else { | ||
96 | xasprintf(&option_string, "%s-4 ", option_string); | ||
97 | } | ||
98 | fping_prog = strdup(PATH_TO_FPING); | ||
99 | |||
82 | /* compose the command */ | 100 | /* compose the command */ |
83 | if (config.target_timeout) { | 101 | if (config.target_timeout) { |
84 | xasprintf(&option_string, "%s-t %d ", option_string, config.target_timeout); | 102 | xasprintf(&option_string, "%s-t %d ", option_string, config.target_timeout); |
@@ -99,19 +117,26 @@ int main(int argc, char **argv) { | |||
99 | xasprintf(&option_string, "%s-R ", option_string); | 117 | xasprintf(&option_string, "%s-R ", option_string); |
100 | } | 118 | } |
101 | 119 | ||
102 | char *fping_prog = NULL; | 120 | if (config.fwmark_set) { |
103 | #ifdef PATH_TO_FPING6 | 121 | xasprintf(&option_string, "%s--fwmark %u ", option_string, config.fwmark); |
104 | if (address_family != AF_INET && is_inet6_addr(server)) { | 122 | } |
105 | fping_prog = strdup(PATH_TO_FPING6); | 123 | |
106 | } else { | 124 | if (config.icmp_timestamp) { |
107 | fping_prog = strdup(PATH_TO_FPING); | 125 | xasprintf(&option_string, "%s--icmp-timestamp ", option_string); |
126 | } | ||
127 | |||
128 | if (config.check_source) { | ||
129 | xasprintf(&option_string, "%s--check-source ", option_string); | ||
108 | } | 130 | } |
109 | #else | ||
110 | fping_prog = strdup(PATH_TO_FPING); | ||
111 | #endif | ||
112 | 131 | ||
113 | char *command_line = NULL; | 132 | char *command_line = NULL; |
114 | xasprintf(&command_line, "%s %s-b %d -c %d %s", fping_prog, option_string, config.packet_size, config.packet_count, server); | 133 | |
134 | if (config.icmp_timestamp) { | ||
135 | // no packet size settable for ICMP timestamp | ||
136 | xasprintf(&command_line, "%s %s -c %d %s", fping_prog, option_string, config.packet_count, server); | ||
137 | } else { | ||
138 | xasprintf(&command_line, "%s %s-b %d -c %d %s", fping_prog, option_string, config.packet_size, config.packet_count, server); | ||
139 | } | ||
115 | 140 | ||
116 | if (verbose) { | 141 | if (verbose) { |
117 | printf("%s\n", command_line); | 142 | printf("%s\n", command_line); |
@@ -268,13 +293,38 @@ mp_state_enum textscan(char *buf, const char *server_name, bool crta_p, double c | |||
268 | 293 | ||
269 | /* process command-line arguments */ | 294 | /* process command-line arguments */ |
270 | check_fping_config_wrapper process_arguments(int argc, char **argv) { | 295 | check_fping_config_wrapper process_arguments(int argc, char **argv) { |
271 | static struct option longopts[] = { | 296 | enum { |
272 | {"hostname", required_argument, 0, 'H'}, {"sourceip", required_argument, 0, 'S'}, {"sourceif", required_argument, 0, 'I'}, | 297 | FWMARK_OPT = CHAR_MAX + 1, |
273 | {"critical", required_argument, 0, 'c'}, {"warning", required_argument, 0, 'w'}, {"alive", no_argument, 0, 'a'}, | 298 | ICMP_TIMESTAMP_OPT, |
274 | {"bytes", required_argument, 0, 'b'}, {"number", required_argument, 0, 'n'}, {"target-timeout", required_argument, 0, 'T'}, | 299 | CHECK_SOURCE_OPT, |
275 | {"interval", required_argument, 0, 'i'}, {"verbose", no_argument, 0, 'v'}, {"version", no_argument, 0, 'V'}, | 300 | }; |
276 | {"help", no_argument, 0, 'h'}, {"use-ipv4", no_argument, 0, '4'}, {"use-ipv6", no_argument, 0, '6'}, | 301 | static struct option longopts[] = {{"hostname", required_argument, 0, 'H'}, |
277 | {"dontfrag", no_argument, 0, 'M'}, {"random", no_argument, 0, 'R'}, {0, 0, 0, 0}}; | 302 | {"sourceip", required_argument, 0, 'S'}, |
303 | {"sourceif", required_argument, 0, 'I'}, | ||
304 | {"critical", required_argument, 0, 'c'}, | ||
305 | {"warning", required_argument, 0, 'w'}, | ||
306 | {"alive", no_argument, 0, 'a'}, | ||
307 | {"bytes", required_argument, 0, 'b'}, | ||
308 | {"number", required_argument, 0, 'n'}, | ||
309 | {"target-timeout", required_argument, 0, 'T'}, | ||
310 | {"interval", required_argument, 0, 'i'}, | ||
311 | {"verbose", no_argument, 0, 'v'}, | ||
312 | {"version", no_argument, 0, 'V'}, | ||
313 | {"help", no_argument, 0, 'h'}, | ||
314 | {"use-ipv4", no_argument, 0, '4'}, | ||
315 | {"use-ipv6", no_argument, 0, '6'}, | ||
316 | {"dontfrag", no_argument, 0, 'M'}, | ||
317 | {"random", no_argument, 0, 'R'}, | ||
318 | #ifdef FPING_VERSION_5_2_OR_HIGHER | ||
319 | // only available with fping version >= 5.2 | ||
320 | {"fwmark", required_argument, NULL, FWMARK_OPT}, | ||
321 | # ifdef FPING_VERSION_5_3_OR_HIGHER | ||
322 | // only available with fping version >= 5.3 | ||
323 | {"icmp-timestamp", no_argument, NULL, ICMP_TIMESTAMP_OPT}, | ||
324 | {"check-source", no_argument, NULL, CHECK_SOURCE_OPT}, | ||
325 | # endif | ||
326 | #endif | ||
327 | {0, 0, 0, 0}}; | ||
278 | 328 | ||
279 | char *rv[2]; | 329 | char *rv[2]; |
280 | rv[PL] = NULL; | 330 | rv[PL] = NULL; |
@@ -299,7 +349,7 @@ check_fping_config_wrapper process_arguments(int argc, char **argv) { | |||
299 | argc--; | 349 | argc--; |
300 | } | 350 | } |
301 | 351 | ||
302 | while (1) { | 352 | while (true) { |
303 | int option_index = getopt_long(argc, argv, "+hVvaH:S:c:w:b:n:T:i:I:M:R:46", longopts, &option); | 353 | int option_index = getopt_long(argc, argv, "+hVvaH:S:c:w:b:n:T:i:I:M:R:46", longopts, &option); |
304 | 354 | ||
305 | if (option_index == -1 || option_index == EOF || option_index == 1) { | 355 | if (option_index == -1 || option_index == EOF || option_index == 1) { |
@@ -340,11 +390,7 @@ check_fping_config_wrapper process_arguments(int argc, char **argv) { | |||
340 | address_family = AF_INET; | 390 | address_family = AF_INET; |
341 | break; | 391 | break; |
342 | case '6': /* IPv6 only */ | 392 | case '6': /* IPv6 only */ |
343 | #ifdef USE_IPV6 | ||
344 | address_family = AF_INET6; | 393 | address_family = AF_INET6; |
345 | #else | ||
346 | usage(_("IPv6 support not available\n")); | ||
347 | #endif | ||
348 | break; | 394 | break; |
349 | case 'c': | 395 | case 'c': |
350 | get_threshold(optarg, rv); | 396 | get_threshold(optarg, rv); |
@@ -406,6 +452,20 @@ check_fping_config_wrapper process_arguments(int argc, char **argv) { | |||
406 | case 'M': | 452 | case 'M': |
407 | result.config.dontfrag = true; | 453 | result.config.dontfrag = true; |
408 | break; | 454 | break; |
455 | case FWMARK_OPT: | ||
456 | if (is_intpos(optarg)) { | ||
457 | result.config.fwmark = (unsigned int)atol(optarg); | ||
458 | result.config.fwmark_set = true; | ||
459 | } else { | ||
460 | usage(_("fwmark must be a positive integer")); | ||
461 | } | ||
462 | break; | ||
463 | case ICMP_TIMESTAMP_OPT: | ||
464 | result.config.icmp_timestamp = true; | ||
465 | break; | ||
466 | case CHECK_SOURCE_OPT: | ||
467 | result.config.check_source = true; | ||
468 | break; | ||
409 | } | 469 | } |
410 | } | 470 | } |
411 | 471 | ||
@@ -493,6 +553,16 @@ void print_help(void) { | |||
493 | printf(" %s\n", _("set the Don't Fragment flag")); | 553 | printf(" %s\n", _("set the Don't Fragment flag")); |
494 | printf(" %s\n", "-R, --random"); | 554 | printf(" %s\n", "-R, --random"); |
495 | printf(" %s\n", _("random packet data (to foil link data compression)")); | 555 | printf(" %s\n", _("random packet data (to foil link data compression)")); |
556 | #ifdef FPING_VERSION_5_2_OR_HIGHER | ||
557 | printf(" %s\n", "--fwmark=INTEGER"); | ||
558 | printf(" %s\n", _("set the routing mark to INTEGER (fping option)")); | ||
559 | # ifdef FPING_VERSION_5_3_OR_HIGHER | ||
560 | printf(" %s\n", "--icmp-timestamp"); | ||
561 | printf(" %s\n", _("use ICMP Timestamp instead of ICMP Echo (fping option)")); | ||
562 | printf(" %s\n", "--check-source"); | ||
563 | printf(" %s\n", _("discard replies not from target address (fping option)")); | ||
564 | # endif | ||
565 | #endif | ||
496 | printf(UT_VERBOSE); | 566 | printf(UT_VERBOSE); |
497 | printf("\n"); | 567 | printf("\n"); |
498 | printf(" %s\n", _("THRESHOLD is <rta>,<pl>%% where <rta> is the round trip average travel time (ms)")); | 568 | printf(" %s\n", _("THRESHOLD is <rta>,<pl>%% where <rta> is the round trip average travel time (ms)")); |
diff --git a/plugins/check_fping.d/config.h b/plugins/check_fping.d/config.h index a0697bf3..d95e9ded 100644 --- a/plugins/check_fping.d/config.h +++ b/plugins/check_fping.d/config.h | |||
@@ -29,6 +29,21 @@ typedef struct { | |||
29 | bool cpl_p; | 29 | bool cpl_p; |
30 | int wpl; | 30 | int wpl; |
31 | bool wpl_p; | 31 | bool wpl_p; |
32 | |||
33 | // only available with fping version >= 5.2 | ||
34 | // for a given uint _fwmark_ fping sets _fwmark_ as a firewall mark | ||
35 | // in the packets | ||
36 | unsigned int fwmark; | ||
37 | bool fwmark_set; | ||
38 | |||
39 | |||
40 | // only available with fping version >= 5.3 | ||
41 | // Setting icmp_timestamp tells fping to use ICMP Timestamp (ICMP type 13) instead | ||
42 | // of ICMP Echo | ||
43 | bool icmp_timestamp; | ||
44 | |||
45 | // Setting check_source lets fping discard replies which are not from the target address | ||
46 | bool check_source; | ||
32 | } check_fping_config; | 47 | } check_fping_config; |
33 | 48 | ||
34 | check_fping_config check_fping_config_init() { | 49 | check_fping_config check_fping_config_init() { |
@@ -53,6 +68,15 @@ check_fping_config check_fping_config_init() { | |||
53 | .cpl_p = false, | 68 | .cpl_p = false, |
54 | .wpl = 0, | 69 | .wpl = 0, |
55 | .wpl_p = false, | 70 | .wpl_p = false, |
71 | |||
72 | // only available with fping version >= 5.2 | ||
73 | .fwmark = 0, | ||
74 | .fwmark_set = false, // just to be deterministic | ||
75 | |||
76 | // only available with fping version >= 5.3 | ||
77 | .icmp_timestamp = false, | ||
78 | .check_source = false, | ||
79 | |||
56 | }; | 80 | }; |
57 | return tmp; | 81 | return tmp; |
58 | } | 82 | } |
diff --git a/plugins/check_http.c b/plugins/check_http.c index baff682a..8e0c15ec 100644 --- a/plugins/check_http.c +++ b/plugins/check_http.c | |||
@@ -1724,6 +1724,16 @@ print_help (void) | |||
1724 | printf ("%s\n", _("strings and regular expressions, check connection times, and report on")); | 1724 | printf ("%s\n", _("strings and regular expressions, check connection times, and report on")); |
1725 | printf ("%s\n", _("certificate expiration times.")); | 1725 | printf ("%s\n", _("certificate expiration times.")); |
1726 | 1726 | ||
1727 | printf ("\n"); | ||
1728 | printf ("%s\n", _("ATTENTION!")); | ||
1729 | printf ("\n"); | ||
1730 | printf ("%s\n", _("THIS PLUGIN IS DEPRECATED. The functionality was reimplemented by the")); | ||
1731 | printf ("%s\n", _("check_curl plugin, which can be used as a drop-in replacement. You should")); | ||
1732 | printf ("%s\n", _("migrate your checks over to check_curl, because check_http is going to be")); | ||
1733 | printf ("%s\n", _("removed sooner than later. Just replace check_http with check_curl in your")); | ||
1734 | printf ("%s\n", _("check command definitions.")); | ||
1735 | printf ("%s\n", _("Report issues to: https://github.com/monitoring-plugins/monitoring-plugins/issues")); | ||
1736 | |||
1727 | printf ("\n\n"); | 1737 | printf ("\n\n"); |
1728 | 1738 | ||
1729 | print_usage (); | 1739 | print_usage (); |
diff --git a/plugins/sslutils.c b/plugins/sslutils.c index 719de575..96740b3a 100644 --- a/plugins/sslutils.c +++ b/plugins/sslutils.c | |||
@@ -201,7 +201,7 @@ int np_net_ssl_check_certificate(X509 *certificate, int days_till_exp_warn, int | |||
201 | time_t tm_t; | 201 | time_t tm_t; |
202 | 202 | ||
203 | if (!certificate) { | 203 | if (!certificate) { |
204 | printf("%s\n", _("CRITICAL - Cannot retrieve server certificate.")); | 204 | printf("%s\n", _("CRITICAL - No server certificate present to inspect.")); |
205 | return STATE_CRITICAL; | 205 | return STATE_CRITICAL; |
206 | } | 206 | } |
207 | 207 | ||