summaryrefslogtreecommitdiffstats
path: root/plugins/check_dns.c
diff options
context:
space:
mode:
Diffstat (limited to 'plugins/check_dns.c')
-rw-r--r--plugins/check_dns.c72
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
42int process_arguments (int, char **); 42int process_arguments (int, char **);
43int validate_arguments (void); 43int validate_arguments (void);
44int error_scan (char *, int *); 44int error_scan (char *, bool *);
45int ip_match_cidr(const char *, const char *); 45bool ip_match_cidr(const char *, const char *);
46unsigned long ip2long(const char *); 46unsigned long ip2long(const char *);
47void print_help (void); 47void print_help (void);
48void print_usage (void); 48void print_usage (void);
@@ -51,13 +51,13 @@ void print_usage (void);
51char query_address[ADDRESS_LENGTH] = ""; 51char query_address[ADDRESS_LENGTH] = "";
52char dns_server[ADDRESS_LENGTH] = ""; 52char dns_server[ADDRESS_LENGTH] = "";
53char ptr_server[ADDRESS_LENGTH] = ""; 53char ptr_server[ADDRESS_LENGTH] = "";
54int verbose = FALSE; 54bool verbose = false;
55char **expected_address = NULL; 55char **expected_address = NULL;
56int expected_address_cnt = 0; 56int expected_address_cnt = 0;
57int expect_nxdomain = FALSE; 57bool expect_nxdomain = false;
58 58
59int expect_authority = FALSE; 59bool expect_authority = false;
60int all_match = FALSE; 60bool all_match = false;
61thresholds *time_thresholds = NULL; 61thresholds *time_thresholds = NULL;
62 62
63static int 63static 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
330int 329bool ip_match_cidr(const char *addr, const char *cidr_ro) {
331ip_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
357int 355int
358error_scan (char *input_buffer, int *is_nxdomain) 356error_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;