Project

General

Profile

Download (17 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php 
2
/*
3
	interfaces_assign.php
4
	part of m0n0wall (http://m0n0.ch/wall)
5
	Written by Jim McBeath based on existing m0n0wall files
6
	
7
	Copyright (C) 2003-2005 Manuel Kasper <mk@neon1.net>.
8
	All rights reserved.
9
	
10
	Redistribution and use in source and binary forms, with or without
11
	modification, are permitted provided that the following conditions are met:
12
	
13
	1. Redistributions of source code must retain the above copyright notice,
14
	   this list of conditions and the following disclaimer.
15
	
16
	2. Redistributions in binary form must reproduce the above copyright
17
	   notice, this list of conditions and the following disclaimer in the
18
	   documentation and/or other materials provided with the distribution.
19
	
20
	THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
21
	INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
22
	AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23
	AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
24
	OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
	POSSIBILITY OF SUCH DAMAGE.
30
*/
31
/*
32
	pfSense_BUILDER_BINARIES:	/bin/rm
33
	pfSense_MODULE:	interfaces
34
*/
35

    
36
##|+PRIV
37
##|*IDENT=page-interfaces-assignnetworkports
38
##|*NAME=Interfaces: Assign network ports page
39
##|*DESCR=Allow access to the 'Interfaces: Assign network ports' page.
40
##|*MATCH=interfaces_assign.php*
41
##|-PRIV
42

    
43
$pgtitle = array(gettext("Interfaces"),gettext("Assign network ports"));
44
$statusurl = "status_interfaces.php";
45

    
46
require("guiconfig.inc");
47
require("functions.inc");
48
require("filter.inc");
49
require("shaper.inc");
50
require("ipsec.inc");
51
require("vpn.inc");
52
require("captiveportal.inc");
53
require("rrd.inc");
54

    
55
/*
56
	In this file, "port" refers to the physical port name,
57
	while "interface" refers to LAN, WAN, or OPTn.
58
*/
59

    
60
/* get list without VLAN interfaces */
61
$portlist = get_interface_list();
62

    
63
/* add wireless clone interfaces */
64
if (is_array($config['wireless']['clone']) && count($config['wireless']['clone'])) {
65
	foreach ($config['wireless']['clone'] as $clone) {
66
		$portlist[$clone['cloneif']] = $clone;
67
		$portlist[$clone['cloneif']]['iswlclone'] = true;
68
	}
69
}
70

    
71
/* add VLAN interfaces */
72
if (is_array($config['vlans']['vlan']) && count($config['vlans']['vlan'])) {
73
	foreach ($config['vlans']['vlan'] as $vlan) {
74
		$portlist[$vlan['vlanif']] = $vlan;
75
		$portlist[$vlan['vlanif']]['isvlan'] = true;
76
	}
77
}
78

    
79
/* add Bridge interfaces */
80
if (is_array($config['bridges']['bridged']) && count($config['bridges']['bridged'])) {
81
        foreach ($config['bridges']['bridged'] as $bridge) {
82
                $portlist[$bridge['bridgeif']] = $bridge;
83
                $portlist[$bridge['bridgeif']]['isbridge'] = true;
84
        }
85
}
86

    
87
/* add GIF interfaces */
88
if (is_array($config['gifs']['gif']) && count($config['gifs']['gif'])) {
89
        foreach ($config['gifs']['gif'] as $gif) {
90
                $portlist[$gif['gifif']] = $gif;
91
                $portlist[$gif['gifif']]['isgif'] = true;
92
        }
93
}
94

    
95
/* add GRE interfaces */
96
if (is_array($config['gres']['gre']) && count($config['gres']['gre'])) {
97
        foreach ($config['gres']['gre'] as $gre) {
98
                $portlist[$gre['greif']] = $gre;
99
                $portlist[$gre['greif']]['isgre'] = true;
100
        }
101
}
102

    
103
/* add LAGG interfaces */
104
if (is_array($config['laggs']['lagg']) && count($config['laggs']['lagg'])) {
105
        foreach ($config['laggs']['lagg'] as $lagg) {
106
                $portlist[$lagg['laggif']] = $lagg;
107
                $portlist[$lagg['laggif']]['islagg'] = true;
108
		/* LAGG members cannot be assigned */
109
		$lagifs = explode(',', $lagg['members']);
110
		foreach ($lagifs as $lagif)
111
			if (isset($portlist[$lagif]))
112
				unset($portlist[$lagif]);
113
        }
114
}
115

    
116
/* add QinQ interfaces */
117
if (is_array($config['qinqs']['qinqentry']) && count($config['qinqs']['qinqentry'])) {
118
        foreach ($config['qinqs']['qinqentry'] as $qinq) {
119
                $portlist["vlan{$qinq['tag']}"]['descr'] = "VLAN {$qinq['tag']}";
120
                $portlist["vlan{$qinq['tag']}"]['isqinq'] = true;
121
                /* QinQ members */
122
                $qinqifs = explode(' ', $qinq['members']);
123
                foreach ($qinqifs as $qinqif) {
124
			$portlist["vlan{$qinq['tag']}_{$qinqif}"]['descr'] = "QinQ {$qinqif}";
125
			$portlist["vlan{$qinq['tag']}_{$qinqif}"]['isqinq'] = true;
126
		}
127
        }
128
}
129

    
130
/* add PPP interfaces */
131
if (is_array($config['ppps']['ppp']) && count($config['ppps']['ppp'])) {
132
	foreach ($config['ppps']['ppp'] as $pppid => $ppp) {
133
		$portname = $ppp['if'];
134
		$portlist[$portname] = $ppp;
135
		$portlist[$portname]['isppp'] = true;
136
		$ports_base = basename($ppp['ports']);
137
		if (isset($ppp['descr']))
138
			$portlist[$portname]['descr'] = strtoupper($ppp['if']). "({$ports_base}) - {$ppp['descr']}";
139
		else if (isset($ppp['username']))
140
			$portlist[$portname]['descr'] = strtoupper($ppp['if']). "({$ports_base}) - {$ppp['username']}";
141
		else
142
			$portlist[$portname]['descr'] = strtoupper($ppp['if']). "({$ports_base})";
143
	}
144
}
145

    
146
if ($_POST['apply']) {
147
	if (file_exists("/var/run/interface_mismatch_reboot_needed"))
148
		system_reboot();
149
	else {
150
		write_config();
151

    
152
		$retval = 0;
153
		$retval = filter_configure();
154
		$savemsg = get_std_save_message($retval);
155

    
156
		if (stristr($retval, "error") <> true)
157
			$savemsg = get_std_save_message($retval);
158
		else
159
			$savemsg = $retval;
160

    
161
		unlink_if_exists("/tmp/reload_interfaces");
162
	}
163

    
164
} else if ($_POST) {
165

    
166
	unset($input_errors);
167

    
168
	/* input validation */
169

    
170
	/* Build a list of the port names so we can see how the interfaces map */
171
	$portifmap = array();
172
	foreach ($portlist as $portname => $portinfo)
173
		$portifmap[$portname] = array();
174

    
175
	/* Go through the list of ports selected by the user,
176
	   build a list of port-to-interface mappings in portifmap */
177
	foreach ($_POST as $ifname => $ifport) {
178
		if (($ifname == 'lan') || ($ifname == 'wan') || (substr($ifname, 0, 3) == 'opt'))
179
			$portifmap[$ifport][] = strtoupper($ifname);
180
	}
181

    
182
	/* Deliver error message for any port with more than one assignment */
183
	foreach ($portifmap as $portname => $ifnames) {
184
		if (count($ifnames) > 1) {
185
			$errstr = sprintf(gettext('Port %1$s '.
186
				' was assigned to %2$s' .
187
				' interfaces:'), $portname, count($ifnames));
188
				
189
			foreach ($portifmap[$portname] as $ifn)
190
				$errstr .= " " . $ifn;
191
			
192
			$input_errors[] = $errstr;
193
		}
194
	}
195

    
196

    
197
	if (!$input_errors) {
198
		/* No errors detected, so update the config */
199
		foreach ($_POST as $ifname => $ifport) {
200
		
201
			if (($ifname == 'lan') || ($ifname == 'wan') ||
202
				(substr($ifname, 0, 3) == 'opt')) {
203
				
204
				if (!is_array($ifport)) {
205
					$reloadif = false;
206
					if (!empty($config['interfaces'][$ifname]['if']) && $config['interfaces'][$ifname]['if'] <> $ifport) {
207
						interface_bring_down($ifname);
208
						/* Mark this to be reconfigured in any case. */
209
						$reloadif = true;
210
					}
211
					$config['interfaces'][$ifname]['if'] = $ifport;
212
					if (isset($portlist[$ifport]['isppp']))
213
						$config['interfaces'][$ifname]['ipaddr'] = $portlist[$ifport]['type'];
214
					
215
					/* check for wireless interfaces, set or clear ['wireless'] */
216
					if (preg_match($g['wireless_regex'], $ifport)) {
217
						if (!is_array($config['interfaces'][$ifname]['wireless']))
218
							$config['interfaces'][$ifname]['wireless'] = array();
219
					} else {
220
						unset($config['interfaces'][$ifname]['wireless']);
221
					}
222
					
223
					/* make sure there is a descr for all interfaces */
224
					if (!isset($config['interfaces'][$ifname]['descr']))
225
						$config['interfaces'][$ifname]['descr'] = strtoupper($ifname);
226
						
227
					if ($reloadif == true) {
228
						if (preg_match($g['wireless_regex'], $ifport))
229
							interface_sync_wireless_clones($config['interfaces'][$ifname], false);
230
						/* Reload all for the interface. */
231
						interface_configure($ifname, true);
232
					}
233
				}
234
			}
235
		}
236
	
237
		write_config();
238
		
239
		enable_rrd_graphing();
240
	}
241
}
242

    
243
if ($_GET['act'] == "del") {
244
	$id = $_GET['id'];
245

    
246
	if (link_interface_to_bridge($id))
247
		$input_errors[] = gettext("The interface is part of a bridge. Please remove it from the bridge to continue");
248
	else if (link_interface_to_gre($id))
249
		$input_errors[] = gettext("The interface is part of a gre tunnel. Please delete the tunnel to continue");
250
	else if (link_interface_to_gif($id))
251
		$input_errors[] = gettext("The interface is part of a gif tunnel. Please delete the tunnel to continue");
252
	else {
253
		unset($config['interfaces'][$id]['enable']);
254
		$realid = get_real_interface($id);
255
		interface_bring_down($id);   /* down the interface */
256
		
257
		unset($config['interfaces'][$id]);	/* delete the specified OPTn or LAN*/
258

    
259
		if($id == "lan") {
260
			unset($config['interfaces']['lan']);
261
			if (is_array($config['dhcpd']))
262
				unset($config['dhcpd']['lan']);
263
				unset($config['shaper']);
264
				unset($config['ezshaper']);
265
				unset($config['nat']);
266
				system("rm /var/dhcpd/var/db/*");
267
        			services_dhcpd_configure();
268
		}
269

    
270
		if (count($config['filter']['rule']) > 0) {
271
			foreach ($config['filter']['rule'] as $x => $rule) {
272
				if($rule['interface'] == $id)
273
					unset($config['filter']['rule'][$x]);
274
			}
275
        	}
276
		if (is_array($config['nat']['advancedoutbound']) && count($config['nat']['advancedoutbound']['rule']) > 0) {
277
        	foreach ($config['nat']['advancedoutbound']['rule'] as $x => $rule) {
278
				if($rule['interface'] == $id)
279
					unset($config['nat']['advancedoutbound']['rule'][$x]['interface']);
280
        		}
281
		}
282
		if (is_array($config['nat']['rule']) && count($config['nat']['rule']) > 0) {
283
			foreach ($config['nat']['rule'] as $x => $rule) {
284
				if($rule['interface'] == $id)
285
					unset($config['nat']['rule'][$x]['interface']);
286
			}
287
        }
288

    
289
		write_config();
290
	
291
		/* If we are in firewall/routing mode (not single interface)
292
		 * then ensure that we are not running DHCP on the wan which
293
		 * will make a lot of ISP's unhappy.
294
		 */
295
		if($config['interfaces']['lan']) {
296
			unset($config['dhcpd']['wan']);		
297
		}
298

    
299
		link_interface_to_vlans($realid, "update");
300
	
301
		$savemsg = gettext("Interface has been deleted.");
302
	}
303
}
304

    
305
if ($_GET['act'] == "add") {
306
	/* find next free optional interface number */
307
	if(!$config['interfaces']['lan']) {
308
		$newifname = gettext("lan");
309
		$descr = gettext("LAN");
310
		$config['interfaces'][$newifname] = array();
311
		$config['interfaces'][$newifname]['descr'] = $descr;
312
	} else {
313
		for ($i = 1; $i <= count($config['interfaces']); $i++) {
314
			if (!$config['interfaces']["opt{$i}"])
315
				break;
316
		}
317
		$newifname = 'opt' . $i;
318
		$descr = "OPT" . $i;
319
		$config['interfaces'][$newifname] = array();
320
		$config['interfaces'][$newifname]['descr'] = $descr;
321
	}
322

    
323
	uksort($config['interfaces'], "compare_interface_names");
324

    
325
	/* Find an unused port for this interface */
326
	foreach ($portlist as $portname => $portinfo) {
327
		$portused = false;
328
		foreach ($config['interfaces'] as $ifname => $ifdata) {
329
			if ($ifdata['if'] == $portname) {
330
				$portused = true;
331
				break;
332
			}
333
		}
334
		if (!$portused) {
335
			$config['interfaces'][$newifname]['if'] = $portname;
336
			if (preg_match($g['wireless_regex'], $portname)) {
337
				$config['interfaces'][$newifname]['wireless'] = array();
338
				interface_sync_wireless_clones($config['interfaces'][$newifname], false);
339
			}
340
			break;
341
		}
342
	}
343
	
344
        /* XXX: Do not remove this. */
345
        mwexec("/bin/rm -f /tmp/config.cache");
346

    
347
	write_config();
348

    
349
	$savemsg = gettext("Interface has been added.");
350

    
351
}
352

    
353
function compare_interface_names($a, $b) {
354
	if ($a == $b)
355
		return 0;
356
	else if ($a == 'wan')
357
		return -1;
358
	else if ($b == 'wan')
359
		return 1;
360
	else if ($a == 'lan')
361
		return -1;
362
	else if ($b == 'lan')
363
		return 1;
364

    
365
	return strnatcmp($a, $b);
366
}
367

    
368
include("head.inc");
369

    
370
if(file_exists("/var/run/interface_mismatch_reboot_needed")) 
371
	if ($_POST)
372
		$savemsg = gettext("Reboot is needed. Please apply the settings in order to reboot.");
373
	else
374
		$savemsg = gettext("Interface mismatch detected.  Please resolve the mismatch and click Save.  The firewall will reboot afterwards.");
375

    
376
?>
377

    
378
<body link="#0000CC" vlink="#0000CC" alink="#0000CC">
379
<?php include("fbegin.inc"); ?>
380

    
381
<form action="interfaces_assign.php" method="post" name="iform" id="iform">
382

    
383
<?php if (file_exists("/tmp/reload_interfaces")): ?><p>
384
	<?php print_info_box_np(gettext("The interface configuration has been changed.<br>You must apply the changes in order for them to take effect."));?><br>
385
<?php elseif($savemsg): ?>
386
	<?php print_info_box($savemsg); ?>
387
<?php endif; ?>
388

    
389
<?php if ($input_errors) print_input_errors($input_errors); ?>
390

    
391
<table width="100%" border="0" cellpadding="0" cellspacing="0">
392
  <tr><td class="tabnavtbl">
393
<?php
394
	$tab_array = array();
395
	$tab_array[0] = array(gettext("Interface assignments"), true, "interfaces_assign.php");
396
	$tab_array[1] = array(gettext("Interface Groups"), false, "interfaces_groups.php");
397
	$tab_array[2] = array(gettext("Wireless"), false, "interfaces_wireless.php");
398
	$tab_array[3] = array(gettext("VLANs"), false, "interfaces_vlan.php");
399
	$tab_array[4] = array(gettext("QinQs"), false, "interfaces_qinq.php");
400
	$tab_array[5] = array(gettext("PPPs"), false, "interfaces_ppps.php");
401
	$tab_array[7] = array(gettext("GRE"), false, "interfaces_gre.php");
402
	$tab_array[8] = array(gettext("GIF"), false, "interfaces_gif.php");
403
	$tab_array[9] = array(gettext("Bridges"), false, "interfaces_bridge.php");
404
	$tab_array[10] = array(gettext("LAGG"), false, "interfaces_lagg.php");
405
	display_top_tabs($tab_array);
406
?>  
407
  </td></tr>
408
  <tr> 
409
    <td>
410
	<div id="mainarea">
411
        <table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0">
412
       <tr> 
413
	<td class="listhdrr"><?=gettext("Interface"); ?></td>
414
	<td class="listhdr"><?=gettext("Network port"); ?></td>
415
	<td class="list">&nbsp;</td>
416
  </tr>
417
  <?php foreach ($config['interfaces'] as $ifname => $iface):
418
  	if ($iface['descr'])
419
		$ifdescr = $iface['descr'];
420
	else
421
		$ifdescr = strtoupper($ifname);
422
	?>
423
  <tr> 
424
	<td class="listlr" valign="middle"><strong><?=$ifdescr;?></strong></td>
425
	  <td valign="middle" class="listr">
426
		<select onChange="javascript:\$('savediv').appear();" name="<?=$ifname;?>" id="<?=$ifname;?>">
427
		  <?php foreach ($portlist as $portname => $portinfo): ?>
428
			<option  value="<?=$portname;?>"  <?php if ($portname == $iface['if']) echo " selected";?>>
429
				<?php if ($portinfo['isvlan']) {
430
					$descr = sprintf(gettext('VLAN %1$s on %2$s'),$portinfo['tag'],$portinfo['if']);
431
				if ($portinfo['descr'])
432
					$descr .= " (" . $portinfo['descr'] . ")";
433
					echo htmlspecialchars($descr);
434
				} elseif ($portinfo['iswlclone']) {
435
					$descr = $portinfo['cloneif'];
436
					if ($portinfo['descr'])
437
						$descr .= " (" . $portinfo['descr'] . ")";
438
					echo htmlspecialchars($descr);
439
				} elseif ($portinfo['isppp']) {
440
					echo htmlspecialchars($portinfo['descr']);
441
				} elseif ($portinfo['isbridge']) {
442
					$descr = strtoupper($portinfo['bridgeif']);
443
					if ($portinfo['descr'])
444
						$descr .= " (" . $portinfo['descr'] . ")";
445
					echo htmlspecialchars($descr);
446
				} elseif ($portinfo['isgre']) {
447
					$descr = "GRE {$portinfo['remote-addr']}";
448
					if ($portinfo['descr'])
449
						$descr .= " (" . $portinfo['descr'] . ")";
450
					echo htmlspecialchars($descr);
451
				} elseif ($portinfo['isgif']) {
452
					$descr = "GRE {$portinfo['remote-addr']}";
453
					if ($portinfo['descr'])
454
						$descr .= " (" . $portinfo['descr'] . ")";
455
					echo htmlspecialchars($descr);
456
				} elseif ($portinfo['islagg']) {
457
					$descr = strtoupper($portinfo['laggif']);
458
					if ($portinfo['descr'])
459
						$descr .= " (" . $portinfo['descr'] . ")";
460
					echo htmlspecialchars($descr);
461
				} elseif ($portinfo['isqinq']) {
462
					echo htmlspecialchars($portinfo['descr']);
463
				} else
464
					echo htmlspecialchars($portname . " (" . $portinfo['mac'] . ")");
465
			?></option>
466
		<?php endforeach; ?>
467
	</select>
468
	</td>
469
	<td valign="middle" class="list">
470
		  <?php if ($ifname != 'wan'): ?>
471
		  <a href="interfaces_assign.php?act=del&id=<?=$ifname;?>"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" title=<?=gettext("delete interface"); ?> width="17" height="17" border="0"></a> 
472
		  <?php endif; ?>
473
		</td>
474
  </tr>
475
  <?php endforeach; ?>
476
  <?php if (count($config['interfaces']) < count($portlist)): ?>
477
  <tr>
478
	<td class="list" colspan="2"></td>
479
	<td class="list" nowrap>
480
	<a href="interfaces_assign.php?act=add"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" title=<?=gettext("add interface"); ?> width="17" height="17" border="0"></a>
481
	</td>
482
  </tr>
483
  <?php else: ?>
484
  <tr>
485
	<td class="list" colspan="3" height="10"></td>
486
  </tr>
487
  <?php endif; ?>
488
</table>
489
</div>
490
<br/>
491
<div name='savediv' id='savediv' style='display:none;'>
492
	<input name="Submit" type="submit" class="formbtn" value="<?=gettext("Save"); ?>"><br><br>
493
	<p>
494
</div>
495
</p>
496
<ul>
497
  <li><span class="vexpl"><?=gettext("change the IP address of your computer"); ?></span></li>
498
  <li><span class="vexpl"><?=gettext("renew its DHCP lease"); ?></span></li>
499
  <li><span class="vexpl"><?=gettext("access the webConfigurator with the new IP address"); ?></span></li>
500
  <li><span class="vexpl"><?=gettext("interfaces that are configured as members of a lagg(4) interface will not be shown."); ?></span></li>
501
</ul></td>
502
	</tr>
503
</table>
504
</form>
505
<?php include("fend.inc"); ?>
506
</body>
507
</html>
(83-83/222)