From 0b6423f9c99d9edf8c96fefd0f6c453859395aa1 Mon Sep 17 00:00:00 2001 From: Holger Weiss Date: Mon, 30 Sep 2013 00:03:24 +0200 Subject: Import Nagios Plugins site Import the Nagios Plugins web site, Cronjobs, infrastructure scripts, and configuration files. --- .../436432-check_fping_ipv6_support.patch | 106 +++++++++++++++++++++ 1 file changed, 106 insertions(+) create mode 100644 web/attachments/436432-check_fping_ipv6_support.patch (limited to 'web/attachments/436432-check_fping_ipv6_support.patch') diff --git a/web/attachments/436432-check_fping_ipv6_support.patch b/web/attachments/436432-check_fping_ipv6_support.patch new file mode 100644 index 0000000..121a527 --- /dev/null +++ b/web/attachments/436432-check_fping_ipv6_support.patch @@ -0,0 +1,106 @@ +diff --git a/configure.in b/configure.in +index 1d16bcd..fec55a0 100644 +--- a/configure.in ++++ b/configure.in +@@ -1364,6 +1364,17 @@ else + AC_MSG_WARN([Get fping from http://www.fping.com in order to make check_fping plugin]) + fi + ++AC_PATH_PROG(PATH_TO_FPING6,fping6) ++AC_ARG_WITH(fping6_command, ++ ACX_HELP_STRING([--with-fping6-command=PATH], ++ [Path to fping6 command]), PATH_TO_FPING6=$withval) ++if test -n "$PATH_TO_FPING6" ++then ++ AC_DEFINE_UNQUOTED(PATH_TO_FPING6,"$PATH_TO_FPING6",[path to fping6]) ++else ++ AC_MSG_WARN([Get fping6 from http://www.fping.com in order to make check_fping plugin]) ++fi ++ + AC_PATH_PROG(PATH_TO_SSH,ssh) + AC_ARG_WITH(ssh_command, + ACX_HELP_STRING([--with-ssh-command=PATH], +diff --git a/plugins/check_fping.c b/plugins/check_fping.c +index dd3f86d..d45e76b 100644 +--- a/plugins/check_fping.c ++++ b/plugins/check_fping.c +@@ -72,6 +72,7 @@ main (int argc, char **argv) + /* normaly should be int result = STATE_UNKNOWN; */ + + int status = STATE_UNKNOWN; ++ char *fping_prog = NULL; + char *server = NULL; + char *command_line = NULL; + char *input_buffer = NULL; +@@ -96,7 +97,16 @@ main (int argc, char **argv) + if (packet_interval) + asprintf(&option_string, "%s-p %d ", option_string, packet_interval); + +- asprintf (&command_line, "%s %s-b %d -c %d %s", PATH_TO_FPING, ++#ifdef USE_IPV6 ++ if (address_family == AF_INET6) ++ fping_prog = strdup(PATH_TO_FPING6); ++ else ++ fping_prog = strdup(PATH_TO_FPING); ++#else ++ fping_prog = strdup(PATH_TO_FPING); ++#endif ++ ++ asprintf (&command_line, "%s %s-b %d -c %d %s", fping_prog, + option_string, packet_size, packet_count, server); + + if (verbose) +@@ -241,6 +251,8 @@ process_arguments (int argc, char **argv) + {"verbose", no_argument, 0, 'v'}, + {"version", no_argument, 0, 'V'}, + {"help", no_argument, 0, 'h'}, ++ {"use-ipv4", no_argument, 0, '4'}, ++ {"use-ipv6", no_argument, 0, '6'}, + {0, 0, 0, 0} + }; + +@@ -258,7 +270,7 @@ process_arguments (int argc, char **argv) + } + + while (1) { +- c = getopt_long (argc, argv, "+hVvH:c:w:b:n:T:i:", longopts, &option); ++ c = getopt_long (argc, argv, "+hVvH:c:w:b:n:T:i:46", longopts, &option); + + if (c == -1 || c == EOF || c == 1) + break; +@@ -281,6 +293,16 @@ process_arguments (int argc, char **argv) + } + server_name = strscpy (server_name, optarg); + break; ++ case '4': /* IPv4 only */ ++ address_family = AF_INET; ++ break; ++ case '6': /* IPv6 only */ ++#ifdef USE_IPV6 ++ address_family = AF_INET6; ++#else ++ usage (_("IPv6 support not available\n")); ++#endif ++ break; + case 'c': + get_threshold (optarg, rv); + if (rv[RTA]) { +@@ -402,6 +424,8 @@ print_help (void) + printf (UT_HELP_VRSN); + printf (UT_EXTRA_OPTS); + ++ printf (UT_IPv46); ++ + printf (" %s\n", "-H, --hostname=HOST"); + printf (" %s\n", _("name or IP Address of host to ping (IP Address bypasses name lookup, reducing system load)")); + printf (" %s\n", "-w, --warning=THRESHOLD"); +@@ -422,6 +446,9 @@ print_help (void) + printf (" %s\n", _("which triggers a WARNING or CRITICAL state, and is the percentage of")); + printf (" %s\n", _("packet loss to trigger an alarm state.")); + ++ printf ("\n"); ++ printf (" %s\n", _("IPv4 is used by default. Specify -6 to use IPv6.")); ++ + printf (UT_SUPPORT); + } + -- cgit v1.2.3-74-g34f1