diff options
Diffstat (limited to 'plugins/check_dns.c')
-rw-r--r-- | plugins/check_dns.c | 72 |
1 files changed, 35 insertions, 37 deletions
diff --git a/plugins/check_dns.c b/plugins/check_dns.c index 7ffce98b..468bc958 100644 --- a/plugins/check_dns.c +++ b/plugins/check_dns.c | |||
@@ -41,8 +41,8 @@ const char *email = "devel@monitoring-plugins.org"; | |||
41 | 41 | ||
42 | int process_arguments (int, char **); | 42 | int process_arguments (int, char **); |
43 | int validate_arguments (void); | 43 | int validate_arguments (void); |
44 | int error_scan (char *, int *); | 44 | int error_scan (char *, bool *); |
45 | int ip_match_cidr(const char *, const char *); | 45 | bool ip_match_cidr(const char *, const char *); |
46 | unsigned long ip2long(const char *); | 46 | unsigned long ip2long(const char *); |
47 | void print_help (void); | 47 | void print_help (void); |
48 | void print_usage (void); | 48 | void print_usage (void); |
@@ -51,13 +51,13 @@ void print_usage (void); | |||
51 | char query_address[ADDRESS_LENGTH] = ""; | 51 | char query_address[ADDRESS_LENGTH] = ""; |
52 | char dns_server[ADDRESS_LENGTH] = ""; | 52 | char dns_server[ADDRESS_LENGTH] = ""; |
53 | char ptr_server[ADDRESS_LENGTH] = ""; | 53 | char ptr_server[ADDRESS_LENGTH] = ""; |
54 | int verbose = FALSE; | 54 | bool verbose = false; |
55 | char **expected_address = NULL; | 55 | char **expected_address = NULL; |
56 | int expected_address_cnt = 0; | 56 | int expected_address_cnt = 0; |
57 | int expect_nxdomain = FALSE; | 57 | bool expect_nxdomain = false; |
58 | 58 | ||
59 | int expect_authority = FALSE; | 59 | bool expect_authority = false; |
60 | int all_match = FALSE; | 60 | bool all_match = false; |
61 | thresholds *time_thresholds = NULL; | 61 | thresholds *time_thresholds = NULL; |
62 | 62 | ||
63 | static int | 63 | static int |
@@ -80,15 +80,14 @@ main (int argc, char **argv) | |||
80 | int n_addresses = 0; | 80 | int n_addresses = 0; |
81 | char *msg = NULL; | 81 | char *msg = NULL; |
82 | char *temp_buffer = NULL; | 82 | char *temp_buffer = NULL; |
83 | int non_authoritative = FALSE; | 83 | bool non_authoritative = false; |
84 | int result = STATE_UNKNOWN; | 84 | int result = STATE_UNKNOWN; |
85 | double elapsed_time; | 85 | double elapsed_time; |
86 | long microsec; | 86 | long microsec; |
87 | struct timeval tv; | 87 | struct timeval tv; |
88 | int parse_address = FALSE; /* This flag scans for Address: but only after Name: */ | 88 | bool parse_address = false; /* This flag scans for Address: but only after Name: */ |
89 | output chld_out, chld_err; | 89 | output chld_out, chld_err; |
90 | size_t i; | 90 | bool is_nxdomain = false; |
91 | int is_nxdomain = FALSE; | ||
92 | 91 | ||
93 | setlocale (LC_ALL, ""); | 92 | setlocale (LC_ALL, ""); |
94 | bindtextdomain (PACKAGE, LOCALEDIR); | 93 | bindtextdomain (PACKAGE, LOCALEDIR); |
@@ -122,7 +121,7 @@ main (int argc, char **argv) | |||
122 | } | 121 | } |
123 | 122 | ||
124 | /* scan stdout */ | 123 | /* scan stdout */ |
125 | for(i = 0; i < chld_out.lines; i++) { | 124 | for(size_t i = 0; i < chld_out.lines; i++) { |
126 | if (addresses == NULL) | 125 | if (addresses == NULL) |
127 | addresses = malloc(sizeof(*addresses)*10); | 126 | addresses = malloc(sizeof(*addresses)*10); |
128 | else if (!(n_addresses % 10)) | 127 | else if (!(n_addresses % 10)) |
@@ -164,8 +163,8 @@ main (int argc, char **argv) | |||
164 | 163 | ||
165 | /* the server is responding, we just got the host name... */ | 164 | /* the server is responding, we just got the host name... */ |
166 | if (strstr (chld_out.line[i], "Name:")) | 165 | if (strstr (chld_out.line[i], "Name:")) |
167 | parse_address = TRUE; | 166 | parse_address = true; |
168 | else if (parse_address == TRUE && (strstr (chld_out.line[i], "Address:") || | 167 | else if (parse_address && (strstr (chld_out.line[i], "Address:") || |
169 | strstr (chld_out.line[i], "Addresses:"))) { | 168 | strstr (chld_out.line[i], "Addresses:"))) { |
170 | temp_buffer = index (chld_out.line[i], ':'); | 169 | temp_buffer = index (chld_out.line[i], ':'); |
171 | temp_buffer++; | 170 | temp_buffer++; |
@@ -184,7 +183,7 @@ main (int argc, char **argv) | |||
184 | addresses[n_addresses++] = strdup(temp_buffer); | 183 | addresses[n_addresses++] = strdup(temp_buffer); |
185 | } | 184 | } |
186 | else if (strstr (chld_out.line[i], _("Non-authoritative answer:"))) { | 185 | else if (strstr (chld_out.line[i], _("Non-authoritative answer:"))) { |
187 | non_authoritative = TRUE; | 186 | non_authoritative = true; |
188 | } | 187 | } |
189 | 188 | ||
190 | 189 | ||
@@ -197,7 +196,7 @@ main (int argc, char **argv) | |||
197 | } | 196 | } |
198 | 197 | ||
199 | /* scan stderr */ | 198 | /* scan stderr */ |
200 | for(i = 0; i < chld_err.lines; i++) { | 199 | for(size_t i = 0; i < chld_err.lines; i++) { |
201 | if (verbose) | 200 | if (verbose) |
202 | puts(chld_err.line[i]); | 201 | puts(chld_err.line[i]); |
203 | 202 | ||
@@ -241,7 +240,7 @@ main (int argc, char **argv) | |||
241 | unsigned long expect_match = (1 << expected_address_cnt) - 1; | 240 | unsigned long expect_match = (1 << expected_address_cnt) - 1; |
242 | unsigned long addr_match = (1 << n_addresses) - 1; | 241 | unsigned long addr_match = (1 << n_addresses) - 1; |
243 | 242 | ||
244 | for (i=0; i<expected_address_cnt; i++) { | 243 | for (int i=0; i<expected_address_cnt; i++) { |
245 | int j; | 244 | int j; |
246 | /* check if we get a match on 'raw' ip or cidr */ | 245 | /* check if we get a match on 'raw' ip or cidr */ |
247 | for (j=0; j<n_addresses; j++) { | 246 | for (j=0; j<n_addresses; j++) { |
@@ -298,21 +297,21 @@ main (int argc, char **argv) | |||
298 | printf (_(". %s returns %s"), query_address, address); | 297 | printf (_(". %s returns %s"), query_address, address); |
299 | if ((time_thresholds->warning != NULL) && (time_thresholds->critical != NULL)) { | 298 | if ((time_thresholds->warning != NULL) && (time_thresholds->critical != NULL)) { |
300 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", | 299 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", |
301 | TRUE, time_thresholds->warning->end, | 300 | true, time_thresholds->warning->end, |
302 | TRUE, time_thresholds->critical->end, | 301 | true, time_thresholds->critical->end, |
303 | TRUE, 0, FALSE, 0)); | 302 | true, 0, false, 0)); |
304 | } else if ((time_thresholds->warning == NULL) && (time_thresholds->critical != NULL)) { | 303 | } else if ((time_thresholds->warning == NULL) && (time_thresholds->critical != NULL)) { |
305 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", | 304 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", |
306 | FALSE, 0, | 305 | false, 0, |
307 | TRUE, time_thresholds->critical->end, | 306 | true, time_thresholds->critical->end, |
308 | TRUE, 0, FALSE, 0)); | 307 | true, 0, false, 0)); |
309 | } else if ((time_thresholds->warning != NULL) && (time_thresholds->critical == NULL)) { | 308 | } else if ((time_thresholds->warning != NULL) && (time_thresholds->critical == NULL)) { |
310 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", | 309 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", |
311 | TRUE, time_thresholds->warning->end, | 310 | true, time_thresholds->warning->end, |
312 | FALSE, 0, | 311 | false, 0, |
313 | TRUE, 0, FALSE, 0)); | 312 | true, 0, false, 0)); |
314 | } else | 313 | } else |
315 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", FALSE, 0, FALSE, 0, TRUE, 0, FALSE, 0)); | 314 | printf ("|%s\n", fperfdata ("time", elapsed_time, "s", false, 0, false, 0, true, 0, false, 0)); |
316 | } | 315 | } |
317 | else if (result == STATE_WARNING) | 316 | else if (result == STATE_WARNING) |
318 | printf (_("DNS WARNING - %s\n"), | 317 | printf (_("DNS WARNING - %s\n"), |
@@ -327,15 +326,14 @@ main (int argc, char **argv) | |||
327 | return result; | 326 | return result; |
328 | } | 327 | } |
329 | 328 | ||
330 | int | 329 | bool ip_match_cidr(const char *addr, const char *cidr_ro) { |
331 | ip_match_cidr(const char *addr, const char *cidr_ro) | ||
332 | { | ||
333 | char *subnet, *mask_c, *cidr = strdup(cidr_ro); | 330 | char *subnet, *mask_c, *cidr = strdup(cidr_ro); |
334 | int mask; | 331 | int mask; |
335 | subnet = strtok(cidr, "/"); | 332 | subnet = strtok(cidr, "/"); |
336 | mask_c = strtok(NULL, "\0"); | 333 | mask_c = strtok(NULL, "\0"); |
337 | if (!subnet || !mask_c) | 334 | if (!subnet || !mask_c) { |
338 | return FALSE; | 335 | return false; |
336 | } | ||
339 | mask = atoi(mask_c); | 337 | mask = atoi(mask_c); |
340 | 338 | ||
341 | /* https://www.cryptobells.com/verifying-ips-in-a-subnet-in-php/ */ | 339 | /* https://www.cryptobells.com/verifying-ips-in-a-subnet-in-php/ */ |
@@ -355,14 +353,14 @@ ip2long(const char* src) { | |||
355 | } | 353 | } |
356 | 354 | ||
357 | int | 355 | int |
358 | error_scan (char *input_buffer, int *is_nxdomain) | 356 | error_scan (char *input_buffer, bool *is_nxdomain) |
359 | { | 357 | { |
360 | 358 | ||
361 | const int nxdomain = strstr (input_buffer, "Non-existent") || | 359 | const int nxdomain = strstr (input_buffer, "Non-existent") || |
362 | strstr (input_buffer, "** server can't find") || | 360 | strstr (input_buffer, "** server can't find") || |
363 | strstr (input_buffer, "** Can't find") || | 361 | strstr (input_buffer, "** Can't find") || |
364 | strstr (input_buffer, "NXDOMAIN"); | 362 | strstr (input_buffer, "NXDOMAIN"); |
365 | if (nxdomain) *is_nxdomain = TRUE; | 363 | if (nxdomain) *is_nxdomain = true; |
366 | 364 | ||
367 | /* the DNS lookup timed out */ | 365 | /* the DNS lookup timed out */ |
368 | if (strstr (input_buffer, _("Note: nslookup is deprecated and may be removed from future releases.")) || | 366 | if (strstr (input_buffer, _("Note: nslookup is deprecated and may be removed from future releases.")) || |
@@ -461,7 +459,7 @@ process_arguments (int argc, char **argv) | |||
461 | print_revision (progname, NP_VERSION); | 459 | print_revision (progname, NP_VERSION); |
462 | exit (STATE_UNKNOWN); | 460 | exit (STATE_UNKNOWN); |
463 | case 'v': /* version */ | 461 | case 'v': /* version */ |
464 | verbose = TRUE; | 462 | verbose = true; |
465 | break; | 463 | break; |
466 | case 't': /* timeout period */ | 464 | case 't': /* timeout period */ |
467 | timeout_interval = atoi (optarg); | 465 | timeout_interval = atoi (optarg); |
@@ -508,13 +506,13 @@ process_arguments (int argc, char **argv) | |||
508 | } | 506 | } |
509 | break; | 507 | break; |
510 | case 'n': /* expect NXDOMAIN */ | 508 | case 'n': /* expect NXDOMAIN */ |
511 | expect_nxdomain = TRUE; | 509 | expect_nxdomain = true; |
512 | break; | 510 | break; |
513 | case 'A': /* expect authority */ | 511 | case 'A': /* expect authority */ |
514 | expect_authority = TRUE; | 512 | expect_authority = true; |
515 | break; | 513 | break; |
516 | case 'L': /* all must match */ | 514 | case 'L': /* all must match */ |
517 | all_match = TRUE; | 515 | all_match = true; |
518 | break; | 516 | break; |
519 | case 'w': | 517 | case 'w': |
520 | warning = optarg; | 518 | warning = optarg; |