Project

General

Profile

Download (9.18 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
$pgtitle = array(gettext("Diagnostics"), gettext("DNS Lookup"));
60
require("guiconfig.inc");
61

    
62
$host = trim($_REQUEST['host'], " \t\n\r\0\x0B[];\"'");
63
$host_esc = escapeshellarg($host);
64

    
65
/* If this section of config.xml has not been populated yet we need to set it up
66
*/
67
if (!is_array($config['aliases']['alias'])) {
68
	$config['aliases']['alias'] = array();
69
}
70
$a_aliases = &$config['aliases']['alias'];
71

    
72
$aliasname = str_replace(array(".", "-"), "_", $host);
73
$alias_exists = false;
74
$counter = 0;
75
foreach ($a_aliases as $a) {
76
	if ($a['name'] == $aliasname) {
77
		$alias_exists = true;
78
		$id = $counter;
79
	}
80
	$counter++;
81
}
82

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

    
121
if ($_POST) {
122
	unset($input_errors);
123

    
124
	$reqdfields = explode(" ", "host");
125
	$reqdfieldsn = explode(",", "Host");
126

    
127
	do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
128

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

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

    
174
		if ($host == $resolved) {
175
			$resolved = gettext("No record found");
176
		}
177
	}
178
}
179

    
180
if (($_POST['host']) && ($_POST['dialog_output'])) {
181
	display_host_results ($host, $resolved, $dns_speeds);
182
	exit;
183
}
184

    
185
function display_host_results ($address, $hostname, $dns_speeds) {
186
	$map_lengths = function($element) { return strlen($element[0]); };
187

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

    
204
include("head.inc");
205

    
206
/* Display any error messages resulting from user input */
207
if ($input_errors)
208
	print_input_errors($input_errors);
209
else if (!$resolved && $type)
210
	print('<div class="alert alert-warning" role="alert">' . gettext("Host") .' "'. $host .'" '. gettext("could not be resolved") . '</div>');
211

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

    
215
require_once('classes/Form.class.php');
216

    
217
$form = new Form('Lookup');
218
$section = new Form_Section('DNS Lookup');
219

    
220
$section->addInput(new Form_Input(
221
	'host',
222
	'Hostname',
223
	'text',
224
	$host,
225
	['placeholder' => 'Hostname to look up.']
226
));
227

    
228
if (!empty($resolved)) {
229
	$form->addGlobal(new Form_Button(
230
		'create_alias',
231
		'Add alias'
232
	))->removeClass('btn-primary')->addClass('btn-success');
233
}
234

    
235
$form->add($section);
236
print $form;
237

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

    
260
<!-- Second table displays the server resolution times -->
261
<div class="panel panel-default">
262
	<div class="panel-heading"><h2 class="panel-title">Timings</h2></div>
263
	<div class="panel-body">
264
		<table class="table">
265
		<thead>
266
			<tr>
267
				<th>Name server</th>
268
				<th>Query time</th>
269
			</tr>
270
		</thead>
271

    
272
		<tbody>
273
<? foreach ((array)$dns_speeds as $qt):?>
274
		<tr>
275
			<td><?=$qt['dns_server']?></td><td><?=$qt['query_time']?></td>
276
		</tr>
277
<? endforeach?>
278
		</tbody>
279
		</table>
280
	</div>
281
</div>
282

    
283
<!-- Third table displays "More information" -->
284
<div class="panel panel-default">
285
	<div class="panel-heading"><h2 class="panel-title">More information</h2></div>
286
	<div class="panel-body">
287
		<ul class="list-group">
288
			<li class="list-group-item"><a href="/diag_ping.php?host=<?=htmlspecialchars($host)?>&amp;count=3"><?=gettext("Ping")?></a></li>
289
			<li class="list-group-item"><a href="/diag_traceroute.php?host=<?=htmlspecialchars($host)?>&amp;ttl=18"><?=gettext("Traceroute")?></a></li>
290
		</ul>
291
		<p><?=gettext("NOTE: The following links are to external services, so their reliability cannot be guaranteed.");?></p>
292
		<ul class="list-group">
293
			<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>
294
			<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>
295
		</ul>
296
	</div>
297
</div>
298
<?php
299
}
300
include("foot.inc");
(11-11/228)