Project

General

Profile

Download (10.6 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/*
3
 * system_gateways.php
4
 *
5
 * part of pfSense (https://www.pfsense.org)
6
 * Copyright (c) 2004-2016 Rubicon Communications, LLC (Netgate)
7
 * Copyright (c) 2010 Seth Mos <seth.mos@dds.nl>
8
 * All rights reserved.
9
 *
10
 * Licensed under the Apache License, Version 2.0 (the "License");
11
 * you may not use this file except in compliance with the License.
12
 * You may obtain a copy of the License at
13
 *
14
 * http://www.apache.org/licenses/LICENSE-2.0
15
 *
16
 * Unless required by applicable law or agreed to in writing, software
17
 * distributed under the License is distributed on an "AS IS" BASIS,
18
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
19
 * See the License for the specific language governing permissions and
20
 * limitations under the License.
21
 */
22

    
23
##|+PRIV
24
##|*IDENT=page-system-gateways
25
##|*NAME=System: Gateways
26
##|*DESCR=Allow access to the 'System: Gateways' page.
27
##|*MATCH=system_gateways.php*
28
##|-PRIV
29

    
30
require_once("guiconfig.inc");
31
require_once("functions.inc");
32
require_once("filter.inc");
33
require_once("shaper.inc");
34

    
35
$a_gateways = return_gateways_array(true, false, true);
36
$a_gateways_arr = array();
37
foreach ($a_gateways as $gw) {
38
	$a_gateways_arr[] = $gw;
39
}
40
$a_gateways = $a_gateways_arr;
41

    
42
if (!is_array($config['gateways']['gateway_item'])) {
43
	$config['gateways']['gateway_item'] = array();
44
}
45

    
46
$a_gateway_item = &$config['gateways']['gateway_item'];
47

    
48
if ($_POST) {
49

    
50
	$pconfig = $_POST;
51

    
52
	if ($_POST['apply']) {
53

    
54
		$retval = 0;
55

    
56
		$retval = system_routing_configure();
57
		$retval |= system_resolvconf_generate();
58
		$retval |= filter_configure();
59
		/* reconfigure our gateway monitor */
60
		setup_gateways_monitor();
61
		/* Dynamic DNS on gw groups may have changed */
62
		send_event("service reload dyndnsall");
63

    
64
		$savemsg = get_std_save_message($retval);
65
		if ($retval == 0) {
66
			clear_subsystem_dirty('staticroutes');
67
		}
68
	}
69
}
70

    
71
function can_delete_disable_gateway_item($id, $disable = false) {
72
	global $config, $input_errors, $a_gateways;
73

    
74
	if (!isset($a_gateways[$id])) {
75
		return false;
76
	}
77

    
78
	if (is_array($config['gateways']['gateway_group'])) {
79
		foreach ($config['gateways']['gateway_group'] as $group) {
80
			foreach ($group['item'] as $item) {
81
				$items = explode("|", $item);
82
				if ($items[0] == $a_gateways[$id]['name']) {
83
					if (!$disable) {
84
						$input_errors[] = sprintf(gettext('Gateway "%1$s" cannot be deleted because it is in use on Gateway Group "%2$s"'), $a_gateways[$id]['name'], $group['name']);
85
					} else {
86
						$input_errors[] = sprintf(gettext('Gateway "%1$s" cannot be disabled because it is in use on Gateway Group "%2$s"'), $a_gateways[$id]['name'], $group['name']);
87
					}
88
				}
89
			}
90
		}
91
	}
92

    
93
	if (is_array($config['staticroutes']['route'])) {
94
		foreach ($config['staticroutes']['route'] as $route) {
95
			if ($route['gateway'] == $a_gateways[$id]['name']) {
96
				if (!$disable) {
97
					// The user wants to delete this gateway, but there is a static route (enabled or disabled) that refers to the gateway.
98
					$input_errors[] = sprintf(gettext('Gateway "%1$s" cannot be deleted because it is in use on Static Route "%2$s"'), $a_gateways[$id]['name'], $route['network']);
99
				} else if (!isset($route['disabled'])) {
100
					// The user wants to disable this gateway.
101
					// But there is a static route that uses this gateway and is enabled (not disabled).
102
					$input_errors[] = sprintf(gettext('Gateway "%1$s" cannot be disabled because it is in use on Static Route "%2$s"'), $a_gateways[$id]['name'], $route['network']);
103
				}
104
			}
105
		}
106
	}
107

    
108
	if (isset($input_errors)) {
109
		return false;
110
	}
111

    
112
	return true;
113
}
114

    
115
function delete_gateway_item($id) {
116
	global $config, $a_gateways;
117

    
118
	if (!isset($a_gateways[$id])) {
119
		return;
120
	}
121

    
122
	/* If the removed gateway was the default route, remove the default route */
123
	if (!empty($a_gateways[$id]) && is_ipaddr($a_gateways[$id]['gateway']) &&
124
	    !isset($a_gateways[$id]['disabled']) &&
125
	    isset($a_gateways[$id]['defaultgw'])) {
126
		$inet = (!is_ipaddrv4($a_gateways[$id]['gateway']) ? '-inet6' : '-inet');
127
		mwexec("/sbin/route delete {$inet} default");
128
	}
129

    
130
	/* NOTE: Cleanup static routes for the interface route if any */
131
	if (!empty($a_gateways[$id]) && is_ipaddr($a_gateways[$id]['gateway']) &&
132
	    $gateway['gateway'] != $a_gateways[$id]['gateway'] &&
133
	    isset($a_gateways[$id]["nonlocalgateway"])) {
134
		$realif = get_real_interface($a_gateways[$id]['interface']);
135
		$inet = (!is_ipaddrv4($a_gateways[$id]['gateway']) ? "-inet6" : "-inet");
136
		$cmd = "/sbin/route delete $inet " . escapeshellarg($a_gateways[$id]['gateway']) . " -iface " . escapeshellarg($realif);
137
		mwexec($cmd);
138
	}
139
	/* NOTE: Cleanup static routes for the monitor ip if any */
140
	if (!empty($a_gateways[$id]['monitor']) &&
141
	    $a_gateways[$id]['monitor'] != "dynamic" &&
142
	    is_ipaddr($a_gateways[$id]['monitor']) &&
143
	    $a_gateways[$id]['gateway'] != $a_gateways[$id]['monitor']) {
144
		if (is_ipaddrv4($a_gateways[$id]['monitor'])) {
145
			mwexec("/sbin/route delete " . escapeshellarg($a_gateways[$id]['monitor']));
146
		} else {
147
			mwexec("/sbin/route delete -inet6 " . escapeshellarg($a_gateways[$id]['monitor']));
148
		}
149
	}
150

    
151
	if ($config['interfaces'][$a_gateways[$id]['friendlyiface']]['gateway'] == $a_gateways[$id]['name']) {
152
		unset($config['interfaces'][$a_gateways[$id]['friendlyiface']]['gateway']);
153
	}
154
	unset($config['gateways']['gateway_item'][$a_gateways[$id]['attribute']]);
155
}
156

    
157
unset($input_errors);
158
if ($_GET['act'] == "del") {
159
	if (can_delete_disable_gateway_item($_GET['id'])) {
160
		$realid = $a_gateways[$_GET['id']]['attribute'];
161
		delete_gateway_item($_GET['id']);
162
		write_config("Gateways: removed gateway {$realid}");
163
		mark_subsystem_dirty('staticroutes');
164
		header("Location: system_gateways.php");
165
		exit;
166
	}
167
}
168

    
169
if (isset($_POST['del_x'])) {
170
	/* delete selected items */
171
	if (is_array($_POST['rule']) && count($_POST['rule'])) {
172
		foreach ($_POST['rule'] as $rulei) {
173
			if (!can_delete_disable_gateway_item($rulei)) {
174
				break;
175
			}
176
		}
177

    
178
		if (!isset($input_errors)) {
179
			$items_deleted = "";
180
			foreach ($_POST['rule'] as $rulei) {
181
				delete_gateway_item($rulei);
182
				$items_deleted .= "{$rulei} ";
183
			}
184
			if (!empty($items_deleted)) {
185
				write_config(sprintf(gettext("Gateways: removed gateways %s", $items_deleted)));
186
				mark_subsystem_dirty('staticroutes');
187
			}
188
			header("Location: system_gateways.php");
189
			exit;
190
		}
191
	}
192

    
193
} else if ($_GET['act'] == "toggle" && $a_gateways[$_GET['id']]) {
194
	$realid = $a_gateways[$_GET['id']]['attribute'];
195
	$disable_gw = !isset($a_gateway_item[$realid]['disabled']);
196
	if ($disable_gw) {
197
		// The user wants to disable the gateway, so check if that is OK.
198
		$ok_to_toggle = can_delete_disable_gateway_item($_GET['id'], $disable_gw);
199
	} else {
200
		// The user wants to enable the gateway. That is always OK.
201
		$ok_to_toggle = true;
202
	}
203
	if ($ok_to_toggle) {
204
		if ($disable_gw) {
205
			$a_gateway_item[$realid]['disabled'] = true;
206
			/* If the disabled gateway was the default route, remove the default route */
207
			if (!empty($a_gateway_item[$realid]) && is_ipaddr($a_gateway_item[$realid]['gateway']) &&
208
			    isset($a_gateway_item[$realid]['defaultgw'])) {
209
				$inet = (!is_ipaddrv4($a_gateway_item[$realid]['gateway']) ? '-inet6' : '-inet');
210
				mwexec("/sbin/route delete {$inet} default");
211
			}
212
		} else {
213
			unset($a_gateway_item[$realid]['disabled']);
214
		}
215

    
216
		if (write_config("Gateways: enable/disable")) {
217
			mark_subsystem_dirty('staticroutes');
218
		}
219

    
220
		header("Location: system_gateways.php");
221
		exit;
222
	}
223
}
224

    
225
$pgtitle = array(gettext("System"), gettext("Routing"), gettext("Gateways"));
226
$shortcut_section = "gateways";
227

    
228
include("head.inc");
229

    
230
if ($input_errors) {
231
	print_input_errors($input_errors);
232
}
233
if ($savemsg) {
234
	print_info_box($savemsg, 'success');
235
}
236

    
237
if (is_subsystem_dirty('staticroutes')) {
238
	print_apply_box(gettext("The gateway configuration has been changed.") . "<br />" . gettext("The changes must be applied for them to take effect."));
239
}
240

    
241
$tab_array = array();
242
$tab_array[0] = array(gettext("Gateways"), true, "system_gateways.php");
243
$tab_array[1] = array(gettext("Static Routes"), false, "system_routes.php");
244
$tab_array[2] = array(gettext("Gateway Groups"), false, "system_gateway_groups.php");
245
display_top_tabs($tab_array);
246

    
247
?>
248
<div class="panel panel-default">
249
	<div class="panel-heading"><h2 class="panel-title"><?=gettext('Gateways')?></h2></div>
250
	<div class="panel-body">
251
		<div class="table-responsive">
252
			<table class="table table-striped table-hover table-condensed table-rowdblclickedit">
253
				<thead>
254
					<tr>
255
						<th></th>
256
						<th><?=gettext("Name")?></th>
257
						<th><?=gettext("Interface")?></th>
258
						<th><?=gettext("Gateway")?></th>
259
						<th><?=gettext("Monitor IP")?></th>
260
						<th><?=gettext("Description")?></th>
261
						<th><?=gettext("Actions")?></th>
262
					</tr>
263
				</thead>
264
				<tbody>
265
<?php
266
foreach ($a_gateways as $i => $gateway):
267
	if (isset($gateway['inactive'])) {
268
		$icon = 'fa-times-circle-o';
269
	} elseif (isset($gateway['disabled'])) {
270
		$icon = 'fa-ban';
271
	} else {
272
		$icon = 'fa-check-circle-o';
273
	}
274

    
275
	if (isset($gateway['inactive'])) {
276
		$title = gettext("This gateway is inactive because interface is missing");
277
	} else {
278
		$title = '';
279
	}
280
?>
281
				<tr<?=($icon != 'fa-check-circle-o')? ' class="disabled"' : ''?>>
282
					<td title="<?=$title?>"><i class="fa <?=$icon?>"></i></td>
283
					<td>
284
						<?=htmlspecialchars($gateway['name'])?>
285
<?php
286
			if (isset($gateway['defaultgw'])) {
287
				echo " <strong>(default)</strong>";
288
			}
289
?>
290
						</td>
291
						<td>
292
							<?=htmlspecialchars(convert_friendly_interface_to_friendly_descr($gateway['friendlyiface']))?>
293
						</td>
294
						<td>
295
							<?=htmlspecialchars($gateway['gateway'])?>
296
						</td>
297
						<td>
298
							<?=htmlspecialchars($gateway['monitor'])?>
299
						</td>
300
						<td>
301
							<?=htmlspecialchars($gateway['descr'])?>
302
						</td>
303
						<td>
304
							<a href="system_gateways_edit.php?id=<?=$i?>" class="fa fa-pencil" title="<?=gettext('Edit gateway');?>"></a>
305
							<a href="system_gateways_edit.php?dup=<?=$i?>" class="fa fa-clone" title="<?=gettext('Copy gateway')?>"></a>
306

    
307
<?php if (is_numeric($gateway['attribute'])): ?>
308
	<?php if (isset($gateway['disabled'])) {
309
	?>
310
							<a href="?act=toggle&amp;id=<?=$i?>" class="fa fa-check-square-o" title="<?=gettext('Enable gateway')?>"></a>
311
	<?php } else {
312
	?>
313
							<a href="?act=toggle&amp;id=<?=$i?>" class="fa fa-ban" title="<?=gettext('Disable gateway')?>"></a>
314
	<?php }
315
	?>
316
							<a href="system_gateways.php?act=del&amp;id=<?=$i?>" class="fa fa-trash" title="<?=gettext('Delete gateway')?>"></a>
317

    
318
<?php endif; ?>
319
						</td>
320
					</tr>
321
<?php endforeach; ?>
322
				</tbody>
323
			</table>
324
		</div>
325
	</div>
326
</div>
327

    
328
<nav class="action-buttons">
329
	<a href="system_gateways_edit.php" role="button" class="btn btn-success">
330
		<i class="fa fa-plus icon-embed-btn"></i>
331
		<?=gettext("Add");?>
332
	</a>
333
</nav>
334
<?php
335

    
336
include("foot.inc");
(197-197/225)