Feature #4133 » pf_pcp_git.diff
| /pfsense/gitrepo/pfSenseGITREPO/etc/inc/config.inc 2014-12-20 13:20:39.000000000 +0100 | ||
|---|---|---|
| 205 | 205 |
$timezone = "Etc/UTC"; |
| 206 | 206 |
date_default_timezone_set("$timezone");
|
| 207 | 207 | |
| 208 |
/* compatibility with older configs using vlan "tags" */ |
|
| 209 |
if (($config['version'] < 11) && (is_array($config['vlans']['vlan']) && count($config['vlans']['vlan'])) {
|
|
| 210 |
foreach ($config['vlans']['vlan'] as &$vlan) {
|
|
| 211 |
if (empty($vlan['vid']) && !empty($vlan['tag'])) {
|
|
| 212 |
$vlan['vid'] = $vlan['tag']; |
|
| 213 |
unset($vlan['tag']); |
|
| 214 |
} |
|
| 215 |
} |
|
| 216 | ||
| 208 | 217 |
if($config_parsed == true) {
|
| 209 | 218 |
/* process packager manager custom rules */ |
| 210 | 219 |
if(is_dir("/usr/local/pkg/parse_config")) {
|
| /pfsense/gitrepo/pfSenseGITREPO/etc/inc/interfaces.inc 2014-12-13 15:11:56.000000000 +0100 | ||
|---|---|---|
| 198 | 198 |
if (is_array($config['vlans']['vlan']) && count($config['vlans']['vlan'])) {
|
| 199 | 199 |
foreach ($config['vlans']['vlan'] as $vlan) {
|
| 200 | 200 |
if (empty($vlan['vlanif'])) |
| 201 |
$vlan['vlanif'] = "{$vlan['if']}_vlan{$vlan['tag']}";
|
|
| 201 |
$vlan['vlanif'] = "{$vlan['if']}_vlan{$vlan['vid']}";
|
|
| 202 | 202 |
if (!empty($realif) && $realif != $vlan['vlanif']) |
| 203 | 203 |
continue; |
| 204 | 204 | |
| ... | ... | |
| 218 | 218 |
return; |
| 219 | 219 |
} |
| 220 | 220 |
$if = $vlan['if']; |
| 221 |
$vlanif = empty($vlan['vlanif']) ? "{$if}_vlan{$vlan['tag']}" : $vlan['vlanif'];
|
|
| 222 |
$tag = $vlan['tag']; |
|
| 223 | ||
| 224 | 221 |
if (empty($if)) {
|
| 225 | 222 |
log_error(gettext("interface_vlan_configure called with if undefined."));
|
| 226 | 223 |
return; |
| 227 |
} |
|
| 224 |
} |
|
| 225 |
|
|
| 226 |
$vlanif = empty($vlan['vlanif']) ? "{$if}_vlan{$vlan['vid']}" : $vlan['vlanif'];
|
|
| 227 |
$vid = $vlan['vid']; |
|
| 228 |
$pcp = empty($vlan['pcp']) ? 0 : $vlan['pcp']; /* Apply "Best Effort" if not set */ |
|
| 228 | 229 | |
| 229 | 230 |
/* make sure the parent interface is up */ |
| 230 | 231 |
interfaces_bring_up($if); |
| ... | ... | |
| 239 | 240 |
pfSense_ngctl_name("{$tmpvlanif}:", $vlanif);
|
| 240 | 241 |
} |
| 241 | 242 | |
| 242 |
pfSense_vlan_create($vlanif, $if, $tag);
|
|
| 243 |
pfSense_vlan_create($vlanif, $if, $vid, $pcp);
|
|
| 243 | 244 | |
| 244 | 245 |
interfaces_bring_up($vlanif); |
| 245 | 246 | |
| ... | ... | |
| 261 | 262 |
} |
| 262 | 263 | |
| 263 | 264 |
$qinqif = $vlan['if']; |
| 264 |
$tag = $vlan['tag'];
|
|
| 265 |
$tag = $vlan['vid'];
|
|
| 265 | 266 |
if(empty($qinqif)) {
|
| 266 | 267 |
log_error(sprintf(gettext("interface_qinq_configure called with if undefined.%s"), "\n"));
|
| 267 | 268 |
return; |
| ... | ... | |
| 4582 | 4583 |
if ($action == "update") {
|
| 4583 | 4584 |
interfaces_bring_up($int); |
| 4584 | 4585 |
} else |
| 4585 |
$ifaces[$vlan['tag']] = $vlan;
|
|
| 4586 |
$ifaces[$vlan['vid']] = $vlan;
|
|
| 4586 | 4587 |
} |
| 4587 | 4588 |
} |
| 4588 | 4589 |
if (!empty($ifaces)) |
| /pfsense/gitrepo/pfSenseGITREPO/usr/local/www/interfaces_assign.php 2014-12-13 15:06:55.000000000 +0100 | ||
|---|---|---|
| 56 | 56 |
function interface_assign_description($portinfo, $portname) {
|
| 57 | 57 |
global $ovpn_descrs; |
| 58 | 58 |
if ($portinfo['isvlan']) {
|
| 59 |
$descr = sprintf(gettext('VLAN %1$s on %2$s'),$portinfo['tag'],$portinfo['if']);
|
|
| 59 |
$descr = sprintf(gettext('VLAN %1$s on %2$s'),$portinfo['vid'],$portinfo['if']);
|
|
| 60 | 60 |
if ($portinfo['descr']) |
| 61 | 61 |
$descr .= " (" . $portinfo['descr'] . ")";
|
| 62 | 62 |
} elseif ($portinfo['iswlclone']) {
|
| ... | ... | |
| 298 | 298 |
if (is_array($config['vlans']['vlan'])) {
|
| 299 | 299 |
foreach ($config['vlans']['vlan'] as $vlan) {
|
| 300 | 300 |
if (does_interface_exist($vlan['if']) == false) |
| 301 |
$input_errors[] = "Vlan parent interface {$vlan['if']} does not exist anymore so vlan id {$vlan['tag']} cannot be created please fix the issue before continuing.";
|
|
| 301 |
$input_errors[] = "Vlan parent interface {$vlan['if']} does not exist anymore so vlan id {$vlan['vid']} cannot be created please fix the issue before continuing.";
|
|
| 302 | 302 |
} |
| 303 | 303 |
} |
| 304 | 304 | |
| /pfsense/gitrepo/pfSenseGITREPO/usr/local/www/interfaces_vlan.php 2014-12-13 15:06:55.000000000 +0100 | ||
|---|---|---|
| 112 | 112 |
<div id="mainarea"> |
| 113 | 113 |
<table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0" summary="main area"> |
| 114 | 114 |
<tr> |
| 115 |
<td width="20%" class="listhdrr"><?=gettext("Interface");?></td>
|
|
| 116 |
<td width="20%" class="listhdrr"><?=gettext("VLAN tag");?></td>
|
|
| 115 |
<td width="16%" class="listhdrr"><?=gettext("Interface");?></td>
|
|
| 116 |
<td width="12%" class="listhdrr"><?=gettext("VLAN");?></td>
|
|
| 117 |
<td width="12%" class="listhdrr"><?=gettext("Priority");?></td>
|
|
| 117 | 118 |
<td width="50%" class="listhdr"><?=gettext("Description");?></td>
|
| 118 | 119 |
<td width="10%" class="list"></td> |
| 119 | 120 |
</tr> |
| ... | ... | |
| 123 | 124 |
<?=htmlspecialchars($vlan['if']);?> |
| 124 | 125 |
</td> |
| 125 | 126 |
<td class="listr"> |
| 126 |
<?=htmlspecialchars($vlan['tag']);?>
|
|
| 127 |
<?=htmlspecialchars($vlan['vid']);?>
|
|
| 127 | 128 |
</td> |
| 129 |
<td class="listr"> |
|
| 130 |
<?=htmlspecialchars($vlan['pcp']);?> |
|
| 131 |
</td> |
|
| 128 | 132 |
<td class="listbg"> |
| 129 | 133 |
<?=htmlspecialchars($vlan['descr']);?> |
| 130 | 134 |
</td> |
| /pfsense/gitrepo/pfSenseGITREPO/usr/local/www/interfaces_vlan_edit.php 2014-12-13 15:06:55.000000000 +0100 | ||
|---|---|---|
| 65 | 65 |
if (isset($id) && $a_vlans[$id]) {
|
| 66 | 66 |
$pconfig['if'] = $a_vlans[$id]['if']; |
| 67 | 67 |
$pconfig['vlanif'] = $a_vlans[$id]['vlanif']; |
| 68 |
$pconfig['tag'] = $a_vlans[$id]['tag']; |
|
| 68 |
$pconfig['vid'] = $a_vlans[$id]['vid']; |
|
| 69 |
$pconfig['pcp'] = $a_vlans[$id]['pcp']; |
|
| 69 | 70 |
$pconfig['descr'] = $a_vlans[$id]['descr']; |
| 70 | 71 |
} |
| 71 | 72 | |
| ... | ... | |
| 75 | 76 |
$pconfig = $_POST; |
| 76 | 77 | |
| 77 | 78 |
/* input validation */ |
| 78 |
$reqdfields = explode(" ", "if tag");
|
|
| 79 |
$reqdfieldsn = array(gettext("Parent interface"),gettext("VLAN tag"));
|
|
| 79 |
$reqdfields = explode(" ", "if vid");
|
|
| 80 |
$reqdfieldsn = array(gettext("Parent interface"),gettext("VLAN"));
|
|
| 80 | 81 | |
| 81 | 82 |
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors); |
| 82 | 83 | |
| 83 |
if ($_POST['tag'] && (!is_numericint($_POST['tag']) || ($_POST['tag'] < '1') || ($_POST['tag'] > '4094'))) {
|
|
| 84 |
$input_errors[] = gettext("The VLAN tag must be an integer between 1 and 4094.");
|
|
| 84 |
if ($_POST['vid'] && (!is_numericint($_POST['vid']) || ($_POST['vid'] < '1') || ($_POST['vid'] > '4094'))) {
|
|
| 85 |
$input_errors[] = gettext("The VLAN ID must be an integer between 1 and 4094.");
|
|
| 86 |
} |
|
| 87 |
if ($_POST['pcp'] && (!is_numericint($_POST['pcp']) || ($_POST['pcp'] < '0') || ($_POST['pcp'] > '7'))) {
|
|
| 88 |
$input_errors[] = gettext("The VLAN Priority must be an integer between 0 and 7.");
|
|
| 85 | 89 |
} |
| 86 | 90 | |
| 87 | 91 |
if (!does_interface_exist($_POST['if'])) |
| 88 | 92 |
$input_errors[] = gettext("Interface supplied as parent is invalid");
|
| 89 | 93 | |
| 90 | 94 |
if (isset($id)) {
|
| 91 |
if ($_POST['tag'] && $_POST['tag'] != $a_vlans[$id]['tag']) {
|
|
| 92 |
if (!empty($a_vlans[$id]['vlanif']) && convert_real_interface_to_friendly_interface_name($a_vlans[$id]['vlanif']) != NULL) |
|
| 93 |
$input_errors[] = gettext("Interface is assigned and you cannot change the VLAN tag while assigned.");
|
|
| 94 |
} |
|
| 95 |
if ($_POST['vid'] && $_POST['vid'] != $a_vlans[$id]['vid']) {
|
|
| 96 |
if (!empty($a_vlans[$id]['vlanif']) && convert_real_interface_to_friendly_interface_name($a_vlans[$id]['vlanif']) != NULL)
|
|
| 97 |
$input_errors[] = gettext("Interface is assigned and you cannot change the VLAN id while assigned.");
|
|
| 98 |
}
|
|
| 95 | 99 |
} |
| 96 | 100 |
foreach ($a_vlans as $vlan) {
|
| 97 | 101 |
if (isset($id) && ($a_vlans[$id]) && ($a_vlans[$id] === $vlan)) |
| 98 | 102 |
continue; |
| 99 | 103 | |
| 100 |
if (($vlan['if'] == $_POST['if']) && ($vlan['tag'] == $_POST['tag'])) {
|
|
| 101 |
$input_errors[] = sprintf(gettext("A VLAN with the tag %s is already defined on this interface."),$vlan['tag']);
|
|
| 104 |
if (($vlan['if'] == $_POST['if']) && ($vlan['vid'] == $_POST['vid'])) {
|
|
| 105 |
$input_errors[] = sprintf(gettext("A VLAN with id %s is already defined on this interface."),$vlan['vid']);
|
|
| 102 | 106 |
break; |
| 103 | 107 |
} |
| 104 | 108 |
} |
| 105 | 109 |
if (is_array($config['qinqs']['qinqentry'])) {
|
| 106 | 110 |
foreach ($config['qinqs']['qinqentry'] as $qinq) |
| 107 |
if ($qinq['tag'] == $_POST['tag'] && $qinq['if'] == $_POST['if'])
|
|
| 108 |
$input_errors[] = gettext("A QinQ VLAN exists with this tag please remove it to use this tag with.");
|
|
| 111 |
if ($qinq['tag'] == $_POST['vid'] && $qinq['if'] == $_POST['if'])
|
|
| 112 |
$input_errors[] = gettext("A QinQ VLAN exists with this id please remove it to use this id with.");
|
|
| 109 | 113 |
} |
| 110 | 114 | |
| 111 | 115 |
if (!$input_errors) {
|
| 112 | 116 |
if (isset($id) && $a_vlans[$id]) {
|
| 113 |
if (($a_vlans[$id]['if'] != $_POST['if']) || ($a_vlans[$id]['tag'] != $_POST['tag'])) {
|
|
| 117 |
if (($a_vlans[$id]['if'] != $_POST['if']) || ($a_vlans[$id]['vid'] != $_POST['vid'])) {
|
|
| 114 | 118 |
if (!empty($a_vlans[$id]['vlanif'])) {
|
| 115 | 119 |
$confif = convert_real_interface_to_friendly_interface_name($vlan['vlanif']); |
| 116 | 120 |
// Destroy previous vlan |
| 117 | 121 |
pfSense_interface_destroy($a_vlans[$id]['vlanif']); |
| 118 | 122 |
} else {
|
| 119 |
pfSense_interface_destroy("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}");
|
|
| 120 |
$confif = convert_real_interface_to_friendly_interface_name("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}");
|
|
| 123 |
pfSense_interface_destroy("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['vid']}");
|
|
| 124 |
$confif = convert_real_interface_to_friendly_interface_name("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['vid']}");
|
|
| 121 | 125 |
} |
| 122 | 126 |
if ($confif <> "") |
| 123 |
$config['interfaces'][$confif]['if'] = "{$_POST['if']}_vlan{$_POST['tag']}";
|
|
| 127 |
$config['interfaces'][$confif]['if'] = "{$_POST['if']}_vlan{$_POST['vid']}";
|
|
| 124 | 128 |
} |
| 125 | 129 |
} |
| 126 | 130 |
$vlan = array(); |
| 127 | 131 |
$vlan['if'] = $_POST['if']; |
| 128 |
$vlan['tag'] = $_POST['tag']; |
|
| 129 |
$vlan['descr'] = $_POST['descr']; |
|
| 130 |
$vlan['vlanif'] = "{$_POST['if']}_vlan{$_POST['tag']}";
|
|
| 132 |
$vlan['vid'] = $_POST['vid']; |
|
| 133 |
if ($_POST['pcp'] != '') |
|
| 134 |
$vlan['pcp'] = $_POST['pcp']; /* Leave PCP unset if not required */ |
|
| 135 |
$vlan['descr'] = $_POST['descr']; |
|
| 136 |
$vlan['vlanif'] = "{$_POST['if']}_vlan{$_POST['vid']}";
|
|
| 131 | 137 | |
| 132 | 138 |
$vlan['vlanif'] = interface_vlan_configure($vlan); |
| 133 | 139 |
if ($vlan['vlanif'] == "" || !stristr($vlan['vlanif'], "vlan")) |
| ... | ... | |
| 183 | 189 |
<span class="vexpl"><?=gettext("Only VLAN capable interfaces will be shown.");?></span></td>
|
| 184 | 190 |
</tr> |
| 185 | 191 |
<tr> |
| 186 |
<td valign="top" class="vncellreq"><?=gettext("VLAN tag ");?></td>
|
|
| 192 |
<td valign="top" class="vncellreq"><?=gettext("VLAN id ");?></td>
|
|
| 187 | 193 |
<td class="vtable"> |
| 188 |
<input name="tag" type="text" class="formfld unknown" id="tag" size="6" value="<?=htmlspecialchars($pconfig['tag']);?>" />
|
|
| 194 |
<input name="vid" type="text" class="formfld unknown" id="vid" size="6" value="<?=htmlspecialchars($pconfig['vid']);?>" />
|
|
| 189 | 195 |
<br /> |
| 190 |
<span class="vexpl"><?=gettext("802.1Q VLAN tag (between 1 and 4094) ");?></span></td>
|
|
| 196 |
<span class="vexpl"><?=gettext("802.1Q VLAN vid (between 1 and 4094) ");?></span></td>
|
|
| 191 | 197 |
</tr> |
| 192 | 198 |
<tr> |
| 199 |
<td valign="top" class="vncell"><?=gettext("VLAN Priority ");?></td>
|
|
| 200 |
<td class="vtable"> |
|
| 201 |
<input name="pcp" type="text" class="formfld unknown" id="pcp" size="4" value="<?=htmlspecialchars($pconfig['pcp']);?>" /> |
|
| 202 |
<br/> |
|
| 203 |
<span class="vexpl"><?=gettext("802.1Q VLAN pcp (between 0 and 7, default 0) ");?></span></td>
|
|
| 204 |
</tr> |
|
| 205 |
<tr> |
|
| 193 | 206 |
<td width="22%" valign="top" class="vncell"><?=gettext("Description");?></td>
|
| 194 | 207 |
<td width="78%" class="vtable"> |
| 195 | 208 |
<input name="descr" type="text" class="formfld unknown" id="descr" size="40" value="<?=htmlspecialchars($pconfig['descr']);?>" /> |