Project

General

Profile

Download (5.28 KB) Statistics
| Branch: | Tag: | Revision:
1 93e1b16c Scott Ullrich
<?php
2
/*
3 c5d81585 Renato Botelho
 * diag_traceroute.php
4
 *
5
 * part of pfSense (https://www.pfsense.org)
6 38809d47 Renato Botelho do Couto
 * Copyright (c) 2004-2013 BSD Perimeter
7
 * Copyright (c) 2013-2016 Electric Sheep Fencing
8
 * Copyright (c) 2014-2019 Rubicon Communications, LLC (Netgate)
9 c5d81585 Renato Botelho
 * Copyright (c) 2005 Paul Taylor (paultaylor@winndixie.com)
10
 * All rights reserved.
11
 *
12
 * originally based on m0n0wall (http://m0n0.ch/wall)
13
 * Copyright (c) 2003-2004 Manuel Kasper <mk@neon1.net>.
14
 * All rights reserved.
15
 *
16 b12ea3fb Renato Botelho
 * Licensed under the Apache License, Version 2.0 (the "License");
17
 * you may not use this file except in compliance with the License.
18
 * You may obtain a copy of the License at
19 c5d81585 Renato Botelho
 *
20 b12ea3fb Renato Botelho
 * http://www.apache.org/licenses/LICENSE-2.0
21 c5d81585 Renato Botelho
 *
22 b12ea3fb Renato Botelho
 * Unless required by applicable law or agreed to in writing, software
23
 * distributed under the License is distributed on an "AS IS" BASIS,
24
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
25
 * See the License for the specific language governing permissions and
26
 * limitations under the License.
27 fd9ebcd5 Stephen Beaver
 */
28 93e1b16c Scott Ullrich
29 6b07c15a Matthew Grooms
##|+PRIV
30
##|*IDENT=page-diagnostics-traceroute
31 5230f468 jim-p
##|*NAME=Diagnostics: Traceroute
32 6b07c15a Matthew Grooms
##|*DESCR=Allow access to the 'Diagnostics: Traceroute' page.
33
##|*MATCH=diag_traceroute.php*
34
##|-PRIV
35
36 c81ef6e2 Phil Davis
require_once("guiconfig.inc");
37 13d193c2 Scott Ullrich
38 643bc7b0 jim-p
$allowautocomplete = true;
39 699737d9 Phil Davis
$pgtitle = array(gettext("Diagnostics"), gettext("Traceroute"));
40 b8a66425 Scott Ullrich
include("head.inc");
41 444381d1 sbeaver
42 2afb45ba jim-p
/* Max TTL of both traceroute and traceroute6 is 255, but in practice more than
43
   64 hops would most likely time out in the GUI. If a user requires a
44
   traceroute that long, they can use the CLI. */
