$ppp) {
if ($wancfg['if'] == $ppp['if']) {
break;
}
}
$type_disabled = (substr($wancfg['if'], 0, 3) == 'gre') ? 'disabled' : '';
if ($wancfg['if'] == $a_ppps[$pppid]['if']) {
$pconfig['pppid'] = $pppid;
$pconfig['ptpid'] = $a_ppps[$pppid]['ptpid'];
$pconfig['port'] = $a_ppps[$pppid]['ports'];
if ($a_ppps[$pppid]['type'] == "ppp") {
$pconfig['ppp_username'] = $a_ppps[$pppid]['username'];
$pconfig['ppp_password'] = base64_decode($a_ppps[$pppid]['password']);
$pconfig['phone'] = $a_ppps[$pppid]['phone'];
$pconfig['apn'] = $a_ppps[$pppid]['apn'];
} else if ($a_ppps[$pppid]['type'] == "pppoe") {
$pconfig['pppoe_username'] = $a_ppps[$pppid]['username'];
$pconfig['pppoe_password'] = base64_decode($a_ppps[$pppid]['password']);
$pconfig['provider'] = $a_ppps[$pppid]['provider'];
$pconfig['pppoe_dialondemand'] = isset($a_ppps[$pppid]['ondemand']);
$pconfig['pppoe_idletimeout'] = $a_ppps[$pppid]['idletimeout'];
/* ================================================ */
/* = force a connection reset at a specific time? = */
/* ================================================ */
if (isset($a_ppps[$pppid]['pppoe-reset-type'])) {
$pconfig['pppoe-reset-type'] = $a_ppps[$pppid]['pppoe-reset-type'];
$itemhash = getMPDCRONSettings($a_ppps[$pppid]['if']);
if ($itemhash) {
$cronitem = $itemhash['ITEM'];
}
if (isset($cronitem)) {
$resetTime = "{$cronitem['minute']} {$cronitem['hour']} {$cronitem['mday']} {$cronitem['month']} {$cronitem['wday']}";
} else {
$resetTime = NULL;
}
//log_error("ResetTime:".$resetTime);
if ($a_ppps[$pppid]['pppoe-reset-type'] == "custom") {
if ($cronitem) {
$pconfig['pppoe_pr_custom'] = true;
$pconfig['pppoe_resetminute'] = $cronitem['minute'];
$pconfig['pppoe_resethour'] = $cronitem['hour'];
if ($cronitem['mday'] != "*" && $cronitem['month'] != "*") {
$pconfig['pppoe_resetdate'] = "{$cronitem['month']}/{$cronitem['mday']}/" . date("Y");
}
}
} else if ($a_ppps[$pppid]['pppoe-reset-type'] == "preset") {
$pconfig['pppoe_pr_preset'] = true;
switch ($resetTime) {
case CRON_MONTHLY_PATTERN:
$pconfig['pppoe_monthly'] = true;
break;
case CRON_WEEKLY_PATTERN:
$pconfig['pppoe_weekly'] = true;
break;
case CRON_DAILY_PATTERN:
$pconfig['pppoe_daily'] = true;
break;
case CRON_HOURLY_PATTERN:
$pconfig['pppoe_hourly'] = true;
break;
}
}
} // End force pppoe reset at specific time
// End if type == pppoe
} else if ($a_ppps[$pppid]['type'] == "pptp" || $a_ppps[$pppid]['type'] == "l2tp") {
$pconfig['pptp_username'] = $a_ppps[$pppid]['username'];
$pconfig['pptp_password'] = base64_decode($a_ppps[$pppid]['password']);
$pconfig['pptp_localip'] = explode(",", $a_ppps[$pppid]['localip']);
$pconfig['pptp_subnet'] = explode(",", $a_ppps[$pppid]['subnet']);
$pconfig['pptp_remote'] = explode(",", $a_ppps[$pppid]['gateway']);
$pconfig['pptp_dialondemand'] = isset($a_ppps[$pppid]['ondemand']);
$pconfig['pptp_idletimeout'] = $a_ppps[$pppid]['timeout'];
}
} else {
$pconfig['ptpid'] = interfaces_ptpid_next();
$pppid = count($a_ppps);
}
$pconfig['dhcphostname'] = $wancfg['dhcphostname'];
$pconfig['alias-address'] = $wancfg['alias-address'];
$pconfig['alias-subnet'] = $wancfg['alias-subnet'];
$pconfig['dhcprejectfrom'] = $wancfg['dhcprejectfrom'];
$pconfig['adv_dhcp_pt_timeout'] = $wancfg['adv_dhcp_pt_timeout'];
$pconfig['adv_dhcp_pt_retry'] = $wancfg['adv_dhcp_pt_retry'];
$pconfig['adv_dhcp_pt_select_timeout'] = $wancfg['adv_dhcp_pt_select_timeout'];
$pconfig['adv_dhcp_pt_reboot'] = $wancfg['adv_dhcp_pt_reboot'];
$pconfig['adv_dhcp_pt_backoff_cutoff'] = $wancfg['adv_dhcp_pt_backoff_cutoff'];
$pconfig['adv_dhcp_pt_initial_interval'] = $wancfg['adv_dhcp_pt_initial_interval'];
$pconfig['adv_dhcp_pt_values'] = $wancfg['adv_dhcp_pt_values'];
$pconfig['adv_dhcp_send_options'] = $wancfg['adv_dhcp_send_options'];
$pconfig['adv_dhcp_request_options'] = $wancfg['adv_dhcp_request_options'];
$pconfig['adv_dhcp_required_options'] = $wancfg['adv_dhcp_required_options'];
$pconfig['adv_dhcp_option_modifiers'] = $wancfg['adv_dhcp_option_modifiers'];
$pconfig['adv_dhcp_config_advanced'] = $wancfg['adv_dhcp_config_advanced'];
$pconfig['adv_dhcp_config_file_override'] = $wancfg['adv_dhcp_config_file_override'];
$pconfig['adv_dhcp_config_file_override_path'] = $wancfg['adv_dhcp_config_file_override_path'];
$pconfig['adv_dhcp6_interface_statement_send_options'] = $wancfg['adv_dhcp6_interface_statement_send_options'];
$pconfig['adv_dhcp6_interface_statement_request_options'] = $wancfg['adv_dhcp6_interface_statement_request_options'];
$pconfig['adv_dhcp6_interface_statement_information_only_enable'] = $wancfg['adv_dhcp6_interface_statement_information_only_enable'];
$pconfig['adv_dhcp6_interface_statement_script'] = $wancfg['adv_dhcp6_interface_statement_script'];
$pconfig['adv_dhcp6_id_assoc_statement_address_enable'] = $wancfg['adv_dhcp6_id_assoc_statement_address_enable'];
$pconfig['adv_dhcp6_id_assoc_statement_address'] = $wancfg['adv_dhcp6_id_assoc_statement_address'];
$pconfig['adv_dhcp6_id_assoc_statement_address_id'] = $wancfg['adv_dhcp6_id_assoc_statement_address_id'];
$pconfig['adv_dhcp6_id_assoc_statement_address_pltime'] = $wancfg['adv_dhcp6_id_assoc_statement_address_pltime'];
$pconfig['adv_dhcp6_id_assoc_statement_address_vltime'] = $wancfg['adv_dhcp6_id_assoc_statement_address_vltime'];
$pconfig['adv_dhcp6_id_assoc_statement_prefix_enable'] = $wancfg['adv_dhcp6_id_assoc_statement_prefix_enable'];
$pconfig['adv_dhcp6_id_assoc_statement_prefix'] = $wancfg['adv_dhcp6_id_assoc_statement_prefix'];
$pconfig['adv_dhcp6_id_assoc_statement_prefix_id'] = $wancfg['adv_dhcp6_id_assoc_statement_prefix_id'];
$pconfig['adv_dhcp6_id_assoc_statement_prefix_pltime'] = $wancfg['adv_dhcp6_id_assoc_statement_prefix_pltime'];
$pconfig['adv_dhcp6_id_assoc_statement_prefix_vltime'] = $wancfg['adv_dhcp6_id_assoc_statement_prefix_vltime'];
$pconfig['adv_dhcp6_prefix_interface_statement_sla_id'] = $wancfg['adv_dhcp6_prefix_interface_statement_sla_id'];
$pconfig['adv_dhcp6_prefix_interface_statement_sla_len'] = $wancfg['adv_dhcp6_prefix_interface_statement_sla_len'];
$pconfig['adv_dhcp6_authentication_statement_authname'] = $wancfg['adv_dhcp6_authentication_statement_authname'];
$pconfig['adv_dhcp6_authentication_statement_protocol'] = $wancfg['adv_dhcp6_authentication_statement_protocol'];
$pconfig['adv_dhcp6_authentication_statement_algorithm'] = $wancfg['adv_dhcp6_authentication_statement_algorithm'];
$pconfig['adv_dhcp6_authentication_statement_rdm'] = $wancfg['adv_dhcp6_authentication_statement_rdm'];
$pconfig['adv_dhcp6_key_info_statement_keyname'] = $wancfg['adv_dhcp6_key_info_statement_keyname'];
$pconfig['adv_dhcp6_key_info_statement_realm'] = $wancfg['adv_dhcp6_key_info_statement_realm'];
$pconfig['adv_dhcp6_key_info_statement_keyid'] = $wancfg['adv_dhcp6_key_info_statement_keyid'];
$pconfig['adv_dhcp6_key_info_statement_secret'] = $wancfg['adv_dhcp6_key_info_statement_secret'];
$pconfig['adv_dhcp6_key_info_statement_expire'] = $wancfg['adv_dhcp6_key_info_statement_expire'];
$pconfig['adv_dhcp6_config_advanced'] = $wancfg['adv_dhcp6_config_advanced'];
$pconfig['adv_dhcp6_config_file_override'] = $wancfg['adv_dhcp6_config_file_override'];
$pconfig['adv_dhcp6_config_file_override_path'] = $wancfg['adv_dhcp6_config_file_override_path'];
$pconfig['dhcp_plus'] = isset($wancfg['dhcp_plus']);
$pconfig['descr'] = remove_bad_chars($wancfg['descr']);
$pconfig['enable'] = isset($wancfg['enable']);
if (is_array($config['aliases']['alias'])) {
foreach ($config['aliases']['alias'] as $alias) {
if ($alias['name'] == $wancfg['descr']) {
$input_errors[] = sprintf(gettext("Sorry, an alias with the name %s already exists."), $wancfg['descr']);
}
}
}
switch ($wancfg['ipaddr']) {
case "dhcp":
$pconfig['type'] = "dhcp";
break;
case "pppoe":
case "pptp":
case "l2tp":
case "ppp":
$pconfig['type'] = $wancfg['ipaddr'];
break;
default:
if (is_ipaddrv4($wancfg['ipaddr'])) {
$pconfig['type'] = "staticv4";
$pconfig['ipaddr'] = $wancfg['ipaddr'];
$pconfig['subnet'] = $wancfg['subnet'];
$pconfig['gateway'] = $wancfg['gateway'];
} else {
$pconfig['type'] = "none";
}
break;
}
switch ($wancfg['ipaddrv6']) {
case "slaac":
$pconfig['type6'] = "slaac";
break;
case "dhcp6":
$pconfig['dhcp6-duid'] = $wancfg['dhcp6-duid'];
if (!isset($wancfg['dhcp6-ia-pd-len'])) {
$wancfg['dhcp6-ia-pd-len'] = "none";
}
$pconfig['dhcp6-ia-pd-len'] = $wancfg['dhcp6-ia-pd-len'];
$pconfig['dhcp6-ia-pd-send-hint'] = isset($wancfg['dhcp6-ia-pd-send-hint']);
$pconfig['type6'] = "dhcp6";
$pconfig['dhcp6prefixonly'] = isset($wancfg['dhcp6prefixonly']);
$pconfig['dhcp6usev4iface'] = isset($wancfg['dhcp6usev4iface']);
break;
case "6to4":
$pconfig['type6'] = "6to4";
break;
case "track6":
$pconfig['type6'] = "track6";
$pconfig['track6-interface'] = $wancfg['track6-interface'];
if ($wancfg['track6-prefix-id'] == "") {
$pconfig['track6-prefix-id'] = 0;
} else {
$pconfig['track6-prefix-id'] = $wancfg['track6-prefix-id'];
}
$pconfig['track6-prefix-id--hex'] = sprintf("%x", $pconfig['track6-prefix-id']);
break;
case "6rd":
$pconfig['prefix-6rd'] = $wancfg['prefix-6rd'];
if ($wancfg['prefix-6rd-v4plen'] == "") {
$wancfg['prefix-6rd-v4plen'] = "0";
}
$pconfig['prefix-6rd-v4plen'] = $wancfg['prefix-6rd-v4plen'];
$pconfig['type6'] = "6rd";
$pconfig['gateway-6rd'] = $wancfg['gateway-6rd'];
break;
default:
if (is_ipaddrv6($wancfg['ipaddrv6'])) {
$pconfig['type6'] = "staticv6";
$pconfig['ipaddrv6'] = $wancfg['ipaddrv6'];
$pconfig['subnetv6'] = $wancfg['subnetv6'];
$pconfig['gatewayv6'] = $wancfg['gatewayv6'];
} else {
$pconfig['type6'] = "none";
}
break;
}
$pconfig['blockpriv'] = isset($wancfg['blockpriv']);
$pconfig['blockbogons'] = isset($wancfg['blockbogons']);
$pconfig['spoofmac'] = $wancfg['spoofmac'];
$pconfig['mtu'] = $wancfg['mtu'];
$pconfig['mss'] = $wancfg['mss'];
/* Wireless interface? */
if (isset($wancfg['wireless'])) {
/* Sync first to be sure it displays the actual settings that will be used */
interface_sync_wireless_clones($wancfg, false);
/* Get wireless modes */
$wlanif = get_real_interface($if);
if (!does_interface_exist($wlanif)) {
interface_wireless_clone($wlanif, $wancfg);
}
$wlanbaseif = interface_get_wireless_base($wancfg['if']);
preg_match("/^(.*?)([0-9]*)$/", $wlanbaseif, $wlanbaseif_split);
$wl_modes = get_wireless_modes($if);
$wl_chaninfo = get_wireless_channel_info($if);
$wl_sysctl_prefix = 'dev.' . $wlanbaseif_split[1] . '.' . $wlanbaseif_split[2];
$wl_sysctl = get_sysctl(
array(
"{$wl_sysctl_prefix}.diversity",
"{$wl_sysctl_prefix}.txantenna",
"{$wl_sysctl_prefix}.rxantenna",
"{$wl_sysctl_prefix}.slottime",
"{$wl_sysctl_prefix}.acktimeout",
"{$wl_sysctl_prefix}.ctstimeout"));
$wl_regdomain_xml_attr = array();
$wl_regdomain_xml = parse_xml_regdomain($wl_regdomain_xml_attr);
$wl_regdomains = &$wl_regdomain_xml['regulatory-domains']['rd'];
$wl_regdomains_attr = &$wl_regdomain_xml_attr['regulatory-domains']['rd'];
$wl_countries = &$wl_regdomain_xml['country-codes']['country'];
$wl_countries_attr = &$wl_regdomain_xml_attr['country-codes']['country'];
$pconfig['persistcommonwireless'] = isset($config['wireless']['interfaces'][$wlanbaseif]);
$pconfig['standard'] = $wancfg['wireless']['standard'];
$pconfig['mode'] = $wancfg['wireless']['mode'];
$pconfig['protmode'] = $wancfg['wireless']['protmode'];
$pconfig['ssid'] = $wancfg['wireless']['ssid'];
$pconfig['channel'] = $wancfg['wireless']['channel'];
$pconfig['txpower'] = $wancfg['wireless']['txpower'];
$pconfig['diversity'] = $wancfg['wireless']['diversity'];
$pconfig['txantenna'] = $wancfg['wireless']['txantenna'];
$pconfig['rxantenna'] = $wancfg['wireless']['rxantenna'];
$pconfig['distance'] = $wancfg['wireless']['distance'];
$pconfig['regdomain'] = $wancfg['wireless']['regdomain'];
$pconfig['regcountry'] = $wancfg['wireless']['regcountry'];
$pconfig['reglocation'] = $wancfg['wireless']['reglocation'];
$pconfig['wme_enable'] = isset($wancfg['wireless']['wme']['enable']);
if (isset($wancfg['wireless']['puren']['enable'])) {
$pconfig['puremode'] = '11n';
} else if (isset($wancfg['wireless']['pureg']['enable'])) {
$pconfig['puremode'] = '11g';
} else {
$pconfig['puremode'] = 'any';
}
$pconfig['apbridge_enable'] = isset($wancfg['wireless']['apbridge']['enable']);
$pconfig['authmode'] = $wancfg['wireless']['authmode'];
$pconfig['hidessid_enable'] = isset($wancfg['wireless']['hidessid']['enable']);
$pconfig['auth_server_addr'] = $wancfg['wireless']['auth_server_addr'];
$pconfig['auth_server_port'] = $wancfg['wireless']['auth_server_port'];
$pconfig['auth_server_shared_secret'] = $wancfg['wireless']['auth_server_shared_secret'];
$pconfig['auth_server_addr2'] = $wancfg['wireless']['auth_server_addr2'];
$pconfig['auth_server_port2'] = $wancfg['wireless']['auth_server_port2'];
$pconfig['auth_server_shared_secret2'] = $wancfg['wireless']['auth_server_shared_secret2'];
if (is_array($wancfg['wireless']['wpa'])) {
$pconfig['debug_mode'] = $wancfg['wireless']['wpa']['debug_mode'];
$pconfig['macaddr_acl'] = $wancfg['wireless']['wpa']['macaddr_acl'];
$pconfig['mac_acl_enable'] = isset($wancfg['wireless']['wpa']['mac_acl_enable']);
$pconfig['wpa_mode'] = $wancfg['wireless']['wpa']['wpa_mode'];
$pconfig['wpa_key_mgmt'] = $wancfg['wireless']['wpa']['wpa_key_mgmt'];
$pconfig['wpa_pairwise'] = $wancfg['wireless']['wpa']['wpa_pairwise'];
$pconfig['wpa_group_rekey'] = $wancfg['wireless']['wpa']['wpa_group_rekey'];
$pconfig['wpa_gmk_rekey'] = $wancfg['wireless']['wpa']['wpa_gmk_rekey'];
$pconfig['wpa_strict_rekey'] = isset($wancfg['wireless']['wpa']['wpa_strict_rekey']);
$pconfig['passphrase'] = $wancfg['wireless']['wpa']['passphrase'];
$pconfig['ieee8021x'] = isset($wancfg['wireless']['wpa']['ieee8021x']['enable']);
$pconfig['rsn_preauth'] = isset($wancfg['wireless']['wpa']['rsn_preauth']);
$pconfig['ext_wpa_sw'] = $wancfg['wireless']['wpa']['ext_wpa_sw'];
$pconfig['wpa_enable'] = isset($wancfg['wireless']['wpa']['enable']);
}
$pconfig['mac_acl'] = $wancfg['wireless']['mac_acl'];
}
if ($_POST['apply']) {
unset($input_errors);
if (!is_subsystem_dirty('interfaces')) {
$input_errors[] = gettext("You have already applied your settings!");
} else {
unlink_if_exists("{$g['tmp_path']}/config.cache");
clear_subsystem_dirty('interfaces');
if (file_exists("{$g['tmp_path']}/.interfaces.apply")) {
$toapplylist = unserialize(file_get_contents("{$g['tmp_path']}/.interfaces.apply"));
foreach ($toapplylist as $ifapply => $ifcfgo) {
if (isset($config['interfaces'][$ifapply]['enable'])) {
interface_bring_down($ifapply, false, $ifcfgo);
interface_configure($ifapply, true);
} else {
interface_bring_down($ifapply, true, $ifcfgo);
if (isset($config['dhcpd'][$ifapply]['enable']) ||
isset($config['dhcpdv6'][$ifapply]['enable'])) {
services_dhcpd_configure();
}
}
}
}
/* restart snmp so that it binds to correct address */
services_snmpd_configure();
/* sync filter configuration */
setup_gateways_monitor();
clear_subsystem_dirty('interfaces');
filter_configure();
enable_rrd_graphing();
if (is_subsystem_dirty('staticroutes') && (system_routing_configure() == 0)) {
clear_subsystem_dirty('staticroutes');
}
}
@unlink("{$g['tmp_path']}/.interfaces.apply");
header("Location: interfaces.php?if={$if}");
exit;
} else if ($_POST && $_POST['enable'] != "yes") {
unset($wancfg['enable']);
if (isset($wancfg['wireless'])) {
interface_sync_wireless_clones($wancfg, false);
}
write_config("Interface {$_POST['descr']}({$if}) is now disabled.");
mark_subsystem_dirty('interfaces');
if (file_exists("{$g['tmp_path']}/.interfaces.apply")) {
$toapplylist = unserialize(file_get_contents("{$g['tmp_path']}/.interfaces.apply"));
} else {
$toapplylist = array();
}
$toapplylist[$if]['ifcfg'] = $wancfg;
$toapplylist[$if]['ppps'] = $a_ppps;
/* we need to be able remove IP aliases for IPv6 */
file_put_contents("{$g['tmp_path']}/.interfaces.apply", serialize($toapplylist));
header("Location: interfaces.php?if={$if}");
exit;
} else if ($_POST) {
unset($input_errors);
$pconfig = $_POST;
if (is_numeric("0x" . $_POST['track6-prefix-id--hex'])) {
$pconfig['track6-prefix-id'] = intval($_POST['track6-prefix-id--hex'], 16);
} else {
$pconfig['track6-prefix-id'] = 0;
}
conf_mount_rw();
/* filter out spaces from descriptions */
$_POST['descr'] = remove_bad_chars($_POST['descr']);
/* okay first of all, cause we are just hiding the PPPoE HTML
* fields related to PPPoE resets, we are going to unset $_POST
* vars, if the reset feature should not be used. Otherwise the
* data validation procedure below, may trigger a false error
* message.
*/
if (empty($_POST['pppoe-reset-type'])) {
unset($_POST['pppoe_pr_type']);
unset($_POST['pppoe_resethour']);
unset($_POST['pppoe_resetminute']);
unset($_POST['pppoe_resetdate']);
unset($_POST['pppoe_pr_preset_val']);
}
/* description unique? */
foreach ($ifdescrs as $ifent => $ifdescr) {
if ($if != $ifent && $ifdescr == $_POST['descr']) {
$input_errors[] = gettext("An interface with the specified description already exists.");
break;
}
}
if (is_numeric($_POST['descr'])) {
$input_errors[] = gettext("The interface description cannot contain only numbers.");
}
/* input validation */
if (isset($config['dhcpd']) && isset($config['dhcpd'][$if]['enable']) && (!preg_match("/^staticv4/", $_POST['type']))) {
$input_errors[] = gettext("The DHCP Server is active on this interface and it can be used only with a static IP configuration. Please disable the DHCP Server service on this interface first, then change the interface configuration.");
}
if (isset($config['dhcpdv6']) && isset($config['dhcpdv6'][$if]['enable']) && (!preg_match("/^staticv6/", $_POST['type6']))) {
$input_errors[] = gettext("The DHCP6 Server is active on this interface and it can be used only with a static IPv6 configuration. Please disable the DHCPv6 Server service on this interface first, then change the interface configuration.");
}
switch (strtolower($_POST['type'])) {
case "staticv4":
$reqdfields = explode(" ", "ipaddr subnet gateway");
$reqdfieldsn = array(gettext("IPv4 address"), gettext("Subnet bit count"), gettext("Gateway"));
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
case "none":
if (is_array($config['virtualip']['vip'])) {
foreach ($config['virtualip']['vip'] as $vip) {
if (is_ipaddrv4($vip['subnet']) && $vip['interface'] == $if) {
$input_errors[] = gettext("This interface is referenced by IPv4 VIPs. Please delete those before setting the interface to 'none' configuration.");
}
}
}
break;
case "ppp":
$reqdfields = explode(" ", "port phone");
$reqdfieldsn = array(gettext("Modem Port"), gettext("Phone Number"));
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
case "pppoe":
if ($_POST['pppoe_dialondemand']) {
$reqdfields = explode(" ", "pppoe_username pppoe_password pppoe_dialondemand pppoe_idletimeout");
$reqdfieldsn = array(gettext("PPPoE username"), gettext("PPPoE password"), gettext("Dial on demand"), gettext("Idle timeout value"));
} else {
$reqdfields = explode(" ", "pppoe_username pppoe_password");
$reqdfieldsn = array(gettext("PPPoE username"), gettext("PPPoE password"));
}
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
case "pptp":
if ($_POST['pptp_dialondemand']) {
$reqdfields = explode(" ", "pptp_username pptp_password pptp_local0 pptp_subnet0 pptp_remote0 pptp_dialondemand pptp_idletimeout");
$reqdfieldsn = array(gettext("PPTP username"), gettext("PPTP password"), gettext("PPTP local IP address"), gettext("PPTP subnet"), gettext("PPTP remote IP address"), gettext("Dial on demand"), gettext("Idle timeout value"));
} else {
$reqdfields = explode(" ", "pptp_username pptp_password pptp_local0 pptp_subnet0 pptp_remote0");
$reqdfieldsn = array(gettext("PPTP username"), gettext("PPTP password"), gettext("PPTP local IP address"), gettext("PPTP subnet"), gettext("PPTP remote IP address"));
}
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
case "l2tp":
if ($_POST['pptp_dialondemand']) {
$reqdfields = explode(" ", "pptp_username pptp_password pptp_remote0 pptp_dialondemand pptp_idletimeout");
$reqdfieldsn = array(gettext("L2TP username"), gettext("L2TP password"), gettext("L2TP remote IP address"), gettext("Dial on demand"), gettext("Idle timeout value"));
} else {
$reqdfields = explode(" ", "pptp_username pptp_password pptp_remote0");
$reqdfieldsn = array(gettext("L2TP username"), gettext("L2TP password"), gettext("L2TP remote IP address"));
}
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
}
switch (strtolower($_POST['type6'])) {
case "staticv6":
$reqdfields = explode(" ", "ipaddrv6 subnetv6 gatewayv6");
$reqdfieldsn = array(gettext("IPv6 address"), gettext("Subnet bit count"), gettext("Gateway"));
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
break;
case "none":
if (is_array($config['virtualip']['vip'])) {
foreach ($config['virtualip']['vip'] as $vip) {
if (is_ipaddrv6($vip['subnet']) && $vip['interface'] == $if) {
$input_errors[] = gettext("This interface is referenced by IPv6 VIPs. Please delete those before setting the interface to 'none' configuration.");
}
}
}
break;
case "dhcp6":
if (in_array($wancfg['ipaddrv6'], array())) {
$input_errors[] = sprintf(gettext("You have to reassign the interface to be able to configure as %s."), $_POST['type6']);
}
if ($_POST['dhcp6-ia-pd-send-hint'] && strtolower($_POST['dhcp6-ia-pd-len']) == 'none') {
$input_errors[] = gettext('DHCPv6 Prefix Delegation size must be provided when Send IPv6 prefix hint flag is checked');
}
break;
case "6rd":
foreach ($ifdescrs as $ifent => $ifdescr) {
if ($if != $ifent && ($config[interfaces][$ifent]['ipaddrv6'] == $_POST['type6'])) {
if ($config[interfaces][$ifent]['prefix-6rd'] == $_POST['prefix-6rd']) {
$input_errors[] = gettext("You can only have one interface configured in 6rd with same prefix.");
break;
}
}
}
if (!is_ipaddrv4($_POST['gateway-6rd'])) {
$input_errors[] = gettext("6RD Border Gateway must be an IPv4 address.");
}
if (in_array($wancfg['ipaddrv6'], array())) {
$input_errors[] = sprintf(gettext("You have to reassign the interface to be able to configure as %s."), $_POST['type6']);
}
break;
case "6to4":
foreach ($ifdescrs as $ifent => $ifdescr) {
if ($if != $ifent && ($config[interfaces][$ifent]['ipaddrv6'] == $_POST['type6'])) {
$input_errors[] = sprintf(gettext("You can only have one interface configured as 6to4."), $_POST['type6']);
break;
}
}
if (in_array($wancfg['ipaddrv6'], array())) {
$input_errors[] = sprintf(gettext("You have to reassign the interface to be able to configure as %s."), $_POST['type6']);
}
break;
case "track6":
/* needs to check if $track6-prefix-id is used on another interface */
if (in_array($wancfg['ipaddrv6'], array())) {
$input_errors[] = sprintf(gettext("You have to reassign the interface to be able to configure as %s."), $_POST['type6']);
}
if ($_POST['track6-prefix-id--hex'] != "" && !is_numeric("0x" . $_POST['track6-prefix-id--hex'])) {
$input_errors[] = gettext("You must enter a valid hexadecimal number for the IPv6 prefix ID.");
} else {
$track6_prefix_id = intval($_POST['track6-prefix-id--hex'], 16);
if ($track6_prefix_id < 0 || $track6_prefix_id > $_POST['ipv6-num-prefix-ids-' . $_POST['track6-interface']]) {
$input_errors[] = gettext("You specified an IPv6 prefix ID that is out of range.") .
" ({$_POST['track6-interface']}) - (0) - (" . sprintf('%x', $_POST['ipv6-num-prefix-ids-' . $_POST['track6-interface']]) . ")";
} else {
foreach ($ifdescrs as $ifent => $ifdescr) {
if ($if == $ifent) {
continue;
}
if ($config['interfaces'][$ifent]['ipaddrv6'] == 'track6' &&
$config['interfaces'][$ifent]['track6-interface'] == $_POST['track6-interface'] &&
$config['interfaces'][$ifent]['track6-prefix-id'] == $track6_prefix_id) {
$input_errors[] = sprintf(gettext("This track6 prefix ID is already being used in %s."), $ifdescr);
}
}
}
}
break;
}
/* normalize MAC addresses - lowercase and convert Windows-ized hyphenated MACs to colon delimited */
$staticroutes = get_staticroutes(true);
$_POST['spoofmac'] = strtolower(str_replace("-", ":", $_POST['spoofmac']));
if ($_POST['ipaddr']) {
if (!is_ipaddrv4($_POST['ipaddr'])) {
$input_errors[] = gettext("A valid IPv4 address must be specified.");
} else {
$where_ipaddr_configured = where_is_ipaddr_configured($_POST['ipaddr'], $if, true, true, $_POST['subnet']);
if (count($where_ipaddr_configured)) {
$subnet_conflict_text = sprintf(gettext("IPv4 address %s is being used by or overlaps with:"), $_POST['ipaddr'] . "/" . $_POST['subnet']);
foreach ($where_ipaddr_configured as $subnet_conflict) {
$subnet_conflict_text .= " " . convert_friendly_interface_to_friendly_descr($subnet_conflict['if']) . " (" . $subnet_conflict['ip_or_subnet'] . ")";
}
$input_errors[] = $subnet_conflict_text;
}
/* Do not accept network or broadcast address, except if subnet is 31 or 32 */
if ($_POST['subnet'] < 31) {
if ($_POST['ipaddr'] == gen_subnet($_POST['ipaddr'], $_POST['subnet'])) {
$input_errors[] = gettext("This IPv4 address is the network address and cannot be used");
} else if ($_POST['ipaddr'] == gen_subnet_max($_POST['ipaddr'], $_POST['subnet'])) {
$input_errors[] = gettext("This IPv4 address is the broadcast address and cannot be used");
}
}
foreach ($staticroutes as $route_subnet) {
list($network, $subnet) = explode("/", $route_subnet);
if ($_POST['subnet'] == $subnet && $network == gen_subnet($_POST['ipaddr'], $_POST['subnet'])) {
$input_errors[] = gettext("This IPv4 address conflicts with a Static Route.");
break;
}
unset($network, $subnet);
}
}
}
if ($_POST['ipaddrv6']) {
if (!is_ipaddrv6($_POST['ipaddrv6'])) {
$input_errors[] = gettext("A valid IPv6 address must be specified.");
} else {
if (ip_in_subnet($_POST['ipaddrv6'], "fe80::/10")) {
$input_errors[] = gettext("IPv6 link local addresses cannot be configured as an interface IP.");
}
$where_ipaddr_configured = where_is_ipaddr_configured($_POST['ipaddrv6'], $if, true, true, $_POST['subnetv6']);
if (count($where_ipaddr_configured)) {
$subnet_conflict_text = sprintf(gettext("IPv6 address %s is being used by or overlaps with:"), $_POST['ipaddrv6'] . "/" . $_POST['subnetv6']);
foreach ($where_ipaddr_configured as $subnet_conflict) {
$subnet_conflict_text .= " " . convert_friendly_interface_to_friendly_descr($subnet_conflict['if']) . " (" . $subnet_conflict['ip_or_subnet'] . ")";
}
$input_errors[] = $subnet_conflict_text;
}
foreach ($staticroutes as $route_subnet) {
list($network, $subnet) = explode("/", $route_subnet);
if ($_POST['subnetv6'] == $subnet && $network == gen_subnetv6($_POST['ipaddrv6'], $_POST['subnetv6'])) {
$input_errors[] = gettext("This IPv6 address conflicts with a Static Route.");
break;
}
unset($network, $subnet);
}
}
}
if (($_POST['subnet'] && !is_numeric($_POST['subnet']))) {
$input_errors[] = gettext("A valid subnet bit count must be specified.");
}
if (($_POST['subnetv6'] && !is_numeric($_POST['subnetv6']))) {
$input_errors[] = gettext("A valid subnet bit count must be specified.");
}
if (($_POST['alias-address'] && !is_ipaddrv4($_POST['alias-address']))) {
$input_errors[] = gettext("A valid alias IP address must be specified.");
}
if (($_POST['alias-subnet'] && !is_numeric($_POST['alias-subnet']))) {
$input_errors[] = gettext("A valid alias subnet bit count must be specified.");
}
if ($_POST['dhcprejectfrom'] && !is_ipaddrv4($_POST['dhcprejectfrom'])) {
$input_errors[] = gettext("A valid alias IP address must be specified to reject DHCP Leases from.");
}
if (($_POST['gateway'] != "none") || ($_POST['gatewayv6'] != "none")) {
$match = false;
foreach ($a_gateways as $gateway) {
if (in_array($_POST['gateway'], $gateway)) {
$match = true;
}
}
foreach ($a_gateways as $gateway) {
if (in_array($_POST['gatewayv6'], $gateway)) {
$match = true;
}
}
if (!$match) {
$input_errors[] = gettext("A valid gateway must be specified.");
}
}
if (($_POST['provider'] && !is_domain($_POST['provider']))) {
$input_errors[] = gettext("The service name contains invalid characters.");
}
if (($_POST['pppoe_idletimeout'] != "") && !is_numericint($_POST['pppoe_idletimeout'])) {
$input_errors[] = gettext("The idle timeout value must be an integer.");
}
if ($_POST['pppoe_resethour'] != "" && !is_numericint($_POST['pppoe_resethour']) &&
$_POST['pppoe_resethour'] >= 0 && $_POST['pppoe_resethour'] <=23) {
$input_errors[] = gettext("A valid PPPoE reset hour must be specified (0-23).");
}
if ($_POST['pppoe_resetminute'] != "" && !is_numericint($_POST['pppoe_resetminute']) &&
$_POST['pppoe_resetminute'] >= 0 && $_POST['pppoe_resetminute'] <=59) {
$input_errors[] = gettext("A valid PPPoE reset minute must be specified (0-59).");
}
if ($_POST['pppoe_resetdate'] != "" && !is_numeric(str_replace("/", "", $_POST['pppoe_resetdate']))) {
$input_errors[] = gettext("A valid PPPoE reset date must be specified (mm/dd/yyyy).");
}
if (($_POST['pptp_local0'] && !is_ipaddrv4($_POST['pptp_local0']))) {
$input_errors[] = gettext("A valid PPTP local IP address must be specified.");
}
if (($_POST['pptp_subnet0'] && !is_numeric($_POST['pptp_subnet0']))) {
$input_errors[] = gettext("A valid PPTP subnet bit count must be specified.");
}
if (($_POST['pptp_remote0'] && !is_ipaddrv4($_POST['pptp_remote0']) && !is_hostname($_POST['gateway'][$iface]))) {
$input_errors[] = gettext("A valid PPTP remote IP address must be specified.");
}
if (($_POST['pptp_idletimeout'] != "") && !is_numericint($_POST['pptp_idletimeout'])) {
$input_errors[] = gettext("The idle timeout value must be an integer.");
}
if (($_POST['spoofmac'] && !is_macaddr($_POST['spoofmac']))) {
$input_errors[] = gettext("A valid MAC address must be specified.");
}
if ($_POST['mtu']) {
if (!is_numericint($_POST['mtu'])) {
$input_errors[] = "MTU must be an integer.";
}
if (substr($wancfg['if'], 0, 3) == 'gif') {
$min_mtu = 1280;
$max_mtu = 8192;
} else {
$min_mtu = 576;
$max_mtu = 9000;
}
if ($_POST['mtu'] < $min_mtu || $_POST['mtu'] > $max_mtu) {
$input_errors[] = sprintf(gettext("The MTU must be between %d and %d bytes."), $min_mtu, $max_mtu);
}
unset($min_mtu, $max_mtu);
if (stristr($wancfg['if'], "_vlan")) {
$realhwif_array = get_parent_interface($wancfg['if']);
// Need code to handle MLPPP if we ever use $realhwif for MLPPP handling
$parent_realhwif = $realhwif_array[0];
$parent_if = convert_real_interface_to_friendly_interface_name($parent_realhwif);
if (!empty($parent_if) && !empty($config['interfaces'][$parent_if]['mtu'])) {
if ($_POST['mtu'] > intval($config['interfaces'][$parent_if]['mtu'])) {
$input_errors[] = gettext("The MTU of a VLAN cannot be greater than that of its parent interface.");
}
}
} else {
foreach ($config['interfaces'] as $idx => $ifdata) {
if (($idx == $if) || !preg_match('/_vlan[0-9]/', $ifdata['if'])) {
continue;
}
$realhwif_array = get_parent_interface($ifdata['if']);
// Need code to handle MLPPP if we ever use $realhwif for MLPPP handling
$parent_realhwif = $realhwif_array[0];
if ($parent_realhwif != $wancfg['if']) {
continue;
}
if (isset($ifdata['mtu']) && $ifdata['mtu'] > $_POST['mtu']) {
$input_errors[] = sprintf(gettext("Interface %s (VLAN) has MTU set to a larger value"), $ifdata['descr']);
}
}
}
}
if ($_POST['mss'] != '') {
if (!is_numericint($_POST['mss']) || ($_POST['mss'] < 576 || $_POST['mss'] > 65535)) {
$input_errors[] = gettext("The MSS must be an integer between 576 and 65535 bytes.");
}
}
/* Wireless interface? */
if (isset($wancfg['wireless'])) {
$reqdfields = array("mode");
$reqdfieldsn = array(gettext("Mode"));
if ($_POST['mode'] == 'hostap') {
$reqdfields[] = "ssid";
$reqdfieldsn[] = gettext("SSID");
if (isset($_POST['channel']) && $_POST['channel'] == "0") {
// auto channel with hostap is broken, prevent this for now.
$input_errors[] = gettext("A specific channel, not auto, must be selected for Access Point mode.");
}
}
if (stristr($_POST['standard'], '11n')) {
if (!($_POST['wme_enable'])) {
$input_errors[] = gettext("802.11n standards require enabling WME.");
}
}
do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
check_wireless_mode();
if (isset($_POST['wpa_group_rekey']) && (!is_numericint($_POST['wpa_group_rekey']) || $_POST['wpa_group_rekey'] < 1 || $_POST['wpa_group_rekey'] > 9999)) {
$input_errors[] = gettext("Key Rotation must be an integer between 1 and 9999.");
}
if (isset($_POST['wpa_gmk_rekey']) && (!is_numericint($_POST['wpa_gmk_rekey']) || $_POST['wpa_gmk_rekey'] < 1 || $_POST['wpa_gmk_rekey'] > 9999)) {
$input_errors[] = gettext("Master Key Regeneration must be an integer between 1 and 9999.");
}
if (isset($_POST['wpa_group_rekey']) && isset($_POST['wpa_gmk_rekey'])) {
if ($_POST['wpa_group_rekey'] > $_POST['wpa_gmk_rekey']) {
$input_errors[] = gettext("Master Key Regeneration must be greater than Key Rotation.");
}
}
if (!empty($_POST['auth_server_addr'])) {
if (!is_domain($_POST['auth_server_addr']) && !is_ipaddr($_POST['auth_server_addr'])) {
$input_errors[] = gettext("802.1X Authentication Server must be an IP or hostname.");
}
}
if (!empty($_POST['auth_server_addr2'])) {
if (!is_domain($_POST['auth_server_addr2']) && !is_ipaddr($_POST['auth_server_addr2'])) {
$input_errors[] = gettext("Secondary 802.1X Authentication Server must be an IP or hostname.");
}
}
if (!empty($_POST['auth_server_port'])) {
if (!is_port($_POST['auth_server_port'])) {
$input_errors[] = gettext("802.1X Authentication Server Port must be a valid port number (1-65535).");
}
}
if (!empty($_POST['auth_server_port2'])) {
if (!is_port($_POST['auth_server_port2'])) {
$input_errors[] = gettext("Secondary 802.1X Authentication Server Port must be a valid port number (1-65535).");
}
}
if (isset($_POST['channel']) && !is_numericint($_POST['channel'])) {
if (!is_numericint($_POST['channel'])) {
$input_errors[] = gettext("Invalid channel specified.");
} else {
if ($_POST['channel'] > 255 || $_POST['channel'] < 0) {
$input_errors[] = gettext("Channel must be between 0-255.");
}
}
}
if (!empty($_POST['distance']) && !is_numericint($_POST['distance'])) {
$input_errors[] = gettext("Distance must be an integer.");
}
if (isset($_POST['standard']) && (stristr($_POST['standard'], '11na') || stristr($_POST['standard'], '11a'))) {
if ($_POST['channel'] != 0 && $_POST['channel'] < 15) {
$input_errors[] = gettext("Channel selected is not valid for 802.11a or 802.11na.");
}
}
if (isset($_POST['standard']) && ($_POST['standard'] == "11b" || $_POST['standard'] == "11g")) {
if ($_POST['channel'] > 14) {
$input_errors[] = gettext("Channel selected is not valid for 802.11b or 802.11g.");
}
}
if (!empty($_POST['protmode']) && !in_array($_POST['protmode'], array("off", "cts", "rtscts"))) {
$input_errors[] = gettext("Invalid option chosen for OFDM Protection Mode");
}
if ($_POST['passphrase']) {
$passlen = strlen($_POST['passphrase']);
if ($passlen < 8 || $passlen > 63) {
$input_errors[] = gettext("The WPA passphrase must be between 8 and 63 characters long.");
}
}
if ($_POST['wpa_enable'] == "yes") {
if (empty($_POST['passphrase']) && stristr($_POST['wpa_key_mgmt'], "WPA-PSK")) {
$input_errors[] = gettext("A WPA Passphrase must be specified when WPA PSK is enabled.");
}
}
}
if ($_POST['ppp_password'] != $_POST['ppp_password_confirm']) {
$input_errors[] = gettext("PPP Password and confirmed password must match!");
}
if ($_POST['pppoe_password'] != $_POST['pppoe_password_confirm']) {
$input_errors[] = gettext("PPPoE Password and confirmed password must match!");
}
if ($_POST['pptp_password'] != $_POST['pptp_password_confirm']) {
$input_errors[] = gettext("PTPP Password and confirmed password must match!");
}
if (!$input_errors) {
// These 3 fields can be a list of multiple data items when used for MLPPP.
// The UI in this code only processes the first of the list, so save the data here then we can preserve any other entries.
$poriginal['pptp_localip'] = explode(",", $a_ppps[$pppid]['localip']);
$poriginal['pptp_subnet'] = explode(",", $a_ppps[$pppid]['subnet']);
$poriginal['pptp_remote'] = explode(",", $a_ppps[$pppid]['gateway']);
if ($wancfg['ipaddr'] != $_POST['type']) {
if (in_array($wancfg['ipaddr'], array("ppp", "pppoe", "pptp", "l2tp"))) {
$wancfg['if'] = $a_ppps[$pppid]['ports'];
unset($a_ppps[$pppid]);
} else if ($wancfg['ipaddr'] == "dhcp") {
kill_dhclient_process($wancfg['if']);
}
if ($wancfg['ipaddrv6'] == "dhcp6") {
$pid = find_dhcp6c_process($wancfg['if']);
if ($pid) {
posix_kill($pid, SIGTERM);
}
}
}
$ppp = array();
if ($wancfg['ipaddr'] != "ppp") {
unset($wancfg['ipaddr']);
}
if ($wancfg['ipaddrv6'] != "ppp") {
unset($wancfg['ipaddrv6']);
}
unset($wancfg['subnet']);
unset($wancfg['gateway']);
unset($wancfg['subnetv6']);
unset($wancfg['gatewayv6']);
unset($wancfg['dhcphostname']);
unset($wancfg['dhcprejectfrom']);
unset($wancfg['dhcp6-duid']);
unset($wancfg['dhcp6-ia-pd-len']);
unset($wancfg['dhcp6-ia-pd-send-hint']);
unset($wancfg['dhcp6prefixonly']);
unset($wancfg['dhcp6usev4iface']);
unset($wancfg['track6-interface']);
unset($wancfg['track6-prefix-id']);
unset($wancfg['prefix-6rd']);
unset($wancfg['prefix-6rd-v4plen']);
unset($wancfg['gateway-6rd']);
unset($wancfg['adv_dhcp_pt_timeout']);
unset($wancfg['adv_dhcp_pt_retry']);
unset($wancfg['adv_dhcp_pt_select_timeout']);
unset($wancfg['adv_dhcp_pt_reboot']);
unset($wancfg['adv_dhcp_pt_backoff_cutoff']);
unset($wancfg['adv_dhcp_pt_initial_interval']);
unset($wancfg['adv_dhcp_pt_values']);
unset($wancfg['adv_dhcp_send_options']);
unset($wancfg['adv_dhcp_request_options']);
unset($wancfg['adv_dhcp_required_options']);
unset($wancfg['adv_dhcp_option_modifiers']);
unset($wancfg['adv_dhcp_config_advanced']);
unset($wancfg['adv_dhcp_config_file_override']);
unset($wancfg['adv_dhcp_config_file_override_path']);
unset($wancfg['adv_dhcp6_interface_statement_send_options']);
unset($wancfg['adv_dhcp6_interface_statement_request_options']);
unset($wancfg['adv_dhcp6_interface_statement_information_only_enable']);
unset($wancfg['adv_dhcp6_interface_statement_script']);
unset($wancfg['adv_dhcp6_id_assoc_statement_address_enable']);
unset($wancfg['adv_dhcp6_id_assoc_statement_address']);
unset($wancfg['adv_dhcp6_id_assoc_statement_address_id']);
unset($wancfg['adv_dhcp6_id_assoc_statement_address_pltime']);
unset($wancfg['adv_dhcp6_id_assoc_statement_address_vltime']);
unset($wancfg['adv_dhcp6_id_assoc_statement_prefix_enable']);
unset($wancfg['adv_dhcp6_id_assoc_statement_prefix']);
unset($wancfg['adv_dhcp6_id_assoc_statement_prefix_id']);
unset($wancfg['adv_dhcp6_id_assoc_statement_prefix_pltime']);
unset($wancfg['adv_dhcp6_id_assoc_statement_prefix_vltime']);
unset($wancfg['adv_dhcp6_prefix_interface_statement_sla_id']);
unset($wancfg['adv_dhcp6_prefix_interface_statement_sla_len']);
unset($wancfg['adv_dhcp6_authentication_statement_authname']);
unset($wancfg['adv_dhcp6_authentication_statement_protocol']);
unset($wancfg['adv_dhcp6_authentication_statement_algorithm']);
unset($wancfg['adv_dhcp6_authentication_statement_rdm']);
unset($wancfg['adv_dhcp6_key_info_statement_keyname']);
unset($wancfg['adv_dhcp6_key_info_statement_realm']);
unset($wancfg['adv_dhcp6_key_info_statement_keyid']);
unset($wancfg['adv_dhcp6_key_info_statement_secret']);
unset($wancfg['adv_dhcp6_key_info_statement_expire']);
unset($wancfg['adv_dhcp6_config_advanced']);
unset($wancfg['adv_dhcp6_config_file_override']);
unset($wancfg['adv_dhcp6_config_file_override_path']);
unset($wancfg['pppoe_password']);
unset($wancfg['pptp_username']);
unset($wancfg['pptp_password']);
unset($wancfg['provider']);
unset($wancfg['ondemand']);
unset($wancfg['timeout']);
if (empty($wancfg['pppoe']['pppoe-reset-type'])) {
unset($wancfg['pppoe']['pppoe-reset-type']);
}
unset($wancfg['local']);
unset($wancfg['remote']);
if (is_array($a_ppps[$pppid]) && in_array($wancfg['ipaddr'], array("ppp", "pppoe", "pptp", "l2tp"))) {
if ($wancfg['ipaddr'] != 'ppp') {
unset($a_ppps[$pppid]['apn']);
unset($a_ppps[$pppid]['phone']);
unset($a_ppps[$pppid]['provider']);
unset($a_ppps[$pppid]['ondemand']);
}
if (in_array($wancfg['ipaddr'], array("pppoe", "pptp", "l2tp"))) {
unset($a_ppps[$pppid]['localip']);
unset($a_ppps[$pppid]['subnet']);
unset($a_ppps[$pppid]['gateway']);
}
if ($wancfg['ipaddr'] != 'pppoe') {
unset($a_ppps[$pppid]['pppoe-reset-type']);
}
if ($wancfg['type'] != $_POST['type']) {
unset($a_ppps[$pppid]['idletimeout']);
}
}
$wancfg['descr'] = remove_bad_chars($_POST['descr']);
$wancfg['enable'] = $_POST['enable'] == "yes" ? true : false;
/* let return_gateways_array() do the magic on dynamic interfaces for us */
switch ($_POST['type']) {
case "staticv4":
$wancfg['ipaddr'] = $_POST['ipaddr'];
$wancfg['subnet'] = $_POST['subnet'];
if ($_POST['gateway'] != "none") {
$wancfg['gateway'] = $_POST['gateway'];
}
break;
case "dhcp":
$wancfg['ipaddr'] = "dhcp";
$wancfg['dhcphostname'] = $_POST['dhcphostname'];
$wancfg['alias-address'] = $_POST['alias-address'];
$wancfg['alias-subnet'] = $_POST['alias-subnet'];
$wancfg['dhcprejectfrom'] = $_POST['dhcprejectfrom'];
$wancfg['adv_dhcp_pt_timeout'] = $_POST['adv_dhcp_pt_timeout'];
$wancfg['adv_dhcp_pt_retry'] = $_POST['adv_dhcp_pt_retry'];
$wancfg['adv_dhcp_pt_select_timeout'] = $_POST['adv_dhcp_pt_select_timeout'];
$wancfg['adv_dhcp_pt_reboot'] = $_POST['adv_dhcp_pt_reboot'];
$wancfg['adv_dhcp_pt_backoff_cutoff'] = $_POST['adv_dhcp_pt_backoff_cutoff'];
$wancfg['adv_dhcp_pt_initial_interval'] = $_POST['adv_dhcp_pt_initial_interval'];
$wancfg['adv_dhcp_pt_values'] = $_POST['adv_dhcp_pt_values'];
$wancfg['adv_dhcp_send_options'] = $_POST['adv_dhcp_send_options'];
$wancfg['adv_dhcp_request_options'] = $_POST['adv_dhcp_request_options'];
$wancfg['adv_dhcp_required_options'] = $_POST['adv_dhcp_required_options'];
$wancfg['adv_dhcp_option_modifiers'] = $_POST['adv_dhcp_option_modifiers'];
$wancfg['adv_dhcp_config_advanced'] = $_POST['adv_dhcp_config_advanced'];
$wancfg['adv_dhcp_config_file_override'] = $_POST['adv_dhcp_config_file_override'];
$wancfg['adv_dhcp_config_file_override_path'] = $_POST['adv_dhcp_config_file_override_path'];
$wancfg['dhcp_plus'] = $_POST['dhcp_plus'] == "yes" ? true : false;
if ($gateway_item) {
$a_gateways[] = $gateway_item;
}
break;
case "ppp":
$a_ppps[$pppid]['ptpid'] = $_POST['ptpid'];
$a_ppps[$pppid]['type'] = $_POST['type'];
$a_ppps[$pppid]['if'] = $_POST['type'].$_POST['ptpid'];
$a_ppps[$pppid]['ports'] = $_POST['port'];
$a_ppps[$pppid]['username'] = $_POST['ppp_username'];
if ($_POST['ppp_password'] != DMYPWD) {
$a_ppps[$pppid]['password'] = base64_encode($_POST['ppp_password']);
}
$a_ppps[$pppid]['phone'] = $_POST['phone'];
$a_ppps[$pppid]['apn'] = $_POST['apn'];
$wancfg['if'] = $_POST['type'] . $_POST['ptpid'];
$wancfg['ipaddr'] = $_POST['type'];
break;
case "pppoe":
$a_ppps[$pppid]['ptpid'] = $_POST['ptpid'];
$a_ppps[$pppid]['type'] = $_POST['type'];
$a_ppps[$pppid]['if'] = $_POST['type'].$_POST['ptpid'];
if (isset($_POST['ppp_port'])) {
$a_ppps[$pppid]['ports'] = $_POST['ppp_port'];
} else {
$a_ppps[$pppid]['ports'] = $wancfg['if'];
}
$a_ppps[$pppid]['username'] = $_POST['pppoe_username'];
if ($_POST['pppoe_password'] != DMYPWD) {
$a_ppps[$pppid]['password'] = base64_encode($_POST['pppoe_password']);
}
if (!empty($_POST['provider'])) {
$a_ppps[$pppid]['provider'] = $_POST['provider'];
} else {
$a_ppps[$pppid]['provider'] = true;
}
$a_ppps[$pppid]['ondemand'] = $_POST['pppoe_dialondemand'] ? true : false;
if (!empty($_POST['pppoe_idletimeout'])) {
$a_ppps[$pppid]['idletimeout'] = $_POST['pppoe_idletimeout'];
} else {
unset($a_ppps[$pppid]['idletimeout']);
}
if (!empty($_POST['pppoe-reset-type'])) {
$a_ppps[$pppid]['pppoe-reset-type'] = $_POST['pppoe-reset-type'];
} else {
unset($a_ppps[$pppid]['pppoe-reset-type']);
}
$wancfg['if'] = $_POST['type'].$_POST['ptpid'];
$wancfg['ipaddr'] = $_POST['type'];
if ($gateway_item) {
$a_gateways[] = $gateway_item;
}
break;
case "pptp":
case "l2tp":
$a_ppps[$pppid]['ptpid'] = $_POST['ptpid'];
$a_ppps[$pppid]['type'] = $_POST['type'];
$a_ppps[$pppid]['if'] = $_POST['type'].$_POST['ptpid'];
if (isset($_POST['ppp_port'])) {
$a_ppps[$pppid]['ports'] = $_POST['ppp_port'];
} else {
$a_ppps[$pppid]['ports'] = $wancfg['if'];
}
$a_ppps[$pppid]['username'] = $_POST['pptp_username'];
if ($_POST['pptp_password'] != DMYPWD) {
$a_ppps[$pppid]['password'] = base64_encode($_POST['pptp_password']);
}
// Replace the first (0) entry with the posted data. Preserve any other entries that might be there.
$poriginal['pptp_localip'][0] = $_POST['pptp_local0'];
$a_ppps[$pppid]['localip'] = implode(',', $poriginal['pptp_localip']);
$poriginal['pptp_subnet'][0] = $_POST['pptp_subnet0'];
$a_ppps[$pppid]['subnet'] = implode(',', $poriginal['pptp_subnet']);
$poriginal['pptp_remote'][0] = $_POST['pptp_remote0'];
$a_ppps[$pppid]['gateway'] = implode(',', $poriginal['pptp_remote']);
$a_ppps[$pppid]['ondemand'] = $_POST['pptp_dialondemand'] ? true : false;
if (!empty($_POST['pptp_idletimeout'])) {
$a_ppps[$pppid]['idletimeout'] = $_POST['pptp_idletimeout'];
} else {
unset($a_ppps[$pppid]['idletimeout']);
}
$wancfg['if'] = $_POST['type'].$_POST['ptpid'];
$wancfg['ipaddr'] = $_POST['type'];
if ($gateway_item) {
$a_gateways[] = $gateway_item;
}
break;
case "none":
break;
}
switch ($_POST['type6']) {
case "staticv6":
$wancfg['ipaddrv6'] = $_POST['ipaddrv6'];
$wancfg['subnetv6'] = $_POST['subnetv6'];
if ($_POST['gatewayv6'] != "none") {
$wancfg['gatewayv6'] = $_POST['gatewayv6'];
}
break;
case "slaac":
$wancfg['ipaddrv6'] = "slaac";
break;
case "dhcp6":
$wancfg['ipaddrv6'] = "dhcp6";
$wancfg['dhcp6-duid'] = $_POST['dhcp6-duid'];
$wancfg['dhcp6-ia-pd-len'] = $_POST['dhcp6-ia-pd-len'];
if ($_POST['dhcp6-ia-pd-send-hint'] == "yes") {
$wancfg['dhcp6-ia-pd-send-hint'] = true;
}
if ($_POST['dhcp6prefixonly'] == "yes") {
$wancfg['dhcp6prefixonly'] = true;
}
if ($_POST['dhcp6usev4iface'] == "yes") {
$wancfg['dhcp6usev4iface'] = true;
}
if (!empty($_POST['adv_dhcp6_interface_statement_send_options'])) {
$wancfg['adv_dhcp6_interface_statement_send_options'] = $_POST['adv_dhcp6_interface_statement_send_options'];
}
if (!empty($_POST['adv_dhcp6_interface_statement_request_options'])) {
$wancfg['adv_dhcp6_interface_statement_request_options'] = $_POST['adv_dhcp6_interface_statement_request_options'];
}
if (isset($_POST['adv_dhcp6_interface_statement_information_only_enable'])) {
$wancfg['adv_dhcp6_interface_statement_information_only_enable'] = $_POST['adv_dhcp6_interface_statement_information_only_enable'];
}
if (!empty($_POST['adv_dhcp6_interface_statement_script'])) {
$wancfg['adv_dhcp6_interface_statement_script'] = $_POST['adv_dhcp6_interface_statement_script'];
}
if (isset($_POST['adv_dhcp6_id_assoc_statement_address_enable'])) {
$wancfg['adv_dhcp6_id_assoc_statement_address_enable'] = $_POST['adv_dhcp6_id_assoc_statement_address_enable'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_address'])) {
$wancfg['adv_dhcp6_id_assoc_statement_address'] = $_POST['adv_dhcp6_id_assoc_statement_address'];
}
if (is_numericint($_POST['adv_dhcp6_id_assoc_statement_address_id'])) {
$wancfg['adv_dhcp6_id_assoc_statement_address_id'] = $_POST['adv_dhcp6_id_assoc_statement_address_id'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_address_pltime'])) {
$wancfg['adv_dhcp6_id_assoc_statement_address_pltime'] = $_POST['adv_dhcp6_id_assoc_statement_address_pltime'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_address_vltime'])) {
$wancfg['adv_dhcp6_id_assoc_statement_address_vltime'] = $_POST['adv_dhcp6_id_assoc_statement_address_vltime'];
}
if (isset($_POST['adv_dhcp6_id_assoc_statement_prefix_enable'])) {
$wancfg['adv_dhcp6_id_assoc_statement_prefix_enable'] = $_POST['adv_dhcp6_id_assoc_statement_prefix_enable'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_prefix'])) {
$wancfg['adv_dhcp6_id_assoc_statement_prefix'] = $_POST['adv_dhcp6_id_assoc_statement_prefix'];
}
if (is_numericint($_POST['adv_dhcp6_id_assoc_statement_prefix_id'])) {
$wancfg['adv_dhcp6_id_assoc_statement_prefix_id'] = $_POST['adv_dhcp6_id_assoc_statement_prefix_id'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_prefix_pltime'])) {
$wancfg['adv_dhcp6_id_assoc_statement_prefix_pltime'] = $_POST['adv_dhcp6_id_assoc_statement_prefix_pltime'];
}
if (!empty($_POST['adv_dhcp6_id_assoc_statement_prefix_vltime'])) {
$wancfg['adv_dhcp6_id_assoc_statement_prefix_vltime'] = $_POST['adv_dhcp6_id_assoc_statement_prefix_vltime'];
}
if (is_numericint($_POST['adv_dhcp6_prefix_interface_statement_sla_id'])) {
$wancfg['adv_dhcp6_prefix_interface_statement_sla_id'] = $_POST['adv_dhcp6_prefix_interface_statement_sla_id'];
}
if (is_numericint($_POST['adv_dhcp6_prefix_interface_statement_sla_len'])) {
$wancfg['adv_dhcp6_prefix_interface_statement_sla_len'] = $_POST['adv_dhcp6_prefix_interface_statement_sla_len'];
}
if (!empty($_POST['adv_dhcp6_authentication_statement_authname'])) {
$wancfg['adv_dhcp6_authentication_statement_authname'] = $_POST['adv_dhcp6_authentication_statement_authname'];
}
if (!empty($_POST['adv_dhcp6_authentication_statement_protocol'])) {
$wancfg['adv_dhcp6_authentication_statement_protocol'] = $_POST['adv_dhcp6_authentication_statement_protocol'];
}
if (!empty($_POST['adv_dhcp6_authentication_statement_algorithm'])) {
$wancfg['adv_dhcp6_authentication_statement_algorithm'] = $_POST['adv_dhcp6_authentication_statement_algorithm'];
}
if (!empty($_POST['adv_dhcp6_authentication_statement_rdm'])) {
$wancfg['adv_dhcp6_authentication_statement_rdm'] = $_POST['adv_dhcp6_authentication_statement_rdm'];
}
if (!empty($_POST['adv_dhcp6_key_info_statement_keyname'])) {
$wancfg['adv_dhcp6_key_info_statement_keyname'] = $_POST['adv_dhcp6_key_info_statement_keyname'];
}
if (!empty($_POST['adv_dhcp6_key_info_statement_realm'])) {
$wancfg['adv_dhcp6_key_info_statement_realm'] = $_POST['adv_dhcp6_key_info_statement_realm'];
}
if (!empty($_POST['adv_dhcp6_key_info_statement_keyid'])) {
$wancfg['adv_dhcp6_key_info_statement_keyid'] = $_POST['adv_dhcp6_key_info_statement_keyid'];
}
if (!empty($_POST['adv_dhcp6_key_info_statement_secret'])) {
$wancfg['adv_dhcp6_key_info_statement_secret'] = $_POST['adv_dhcp6_key_info_statement_secret'];
}
if (!empty($_POST['adv_dhcp6_key_info_statement_expire'])) {
$wancfg['adv_dhcp6_key_info_statement_expire'] = $_POST['adv_dhcp6_key_info_statement_expire'];
}
if (!empty($_POST['adv_dhcp6_config_advanced'])) {
$wancfg['adv_dhcp6_config_advanced'] = $_POST['adv_dhcp6_config_advanced'];
}
if (!empty($_POST['adv_dhcp6_config_file_override'])) {
$wancfg['adv_dhcp6_config_file_override'] = $_POST['adv_dhcp6_config_file_override'];
}
if (!empty($_POST['adv_dhcp6_config_file_override_path'])) {
$wancfg['adv_dhcp6_config_file_override_path'] = $_POST['adv_dhcp6_config_file_override_path'];
}
if ($gateway_item) {
$a_gateways[] = $gateway_item;
}
break;
case "6rd":
$wancfg['ipaddrv6'] = "6rd";
$wancfg['prefix-6rd'] = $_POST['prefix-6rd'];
$wancfg['prefix-6rd-v4plen'] = $_POST['prefix-6rd-v4plen'];
$wancfg['gateway-6rd'] = $_POST['gateway-6rd'];
if ($gateway_item) {
$a_gateways[] = $gateway_item;
}
break;
case "6to4":
$wancfg['ipaddrv6'] = "6to4";
break;
case "track6":
$wancfg['ipaddrv6'] = "track6";
$wancfg['track6-interface'] = $_POST['track6-interface'];
if ($_POST['track6-prefix-id--hex'] === "") {
$wancfg['track6-prefix-id'] = 0;
} else if (is_numeric("0x" . $_POST['track6-prefix-id--hex'])) {
$wancfg['track6-prefix-id'] = intval($_POST['track6-prefix-id--hex'], 16);
} else {
$wancfg['track6-prefix-id'] = 0;
}
break;
case "none":
break;
}
handle_pppoe_reset($_POST);
if ($_POST['blockpriv'] == "yes") {
$wancfg['blockpriv'] = true;
} else {
unset($wancfg['blockpriv']);
}
if ($_POST['blockbogons'] == "yes") {
$wancfg['blockbogons'] = true;
} else {
unset($wancfg['blockbogons']);
}
$wancfg['spoofmac'] = $_POST['spoofmac'];
if (empty($_POST['mtu'])) {
unset($wancfg['mtu']);
} else {
$wancfg['mtu'] = $_POST['mtu'];
}
if (empty($_POST['mss'])) {
unset($wancfg['mss']);
} else {
$wancfg['mss'] = $_POST['mss'];
}
if (empty($_POST['mediaopt'])) {
unset($wancfg['media']);
unset($wancfg['mediaopt']);
} else {
$mediaopts = explode(' ', $_POST['mediaopt']);
if ($mediaopts[0] != '') {
$wancfg['media'] = $mediaopts[0];
}
if ($mediaopts[1] != '') {
$wancfg['mediaopt'] = $mediaopts[1];
} else {
unset($wancfg['mediaopt']);
}
}
if (isset($wancfg['wireless'])) {
handle_wireless_post();
}
conf_mount_ro();
write_config();
if (file_exists("{$g['tmp_path']}/.interfaces.apply")) {
$toapplylist = unserialize(file_get_contents("{$g['tmp_path']}/.interfaces.apply"));
} else {
$toapplylist = array();
}
$toapplylist[$if]['ifcfg'] = $old_wancfg;
$toapplylist[$if]['ppps'] = $old_ppps;
file_put_contents("{$g['tmp_path']}/.interfaces.apply", serialize($toapplylist));
mark_subsystem_dirty('interfaces');
/* regenerate cron settings/crontab file */
configure_cron();
header("Location: interfaces.php?if={$if}");
exit;
}
} // end if ($_POST)
function handle_wireless_post() {
global $_POST, $config, $g, $wancfg, $if, $wl_countries_attr, $wlanbaseif;
if (!is_array($wancfg['wireless'])) {
$wancfg['wireless'] = array();
}
$wancfg['wireless']['standard'] = $_POST['standard'];
$wancfg['wireless']['mode'] = $_POST['mode'];
$wancfg['wireless']['protmode'] = $_POST['protmode'];
$wancfg['wireless']['ssid'] = $_POST['ssid'];
$wancfg['wireless']['channel'] = $_POST['channel'];
$wancfg['wireless']['authmode'] = $_POST['authmode'];
$wancfg['wireless']['txpower'] = $_POST['txpower'];
$wancfg['wireless']['distance'] = $_POST['distance'];
$wancfg['wireless']['regdomain'] = $_POST['regdomain'];
$wancfg['wireless']['regcountry'] = $_POST['regcountry'];
$wancfg['wireless']['reglocation'] = $_POST['reglocation'];
if (!empty($wancfg['wireless']['regdomain']) && !empty($wancfg['wireless']['regcountry'])) {
foreach ($wl_countries_attr as $wl_country) {
if ($wancfg['wireless']['regcountry'] == $wl_country['ID']) {
$wancfg['wireless']['regdomain'] = $wl_country['rd'][0]['REF'];
break;
}
}
}
if (!is_array($wancfg['wireless']['wpa'])) {
$wancfg['wireless']['wpa'] = array();
}
$wancfg['wireless']['wpa']['macaddr_acl'] = $_POST['macaddr_acl'];
$wancfg['wireless']['wpa']['wpa_mode'] = $_POST['wpa_mode'];
$wancfg['wireless']['wpa']['wpa_key_mgmt'] = $_POST['wpa_key_mgmt'];
$wancfg['wireless']['wpa']['wpa_pairwise'] = $_POST['wpa_pairwise'];
$wancfg['wireless']['wpa']['wpa_group_rekey'] = $_POST['wpa_group_rekey'];
$wancfg['wireless']['wpa']['wpa_gmk_rekey'] = $_POST['wpa_gmk_rekey'];
$wancfg['wireless']['wpa']['passphrase'] = $_POST['passphrase'];
$wancfg['wireless']['wpa']['ext_wpa_sw'] = $_POST['ext_wpa_sw'];
$wancfg['wireless']['auth_server_addr'] = $_POST['auth_server_addr'];
$wancfg['wireless']['auth_server_port'] = $_POST['auth_server_port'];
$wancfg['wireless']['auth_server_shared_secret'] = $_POST['auth_server_shared_secret'];
$wancfg['wireless']['auth_server_addr2'] = $_POST['auth_server_addr2'];
$wancfg['wireless']['auth_server_port2'] = $_POST['auth_server_port2'];
$wancfg['wireless']['auth_server_shared_secret2'] = $_POST['auth_server_shared_secret2'];
if ($_POST['persistcommonwireless'] == "yes") {
if (!is_array($config['wireless'])) {
$config['wireless'] = array();
}
if (!is_array($config['wireless']['interfaces'])) {
$config['wireless']['interfaces'] = array();
}
if (!is_array($config['wireless']['interfaces'][$wlanbaseif])) {
$config['wireless']['interfaces'][$wlanbaseif] = array();
}
} else if (isset($config['wireless']['interfaces'][$wlanbaseif])) {
unset($config['wireless']['interfaces'][$wlanbaseif]);
}
if (isset($_POST['diversity']) && is_numeric($_POST['diversity'])) {
$wancfg['wireless']['diversity'] = $_POST['diversity'];
} else if (isset($wancfg['wireless']['diversity'])) {
unset($wancfg['wireless']['diversity']);
}
if (isset($_POST['txantenna']) && is_numeric($_POST['txantenna'])) {
$wancfg['wireless']['txantenna'] = $_POST['txantenna'];
} else if (isset($wancfg['wireless']['txantenna'])) {
unset($wancfg['wireless']['txantenna']);
}
if (isset($_POST['rxantenna']) && is_numeric($_POST['rxantenna'])) {
$wancfg['wireless']['rxantenna'] = $_POST['rxantenna'];
} else if (isset($wancfg['wireless']['rxantenna'])) {
unset($wancfg['wireless']['rxantenna']);
}
if ($_POST['hidessid_enable'] == "yes") {
$wancfg['wireless']['hidessid']['enable'] = true;
} else if (isset($wancfg['wireless']['hidessid']['enable'])) {
unset($wancfg['wireless']['hidessid']['enable']);
}
if ($_POST['mac_acl_enable'] == "yes") {
$wancfg['wireless']['wpa']['mac_acl_enable'] = true;
} else if (isset($wancfg['wireless']['wpa']['mac_acl_enable'])) {
unset($wancfg['wireless']['wpa']['mac_acl_enable']);
}
if ($_POST['rsn_preauth'] == "yes") {
$wancfg['wireless']['wpa']['rsn_preauth'] = true;
} else {
unset($wancfg['wireless']['wpa']['rsn_preauth']);
}
if ($_POST['ieee8021x'] == "yes") {
$wancfg['wireless']['wpa']['ieee8021x']['enable'] = true;
} else if (isset($wancfg['wireless']['wpa']['ieee8021x']['enable'])) {
unset($wancfg['wireless']['wpa']['ieee8021x']['enable']);
}
if ($_POST['wpa_strict_rekey'] == "yes") {
$wancfg['wireless']['wpa']['wpa_strict_rekey'] = true;
} else if (isset($wancfg['wireless']['wpa']['wpa_strict_rekey'])) {
unset($wancfg['wireless']['wpa']['wpa_strict_rekey']);
}
if ($_POST['debug_mode'] == "yes") {
$wancfg['wireless']['wpa']['debug_mode'] = true;
} else if (isset($wancfg['wireless']['wpa']['debug_mode'])) {
sunset($wancfg['wireless']['wpa']['debug_mode']);
}
if ($_POST['wpa_enable'] == "yes") {
$wancfg['wireless']['wpa']['enable'] = $_POST['wpa_enable'] = true;
} else if (isset($wancfg['wireless']['wpa']['enable'])) {
unset($wancfg['wireless']['wpa']['enable']);
}
if ($_POST['wme_enable'] == "yes") {
if (!is_array($wancfg['wireless']['wme'])) {
$wancfg['wireless']['wme'] = array();
}
$wancfg['wireless']['wme']['enable'] = $_POST['wme_enable'] = true;
} else if (isset($wancfg['wireless']['wme']['enable'])) {
unset($wancfg['wireless']['wme']['enable']);
}
if ($_POST['puremode'] == "11g") {
if (!is_array($wancfg['wireless']['pureg'])) {
$wancfg['wireless']['pureg'] = array();
}
$wancfg['wireless']['pureg']['enable'] = true;
} else if ($_POST['puremode'] == "11n") {
if (!is_array($wancfg['wireless']['puren'])) {
$wancfg['wireless']['puren'] = array();
}
$wancfg['wireless']['puren']['enable'] = true;
} else {
if (isset($wancfg['wireless']['pureg'])) {
unset($wancfg['wireless']['pureg']);
}
if (isset($wancfg['wireless']['puren'])) {
unset($wancfg['wireless']['puren']);
}
}
if ($_POST['apbridge_enable'] == "yes") {
if (!is_array($wancfg['wireless']['apbridge'])) {
$wancfg['wireless']['apbridge'] = array();
}
$wancfg['wireless']['apbridge']['enable'] = $_POST['apbridge_enable'] = true;
} else if (isset($wancfg['wireless']['apbridge']['enable'])) {
unset($wancfg['wireless']['apbridge']['enable']);
}
if ($_POST['standard'] == "11g Turbo" || $_POST['standard'] == "11a Turbo") {
if (!is_array($wancfg['wireless']['turbo'])) {
$wancfg['wireless']['turbo'] = array();
}
$wancfg['wireless']['turbo']['enable'] = true;
} else if (isset($wancfg['wireless']['turbo']['enable'])) {
unset($wancfg['wireless']['turbo']['enable']);
}
interface_sync_wireless_clones($wancfg, true);
}
function check_wireless_mode() {
global $_POST, $config, $g, $wlan_modes, $wancfg, $if, $wlanif, $wlanbaseif, $old_wireless_mode, $input_errors;
if ($wancfg['wireless']['mode'] == $_POST['mode']) {
return;
}
if (does_interface_exist(interface_get_wireless_clone($wlanbaseif))) {
$clone_count = 1;
} else {
$clone_count = 0;
}
if (isset($config['wireless']['clone']) && is_array($config['wireless']['clone'])) {
foreach ($config['wireless']['clone'] as $clone) {
if ($clone['if'] == $wlanbaseif) {
$clone_count++;
}
}
}
if ($clone_count > 1) {
$old_wireless_mode = $wancfg['wireless']['mode'];
$wancfg['wireless']['mode'] = $_POST['mode'];
if (!interface_wireless_clone("{$wlanif}_", $wancfg)) {
$input_errors[] = sprintf(gettext("Unable to change mode to %s. You may already have the maximum number of wireless clones supported in this mode."), $wlan_modes[$wancfg['wireless']['mode']]);
} else {
mwexec("/sbin/ifconfig " . escapeshellarg($wlanif) . "_ destroy");
}
$wancfg['wireless']['mode'] = $old_wireless_mode;
}
}
// Find all possible media options for the interface
$mediaopts_list = array();
$intrealname = $config['interfaces'][$if]['if'];
exec("/sbin/ifconfig -m $intrealname | grep \"media \"", $mediaopts);
foreach ($mediaopts as $mediaopt) {
preg_match("/media (.*)/", $mediaopt, $matches);
if (preg_match("/(.*) mediaopt (.*)/", $matches[1], $matches1)) {
// there is media + mediaopt like "media 1000baseT mediaopt full-duplex"
array_push($mediaopts_list, $matches1[1] . " " . $matches1[2]);
} else {
// there is only media like "media 1000baseT"
array_push($mediaopts_list, $matches[1]);
}
}
$pgtitle = array(gettext("Interfaces"), $pconfig['descr']);
$shortcut_section = "interfaces";
$types4 = array("none" => gettext("None"), "staticv4" => gettext("Static IPv4"), "dhcp" => gettext("DHCP"), "ppp" => gettext("PPP"), "pppoe" => gettext("PPPoE"), "pptp" => gettext("PPTP"), "l2tp" => gettext("L2TP"));
$types6 = array("none" => gettext("None"), "staticv6" => gettext("Static IPv6"), "dhcp6" => gettext("DHCP6"), "slaac" => gettext("SLAAC"), "6rd" => gettext("6rd Tunnel"), "6to4" => gettext("6to4 Tunnel"), "track6" => gettext("Track Interface"));
// Get the MAC address
$ip = $_SERVER['REMOTE_ADDR'];
$mymac = `/usr/sbin/arp -an | grep '('{$ip}')' | head -n 1 | cut -d" " -f4`;
$mymac = str_replace("\n", "", $mymac);
function build_mediaopts_list() {
global $mediaopts_list;
$list = ["" => "Default (no preference, typically autoselect)",
" " => "------- Media Supported by this interface -------"
];
foreach ($mediaopts_list as $mediaopt) {
$list[$mediaopt] = $mediaopt;
}
return($list);
}
function build_gateway_list() {
global $a_gateways, $if;
$list = array("none" => "None");
foreach ($a_gateways as $gateway) {
if (($gateway['interface'] == $if) && (is_ipaddrv4($gateway['gateway']))) {
$list[$gateway['name']] = $gateway['name'] . " - " . $gateway['gateway'];
}
}
return($list);
}
function build_gatewayv6_list() {
global $a_gateways, $if;
$list = array("none" => "None");
foreach ($a_gateways as $gateway) {
if (($gateway['interface'] == $if) && (is_ipaddrv6($gateway['gateway']))) {
$list[$gateway['name']] = $gateway['name'] . " - " . $gateway['gateway'];
}
}
return($list);
}
include("head.inc");
if ($input_errors) {
print_input_errors($input_errors);
}
if (is_subsystem_dirty('interfaces')) {
print_info_box_np(sprintf(gettext("The %s configuration has been changed."), $wancfg['descr']) . "
" .
gettext("You must apply the changes in order for them to take effect. Don't forget to adjust the DHCP Server range if needed after applying."));
}
if ($savemsg) {
print_info_box($savemsg, 'success');
}
$form = new Form(new Form_Button(
'Submit',
gettext("Save")
));
$section = new Form_Section('General configuration');
$section->addInput(new Form_Checkbox(
'enable',
'Enable',
'Enable interface',
$pconfig['enable'],
'yes'
));
$section->addInput(new Form_Input(
'descr',
'Description',
'text',
$pconfig['descr']
))->setHelp('Enter a description (name) for the interface here.');
$section->addInput(new Form_Select(
'type',
'IPv4 Configuration Type',
$pconfig['type'],
$types4
));
$section->addInput(new Form_Select(
'type6',
'IPv6 Configuration Type',
$pconfig['type6'],
$types6
));
$macaddress = new Form_Input(
'spoofmac',
'MAC Address',
'text',
$pconfig['spoofmac'],
['placeholder' => 'xx:xx:xx:xx:xx:xx']
);
$btnmymac = new Form_Button(
'btnmymac',
'Copy My MAC'
);
$btnmymac->removeClass('btn-primary')->addClass('btn-success btn-sm');
$group = new Form_Group('MAC controls');
$group->add($macaddress);
// $group->add($btnmymac);
$group->setHelp('This field can be used to modify ("spoof") the MAC address of this interface.' . '
' .
'Enter a MAC address in the following format: xx:xx:xx:xx:xx:xx or leave blank');
$section->add($group);
$section->addInput(new Form_Input(
'mtu',
'MTU',
'number',
$pconfig['mtu']
))->setHelp('If you leave this field blank, the adapter\'s default MTU will be used. ' .
'This is typically 1500 bytes but can vary in some circumstances.');
$section->addInput(new Form_Input(
'mss',
'MSS',
'number',
$pconfig['mss']
))->setHelp('If you enter a value in this field, then MSS clamping for TCP connections to the value entered above minus 40 (TCP/IP ' .
'header size) will be in effect.');
if (count($mediaopts_list) > 0) {
$section->addInput(new Form_Select(
'mediaopt',
'Speed and Duplex',
rtrim($mediaopt_from_config),
build_mediaopts_list()
))->setHelp('Here you can explicitly set speed and duplex mode for this interface.' . '
' .
'WARNING: You MUST leave this set to autoselect (automatically negotiate speed) unless the port this interface connects to has its speed and duplex forced.');
}
$form->add($section);
$section = new Form_Section('Static IPv4 configuration');
$section->addClass('staticv4');
$section->addInput(new Form_IpAddress(
'ipaddr',
'IPv4 Address',
$pconfig['ipaddr']
))->addMask('subnet', $pconfig['subnet'], 32);
$group = new Form_Group('IPv4 Upstream gateway');
$group->add(new Form_Select(
'gateway',
'IPv4 Upstream Gateway',
$pconfig['gateway'],
build_gateway_list()
));
$group->add(new Form_Button(
'addgw',
'Add a new gateway'
))->removeClass('btn-primary')->setAttribute('data-target', '#newgateway')->setAttribute('data-toggle', 'modal');
$group->setHelp('If this interface is an Internet connection, select an existing Gateway from the list or add a new one using the "Add" button.' . '
' .
'On local LANs the upstream gateway should be "none".' .
gettext('You can manage gateways by ') . '' . gettext(" clicking here") . '');
$section->add($group);
$form->add($section);
$section = new Form_Section('Static IPv6 configuration');
$section->addClass('staticv6');
$section->addInput(new Form_IpAddress(
'ipaddrv6',
'IPv6 address',
$pconfig['ipaddrv6']
))->addMask('subnetv6', $pconfig['subnetv6'], 128);
$group = new Form_Group('IPv6 Upstream gateway');
$group->add(new Form_Select(
'gatewayv6',
'IPv6 Upstream Gateway',
$pconfig['gatewayv6'],
build_gatewayv6_list()
));
$group->add(new Form_Button(
'addgw6',
'Add a new gateway'
))->removeClass('btn-primary')->setAttribute('data-target', '#newgateway6')->setAttribute('data-toggle', 'modal');
$group->setHelp('If this interface is an Internet connection, select an existing Gateway from the list or add a new one using the "Add" button.' . '
' .
'On local LANs the upstream gateway should be "none". ');
$section->add($group);
$form->add($section);
// Add new gateway modal pop-up for IPv6
$modal = new Modal('New IPv6 gateway', 'newgateway6', 'large');
$modal->addInput(new Form_Checkbox(
'defaultgw6',
'Default',
'Default gateway',
($if == "wan" || $if == "WAN")
));
$modal->addInput(new Form_Input(
'name6',
'Gateway name',
'text',
$wancfg['descr'] . "GWv6"
));
$modal->addInput(new Form_IpAddress(
'gatewayip6',
'Gateway IPv6',
null
));
$modal->addInput(new Form_Input(
'gatewaydescr6',
'Description',
'text'
));
$btnaddgw6 = new Form_Button(
'add6',
'Add'
);
$btnaddgw6->removeClass('btn-primary')->addClass('btn-success');
$btncnxgw6 = new Form_Button(
'cnx6',
'Cancel'
);
$btncnxgw6->removeClass('btn-primary')->addClass('btn-default');
$modal->addInput(new Form_StaticText(
null,
$btnaddgw6 . $btncnxgw6
));
$form->add($modal);
// ==== DHCP client configuration =============================
$section = new Form_Section('DHCP client configuration');
$section->addClass('dhcp');
$group = new Form_Group('Options');
$group->add(new Form_Checkbox(
'dhcpadv',
null,
'Show DHCP advanced options',
false
));
$group->add(new Form_Checkbox(
'dhcpovr',
null,
'Config file override',
false
));
$section->add($group);
$section->addInput(new Form_Input(
'dhcphostname',
'Hostname',
'text',
$pconfig['dhcphostname']
))->setHelp('The value in this field is sent as the DHCP client identifier and hostname when requesting a DHCP lease. Some ISPs may require this (for client identification).');
$section->addInput(new Form_IpAddress(
'alias-address',
'Alias IPv4 address',
$pconfig['alias-address']
))->addMask('alias-subnet', $pconfig['alias-subnet'], 32)->setHelp('The value in this field is used as a fixed alias IPv4 address by the DHCP client.');
$section->addInput(new Form_Input(
'dhcprejectfrom',
'Reject leases from',
'text',
$pconfig['dhcprejectfrom']
))->setHelp('If there is a certain upstream DHCP server that should be ignored, place the IP address or subnet of the DHCP server to be ignored here. ' .
'This is useful for rejecting leases from cable modems that offer private IPs when they lose upstream sync.');
$group = new Form_Group('Protocol timing');
$group->addClass('dhcpadvanced');
$group->add(new Form_Input(
'adv_dhcp_pt_timeout',
null,
'number',
$pconfig['adv_dhcp_pt_timeout']
))->setHelp('Timeout');
$group->add(new Form_Input(
'adv_dhcp_pt_retry',
null,
'number',
$pconfig['adv_dhcp_pt_retry']
))->setHelp('Retry');
$group->add(new Form_Input(
'adv_dhcp_pt_select_timeout',
null,
'number',
$pconfig['adv_dhcp_pt_select_timeout'],
['min' => 0]
))->setHelp('Select timeout');
$group->add(new Form_Input(
'adv_dhcp_pt_reboot',
null,
'number',
$pconfig['adv_dhcp_pt_reboot']
))->setHelp('Reboot');
$group->add(new Form_Input(
'adv_dhcp_pt_backoff_cutoff',
null,
'number',
$pconfig['adv_dhcp_pt_backoff_cutoff']
))->setHelp('Backoff cutoff');
$group->add(new Form_Input(
'adv_dhcp_pt_initial_interval',
null,
'number',
$pconfig['adv_dhcp_pt_initial_interval']
))->setHelp('Initial interval');
$section->add($group);
$group = new Form_Group('Presets');
$group->addClass('dhcpadvanced');
$group->add(new Form_Checkbox(
'adv_dhcp_pt_values',
null,
'FreeBSD default',
null,
'DHCP'
))->displayAsRadio();
$group->add(new Form_Checkbox(
'adv_dhcp_pt_values',
null,
'Clear',
null,
'Clear'
))->displayAsRadio();
$group->add(new Form_Checkbox(
'adv_dhcp_pt_values',
null,
'pfSense Default',
null,
'pfSense'
))->displayAsRadio();
$group->add(new Form_Checkbox(
'adv_dhcp_pt_values',
null,
'Saved Cfg',
null,
'SavedCfg'
))->displayAsRadio();
$group->setHelp('The values in these fields are DHCP protocol timings used when requesting a lease.' . '
' .
'' . 'See here more information' . '');
$section->add($group);
$section->addInput(new Form_Input(
'adv_dhcp_config_file_override_path',
'Config file override',
'text',
$pconfig['adv_dhcp_config_file_override_path']
))->sethelp('The value in this field is the full absolute path to a DHCP client configuration file. [/[dirname/[.../]]filename[.ext]]' . '
' .
'Value Substitutions in Config File: {interface}, {hostname}, {mac_addr_asciiCD}, {mac_addr_hexCD}' . '
' .
'Where C is U(pper) or L(ower) Case, and D is ":-." Delimiter (space, colon, hyphen, or period) (omitted for none).' . '
' .
'Some ISPs may require certain options be or not be sent.');
$form->add($section);
$section = new Form_Section('Lease Requirements and Requests');
$section->addClass('dhcpadvanced');
$section->addInput(new Form_Input(
'adv_dhcp_send_options',
'Send options',
'text',
$pconfig['adv_dhcp_send_options']
))->sethelp('The values in this field are DHCP options to be sent when requesting a DHCP lease. [option declaration [, ...]]' . '
' .
'Value Substitutions: {interface}, {hostname}, {mac_addr_asciiCD}, {mac_addr_hexCD}' . '
' .
'Where C is U(pper) or L(ower) Case, and D is " :-." Delimiter (space, colon, hyphen, or period) (omitted for none).' . '
' .
'Some ISPs may require certain options be or not be sent.');
$section->addInput(new Form_Input(
'adv_dhcp_request_options',
'Request options',
'text',
$pconfig['adv_dhcp_request_options']
))->sethelp('The values in this field are DHCP option 55 to be sent when requesting a DHCP lease. [option [, ...]]' . '
' .
'Some ISPs may require certain options be or not be requested.');
$section->addInput(new Form_Input(
'adv_dhcp_required_options',
'Require options',
'text',
$pconfig['adv_dhcp_required_options']
))->sethelp('The values in this field are DHCP options required by the client when requesting a DHCP lease. [option [, ...]]');
$section->addInput(new Form_Input(
'adv_dhcp_option_modifiers',
'Option modifiers',
'text',
$pconfig['adv_dhcp_option_modifiers']
))->sethelp('The values in this field are DHCP option modifiers applied to obtained DHCP lease. [modifier option declaration [, ...]]' . '
' .
'modifiers: (default, supersede, prepend, append)');
$form->add($section);
// DHCP6 client config
$section = new Form_Section('DHCP6 client configuration');
$section->addClass('dhcp6');
$section->addInput(new Form_Checkbox(
'adv_dhcp6_config_advanced',
'Advanced',
'Show DHCPv6 advanced options',
$pconfig['adv_dhcp6_config_advanced'],
'Selected'
));
$section->addInput(new Form_Checkbox(
'adv_dhcp6_config_file_override',
'Config file override',
'Override the configuration from this file',
$pconfig['adv_dhcp6_config_file_override'],
'Selected'
));
$section->addInput(new Form_Checkbox(
'dhcp6usev4iface',
'Use IPv4 connectivity as parent interface',
'Request a IPv6 prefix/information through the IPv4 connectivity link',
$pconfig['dhcp6usev4iface']
));
$section->addInput(new Form_Checkbox(
'dhcp6prefixonly',
'Request only an IPv6 prefix',
'Only request an IPv6 prefix, do not request an IPv6 address',
$pconfig['dhcp6prefixonly']
));
$section->addInput(new Form_Select(
'dhcp6-ia-pd-len',
'DHCPv6 Prefix Delegation size',
$pconfig['dhcp6-ia-pd-len'],
array("none" => "None", 16 => "48", 12 => "52", 8 => "56", 4 => "60", 3 => "61", 2 => "62", 1 => "63", 0 => "64")
))->setHelp('The value in this field is the delegated prefix length provided by the DHCPv6 server. Normally specified by the ISP.');
$section->addInput(new Form_Checkbox(
'dhcp6-ia-pd-send-hint',
'Send IPv6 prefix hint',
'Send an IPv6 prefix hint to indicate the desired prefix size for delegation',
$pconfig['dhcp6-ia-pd-send-hint']
));
$section->addInput(new Form_Input(
'adv_dhcp6_config_file_override_path',
'Configuration File Override',
'text',
$pconfig['adv_dhcp6_config_file_override_path']
))->setHelp('The value in this field is the full absolute path to a DHCP client configuration file. [/[dirname/[.../]]filename[.ext]]' . '
' .
'Value Substitutions in Config File: {interface}, {hostname}, {mac_addr_asciiCD}, {mac_addr_hexCD}' . '
' .
'Where C is U(pper) or L(ower) Case, and D is \" :-.\" Delimiter (space, colon, hyphen, or period) (omitted for none).' . '
' .
'Some ISPs may require certain options be or not be sent.');
$form->add($section);
// DHCP6 client config - Advanced
$section = new Form_Section('Advanced DHCP6 client configuration');
$section->addClass('dhcp6advanced');
$section->addInput(new Form_Checkbox(
'adv_dhcp6_interface_statement_information_only_enable',
'Information only',
null,
$pconfig['adv_dhcp6_interface_statement_information_only_enable'],
'Selected'
));
$section->addInput(new Form_Input(
'adv_dhcp6_interface_statement_send_options',
'Send options',
'text',
$pconfig['adv_dhcp6_interface_statement_send_options']
))->sethelp('DHCP send options to be sent when requesting a DHCP lease. [option declaration [, ...]]' . '
' .
'Value Substitutions: {interface}, {hostname}, {mac_addr_asciiCD}, {mac_addr_hexCD}' . '
' .
'Where C is U(pper) or L(ower) Case, and D is \" :-.\" Delimiter (space, colon, hyphen, or period) (omitted for none).' . '
' .
'Some DHCP services may require certain options be or not be sent.');
$section->addInput(new Form_Input(
'adv_dhcp6_interface_statement_request_options',
'Request Options',
'text',
$pconfig['adv_dhcp6_interface_statement_request_options']
))->sethelp('DHCP request options to be sent when requesting a DHCP lease. [option [, ...]]' . '
' .
'Some DHCP services may require certain options be or not be requested.');
$section->addInput(new Form_Input(
'adv_dhcp6_interface_statement_script',
'Scripts',
'text',
$pconfig['adv_dhcp6_interface_statement_script']
))->sethelp('Absolute path to a script invoked on certain conditions including when a reply message is received.' . '
' .
'[/[dirname/[.../]]filename[.ext]].');
$group = new Form_Group('Identity Association Statement');
$group->add(new Form_Checkbox(
'adv_dhcp6_id_assoc_statement_address_enable',
null,
'Non-Temporary Address Allocation',
$pconfig['adv_dhcp6_id_assoc_statement_address_enable'],
'Selected'
));
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_address_id',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_address_id']
))->sethelp('id-assoc na ID');
$group->add(new Form_IpAddress(
'adv_dhcp6_id_assoc_statement_address',
null,
$pconfig['adv_dhcp6_id_assoc_statement_address']
))->sethelp('IPv6 address');
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_address_pltime',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_address_pltime']
))->sethelp('pltime');
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_address_vltime',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_address_vltime']
))->sethelp('vltime');
$section->add($group);
// Prefix delegation
$group = new Form_Group('');
$group->add(new Form_Checkbox(
'adv_dhcp6_id_assoc_statement_prefix_enable',
null,
'Prefix Delegation ',
$pconfig['adv_dhcp6_id_assoc_statement_prefix_enable'],
'Selected'
));
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_prefix_id',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_prefix_id']
))->sethelp('id-assoc pd ID');
$group->add(new Form_IpAddress(
'adv_dhcp6_id_assoc_statement_prefix',
null,
$pconfig['adv_dhcp6_id_assoc_statement_prefix']
))->sethelp('IPv6 prefix');
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_prefix_pltime',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_prefix_pltime']
))->sethelp('pltime');
$group->add(new Form_Input(
'adv_dhcp6_id_assoc_statement_prefix_vltime',
null,
'text',
$pconfig['adv_dhcp6_id_assoc_statement_prefix_vltime']
))->sethelp('vltime');
$section->add($group);
$group = new Form_Group('Prefix interface statement');
$group->add(new Form_Input(
'adv_dhcp6_prefix_interface_statement_sla_id',
null,
'text',
$pconfig['adv_dhcp6_prefix_interface_statement_sla_id']
))->sethelp('Prefix Interface sla-id');
$group->add(new Form_Input(
'adv_dhcp6_prefix_interface_statement_sla_len',
null,
'text',
$pconfig['adv_dhcp6_prefix_interface_statement_sla_len']
))->sethelp('sla-len');
$section->add($group);
$group = new Form_Group('Authentication statement');
$group->add(new Form_Input(
'adv_dhcp6_authentication_statement_authname',
null,
'text',
$pconfig['adv_dhcp6_authentication_statement_authname']
))->sethelp('Authname');
$group->add(new Form_Input(
'adv_dhcp6_authentication_statement_protocol',
null,
'text',
$pconfig['adv_dhcp6_authentication_statement_protocol']
))->sethelp('Protocol');
$group->add(new Form_Input(
'adv_dhcp6_authentication_statement_algorithm',
null,
'text',
$pconfig['adv_dhcp6_authentication_statement_algorithm']
))->sethelp('Algorithm');
$group->add(new Form_Input(
'adv_dhcp6_authentication_statement_rdm',
null,
'text',
$pconfig['adv_dhcp6_authentication_statement_rdm']
))->sethelp('RDM');
$section->add($group);
$group = new Form_Group('Keyinfo statement');
$group->add(new Form_Input(
'adv_dhcp6_key_info_statement_keyname',
null,
'text',
$pconfig['adv_dhcp6_key_info_statement_keyname']
))->sethelp('Keyname');
$group->add(new Form_Input(
'adv_dhcp6_key_info_statement_realm',
null,
'text',
$pconfig['adv_dhcp6_key_info_statement_realm']
))->sethelp('Realm');
$section->add($group);
$group = new Form_Group('');
$group->add(new Form_Input(
'adv_dhcp6_key_info_statement_keyid',
null,
'text',
$pconfig['adv_dhcp6_key_info_statement_keyid']
))->sethelp('KeyID');
$group->add(new Form_Input(
'adv_dhcp6_key_info_statement_secret',
null,
'text',
$pconfig['adv_dhcp6_key_info_statement_secret']
))->sethelp('Secret');
$group->add(new Form_Input(
'adv_dhcp6_key_info_statement_expire',
null,
'text',
$pconfig['adv_dhcp6_key_info_statement_expire']
))->sethelp('Expire');
$section->add($group);
$form->add($section);
$section = new Form_Section('6RD Configuration');
$section->addClass('_6rd');
$section->addInput(new Form_Input(
'prefix-6rd',
'6RD Prefix',
'text',
$pconfig['prefix-6rd']
))->sethelp('6RD IPv6 prefix assigned by your ISP. e.g. "2001:db8::/32"');
$section->addInput(new Form_Input(
'gateway-6rd',
'6RD Border relay',
'text',
$pconfig['gateway-6rd']
))->sethelp('6RD IPv4 gateway address assigned by your ISP');
$section->addInput(new Form_Select(
'prefix-6rd-v4plen',
'6RD IPv4 Prefix length',
$pconfig['prefix-6rd-v4plen'],
array_combine(range(0, 32), range(0, 32))
))->setHelp('6RD IPv4 prefix length. Normally specified by the ISP. A value of 0 means we embed the entire IPv4 address in the 6RD prefix.');
$form->add($section);
// Track IPv6 ointerface section
$section = new Form_Section('Track IPv6 Interface');
$section->addClass('track6');
function build_ipv6interface_list() {
global $config, $section;
$list = array('' => '');
$interfaces = get_configured_interface_with_descr(false, true);
$dynv6ifs = array();
foreach ($interfaces as $iface => $ifacename) {
switch ($config['interfaces'][$iface]['ipaddrv6']) {
case "6to4":
case "6rd":
case "dhcp6":
$dynv6ifs[$iface] = array(
'name' => $ifacename,
'ipv6_num_prefix_ids' => pow(2, calculate_ipv6_delegation_length($iface)) - 1
);
break;
default:
continue;
}
}
foreach ($dynv6ifs as $iface => $ifacedata) {
$list[$iface] = $ifacedata['name'];
$section->addInput(new Form_Input(
'ipv6-num-prefix-ids-' . $iface,
null,
'hidden',
$ifacedata['ipv6_num_prefix_ids']
));
}
return($list);
}
$section->addInput(new Form_Select(
'track6-interface',
'IPv6 Interface',
$pconfig['track6-interface'],
build_ipv6interface_list()
))->setHelp('selects the dynamic IPv6 WAN interface to track for configuration');
if ($pconfig['track6-prefix-id'] == "") {
$pconfig['track6-prefix-id'] = 0;
}
$section->addInput(new Form_Input(
'track6-prefix-id--hex' . $iface,
'IPv6 Prefix ID',
'text',
sprintf("%x", $pconfig['track6-prefix-id'])
))->setHelp('The value in this field is the (Delegated) IPv6 prefix ID. This determines the configurable network ID based on the dynamic IPv6 connection. The default value is 0.');
$section->addInput(new Form_Input(
'track6-prefix-id-max' . $iface,
null,
'hidden',
0
));
$form->add($section);
/// PPP section
$section = new Form_Section('PPP Configuration');
$section->addClass('ppp');
$section->addInput(new Form_Select(
'country',
'Country',
$pconfig['country'],
[]
));
$section->addInput(new Form_Select(
'provider_list',
'Provider',
$pconfig['provider_list'],
[]
));
$section->addInput(new Form_Select(
'providerplan',
'Plan',
$pconfig['providerplan'],
[]
))->setHelp('Select to fill in data for your service provider.');
$section->addInput(new Form_Input(
'ppp_username',
'Username',
'text',
$pconfig['ppp_username']
));
$section->addPassword(new Form_Input(
'ppp_password',
'Password',
'password',
$pconfig['ppp_password']
));
$section->addInput(new Form_Input(
'phone',
'Phone number',
'text',
$pconfig['phone']
))->setHelp('Typically *99# for GSM networks and #777 for CDMA networks');
$section->addInput(new Form_Input(
'apn',
'Access Point Name',
'text',
$pconfig['apn']
));
function build_port_list() {
$list = array("" => "None");
$portlist = glob("/dev/cua*");
$modems = glob("/dev/modem*");
$portlist = array_merge($portlist, $modems);
foreach ($portlist as $port) {
if (preg_match("/\.(lock|init)$/", $port)) {
continue;
}
$list[trim($port)] = $port;
}
return($list);
}
$section->addInput(new Form_Select(
'port',
"Modem port",
$pconfig['port'],
build_port_list()
));
$section->addInput(new Form_Button(
'btnadvppp',
'Advanced PPP',
isset($pconfig['pppid']) ? 'interfaces_ppps_edit.php?id=' . htmlspecialchars($pconfig['pppid']) : 'interfaces_ppps_edit.php'
))->setHelp('Create a new PPP configuration');
$form->add($section);
// PPPoE configuration
$section = new Form_Section('PPPoE Configuration');
$section->addClass('pppoe');
$section->addInput(new Form_Input(
'pppoe_username',
'Username',
'text',
$pconfig['pppoe_username']
));
$section->addPassword(new Form_Input(
'pppoe_password',
'Password',
'password',
$pconfig['pppoe_password']
));
$section->addInput(new Form_Input(
'provider',
'Service name',
'text',
$pconfig['provider']
))->setHelp('This field can usually be left empty');
$section->addInput(new Form_Checkbox(
'pppoe_dialondemand',
'Dial on demand',
'Enable Dial-On-Demand mode ',
$pconfig['pppoe_dialondemand'],
'enable'
));
$section->addInput(new Form_Input(
'pppoe_idletimeout',
'Idle timeout',
'number',
$pconfig['pppoe_idletimeout'],
[min => 0]
))->setHelp('If no qualifying outgoing packets are transmitted for the specified number of seconds, the connection is brought down. ' .
'An idle timeout of zero disables this feature.');
$section->addInput(new Form_Select(
'pppoe-reset-type',
'Periodic reset',
$pconfig['pppoe-reset-type'],
['' => 'Disabled', 'custom' => 'Custom', 'preset' => 'Pre-set']
))->setHelp('Select a reset timing type');
$group = new Form_Group('Custom reset');
$group->addClass('pppoecustom');
$group->add(new Form_Input(
'pppoe_resethour',
null,
'number',
$pconfig['pppoe_resethour'],
[min => 0, max => 23]
))->setHelp('Hour (0-23)');
$group->add(new Form_Input(
'pppoe_resetminute',
null,
'number',
$pconfig['pppoe_resetminute'],
[min => 0, max => 59]
))->setHelp('Minutes (0-59)');
// ToDo: Need a date-picker here
$group->add(new Form_Input(
'pppoe_resetdate',
null,
'text',
$pconfig['pppoe_resetdate']
))->setHelp('Specific date (mm/dd/yyyy)');
$group->setHelp('If you leave the date field empty, the reset will be executed each day at the time you specified using the minutes and hour field');
$section->add($group);
$group = new Form_MultiCheckboxGroup('cron based reset');
$group->addClass('pppoepreset');
$group->add(new Form_MultiCheckbox(
'pppoe_pr_preset_val',
null,
'Reset at each month ("0 0 1 * *")',
$pconfig['pppoe_monthly'],
'monthly'
))->displayAsRadio();
$group->add(new Form_MultiCheckbox(
'pppoe_pr_preset_val',
null,
'Reset at each week ("0 0 * * 0")',
$pconfig['pppoe_weekly'],
'weekly'
))->displayAsRadio();
$group->add(new Form_MultiCheckbox(
'pppoe_pr_preset_val',
null,
'Reset at each day ("0 0 * * *")',
$pconfig['pppoe_daily'],
'daily'
))->displayAsRadio();
$group->add(new Form_MultiCheckbox(
'pppoe_pr_preset_val',
null,
'Reset at each hour ("0 * * * *")',
$pconfig['pppoe_hourly'],
'hourly'
))->displayAsRadio();
$section->add($group);
if (isset($pconfig['pppid'])) {
$section->addInput(new Form_StaticText(
'Advanced and MLPPP',
'Click here for additional PPPoE configuration options. Save first if you made changes.'
));
} else {
$section->addInput(new Form_StaticText(
'Advanced and MLPPP',
'Click here for additional PPPoE configuration options and for MLPPP configuration.'
));
}
$form->add($section);
// PPTP & L2TP Configuration section
$section = new Form_Section('PPTP/L2TP Configuration');
$section->addClass('pptp');
$section->addInput(new Form_Input(
'pptp_username',
'Username',
'text',
$pconfig['pptp_username']
));
$section->addPassword(new Form_Input(
'pptp_password',
'Password',
'password',
$pconfig['pptp_password']
));
$section->addInput(new Form_IpAddress(
'pptp_local0',
'Local IP address',
$pconfig['pptp_localip'][0]
))->addMask('pptp_subnet0', $pconfig['pptp_subnet'][0]);
$section->addInput(new Form_IpAddress(
'pptp_remote0',
'Remote IP address',
$pconfig['pptp_remote'][0]
));
$section->addInput(new Form_Checkbox(
'pptp_dialondemand',
'Dial on demand',
'Enable Dial-On-Demand mode ',
$pconfig['pptp_dialondemand'],
'enable'
))->setHelp('This option causes the interface to operate in dial-on-demand mode, allowing you to have a virtual full time connection. ' .
'The interface is configured, but the actual connection of the link is delayed until qualifying outgoing traffic is detected.');
$section->addInput(new Form_Input(
'pptp_idletimeout',
'Idle timeout (seconds)',
'number',
$pconfig['pptp_idletimeout'],
[min => 0]
))->setHelp('If no qualifying outgoing packets are transmitted for the specified number of seconds, the connection is brought down. ' .
'An idle timeout of zero disables this feature.');
if (isset($pconfig['pppid'])) {
if (isset($pconfig['pptp_localip'][1]) || isset($pconfig['pptp_subnet'][1]) || isset($pconfig['pptp_remote'][1])) {
$mlppp_text = gettext("There are additional Local and Remote IP addresses defined for MLPPP.") . "
";
} else {
$mlppp_text = "";
}
$section->addInput(new Form_StaticText(
'Advanced and MLPPP',
$mlppp_text . 'Click here for additional PPTP and L2TP configuration options. Save first if you made changes.'
));
} else {
$section->addInput(new Form_StaticText(
'Advanced and MLPPP',
'Click here for additional PPTP and L2TP configuration options.'
));
}
$form->add($section);
// Wireless interface
if (isset($wancfg['wireless'])) {
$section = new Form_Section('Common wireless configuration - Settings apply to all wireless networks on ' . $wlanbaseif . '.');
$section->addInput(new Form_Checkbox(
'persistcommonwireless',
'Persist common settings',
'Preserve common wireless configuration through interface deletions and reassignments.',
$pconfig['persistcommonwireless'],
'yes'
));
$mode_list = ['auto' => 'Auto'];
if (is_array($wl_modes)) {
foreach ($wl_modes as $wl_standard => $wl_channels) {
$mode_list[$wl_standard] = '802.' . $wl_standard;
}
}
if (count($mode_list) == 1) {
$mode_list[''] = '';
}
$section->addInput(new Form_Select(
'standard',
'Standard',
($pconfig['standard'] == "") ? "11ng":$pconfig['standard'],
$mode_list
));
if (isset($wl_modes['11g'])) {
$section->addInput(new Form_Select(
'protmode',
'802.11g OFDM Protection Mode',
$pconfig['protmode'],
['off' => 'Off', 'cts' => 'CTS to self', 'rtscts' => 'RTS and CTS']
))->setHelp('For IEEE 802.11g, use the specified technique for protecting OFDM frames in a mixed 11b/11g network.');
} else {
$section->addInput(new Form_Input(
'protmode',
null,
'hidden',
'off'
));
}
$mode_list = ['0' => 'Auto'];
if (is_array($wl_modes)) {
foreach ($wl_modes as $wl_standard => $wl_channels) {
if ($wl_standard == "11g") {
$wl_standard = "11b/g";
} else if ($wl_standard == "11ng") {
$wl_standard = "11b/g/n";
} else if ($wl_standard == "11na") {
$wl_standard = "11a/n";
}
foreach ($wl_channels as $wl_channel) {
if (isset($wl_chaninfo[$wl_channel])) {
$mode_list[ $wl_channel] = $wl_standard . ' - ' . $wl_channel;
} else {
$mode_list[ $wl_channel] = $wl_standard . ' - ' . $wl_channel . ' (' . $wl_chaninfo[$wl_channel][1] . ' @ ' . $wl_chaninfo[$wl_channel][2] . ' / ' . $wl_chaninfo[$wl_channel][3] . ')';
}
}
}
}
$section->addInput(new Form_Select(
'channel',
'Channel',
$pconfig['channel'],
$mode_list
))->setHelp('Legend: wireless standards - channel # (frequency @ max TX power / TX power allowed in reg. domain)' . '
' .
'Not all channels may be supported by your card. Auto may override the wireless standard selected above.');
if (ANTENNAS) {
if (isset($wl_sysctl["{$wl_sysctl_prefix}.diversity"]) || isset($wl_sysctl["{$wl_sysctl_prefix}.txantenna"]) || isset($wl_sysctl["{$wl_sysctl_prefix}.rxantenna"])) {
$group = new Form_Group('Antenna Settings');
if (isset($wl_sysctl["{$wl_sysctl_prefix}.diversity"])) {
$group->add(new Form_Select(
'diversity',
null,
(isset($pconfig['diversity'])) ? $pconfig['diversity']:'',
['' => 'Default', '0' => 'Off', '1' => 'On']
))->setHelp('Diversity');
}
if (isset($wl_sysctl["{$wl_sysctl_prefix}.txantenna"])) {
$group->add(new Form_Select(
'txantenna',
null,
(isset($pconfig['txantenna'])) ? $pconfig['txantenna']:'',
['' => 'Default', '0' => 'Auto', '1' => '#1', '2' => '#2']
))->setHelp('Transmit antenna');
}
if (isset($wl_sysctl["{$wl_sysctl_prefix}.rxantenna"])) {
$group->add(new Form_Select(
'rxantenna',
null,
(isset($pconfig['rxantenna'])) ? $pconfig['rxantenna']:'',
['' => 'Default', '0' => 'Auto', '1' => '#1', '2' => '#2']
))->setHelp('Receive antenna');
}
$group->setHelp('Note: The antenna numbers do not always match up with the labels on the card.');
$section->add($group);
}
}
if (isset($wl_sysctl["{$wl_sysctl_prefix}.slottime"]) && isset($wl_sysctl["{$wl_sysctl_prefix}.acktimeout"]) && isset($wl_sysctl["{$wl_sysctl_prefix}.ctstimeout"])) {
$section->addInput(new Form_Input(
'distance',
'Distance setting (meters)',
'test',
$pconfig['distance']
))->setHelp('This field can be used to tune ACK/CTS timers to fit the distance between AP and Client');
}
$form->add($section);
// Regulatory settings
$section = new Form_Section('Regulatory settings');
$domain_list = array("" => 'Default');
if (is_array($wl_regdomains)) {
foreach ($wl_regdomains as $wl_regdomain_key => $wl_regdomain) {
$domain_list[$wl_regdomains_attr[$wl_regdomain_key]['ID']] = $wl_regdomain['name'];
}
}
$section->addInput(new Form_Select(
'regdomain',
'Regulatory domain',
$pconfig['regdomain'],
$domain_list
))->setHelp('Some cards have a default that is not recognized and require changing the regulatory domain to one in this list for the changes to other regulatory settings to work');
$country_list = array('' => 'Default');
if (is_array($wl_countries)) {
foreach ($wl_countries as $wl_country_key => $wl_country) {
$country_list[ $wl_countries_attr[$wl_country_key]['ID'] ] = $wl_country['name'] ; //. ' -- (' . $wl_countries_attr[$wl_country_key]['ID'] . ', ' . strtoupper($wl_countries_attr[$wl_country_key]['rd'][0]['REF']);
}
}
$section->addInput(new Form_Select(
'regcountry',
'Country',
$pconfig['regcountry'],
$country_list
))->setHelp('Any country setting other than "Default" will override the regulatory domain setting');
$section->addInput(new Form_Select(
'reglocation',
'Location',
$pconfig['reglocation'],
['' => 'Default', 'indoor' => 'Indoor', 'outdoor' => 'Outdoor', 'anywhere' => 'Anywhere']
))->setHelp('These settings may affect which channels are available and the maximum transmit power allowed on those channels. ' .
'Using the correct settings to comply with local regulatory requirements is recommended.' . '
' .
'All wireless networks on this interface will be temporarily brought down when changing regulatory settings. ' .
'Some of the regulatory domains or country codes may not be allowed by some cards. ' .
'These settings may not be able to add additional channels that are not already supported.');
$form->add($section);
$section = new Form_Section('Network-specific wireless configuration');
$section->addInput(new Form_Select(
'mode',
'Mode',
$pconfig['mode'],
['bss' => 'Infrastructure (BSS)', 'adhoc' => 'Ad-hoc (IBSS)', 'hostap' => 'Access Point']
));
$section->addInput(new Form_Input(
'ssid',
'SSID',
'text',
$pconfig['ssid']
));
if (isset($wl_modes['11ng']) || isset($wl_modes['11na'])) {
$section->addInput(new Form_Select(
'puremode',
'Minimum wireless standard',
$pconfig['puremode'],
['any' => 'Any', '11g' => '802.11g', '11n' => '802.11n']
))->setHelp('When operating as an access point, allow only stations capable of the selected wireless standard to associate (stations not capable are not permitted to associate)');
} elseif (isset($wl_modes['11g'])) {
$section->addInput(new Form_Checkbox(
'puremode',
'802.11g only',
null,
$pconfig['puremode'],
'11g'
))->setHelp('When operating as an access point in 802.11g mode, allow only 11g-capable stations to associate (11b-only stations are not permitted to associate)');
}
$section->addInput(new Form_Checkbox(
'apbridge_enable',
'Allow intra-BSS communication',
'Allow packets to pass between wireless clients directly when operating as an access point',
$pconfig['apbridge_enable'],
'yes'
))->setHelp('Disabling the internal bridging is useful when traffic is to be processed with packet filtering');
$section->addInput(new Form_Checkbox(
'wme_enable',
'Enable WME',
'Force the card to use WME (wireless QoS)',
$pconfig['wme_enable'],
'yes'
));
$section->addInput(new Form_Checkbox(
'hidessid_enable',
'Hide SSID',
'Force the card to NOT broadcast its SSID (This may cause problems for some clients)',
$pconfig['hidessid_enable'],
'yes'
));
$form->add($section);
// WPA Section
$section = new Form_Section('WPA');
$section->addInput(new Form_Checkbox(
'wpa_enable',
'Enable',
'Enable WPA',
$pconfig['wpa_enable'],
'yes'
));
$section->addInput(new Form_Input(
'passphrase',
'WPA Pre-Shared Key',
'text',
$pconfig['passphrase']
))->setHelp('WPA Passphrase must be between 8 and 63 characters long');
$section->addInput(new Form_Select(
'wpa_mode',
'WPA mode',
(isset($pconfig['wpa_mode'])) ? $pconfig['wpa_mode']: '2',
['1' => 'WPA', '2' => 'WPA2', '3' => 'Both']
));
$section->addInput(new Form_Select(
'wpa_key_mgmt',
'WPA Key Management Mode',
$pconfig['wpa_key_mgmt'],
['WPA-PSK' => 'Pre-Shared Key', 'WPA-EAP' => 'Extensible Authentication Protocol', 'WPA-PSK WPA-EAP' => 'Both']
));
$section->addInput(new Form_Select(
'wpa_pairwise',
'WPA Pairwise',
(isset($pconfig['wpa_pairwise'])) ? $pconfig['wpa_pairwise']:'CCMP',
['CCMP TKIP' => 'Both', 'CCMP' => 'AES (recommended)', 'TKIP' => 'TKIP']
));
$section->addInput(new Form_Input(
'wpa_group_rekey',
'WPA Pre-Shared Key',
'number',
$pconfig['wpa_group_rekey'] ? $pconfig['wpa_group_rekey'] : "60",
['min' => '1', 'max' => 9999]
))->setHelp('Specified in seconds. Allowed values are 1-9999. Must be shorter than Master Key Regeneration time');
$section->addInput(new Form_Input(
'wpa_gmk_rekey',
'Master Key Regeneration',
'number',
$pconfig['wpa_gmk_rekey'] ? $pconfig['wpa_gmk_rekey'] : "3600",
['min' => '1', 'max' => 9999]
))->setHelp('Specified in seconds. Allowed values are 1-9999. Must be longer than Key Rotation time');
$section->addInput(new Form_Checkbox(
'wpa_strict_rekey',
'Strict Key Regeneration',
'Force the AP to rekey whenever a client disassociates',
$pconfig['wpa_strict_rekey'],
'yes'
));
$form->add($section);
$section = new Form_Section('802.1x RADIUS options');
$section->addInput(new Form_Checkbox(
'ieee8021x',
'IEEE802.1X',
'Enable 802.1X authentication',
$pconfig['ieee8021x'],
'yes'
))->setHelp('This option requires that the "Enable WPA box" is checked');
$group = new Form_Group('Primary 802.1X server');
$group->add(new Form_IpAddress(
'auth_server_addr',
'IP Address',
$pconfig['auth_server_addr']
))->setHelp('IP address. (Commonly a Radius server (FreeRadius, Internet Authentication Services, etc.)');
$group->add(new Form_Input(
'auth_server_port',
'Port',
'number',
$pconfig['auth_server_port']
))->setHelp('Server port. Leave blank for the default port 1812');
$group->add(new Form_Input(
'auth_server_shared_secret',
'Shared secret',
'number',
$pconfig['auth_server_shared_secret']
))->setHelp('Shared secret');
$section->add($group);
$group = new Form_Group('Secondary 802.1X server');
$group->add(new Form_IpAddress(
'auth_server_addr2',
'IP Address',
$pconfig['auth_server_addr2']
))->setHelp('IP address. (Commonly a Radius server (FreeRadius, Internet Authentication Services, etc.)');
$group->add(new Form_Input(
'auth_server_port2',
'Port',
'number',
$pconfig['auth_server_port2']
))->setHelp('Server port. Leave blank for the default port 1812');
$group->add(new Form_Input(
'auth_server_shared_secret2',
'Shared secret',
'number',
$pconfig['auth_server_shared_secret2']
))->setHelp('Shared secret');
$section->add($group);
$section->addInput(new Form_Checkbox(
'rsn_preauth',
'Authentication Roaming Preauth',
null,
$pconfig['rsn_preauth'],
'yes'
));
$form->add($section);
}
$section = new Form_Section('Private networks');
$section->addInput(new Form_Checkbox(
'blockpriv',
'Block private networks',
'',
$pconfig['blockpriv'],
'yes'
))->setHelp('Blocks traffic from IP addresses that are reserved for private networks per RFC 1918 (10/8, 172.16/12, 192.168/16) ' .
' as well as loopback addresses (127/8). You should generally leave this option turned on, unless your WAN network ' .
'lies in such a private address space, too.');
$section->addInput(new Form_Checkbox(
'blockbogons',
'Block bogon networks',
'',
$pconfig['blockbogons'],
'yes'
))->setHelp('Blocks traffic from reserved IP addresses (but not RFC 1918) or not yet assigned by IANA. Bogons are prefixes that should ' .
'never appear in the Internet routing table, and so should not appear as the source address in any packets you receive.' . '
' .
'Note: The update frequency can be changed under System->Advanced Firewall/NAT settings');
$form->add($section);
$form->addGlobal(new Form_Input(
'if',
null,
'hidden',
$if
));
if ($wancfg['if'] == $a_ppps[$pppid]['if']) {
$form->addGlobal(new Form_Input(
'ppp_port',
null,
'hidden',
$pconfig['port']
));
}
$form->addGlobal(new Form_Input(
'ptpid',
null,
'hidden',
$pconfig['ptpid']
));
// Add new gateway modal pop-up
$modal = new Modal('New gateway', 'newgateway', 'large');
$modal->addInput(new Form_Checkbox(
'defaultgw',
'Default',
'Default gateway',
($if == "wan" || $if == "WAN")
));
$modal->addInput(new Form_Input(
'name',
'Gateway name',
'text',
$wancfg['descr'] . "GW"
));
$modal->addInput(new Form_IpAddress(
'gatewayip',
'Gateway IPv4',
null
));
$modal->addInput(new Form_Input(
'gatewaydescr',
'Description',
'text'
));
$btnaddgw = new Form_Button(
'add',
'Add'
);
$btnaddgw->removeClass('btn-primary')->addClass('btn-success');
$btncnxgw = new Form_Button(
'cnx',
'Cancel'
);
$btncnxgw->removeClass('btn-primary')->addClass('btn-default');
$modal->addInput(new Form_StaticText(
null,
$btnaddgw . $btncnxgw
));
$form->add($modal);
print($form);
?>