diff options
| author | Oliver Skibbe <oliskibbe@gmail.com> | 2015-09-28 14:22:09 +0200 | 
|---|---|---|
| committer | RincewindsHat <12514511+RincewindsHat@users.noreply.github.com> | 2021-11-18 18:51:27 +0100 | 
| commit | a2eb4e8210deb37133ece1e6e94aad4e6c5bea14 (patch) | |
| tree | dc81e6a69db1a8d45ca2c9f0ba566f9ae9a60c84 /plugins | |
| parent | d6d2254312aede137dcd998a4cdfa26ecd07e379 (diff) | |
| download | monitoring-plugins-a2eb4e8210deb37133ece1e6e94aad4e6c5bea14.tar.gz | |
* check_ping: added option for packet size
  - added option (-s/--packetsize) for setting packet size
    (limited to 65528 Bytes, according to RFC791)
  - added DEFAULT_PACKET_SIZE constant with 56 Bytes)
  - disabled ping check for UnixWare in autoconf: if condition and
    with_ping_command had different syntax
Diffstat (limited to 'plugins')
| -rw-r--r-- | plugins/check_ping.c | 36 | 
1 files changed, 31 insertions, 5 deletions
| diff --git a/plugins/check_ping.c b/plugins/check_ping.c index ba7af373..de173f9f 100644 --- a/plugins/check_ping.c +++ b/plugins/check_ping.c | |||
| @@ -44,7 +44,8 @@ const char *email = "devel@monitoring-plugins.org"; | |||
| 44 | 44 | ||
| 45 | enum { | 45 | enum { | 
| 46 | UNKNOWN_PACKET_LOSS = 200, /* 200% */ | 46 | UNKNOWN_PACKET_LOSS = 200, /* 200% */ | 
| 47 | DEFAULT_MAX_PACKETS = 5 /* default no. of ICMP ECHO packets */ | 47 | DEFAULT_MAX_PACKETS = 5, /* default no. of ICMP ECHO packets */ | 
| 48 | DEFAULT_PACKET_SIZE = 56 /* default size of ICMP ECHO packets */ | ||
| 48 | }; | 49 | }; | 
| 49 | 50 | ||
| 50 | int process_arguments (int, char **); | 51 | int process_arguments (int, char **); | 
| @@ -64,6 +65,7 @@ char **addresses = NULL; | |||
| 64 | int n_addresses = 0; | 65 | int n_addresses = 0; | 
| 65 | int max_addr = 1; | 66 | int max_addr = 1; | 
| 66 | int max_packets = -1; | 67 | int max_packets = -1; | 
| 68 | int packet_size = DEFAULT_PACKET_SIZE; | ||
| 67 | int verbose = 0; | 69 | int verbose = 0; | 
| 68 | 70 | ||
| 69 | float rta = UNKNOWN_TRIP_TIME; | 71 | float rta = UNKNOWN_TRIP_TIME; | 
| @@ -122,13 +124,21 @@ main (int argc, char **argv) | |||
| 122 | 124 | ||
| 123 | /* does the host address of number of packets argument come first? */ | 125 | /* does the host address of number of packets argument come first? */ | 
| 124 | #ifdef PING_PACKETS_FIRST | 126 | #ifdef PING_PACKETS_FIRST | 
| 125 | # ifdef PING_HAS_TIMEOUT | 127 | # if defined(PING_HAS_TIMEOUT) && defined(PING_HAS_PACKETSIZE) | 
| 128 | xasprintf (&cmd, rawcmd, timeout_interval, max_packets, packet_size, addresses[i]); | ||
| 129 | # elif defined(PING_HAS_TIMEOUT) | ||
| 126 | xasprintf (&cmd, rawcmd, timeout_interval, max_packets, addresses[i]); | 130 | xasprintf (&cmd, rawcmd, timeout_interval, max_packets, addresses[i]); | 
| 131 | # elif defined(PING_HAS_PACKETSIZE) | ||
| 132 | xasprintf (&cmd, rawcmd, max_packets, packet_size, addresses[i]); | ||
| 127 | # else | 133 | # else | 
| 128 | xasprintf (&cmd, rawcmd, max_packets, addresses[i]); | 134 | xasprintf (&cmd, rawcmd, max_packets, addresses[i]); | 
| 129 | # endif | 135 | # endif | 
| 130 | #else | 136 | #else | 
| 131 | xasprintf (&cmd, rawcmd, addresses[i], max_packets); | 137 | # ifdef PING_HAS_PACKETSIZE | 
| 138 | xasprintf (&cmd, rawcmd, addresses[i], packet_size, max_packets); | ||
| 139 | # else | ||
| 140 | xasprintf (&cmd, rawcmd, addresses[i], max_packets); | ||
| 141 | # endif | ||
| 132 | #endif | 142 | #endif | 
| 133 | 143 | ||
| 134 | if (verbose >= 2) | 144 | if (verbose >= 2) | 
| @@ -202,6 +212,7 @@ process_arguments (int argc, char **argv) | |||
| 202 | static struct option longopts[] = { | 212 | static struct option longopts[] = { | 
| 203 | STD_LONG_OPTS, | 213 | STD_LONG_OPTS, | 
| 204 | {"packets", required_argument, 0, 'p'}, | 214 | {"packets", required_argument, 0, 'p'}, | 
| 215 | {"packetsize",required_argument, 0, 's'}, | ||
| 205 | {"nohtml", no_argument, 0, 'n'}, | 216 | {"nohtml", no_argument, 0, 'n'}, | 
| 206 | {"link", no_argument, 0, 'L'}, | 217 | {"link", no_argument, 0, 'L'}, | 
| 207 | {"use-ipv4", no_argument, 0, '4'}, | 218 | {"use-ipv4", no_argument, 0, '4'}, | 
| @@ -220,7 +231,7 @@ process_arguments (int argc, char **argv) | |||
| 220 | } | 231 | } | 
| 221 | 232 | ||
| 222 | while (1) { | 233 | while (1) { | 
| 223 | c = getopt_long (argc, argv, "VvhnL46t:c:w:H:p:", longopts, &option); | 234 | c = getopt_long (argc, argv, "VvhnL46t:c:w:H:p:s:", longopts, &option); | 
| 224 | 235 | ||
| 225 | if (c == -1 || c == EOF) | 236 | if (c == -1 || c == EOF) | 
| 226 | break; | 237 | break; | 
| @@ -277,6 +288,12 @@ process_arguments (int argc, char **argv) | |||
| 277 | else | 288 | else | 
| 278 | usage2 (_("<max_packets> (%s) must be a non-negative number\n"), optarg); | 289 | usage2 (_("<max_packets> (%s) must be a non-negative number\n"), optarg); | 
| 279 | break; | 290 | break; | 
| 291 | case 's': /* number of packets to send */ | ||
| 292 | if (is_intnonneg (optarg)) | ||
| 293 | packet_size = atoi (optarg); | ||
| 294 | else | ||
| 295 | usage2 (_("<packet_size> (%s) must be a non-negative number\n"), optarg); | ||
| 296 | break; | ||
| 280 | case 'n': /* no HTML */ | 297 | case 'n': /* no HTML */ | 
| 281 | display_html = FALSE; | 298 | display_html = FALSE; | 
| 282 | break; | 299 | break; | 
| @@ -307,6 +324,7 @@ process_arguments (int argc, char **argv) | |||
| 307 | } | 324 | } | 
| 308 | } | 325 | } | 
| 309 | 326 | ||
| 327 | /* XXX shouldnt this be in function validate_arguments ? */ | ||
| 310 | if (wpl == UNKNOWN_PACKET_LOSS) { | 328 | if (wpl == UNKNOWN_PACKET_LOSS) { | 
| 311 | if (is_intpercent (argv[c]) == FALSE) { | 329 | if (is_intpercent (argv[c]) == FALSE) { | 
| 312 | printf (_("<wpl> (%s) must be an integer percentage\n"), argv[c]); | 330 | printf (_("<wpl> (%s) must be an integer percentage\n"), argv[c]); | 
| @@ -359,6 +377,7 @@ process_arguments (int argc, char **argv) | |||
| 359 | return ERROR; | 377 | return ERROR; | 
| 360 | } | 378 | } | 
| 361 | } | 379 | } | 
| 380 | /* XXX END shouldnt this be in function validate_arguments ? */ | ||
| 362 | 381 | ||
| 363 | return validate_arguments (); | 382 | return validate_arguments (); | 
| 364 | } | 383 | } | 
| @@ -387,6 +406,10 @@ validate_arguments () | |||
| 387 | float max_seconds; | 406 | float max_seconds; | 
| 388 | int i; | 407 | int i; | 
| 389 | 408 | ||
| 409 | if (packet_size > 65528) { | ||
| 410 | printf (_("max packet size cannot be larger than 65528 Bytes")); | ||
| 411 | return ERROR; | ||
| 412 | } | ||
| 390 | if (wrta < 0.0) { | 413 | if (wrta < 0.0) { | 
| 391 | printf (_("<wrta> was not set\n")); | 414 | printf (_("<wrta> was not set\n")); | 
| 392 | return ERROR; | 415 | return ERROR; | 
| @@ -591,6 +614,9 @@ print_help (void) | |||
| 591 | printf (" %s\n", "-p, --packets=INTEGER"); | 614 | printf (" %s\n", "-p, --packets=INTEGER"); | 
| 592 | printf (" %s ", _("number of ICMP ECHO packets to send")); | 615 | printf (" %s ", _("number of ICMP ECHO packets to send")); | 
| 593 | printf (_("(Default: %d)\n"), DEFAULT_MAX_PACKETS); | 616 | printf (_("(Default: %d)\n"), DEFAULT_MAX_PACKETS); | 
| 617 | printf (" %s\n", "-s, --packetsize=INTEGER"); | ||
| 618 | printf (" %s ", _("size of ICMP ECHO packet to send")); | ||
| 619 | printf (_("(Default: %d)\n"), DEFAULT_PACKET_SIZE); | ||
| 594 | printf (" %s\n", "-L, --link"); | 620 | printf (" %s\n", "-L, --link"); | 
| 595 | printf (" %s\n", _("show HTML in the plugin output (obsoleted by urlize)")); | 621 | printf (" %s\n", _("show HTML in the plugin output (obsoleted by urlize)")); | 
| 596 | 622 | ||
| @@ -615,5 +641,5 @@ print_usage (void) | |||
| 615 | { | 641 | { | 
| 616 | printf ("%s\n", _("Usage:")); | 642 | printf ("%s\n", _("Usage:")); | 
| 617 | printf ("%s -H <host_address> -w <wrta>,<wpl>%% -c <crta>,<cpl>%%\n", progname); | 643 | printf ("%s -H <host_address> -w <wrta>,<wpl>%% -c <crta>,<cpl>%%\n", progname); | 
| 618 | printf (" [-p packets] [-t timeout] [-4|-6]\n"); | 644 | printf (" [-p packets] [-s packetsize] [-t timeout] [-4|-6]\n"); | 
| 619 | } | 645 | } | 