45 93e1b16c Scott Ullrich
define('MAX_TTL', 64);
46
define('DEFAULT_TTL', 18);
47
48 cec703ec Phil Davis
// Set defaults in case they are not supplied.
49 ed69a496 jim-p
$do_traceroute = false;
50
$host = '';
51
$ttl = DEFAULT_TTL;
52 cec703ec Phil Davis
$ipproto = 'ipv4';
53
$sourceip = 'any';
54 77af9793 sbeaver
55 b8cc74ed sullrich
if ($_POST || $_REQUEST['host']) {
56 93e1b16c Scott Ullrich
	unset($input_errors);
57
58
	/* input validation */
59
	$reqdfields = explode(" ", "host ttl");
60 699737d9 Phil Davis
	$reqdfieldsn = array(gettext("Host"), gettext("ttl"));
61 1e9b4611 Renato Botelho
	do_input_validation($_REQUEST, $reqdfields, $reqdfieldsn, $input_errors);
62 444381d1 sbeaver
63 b8cc74ed sullrich
	if (($_REQUEST['ttl'] < 1) || ($_REQUEST['ttl'] > MAX_TTL)) {
64 ea6be4a7 Erik Fonnesbeck
		$input_errors[] = sprintf(gettext("Maximum number of hops must be between 1 and %s"), MAX_TTL);
65 93e1b16c Scott Ullrich
	}
66 643bc7b0 jim-p
	$host = trim($_REQUEST['host']);
67
	$ipproto = $_REQUEST['ipproto'];
68 5f601060 Phil Davis
	if (($ipproto == "ipv4") && is_ipaddrv6($host)) {
69 643bc7b0 jim-p
		$input_errors[] = gettext("When using IPv4, the target host must be an IPv4 address or hostname.");
70 5f601060 Phil Davis
	}
71
	if (($ipproto == "ipv6") && is_ipaddrv4($host)) {
72 643bc7b0 jim-p
		$input_errors[] = gettext("When using IPv6, the target host must be an IPv6 address or hostname.");
73 5f601060 Phil Davis
	}
74 93e1b16c Scott Ullrich
75 77af9793 sbeaver
	$sourceip = $_REQUEST['sourceip'];
76
	$ttl = $_REQUEST['ttl'];
77
	$resolve = $_REQUEST['resolve'];
78
	$useicmp = $_REQUEST['useicmp'];
79
80 cec703ec Phil Davis
	if ($_POST && !$input_errors) {
81 ed69a496 jim-p
		$do_traceroute = true;
82
	}
83
84 77af9793 sbeaver
} else {
85
	$resolve = false;
86 444381d1 sbeaver
	$useicmp = false;
87 77af9793 sbeaver
}
88 99e991fd Warren Baker
89 947141fd Phil Davis
if ($input_errors) {
90 77af9793 sbeaver
	print_input_errors($input_errors);
91 947141fd Phil Davis
}
92 444381d1 sbeaver
93 cec703ec Phil Davis
/* Do the traceroute and show any error */
94
if ($do_traceroute) {
95
	$useicmpparam = isset($useicmp) ? "-I" : "";
96
	$n = isset($resolve) ? "" : "-n";
97
98
	$command = "/usr/sbin/traceroute";
99
	if ($ipproto == "ipv6") {
100
		$command .= "6";
101 2afb45ba jim-p
		if (empty($n)) {
102
			$n = "-l";
103
		}
104 cec703ec Phil Davis
		$ifaddr = is_ipaddr($sourceip) ? $sourceip : get_interface_ipv6($sourceip);
105
	} else {
106
		$ifaddr = is_ipaddr($sourceip) ? $sourceip : get_interface_ip($sourceip);
107
	}
108
109
	if ($ifaddr && (is_ipaddr($host) || is_hostname($host))) {
110
		$srcip = "-s " . escapeshellarg($ifaddr);
111
	}
112
113
	$cmd = "{$command} {$n} {$srcip} -w 2 {$useicmpparam} -m " . escapeshellarg($ttl) . " " . escapeshellarg($host);
114
	$result = shell_exec($cmd);
115
116
	if (!$result) {
117 57ccd08b jim-p
		print_info_box(sprintf(gettext('Error: %s could not be traced/resolved'), htmlspecialchars($host)));
118 cec703ec Phil Davis
	}
119
}
120
121 37676f4e jim-p
$form = new Form(false);
122 77af9793 sbeaver
123
$section = new Form_Section('Traceroute');
124
125
$section->addInput(new Form_Input(
126
	'host',
127 3e2028f4 Phil Davis
	'*Hostname',
128 77af9793 sbeaver
	'text',
129
	$host,
130
	['placeholder' => 'Hostname to trace.']
131
));
132
133
$section->addInput(new Form_Select(
134
	'ipproto',
135 fe54f091 Phil Davis
	'*IP Protocol',
136 cec703ec Phil Davis
	$ipproto,
137 77af9793 sbeaver
	array('ipv4' => 'IPv4', 'ipv6' => 'IPv6')
138 3728bbe5 NOYB
))->setHelp('Select the protocol to use.');
139 77af9793 sbeaver
140
$section->addInput(new Form_Select(
141
	'sourceip',
142 fe54f091 Phil Davis
	'*Source Address',
143 cec703ec Phil Davis
	$sourceip,
144 c640d60e Phil Davis
	array('any' => gettext('Any')) + get_possible_traffic_source_addresses(true)
145 3728bbe5 NOYB
))->setHelp('Select source address for the trace.');
146 77af9793 sbeaver
147
$section->addInput(new Form_Select(
148
	'ttl',
149 7a5e4999 NOYB
	'Maximum number of hops',
150 77af9793 sbeaver
	$ttl,
151 cd7d902d sbeaver
	array_combine(range(1, MAX_TTL), range(1, MAX_TTL))
152 3728bbe5 NOYB
))->setHelp('Select the maximum number of network hops to trace.');
153 77af9793 sbeaver
154
$section->addInput(new Form_Checkbox(
155
	'resolve',
156
	'Reverse Address Lookup',
157
	'',
158
	$resolve
159 288a2a0f Phil Davis
))->setHelp('When checked, traceroute will attempt to perform a PTR lookup to locate hostnames for hops along the path. This will slow down the process as it has to wait for DNS replies.');
160 77af9793 sbeaver
161
$section->addInput(new Form_Checkbox(
162
	'useicmp',
163
	gettext("Use ICMP"),
164
	'',
165
	$useicmp
166
))->setHelp('By default, traceroute uses UDP but that may be blocked by some routers. Check this box to use ICMP instead, which may succeed. ');
167
168
$form->add($section);
169 37676f4e jim-p
170
$form->addGlobal(new Form_Button(
171
	'Submit',
172 faab522f Renato Botelho
	'Traceroute',
173 37676f4e jim-p
	null,
174
	'fa-rss'
175
))->addClass('btn-primary');
176
177 77af9793 sbeaver
print $form;
178
179
/* Show the traceroute results */
180 cec703ec Phil Davis
if ($do_traceroute && $result) {
181 444381d1 sbeaver
?>
182
	<div class="panel panel-default">
183 cec703ec Phil Davis
		<div class="panel-heading"><h2 class="panel-title"><?=gettext('Results')?></h2></div>
184 444381d1 sbeaver
		<div class="panel-body">
185
<?php
186 cec703ec Phil Davis
	print('<pre>' . $result . '</pre>');
187 444381d1 sbeaver
?>
188
		</div>
189
	</div>
190
<?php
191 77af9793 sbeaver
}
192
193
include("foot.inc");
194
?>