Commit 2b954b6b authored by Ad Schellevis's avatar Ad Schellevis

(legacy) refactor interfaces_vlan_edit.php

parent 5e3273eb
<?php <?php
/* /*
Copyright (C) 2014-2015 Deciso B.V. Copyright (C) 2014-2016 Deciso B.V.
Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>. Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>.
All rights reserved. All rights reserved.
...@@ -35,42 +35,30 @@ require_once("pfsense-utils.inc"); ...@@ -35,42 +35,30 @@ require_once("pfsense-utils.inc");
require_once("unbound.inc"); require_once("unbound.inc");
require_once("services.inc"); require_once("services.inc");
$referer = (isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '/interfaces_vlan.php'); if (!isset($config['vlans']) || !is_array($config['vlans'])) {
if (!is_array($config['vlans'])) {
$config['vlans'] = array(); $config['vlans'] = array();
} }
if (!isset($config['vlans']['vlan']) || !is_array($config['vlans']['vlan'])) {
if (!is_array($config['vlans']['vlan'])) {
$config['vlans']['vlan'] = array(); $config['vlans']['vlan'] = array();
} }
$a_vlans = &$config['vlans']['vlan']; $a_vlans = &$config['vlans']['vlan'];
$portlist = get_interface_list(); if ($_SERVER['REQUEST_METHOD'] === 'GET') {
// read form data
/* add LAGG interfaces */ if (!empty($a_vlans[$_GET['id']])) {
if (isset($config['laggs']['lagg'])) {
foreach ($config['laggs']['lagg'] as $lagg) {
$portlist[$lagg['laggif']] = $lagg;
}
}
if (is_numericint($_GET['id']))
$id = $_GET['id']; $id = $_GET['id'];
if (isset($_POST['id']) && is_numericint($_POST['id'])) }
$pconfig['if'] = isset($a_vlans[$id]['if']) ? $a_vlans[$id]['if'] : null;
$pconfig['vlanif'] = isset($a_vlans[$id]['vlanif']) ? $a_vlans[$id]['vlanif'] : null;
$pconfig['tag'] = isset($a_vlans[$id]['tag']) ? $a_vlans[$id]['tag'] : null;
$pconfig['descr'] = isset($a_vlans[$id]['descr']) ? $a_vlans[$id]['descr'] : null;
} elseif ($_SERVER['REQUEST_METHOD'] === 'POST') {
// validate / save form data
if (!empty($a_vlans[$_POST['id']])) {
$id = $_POST['id']; $id = $_POST['id'];
}
if (isset($id) && $a_vlans[$id]) { $input_errors = array();
$pconfig['if'] = $a_vlans[$id]['if'];
$pconfig['vlanif'] = $a_vlans[$id]['vlanif'];
$pconfig['tag'] = $a_vlans[$id]['tag'];
$pconfig['descr'] = $a_vlans[$id]['descr'];
}
if ($_POST) {
unset($input_errors);
$pconfig = $_POST; $pconfig = $_POST;
/* input validation */ /* input validation */
...@@ -79,70 +67,72 @@ if ($_POST) { ...@@ -79,70 +67,72 @@ if ($_POST) {
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors); do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
if ($_POST['tag'] && (!is_numericint($_POST['tag']) || ($_POST['tag'] < '1') || ($_POST['tag'] > '4094'))) { if ($pconfig['tag'] && (!is_numericint($pconfig['tag']) || ($pconfig['tag'] < '1') || ($pconfig['tag'] > '4094'))) {
$input_errors[] = gettext("The VLAN tag must be an integer between 1 and 4094."); $input_errors[] = gettext("The VLAN tag must be an integer between 1 and 4094.");
} }
if (!does_interface_exist($_POST['if'])) if (!does_interface_exist($pconfig['if'])) {
$input_errors[] = gettext("Interface supplied as parent is invalid"); $input_errors[] = gettext("Interface supplied as parent is invalid");
}
if (isset($id)) { if (isset($id) && $pconfig['tag'] && $pconfig['tag'] != $a_vlans[$id]['tag']) {
if ($_POST['tag'] && $_POST['tag'] != $a_vlans[$id]['tag']) { if (!empty($a_vlans[$id]['vlanif']) && convert_real_interface_to_friendly_interface_name($a_vlans[$id]['vlanif']) != NULL) {
if (!empty($a_vlans[$id]['vlanif']) && convert_real_interface_to_friendly_interface_name($a_vlans[$id]['vlanif']) != NULL)
$input_errors[] = gettext("Interface is assigned and you cannot change the VLAN tag while assigned."); $input_errors[] = gettext("Interface is assigned and you cannot change the VLAN tag while assigned.");
} }
} }
foreach ($a_vlans as $vlan) { foreach ($a_vlans as $vlan) {
if (isset($id) && ($a_vlans[$id]) && ($a_vlans[$id] === $vlan)) if (isset($id) && $a_vlans[$id] === $vlan) {
continue; continue;
}
if (($vlan['if'] == $_POST['if']) && ($vlan['tag'] == $_POST['tag'])) { if (($vlan['if'] == $pconfig['if']) && ($vlan['tag'] == $_POST['tag'])) {
$input_errors[] = sprintf(gettext("A VLAN with the tag %s is already defined on this interface."),$vlan['tag']); $input_errors[] = sprintf(gettext("A VLAN with the tag %s is already defined on this interface."), $vlan['tag']);
break; break;
} }
} }
if (isset($config['qinqs']['qinqentry'])) { if (isset($config['qinqs']['qinqentry'])) {
foreach ($config['qinqs']['qinqentry'] as $qinq) { foreach ($config['qinqs']['qinqentry'] as $qinq) {
if ($qinq['tag'] == $_POST['tag'] && $qinq['if'] == $_POST['if']) { if ($qinq['tag'] == $pconfig['tag'] && $qinq['if'] == $pconfig['if']) {
$input_errors[] = gettext("A QinQ VLAN exists with this tag please remove it to use this tag with."); $input_errors[] = gettext("A QinQ VLAN exists with this tag please remove it to use this tag with.");
} }
} }
} }
if (!$input_errors) { if (count($input_errors) == 0) {
if (isset($id) && $a_vlans[$id]) { $confif = "";
if (($a_vlans[$id]['if'] != $_POST['if']) || ($a_vlans[$id]['tag'] != $_POST['tag'])) { if (isset($id)) {
if (($a_vlans[$id]['if'] != $pconfig['if']) || ($a_vlans[$id]['tag'] != $pconfig['tag'])) {
if (!empty($a_vlans[$id]['vlanif'])) { if (!empty($a_vlans[$id]['vlanif'])) {
$confif = convert_real_interface_to_friendly_interface_name($vlan['vlanif']); $confif = convert_real_interface_to_friendly_interface_name($a_vlans[$id]['vlanif']);
legacy_interface_destroy($a_vlans[$id]['vlanif']); legacy_interface_destroy($a_vlans[$id]['vlanif']);
} else { } else {
legacy_interface_destroy("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}"); legacy_interface_destroy("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}");
$confif = convert_real_interface_to_friendly_interface_name("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}"); $confif = convert_real_interface_to_friendly_interface_name("{$a_vlans[$id]['if']}_vlan{$a_vlans[$id]['tag']}");
} }
if ($confif <> "") if ($confif <> "") {
$config['interfaces'][$confif]['if'] = "{$_POST['if']}_vlan{$_POST['tag']}"; $config['interfaces'][$confif]['if'] = "{$_POST['if']}_vlan{$_POST['tag']}";
} }
} }
}
$vlan = array(); $vlan = array();
$vlan['if'] = $_POST['if']; $vlan['if'] = $_POST['if'];
$vlan['tag'] = $_POST['tag']; $vlan['tag'] = $_POST['tag'];
$vlan['descr'] = $_POST['descr']; $vlan['descr'] = $_POST['descr'];
$vlan['vlanif'] = "{$_POST['if']}_vlan{$_POST['tag']}"; $vlan['vlanif'] = "{$_POST['if']}_vlan{$_POST['tag']}";
$vlan['vlanif'] = interface_vlan_configure($vlan); $vlan['vlanif'] = interface_vlan_configure($vlan);
if ($vlan['vlanif'] == "" || !stristr($vlan['vlanif'], "vlan")) if ($vlan['vlanif'] == "" || !stristr($vlan['vlanif'], "vlan")) {
$input_errors[] = gettext("Error occurred creating interface, please retry."); $input_errors[] = gettext("Error occurred creating interface, please retry.");
else { } else {
if (isset($id) && $a_vlans[$id]) if (isset($id)) {
$a_vlans[$id] = $vlan; $a_vlans[$id] = $vlan;
else } else {
$a_vlans[] = $vlan; $a_vlans[] = $vlan;
}
write_config(); write_config();
if ($confif <> "") if ($confif <> "") {
interface_configure($confif); interface_configure($confif);
}
header("Location: interfaces_vlan.php"); header("Location: interfaces_vlan.php");
exit; exit;
} }
...@@ -150,86 +140,95 @@ if ($_POST) { ...@@ -150,86 +140,95 @@ if ($_POST) {
} }
include("head.inc"); include("head.inc");
?> ?>
<body> <body>
<?php include("fbegin.inc"); ?> <?php include("fbegin.inc"); ?>
<section class="page-content-main"> <section class="page-content-main">
<div class="container-fluid"> <div class="container-fluid">
<div class="row"> <div class="row">
<?php if (isset($input_errors) && count($input_errors) > 0) print_input_errors($input_errors); ?> <?php if (isset($input_errors) && count($input_errors) > 0) print_input_errors($input_errors); ?>
<div id="inputerrors"></div>
<section class="col-xs-12"> <section class="col-xs-12">
<div class="content-box"> <div class="content-box">
<header class="content-box-head container-fluid">
<h3><?=gettext("VLAN configuration");?></h3>
</header>
<div class="content-box-main">
<form action="interfaces_vlan_edit.php" method="post" name="iform" id="iform">
<div class="table-responsive"> <div class="table-responsive">
<table class="table table-striped table-sort"> <form method="post" name="iform" id="iform">
<table class="table table-striped">
<thead>
<tr> <tr>
<td width="22%" valign="top" class="vncellreq"><?=gettext("Parent interface");?></td> <td width="22%"><strong><?=gettext("Interface QinQ Edit");?></strong></td>
<td width="78%" class="vtable"> <td width="78%" align="right">
<small><?=gettext("full help"); ?> </small>
<i class="fa fa-toggle-off text-danger" style="cursor: pointer;" id="show_all_help_page" type="button"></i></a>
&nbsp;
</td>
</tr>
</thead>
<tbody>
<tr>
<td><a id="help_for_if" href="#" class="showhelp"><i class="fa fa-info-circle"></i></a> <?=gettext("Parent interface");?></td>
<td>
<select name="if" class="selectpicker"> <select name="if" class="selectpicker">
<?php <?php
foreach ($portlist as $ifn => $ifinfo) $portlist = get_interface_list();
if (is_jumbo_capable($ifn)) { /* add LAGG interfaces */
echo "<option value=\"{$ifn}\""; if (isset($config['laggs']['lagg'])) {
if ($ifn == $pconfig['if']) foreach ($config['laggs']['lagg'] as $lagg) {
echo " selected=\"selected\""; $portlist[$lagg['laggif']] = $lagg;
echo ">"; }
echo htmlspecialchars($ifn . " (" . $ifinfo['mac'] . ")"); }
echo "</option>"; foreach ($portlist as $ifn => $ifinfo):
} if (!is_jumbo_capable($ifn)) {
?> continue;
}?>
<option value="<?=$ifn;?>" <?=$ifn == $pconfig['if'] ? " selected=\"selected\"" : "";?>>
<?=htmlspecialchars($ifn);?> ( <?= !empty($ifinfo['mac']) ? $ifinfo['mac'] :"" ;?> )
</option>
<?php
endforeach;?>
</select> </select>
<br /> <div class="hidden" for="help_for_if">
<span class="vexpl"><?=gettext("Only VLAN capable interfaces will be shown.");?></span></td> <?=gettext("Only VLAN capable interfaces will be shown.");?>
</div>
</td>
</tr> </tr>
<tr> <tr>
<td valign="top" class="vncellreq"><?=gettext("VLAN tag ");?></td> <td><a id="help_for_tag" href="#" class="showhelp"><i class="fa fa-info-circle"></i></a> <?=gettext("VLAN tag ");?></td>
<td class="vtable"> <td>
<input name="tag" type="text" class="form-control unknown" id="tag" size="6" value="<?=htmlspecialchars($pconfig['tag']);?>" /> <input name="tag" type="text" value="<?=$pconfig['tag'];?>" />
<br /> <div class="hidden" for="help_for_tag">
<span class="vexpl"><?=gettext("802.1Q VLAN tag (between 1 and 4094) ");?></span></td> <?=gettext("802.1Q VLAN tag (between 1 and 4094) ");?>
</div>
</td>
</tr> </tr>
<tr> <tr>
<td width="22%" valign="top" class="vncell"><?=gettext("Description");?></td> <td><a id="help_for_descr" href="#" class="showhelp"><i class="fa fa-info-circle"></i></a> <?=gettext("Description"); ?></td>
<td width="78%" class="vtable"> <td>
<input name="descr" type="text" class="form-control unknown" id="descr" size="40" value="<?=htmlspecialchars($pconfig['descr']);?>" /> <input name="descr" type="text" value="<?=$pconfig['descr'];?>" />
<br /> <span class="vexpl"><?=gettext("You may enter a description here ". <div class="hidden" for="help_for_descr">
"for your reference (not parsed).");?></span></td> <?=gettext("You may enter a description here for your reference (not parsed).");?>
</div>
</td>
</tr> </tr>
<tr> <tr>
<td width="22%" valign="top">&nbsp;</td> <td width="22%" valign="top">&nbsp;</td>
<td width="78%"> <td width="78%">
<input type="hidden" name="vlanif" value="<?=htmlspecialchars($pconfig['vlanif']); ?>" /> <input type="hidden" name="vlanif" value="<?=$pconfig['vlanif']; ?>" />
<input name="Submit" type="submit" class="btn btn-primary" value="<?=gettext("Save");?>" /> <input name="Submit" type="submit" class="btn btn-primary" value="<?=gettext("Save");?>" />
<input type="button" class="btn btn-default" value="<?=gettext("Cancel");?>" onclick="window.location.href='<?=$referer;?>'" /> <input type="button" class="btn btn-default" value="<?=gettext("Cancel");?>" onclick="window.location.href='<?=(isset($_SERVER['HTTP_REFERER']) ? $_SERVER['HTTP_REFERER'] : '/interfaces_vlan.php');?>'" />
<?php if (isset($id) && $a_vlans[$id]): ?> <?php if (isset($id)): ?>
<input name="id" type="hidden" value="<?=htmlspecialchars($id);?>" /> <input name="id" type="hidden" value="<?=$id;?>" />
<?php endif; ?> <?php endif; ?>
</td> </td>
</tr> </tr>
</tbody>
</table> </table>
</div>
</form> </form>
</div> </div>
</div> </div>
</section> </section>
</div> </div>
</div> </div>
</section> </section>
<?php include("foot.inc"); ?> <?php include("foot.inc"); ?>
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment