Project

General

Profile

Download (9.31 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/*
3
	diag_dns.php
4
*/
5
/* ====================================================================
6
 *  Copyright (c)  2004-2015  Electric Sheep Fencing, LLC. All rights reserved.
7
 *
8
 *  Redistribution and use in source and binary forms, with or without modification,
9
 *  are permitted provided that the following conditions are met:
10
 *
11
 *  1. Redistributions of source code must retain the above copyright notice,
12
 *      this list of conditions and the following disclaimer.
13
 *
14
 *  2. Redistributions in binary form must reproduce the above copyright
15
 *      notice, this list of conditions and the following disclaimer in
16
 *      the documentation and/or other materials provided with the
17
 *      distribution.
18
 *
19
 *  3. All advertising materials mentioning features or use of this software
20
 *      must display the following acknowledgment:
21
 *      "This product includes software developed by the pfSense Project
22
 *       for use in the pfSense software distribution. (http://www.pfsense.org/).
23
 *
24
 *  4. The names "pfSense" and "pfSense Project" must not be used to
25
 *       endorse or promote products derived from this software without
26
 *       prior written permission. For written permission, please contact
27
 *       coreteam@pfsense.org.
28
 *
29
 *  5. Products derived from this software may not be called "pfSense"
30
 *      nor may "pfSense" appear in their names without prior written
31
 *      permission of the Electric Sheep Fencing, LLC.
32
 *
33
 *  6. Redistributions of any form whatsoever must retain the following
34
 *      acknowledgment:
35
 *
36
 *  "This product includes software developed by the pfSense Project
37
 *  for use in the pfSense software distribution (http://www.pfsense.org/).
38
 *
39
 *  THIS SOFTWARE IS PROVIDED BY THE pfSense PROJECT ``AS IS'' AND ANY
40
 *  EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
41
 *  IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
42
 *  PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE pfSense PROJECT OR
43
 *  ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
44
 *  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
45
 *  NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
46
 *  LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
47
 *  HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
48
 *  STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
49
 *  ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
50
 *  OF THE POSSIBILITY OF SUCH DAMAGE.
51
 *
52
 *  ====================================================================
53
 *
54
 */
55
/*
56
	pfSense_MODULE: dns
57
*/
58

    
59
##|+PRIV
60
##|*IDENT=page-diagnostics-dns
61
##|*NAME=Diagnostics: DNS Lookup
62
##|*DESCR=Allow access to the 'Diagnostics: DNS Lookup' page.
63
##|*MATCH=diag_dns.php*
64
##|-PRIV
65

    
66
$pgtitle = array(gettext("Diagnostics"), gettext("DNS Lookup"));
67
require("guiconfig.inc");
68

    
69
$host = trim($_REQUEST['host'], " \t\n\r\0\x0B[];\"'");
70
$host_esc = escapeshellarg($host);
71

    
72
/* If this section of config.xml has not been populated yet we need to set it up
73
*/
74
if (!is_array($config['aliases']['alias'])) {
75
	$config['aliases']['alias'] = array();
76
}
77
$a_aliases = &$config['aliases']['alias'];
78

    
79
$aliasname = str_replace(array(".", "-"), "_", $host);
80
$alias_exists = false;
81
$counter = 0;
82
foreach ($a_aliases as $a) {
83
	if ($a['name'] == $aliasname) {
84
		$alias_exists = true;
85
		$id = $counter;
86
	}
87
	$counter++;
88
}
89

    
90
if (isset($_POST['create_alias']) && (is_hostname($host) || is_ipaddr($host))) {
91
	if ($_POST['override']) {
92
		$override = true;
93
	}
94
	$resolved = gethostbyname($host);
95
	$type = "hostname";
96
	if ($resolved) {
97
		$resolved = array();
98
		exec("/usr/bin/drill {$host_esc} A | /usr/bin/grep {$host_esc} | /usr/bin/grep -v ';' | /usr/bin/awk '{ print $5 }'", $resolved);
99
		$isfirst = true;
100
		foreach ($resolved as $re) {
101
			if ($re != "") {
102
				if (!$isfirst)
103
					$addresses .= " ";
104
				$addresses .= rtrim($re) . "/32";
105
				$isfirst = false;
106
			}
107
		}
108
		$newalias = array();
109
		if ($override) {
110
			$alias_exists = false;
111
		}
112
		if ($alias_exists == false) {
113
			$newalias['name'] = $aliasname;
114
			$newalias['type'] = "network";
115
			$newalias['address'] = $addresses;
116
			$newalias['descr'] = "Created from Diagnostics-> DNS Lookup";
117
			if ($override) {
118
				$a_aliases[$id] = $newalias;
119
			} else {
120
				$a_aliases[] = $newalias;
121
			}
122
			write_config();
123
			$createdalias = true;
124
		}
125
	}
126
}
127

    
128
if ($_POST) {
129
	unset($input_errors);
130

    
131
	$reqdfields = explode(" ", "host");
132
	$reqdfieldsn = explode(",", "Host");
133

    
134
	do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
135

    
136
	if (!is_hostname($host) && !is_ipaddr($host)) {
137
		$input_errors[] = gettext("Host must be a valid hostname or IP address.");
138
	} else {
139
		// Test resolution speed of each DNS server.
140
		$dns_speeds = array();
141
		$dns_servers = array();
142
		exec("/usr/bin/grep nameserver /etc/resolv.conf | /usr/bin/cut -f2 -d' '", $dns_servers);
143
		foreach ($dns_servers as $dns_server) {
144
			$query_time = exec("/usr/bin/drill {$host_esc} " . escapeshellarg("@" . trim($dns_server)) . " | /usr/bin/grep Query | /usr/bin/cut -d':' -f2");
145
			if ($query_time == "") {
146
				$query_time = gettext("No response");
147
			}
148
			$new_qt = array();
149
			$new_qt['dns_server'] = $dns_server;
150
			$new_qt['query_time'] = $query_time;
151
			$dns_speeds[] = $new_qt;
152
			unset($new_qt);
153
		}
154
	}
155

    
156
	$type = "unknown";
157
	$resolved = "";
158
	$ipaddr = "";
159
	$hostname = "";
160
	if (!$input_errors) {
161
		if (is_ipaddr($host)) {
162
			$type = "ip";
163
			$resolved = gethostbyaddr($host);
164
			$ipaddr = $host;
165
			if ($host != $resolved) {
166
				$hostname = $resolved;
167
			}
168
		} elseif (is_hostname($host)) {
169
			$type = "hostname";
170
			$resolved = gethostbyname($host);
171
			if ($resolved) {
172
				$resolved = array();
173
				exec("/usr/bin/drill {$host_esc} A | /usr/bin/grep {$host_esc} | /usr/bin/grep -v ';' | /usr/bin/awk '{ print $5 }'", $resolved);
174
			}
175
			$hostname = $host;
176
			if ($host != $resolved) {
177
				$ipaddr = $resolved[0];
178
			}
179
		}
180

    
181
		if ($host == $resolved) {
182
			$resolved = gettext("No record found");
183
		}
184
	}
185
}
186

    
187
if (($_POST['host']) && ($_POST['dialog_output'])) {
188
	display_host_results ($host, $resolved, $dns_speeds);
189
	exit;
190
}
191

    
192
function display_host_results ($address, $hostname, $dns_speeds) {
193
	$map_lengths = function($element) { return strlen($element[0]); };
194

    
195
	echo gettext("IP Address") . ": {$address} \n";
196
	echo gettext("Host Name") . ": {$hostname} \n";
197
	echo "\n";
198
	$text_table = array();
199
	$text_table[] = array(gettext("Server"), gettext("Query Time"));
200
	if (is_array($dns_speeds)) {
201
		foreach ($dns_speeds as $qt) {
202
			$text_table[] = array(trim($qt['dns_server']), trim($qt['query_time']));
203
		}
204
	}
205
	$col0_padlength = max(array_map($map_lengths, $text_table)) + 4;
206
	foreach ($text_table as $text_row) {
207
		echo str_pad($text_row[0], $col0_padlength) . $text_row[1] . "\n";
208
	}
209
}
210

    
211
include("head.inc");
212

    
213
/* Display any error messages resulting from user input */
214
if ($input_errors)
215
	print_input_errors($input_errors);
216
else if (!$resolved && $type)
217
	print('<div class="alert alert-warning" role="alert">' . gettext("Host") .' "'. $host .'" '. gettext("could not be resolved") . '</div>');
218

    
219
if ($createdalias)
220
	print('<div class="alert alert-success" role="alert">'.gettext("Alias was created/updated successfully").'</div>');
221

    
222
$form = new Form('Lookup');
223
$section = new Form_Section('DNS Lookup');
224

    
225
$section->addInput(new Form_Input(
226
	'host',
227
	'Hostname',
228
	'text',
229
	$host,
230
	['placeholder' => 'Hostname to look up.']
231
));
232

    
233
if (!empty($resolved)) {
234
	$form->addGlobal(new Form_Button(
235
		'create_alias',
236
		'Add alias'
237
	))->removeClass('btn-primary')->addClass('btn-success');
238
}
239

    
240
$form->add($section);
241
print $form;
242

    
243
if (!$input_errors && $type) {
244
	if ($resolved):
245
?>
246
<div class="panel panel-default">
247
	<div class="panel-heading"><h2 class="panel-title">Results</h2></div>
248
	<div class="panel-body">
249
		<ul class="list-group">
250
<?
251
		foreach ((array)$resolved as $hostitem) {
252
?>
253
			<li class="list-group-item"><?=$hostitem?></li>
254
<?
255
			if ($hostitem != "") {
256
				$found++;
257
			}
258
		}
259
?>
260
		</ul>
261
	</div>
262
</div>
263
<? endif?>
264

    
265
<!-- Second table displays the server resolution times -->
266
<div class="panel panel-default">
267
	<div class="panel-heading"><h2 class="panel-title">Timings</h2></div>
268
	<div class="panel-body">
269
		<table class="table">
270
		<thead>
271
			<tr>
272
				<th>Name server</th>
273
				<th>Query time</th>
274
			</tr>
275
		</thead>
276

    
277
		<tbody>
278
<? foreach ((array)$dns_speeds as $qt):?>
279
		<tr>
280
			<td><?=$qt['dns_server']?></td><td><?=$qt['query_time']?></td>
281
		</tr>
282
<? endforeach?>
283
		</tbody>
284
		</table>
285
	</div>
286
</div>
287

    
288
<!-- Third table displays "More information" -->
289
<div class="panel panel-default">
290
	<div class="panel-heading"><h2 class="panel-title">More information</h2></div>
291
	<div class="panel-body">
292
		<ul class="list-group">
293
			<li class="list-group-item"><a href="/diag_ping.php?host=<?=htmlspecialchars($host)?>&amp;count=3"><?=gettext("Ping")?></a></li>
294
			<li class="list-group-item"><a href="/diag_traceroute.php?host=<?=htmlspecialchars($host)?>&amp;ttl=18"><?=gettext("Traceroute")?></a></li>
295
		</ul>
296
		<h5><?=gettext("NOTE: The following links are to external services, so their reliability cannot be guaranteed.");?></h5>
297
		<ul class="list-group">
298
			<li class="list-group-item"><a target="_blank" href="http://private.dnsstuff.com/tools/whois.ch?ip=<?php echo $ipaddr; ?>"><?=gettext("IP WHOIS @ DNS Stuff");?></a></li>
299
			<li class="list-group-item"><a target="_blank" href="http://private.dnsstuff.com/tools/ipall.ch?ip=<?php echo $ipaddr; ?>"><?=gettext("IP Info @ DNS Stuff");?></a></li>
300
		</ul>
301
	</div>
302
</div>
303
<?php
304
}
305
include("foot.inc");
(11-11/228)