diff options
author | Matthias Eble <psychotrahe@users.sourceforge.net> | 2008-01-08 23:08:46 (GMT) |
---|---|---|
committer | Matthias Eble <psychotrahe@users.sourceforge.net> | 2008-01-08 23:08:46 (GMT) |
commit | 7ef7071affd2d40def5b0737a7dec3e0982208a0 (patch) | |
tree | 676745309a9e035beaa95eab67c5c320f2a57d89 /plugins/check_dns.c | |
parent | 8a4f1385270d8d7700a90f0705683187a10a664f (diff) | |
download | monitoring-plugins-7ef7071affd2d40def5b0737a7dec3e0982208a0.tar.gz |
Fixed reverse lookup damaged by previous commit
git-svn-id: https://nagiosplug.svn.sourceforge.net/svnroot/nagiosplug/nagiosplug/trunk@1903 f882894a-f735-0410-b71e-b25c423dba1c
Diffstat (limited to 'plugins/check_dns.c')
-rw-r--r-- | plugins/check_dns.c | 13 |
1 files changed, 7 insertions, 6 deletions
diff --git a/plugins/check_dns.c b/plugins/check_dns.c index 8ae48cd..3565802 100644 --- a/plugins/check_dns.c +++ b/plugins/check_dns.c | |||
@@ -77,7 +77,7 @@ main (int argc, char **argv) | |||
77 | { | 77 | { |
78 | char *command_line = NULL; | 78 | char *command_line = NULL; |
79 | char input_buffer[MAX_INPUT_BUFFER]; | 79 | char input_buffer[MAX_INPUT_BUFFER]; |
80 | char *address = NULL; | 80 | char *address = NULL; /* comma seperated str with addrs/ptrs (sorted) */ |
81 | char **addresses = NULL; | 81 | char **addresses = NULL; |
82 | int n_addresses = 0; | 82 | int n_addresses = 0; |
83 | char *msg = NULL; | 83 | char *msg = NULL; |
@@ -122,12 +122,17 @@ main (int argc, char **argv) | |||
122 | 122 | ||
123 | /* scan stdout */ | 123 | /* scan stdout */ |
124 | for(i = 0; i < chld_out.lines; i++) { | 124 | for(i = 0; i < chld_out.lines; i++) { |
125 | if (addresses == NULL) | ||
126 | addresses = malloc(sizeof(*addresses)*10); | ||
127 | else if (!(n_addresses % 10)) | ||
128 | addresses = realloc(addresses,sizeof(*addresses) * (n_addresses + 10)); | ||
129 | |||
125 | if (verbose) | 130 | if (verbose) |
126 | puts(chld_out.line[i]); | 131 | puts(chld_out.line[i]); |
127 | 132 | ||
128 | if (strstr (chld_out.line[i], ".in-addr.arpa")) { | 133 | if (strstr (chld_out.line[i], ".in-addr.arpa")) { |
129 | if ((temp_buffer = strstr (chld_out.line[i], "name = "))) | 134 | if ((temp_buffer = strstr (chld_out.line[i], "name = "))) |
130 | address = strdup (temp_buffer + 7); | 135 | addresses[n_addresses++] = strdup (temp_buffer + 7); |
131 | else { | 136 | else { |
132 | msg = (char *)_("Warning plugin error"); | 137 | msg = (char *)_("Warning plugin error"); |
133 | result = STATE_WARNING; | 138 | result = STATE_WARNING; |
@@ -153,10 +158,6 @@ main (int argc, char **argv) | |||
153 | NSLOOKUP_COMMAND); | 158 | NSLOOKUP_COMMAND); |
154 | } | 159 | } |
155 | 160 | ||
156 | if (addresses == NULL) | ||
157 | addresses = malloc(sizeof(*addresses)*10); | ||
158 | else if (!(n_addresses % 10)) | ||
159 | addresses = realloc(addresses,sizeof(*addresses) * (n_addresses + 10)); | ||
160 | addresses[n_addresses++] = strdup(temp_buffer); | 161 | addresses[n_addresses++] = strdup(temp_buffer); |
161 | } | 162 | } |
162 | else if (strstr (chld_out.line[i], _("Non-authoritative answer:"))) { | 163 | else if (strstr (chld_out.line[i], _("Non-authoritative answer:"))) { |