diff options
author | Renato Botelho <renato@netgate.com> | 2015-08-26 15:12:02 -0300 |
---|---|---|
committer | Renato Botelho <renato@netgate.com> | 2015-08-26 15:12:02 -0300 |
commit | 03b19a93f4d8d870507ee96121cee4acd748dd2a (patch) | |
tree | 71a34e9e7e73d13de21cb4ad831799fb10c30df4 /src/usr/local/www/services_dhcpv6.php | |
parent | 7f410a121522c5d0e2660256ae50c1fde1df3645 (diff) | |
parent | 30ce58ac1ea27b758d5112cb5a3b190c9760f010 (diff) | |
download | pfsense-03b19a93f4d8d870507ee96121cee4acd748dd2a.zip pfsense-03b19a93f4d8d870507ee96121cee4acd748dd2a.tar.gz |
Merge branch 'master' into bootstrap
Diffstat (limited to 'src/usr/local/www/services_dhcpv6.php')
-rw-r--r-- | src/usr/local/www/services_dhcpv6.php | 1027 |
1 files changed, 1027 insertions, 0 deletions
diff --git a/src/usr/local/www/services_dhcpv6.php b/src/usr/local/www/services_dhcpv6.php new file mode 100644 index 0000000..b8a4909 --- /dev/null +++ b/src/usr/local/www/services_dhcpv6.php @@ -0,0 +1,1027 @@ +<?php +/* $Id$ */ +/* + services_dhcpv6.php + parts of m0n0wall (http://m0n0.ch/wall) + + Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>. + All rights reserved. + + part of pfSense (https://www.pfsense.org) + Copyright (C) 2010 Seth Mos <seth.mos@dds.nl>. + Copyright (C) 2013-2015 Electric Sheep Fencing, LP + All rights reserved. + + Redistribution and use in source and binary forms, with or without + modification, are permitted provided that the following conditions are met: + + 1. Redistributions of source code must retain the above copyright notice, + this list of conditions and the following disclaimer. + + 2. Redistributions in binary form must reproduce the above copyright + notice, this list of conditions and the following disclaimer in the + documentation and/or other materials provided with the distribution. + + THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES, + INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY + AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE + AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, + OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF + SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS + INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN + CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) + ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE + POSSIBILITY OF SUCH DAMAGE. +*/ +/* + pfSense_BUILDER_BINARIES: /bin/rm + pfSense_MODULE: interfaces +*/ + +##|+PRIV +##|*IDENT=page-services-dhcpv6server +##|*NAME=Services: DHCPv6 server page +##|*DESCR=Allow access to the 'Services: DHCPv6 server' page. +##|*MATCH=services_dhcpv6.php* +##|-PRIV + +require("guiconfig.inc"); +require_once("filter.inc"); + +if (!$g['services_dhcp_server_enable']) { + header("Location: /"); + exit; +} + +/* Fix failover DHCP problem + * http://article.gmane.org/gmane.comp.security.firewalls.pfsense.support/18749 + */ +ini_set("memory_limit", "64M"); + +$if = $_GET['if']; +if ($_POST['if']) { + $if = $_POST['if']; +} + +/* if OLSRD is enabled, allow WAN to house DHCP. */ +if ($config['installedpackages']['olsrd']) { + foreach ($config['installedpackages']['olsrd']['config'] as $olsrd) { + if ($olsrd['enable']) { + $is_olsr_enabled = true; + break; + } + } +} + +$iflist = get_configured_interface_with_descr(); +$iflist = array_merge($iflist, get_configured_pppoe_server_interfaces()); + +/* set the starting interface */ +if (!$if || !isset($iflist[$if])) { + foreach ($iflist as $ifent => $ifname) { + $oc = $config['interfaces'][$ifent]; + if ((is_array($config['dhcpdv6'][$ifent]) && !isset($config['dhcpdv6'][$ifent]['enable']) && !(is_ipaddrv6($oc['ipaddrv6']) && (!is_linklocal($oc['ipaddrv6'])))) || + (!is_array($config['dhcpdv6'][$ifent]) && !(is_ipaddrv6($oc['ipaddrv6']) && (!is_linklocal($oc['ipaddrv6']))))) { + continue; + } + $if = $ifent; + break; + } +} + +if (is_array($config['dhcpdv6'][$if])) { + /* DHCPv6 */ + if (is_array($config['dhcpdv6'][$if]['range'])) { + $pconfig['range_from'] = $config['dhcpdv6'][$if]['range']['from']; + $pconfig['range_to'] = $config['dhcpdv6'][$if]['range']['to']; + } + if (is_array($config['dhcpdv6'][$if]['prefixrange'])) { + $pconfig['prefixrange_from'] = $config['dhcpdv6'][$if]['prefixrange']['from']; + $pconfig['prefixrange_to'] = $config['dhcpdv6'][$if]['prefixrange']['to']; + $pconfig['prefixrange_length'] = $config['dhcpdv6'][$if]['prefixrange']['prefixlength']; + } + $pconfig['deftime'] = $config['dhcpdv6'][$if]['defaultleasetime']; + $pconfig['maxtime'] = $config['dhcpdv6'][$if]['maxleasetime']; + $pconfig['domain'] = $config['dhcpdv6'][$if]['domain']; + $pconfig['domainsearchlist'] = $config['dhcpdv6'][$if]['domainsearchlist']; + list($pconfig['wins1'], $pconfig['wins2']) = $config['dhcpdv6'][$if]['winsserver']; + list($pconfig['dns1'], $pconfig['dns2'], $pconfig['dns3'], $pconfig['dns4']) = $config['dhcpdv6'][$if]['dnsserver']; + $pconfig['enable'] = isset($config['dhcpdv6'][$if]['enable']); + $pconfig['ddnsdomain'] = $config['dhcpdv6'][$if]['ddnsdomain']; + $pconfig['ddnsdomainprimary'] = $config['dhcpdv6'][$if]['ddnsdomainprimary']; + $pconfig['ddnsdomainkeyname'] = $config['dhcpdv6'][$if]['ddnsdomainkeyname']; + $pconfig['ddnsdomainkey'] = $config['dhcpdv6'][$if]['ddnsdomainkey']; + $pconfig['ddnsupdate'] = isset($config['dhcpdv6'][$if]['ddnsupdate']); + list($pconfig['ntp1'], $pconfig['ntp2']) = $config['dhcpdv6'][$if]['ntpserver']; + $pconfig['tftp'] = $config['dhcpdv6'][$if]['tftp']; + $pconfig['ldap'] = $config['dhcpdv6'][$if]['ldap']; + $pconfig['netboot'] = isset($config['dhcpdv6'][$if]['netboot']); + $pconfig['bootfile_url'] = $config['dhcpdv6'][$if]['bootfile_url']; + $pconfig['netmask'] = $config['dhcpdv6'][$if]['netmask']; + $pconfig['numberoptions'] = $config['dhcpdv6'][$if]['numberoptions']; + $pconfig['dhcpv6leaseinlocaltime'] = $config['dhcpdv6'][$if]['dhcpv6leaseinlocaltime']; + if (!is_array($config['dhcpdv6'][$if]['staticmap'])) { + $config['dhcpdv6'][$if]['staticmap'] = array(); + } + $a_maps = &$config['dhcpdv6'][$if]['staticmap']; +} + +$ifcfgip = get_interface_ipv6($if); +$ifcfgsn = get_interface_subnetv6($if); + +/* set the enabled flag which will tell us if DHCP relay is enabled + * on any interface. We will use this to disable DHCP server since + * the two are not compatible with each other. + */ + +$dhcrelay_enabled = false; +$dhcrelaycfg = $config['dhcrelay6']; + +if (is_array($dhcrelaycfg)) { + foreach ($dhcrelaycfg as $dhcrelayif => $dhcrelayifconf) { + if (isset($dhcrelayifconf['enable']) && isset($iflist[$dhcrelayif]) && + (!link_interface_to_bridge($dhcrelayif))) { + $dhcrelay_enabled = true; + } + } +} + +if ($_POST) { + unset($input_errors); + + $old_dhcpdv6_enable = ($pconfig['enable'] == true); + $new_dhcpdv6_enable = ($_POST['enable'] ? true : false); + $dhcpdv6_enable_changed = ($old_dhcpdv6_enable != $new_dhcpdv6_enable); + + $pconfig = $_POST; + + $numberoptions = array(); + for ($x = 0; $x < 99; $x++) { + if (isset($_POST["number{$x}"]) && ctype_digit($_POST["number{$x}"])) { + $numbervalue = array(); + $numbervalue['number'] = htmlspecialchars($_POST["number{$x}"]); + $numbervalue['value'] = htmlspecialchars($_POST["value{$x}"]); + $numberoptions['item'][] = $numbervalue; + } + } + // Reload the new pconfig variable that the forum uses. + $pconfig['numberoptions'] = $numberoptions; + + /* input validation */ + if ($_POST['enable']) { + $reqdfields = explode(" ", "range_from range_to"); + $reqdfieldsn = array(gettext("Range begin"), gettext("Range end")); + + do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors); + + if (($_POST['prefixrange_from'] && !is_ipaddrv6($_POST['prefixrange_from']))) { + $input_errors[] = gettext("A valid range must be specified."); + } + if (($_POST['prefixrange_to'] && !is_ipaddrv6($_POST['prefixrange_to']))) { + $input_errors[] = gettext("A valid prefix range must be specified."); + } + if (($_POST['range_from'] && !is_ipaddrv6($_POST['range_from']))) { + $input_errors[] = gettext("A valid range must be specified."); + } + if (($_POST['range_to'] && !is_ipaddrv6($_POST['range_to']))) { + $input_errors[] = gettext("A valid range must be specified."); + } + if (($_POST['gateway'] && !is_ipaddrv6($_POST['gateway']))) { + $input_errors[] = gettext("A valid IPv6 address must be specified for the gateway."); + } + if (($_POST['dns1'] && !is_ipaddrv6($_POST['dns1'])) || + ($_POST['dns2'] && !is_ipaddrv6($_POST['dns2'])) || + ($_POST['dns3'] && !is_ipaddrv6($_POST['dns3'])) || + ($_POST['dns4'] && !is_ipaddrv6($_POST['dns4']))) { + $input_errors[] = gettext("A valid IPv6 address must be specified for each of the DNS servers."); + } + + if ($_POST['deftime'] && (!is_numeric($_POST['deftime']) || ($_POST['deftime'] < 60))) { + $input_errors[] = gettext("The default lease time must be at least 60 seconds."); + } + if ($_POST['maxtime'] && (!is_numeric($_POST['maxtime']) || ($_POST['maxtime'] < 60) || ($_POST['maxtime'] <= $_POST['deftime']))) { + $input_errors[] = gettext("The maximum lease time must be at least 60 seconds and higher than the default lease time."); + } + if (($_POST['ddnsdomain'] && !is_domain($_POST['ddnsdomain']))) { + $input_errors[] = gettext("A valid domain name must be specified for the dynamic DNS registration."); + } + if (($_POST['ddnsdomain'] && !is_ipaddrv4($_POST['ddnsdomainprimary']))) { + $input_errors[] = gettext("A valid primary domain name server IPv4 address must be specified for the dynamic domain name."); + } + if (($_POST['ddnsdomainkey'] && !$_POST['ddnsdomainkeyname']) || + ($_POST['ddnsdomainkeyname'] && !$_POST['ddnsdomainkey'])) { + $input_errors[] = gettext("You must specify both a valid domain key and key name."); + } + if ($_POST['domainsearchlist']) { + $domain_array=preg_split("/[ ;]+/", $_POST['domainsearchlist']); + foreach ($domain_array as $curdomain) { + if (!is_domain($curdomain)) { + $input_errors[] = gettext("A valid domain search list must be specified."); + break; + } + } + } + + if (($_POST['ntp1'] && !is_ipaddrv6($_POST['ntp1'])) || ($_POST['ntp2'] && !is_ipaddrv6($_POST['ntp2']))) { + $input_errors[] = gettext("A valid IPv6 address must be specified for the primary/secondary NTP servers."); + } + if (($_POST['domain'] && !is_domain($_POST['domain']))) { + $input_errors[] = gettext("A valid domain name must be specified for the DNS domain."); + } + if ($_POST['tftp'] && !is_ipaddr($_POST['tftp']) && !is_domain($_POST['tftp']) && !is_URL($_POST['tftp'])) { + $input_errors[] = gettext("A valid IPv6 address or hostname must be specified for the TFTP server."); + } + if (($_POST['bootfile_url'] && !is_URL($_POST['bootfile_url']))) { + $input_errors[] = gettext("A valid URL must be specified for the network bootfile."); + } + + // Disallow a range that includes the virtualip + if (is_array($config['virtualip']['vip'])) { + foreach ($config['virtualip']['vip'] as $vip) { + if ($vip['interface'] == $if) { + if ($vip['subnetv6'] && is_inrange_v6($vip['subnetv6'], $_POST['range_from'], $_POST['range_to'])) { + $input_errors[] = sprintf(gettext("The subnet range cannot overlap with virtual IPv6 address %s."), $vip['subnetv6']); + } + } + } + } + + $noip = false; + if (is_array($a_maps)) { + foreach ($a_maps as $map) { + if (empty($map['ipaddrv6'])) { + $noip = true; + } + } + } + if (!$input_errors) { + /* make sure the range lies within the current subnet */ + $subnet_start = gen_subnetv6($ifcfgip, $ifcfgsn); + $subnet_end = gen_subnetv6_max($ifcfgip, $ifcfgsn); + + if (is_ipaddrv6($ifcfgip)) { + if ((!is_inrange_v6($_POST['range_from'], $subnet_start, $subnet_end)) || + (!is_inrange_v6($_POST['range_to'], $subnet_start, $subnet_end))) { + $input_errors[] = gettext("The specified range lies outside of the current subnet."); + } + } + /* "from" cannot be higher than "to" */ + if (inet_pton($_POST['range_from']) > inet_pton($_POST['range_to'])) { + $input_errors[] = gettext("The range is invalid (first element higher than second element)."); + } + + /* make sure that the DHCP Relay isn't enabled on this interface */ + if (isset($config['dhcrelay'][$if]['enable'])) { + $input_errors[] = sprintf(gettext("You must disable the DHCP relay on the %s interface before enabling the DHCP server."), $iflist[$if]); + } + + + /* Verify static mappings do not overlap: + - available DHCP range + - prefix delegation range (FIXME: still need to be completed) */ + $dynsubnet_start = inet_pton($_POST['range_from']); + $dynsubnet_end = inet_pton($_POST['range_to']); + + if (is_array($a_maps)) { + foreach ($a_maps as $map) { + if (empty($map['ipaddrv6'])) { + continue; + } + if ((inet_pton($map['ipaddrv6']) > $dynsubnet_start) && + (inet_pton($map['ipaddrv6']) < $dynsubnet_end)) { + $input_errors[] = sprintf(gettext("The DHCP range cannot overlap any static DHCP mappings.")); + break; + } + } + } + } + } + + if (!$input_errors) { + if (!is_array($config['dhcpdv6'][$if])) { + $config['dhcpdv6'][$if] = array(); + } + if (!is_array($config['dhcpdv6'][$if]['range'])) { + $config['dhcpdv6'][$if]['range'] = array(); + } + if (!is_array($config['dhcpdv6'][$if]['prefixrange'])) { + $config['dhcpdv6'][$if]['prefixrange'] = array(); + } + + $config['dhcpdv6'][$if]['range']['from'] = $_POST['range_from']; + $config['dhcpdv6'][$if]['range']['to'] = $_POST['range_to']; + $config['dhcpdv6'][$if]['prefixrange']['from'] = $_POST['prefixrange_from']; + $config['dhcpdv6'][$if]['prefixrange']['to'] = $_POST['prefixrange_to']; + $config['dhcpdv6'][$if]['prefixrange']['prefixlength'] = $_POST['prefixrange_length']; + $config['dhcpdv6'][$if]['defaultleasetime'] = $_POST['deftime']; + $config['dhcpdv6'][$if]['maxleasetime'] = $_POST['maxtime']; + $config['dhcpdv6'][$if]['netmask'] = $_POST['netmask']; + + unset($config['dhcpdv6'][$if]['winsserver']); + + unset($config['dhcpdv6'][$if]['dnsserver']); + if ($_POST['dns1']) { + $config['dhcpdv6'][$if]['dnsserver'][] = $_POST['dns1']; + } + if ($_POST['dns2']) { + $config['dhcpdv6'][$if]['dnsserver'][] = $_POST['dns2']; + } + if ($_POST['dns3']) { + $config['dhcpdv6'][$if]['dnsserver'][] = $_POST['dns3']; + } + if ($_POST['dns4']) { + $config['dhcpdv6'][$if]['dnsserver'][] = $_POST['dns4']; + } + + $config['dhcpdv6'][$if]['domain'] = $_POST['domain']; + $config['dhcpdv6'][$if]['domainsearchlist'] = $_POST['domainsearchlist']; + $config['dhcpdv6'][$if]['enable'] = ($_POST['enable']) ? true : false; + $config['dhcpdv6'][$if]['ddnsdomain'] = $_POST['ddnsdomain']; + $config['dhcpdv6'][$if]['ddnsdomainprimary'] = $_POST['ddnsdomainprimary']; + $config['dhcpdv6'][$if]['ddnsdomainkeyname'] = $_POST['ddnsdomainkeyname']; + $config['dhcpdv6'][$if]['ddnsdomainkey'] = $_POST['ddnsdomainkey']; + $config['dhcpdv6'][$if]['ddnsupdate'] = ($_POST['ddnsupdate']) ? true : false; + + unset($config['dhcpdv6'][$if]['ntpserver']); + if ($_POST['ntp1']) { + $config['dhcpdv6'][$if]['ntpserver'][] = $_POST['ntp1']; + } + if ($_POST['ntp2']) { + $config['dhcpdv6'][$if]['ntpserver'][] = $_POST['ntp2']; + } + + $config['dhcpdv6'][$if]['tftp'] = $_POST['tftp']; + $config['dhcpdv6'][$if]['ldap'] = $_POST['ldap']; + $config['dhcpdv6'][$if]['netboot'] = ($_POST['netboot']) ? true : false; + $config['dhcpdv6'][$if]['bootfile_url'] = $_POST['bootfile_url']; + $config['dhcpdv6'][$if]['dhcpv6leaseinlocaltime'] = $_POST['dhcpv6leaseinlocaltime']; + + // Handle the custom options rowhelper + if (isset($config['dhcpdv6'][$if]['numberoptions']['item'])) { + unset($config['dhcpdv6'][$if]['numberoptions']['item']); + } + + $config['dhcpdv6'][$if]['numberoptions'] = $numberoptions; + + write_config(); + + $retval = 0; + $retvaldhcp = 0; + $retvaldns = 0; + /* Stop DHCPv6 so we can cleanup leases */ + killbypid("{$g['dhcpd_chroot_path']}{$g['varrun_path']}/dhcpdv6.pid"); + // dhcp_clean_leases(); + /* dnsmasq_configure calls dhcpd_configure */ + /* no need to restart dhcpd twice */ + if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstatic'])) { + $retvaldns = services_dnsmasq_configure(); + if ($retvaldns == 0) { + clear_subsystem_dirty('hosts'); + clear_subsystem_dirty('staticmaps'); + } + } else if (isset($config['unbound']['enable']) && isset($config['unbound']['regdhcpstatic'])) { + $retvaldns = services_unbound_configure(); + if ($retvaldns == 0) { + clear_subsystem_dirty('unbound'); + clear_subsystem_dirty('staticmaps'); + } + } else { + $retvaldhcp = services_dhcpd_configure(); + if ($retvaldhcp == 0) { + clear_subsystem_dirty('staticmaps'); + } + } + if ($dhcpdv6_enable_changed) { + $retvalfc = filter_configure(); + } + if ($retvaldhcp == 1 || $retvaldns == 1 || $retvalfc == 1) { + $retval = 1; + } + $savemsg = get_std_save_message($retval); + } +} + +if ($_GET['act'] == "del") { + if ($a_maps[$_GET['id']]) { + unset($a_maps[$_GET['id']]); + write_config(); + if (isset($config['dhcpdv6'][$if]['enable'])) { + mark_subsystem_dirty('staticmapsv6'); + if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstaticv6'])) { + mark_subsystem_dirty('hosts'); + } + } + header("Location: services_dhcpv6.php?if={$if}"); + exit; + } +} + +// Delete a row in the options table +if($_GET['act'] == "delopt") { + $idx = $_GET['id']; + + if($pconfig['numberoptions'] && is_array($pconfig['numberoptions']['item'][$idx])) { + unset($pconfig['numberoptions']['item'][$idx]); + } +} + +// Add an option row +if($_GET['act'] == "addopt") { + if(!is_array($pconfig['numberoptions']['item'])) + $pconfig['numberoptions']['item'] = array(); + + array_push($pconfig['numberoptions']['item'], array('number' => null, 'value' => null)); +} + +$closehead = false; +$pgtitle = array(gettext("Services"), gettext("DHCPv6 server")); +$shortcut_section = "dhcp6"; + +include("head.inc"); + +if ($input_errors) + print_input_errors($input_errors); + +if ($savemsg) + print_info_box($savemsg, 'success'); + +if ($dhcrelay_enabled) { + print_info_box(gettext("DHCP Relay is currently enabled. Cannot enable the DHCP Server service while the DHCP Relay is enabled on any interface."), 'danger'); + include("foot.inc"); + exit; +} + +if (is_subsystem_dirty('staticmaps')) + print_info_box_np(gettext('The static mapping configuration has been changed') . '.<br />' . gettext('You must apply the changes in order for them to take effect.')); + +/* active tabs */ +$tab_array = array(); +$tabscounter = 0; +$i = 0; +foreach ($iflist as $ifent => $ifname) { + $oc = $config['interfaces'][$ifent]; + if ((is_array($config['dhcpdv6'][$ifent]) && !isset($config['dhcpdv6'][$ifent]['enable']) && !(is_ipaddrv6($oc['ipaddrv6']) && (!is_linklocal($oc['ipaddrv6'])))) || + (!is_array($config['dhcpdv6'][$ifent]) && !(is_ipaddrv6($oc['ipaddrv6']) && (!is_linklocal($oc['ipaddrv6']))))) + continue; + + if ($ifent == $if) + $active = true; + else + $active = false; + + $tab_array[] = array($ifname, $active, "services_dhcpv6.php?if={$ifent}"); + $tabscounter++; +} +/* tack on PPPoE or PPtP servers here */ +/* pppoe server */ +if (is_array($config['pppoes']['pppoe'])) { + foreach($config['pppoes']['pppoe'] as $pppoe) { + if ($pppoe['mode'] == "server") { + $ifent = "poes". $pppoe['pppoeid']; + $ifname = strtoupper($ifent); + + if ($ifent == $if) + $active = true; + else + $active = false; + + $tab_array[] = array($ifname, $active, "services_dhcpv6.php?if={$ifent}"); + $tabscounter++; + } + } +} + +if (empty($tabs_array)) { + print_info_box(gettext("The DHCPv6 Server can only be enabled on interfaces configured with a static IPv6 address. This system has none."), 'danger'); + include("foot.inc"); + exit; +} + +$tab_array = array(); +$tab_array[] = array(gettext("DHCPv6 Server"), true, "services_dhcpv6.php?if={$if}"); +$tab_array[] = array(gettext("Router Advertisements"), false, "services_router_advertisements.php?if={$if}"); +display_top_tabs($tab_array); + +require('classes/Form.class.php'); + +$form = new Form(new Form_Button( + 'Submit', + 'Save' +)); + +$section = new Form_Section('DHCPv6 Options'); + +$section->addInput(new Form_Checkbox( + 'enable', + 'DHCPv6 Server', + 'Enable DHCPv6 server on interface ' . $iflist[$if], + $pconfig['enable'] +))->toggles('.form-group:not(:first-child)'); + +if(is_ipaddrv6($ifcfgip)) { + + $section->addInput(new Form_StaticText( + 'Subnet', + gen_subnetv6($ifcfgip, $ifcfgsn) + )); + + $section->addInput(new Form_StaticText( + 'Subnet Mask', + $ifcfgsn . ' bits' + )); + + $section->addInput(new Form_StaticText( + 'Available Range', + $range_from = gen_subnetv6($ifcfgip, $ifcfgsn) . ' to ' . gen_subnetv6_max($ifcfgip, $ifcfgsn) + )); +} + +if($is_olsr_enabled) { + $section->addInput(new Form_Select( + 'netmask', + 'Subnetmask', + $pconfig['netmask'], + array_combine(range(128, 1, -1), range(128, 1, -1)) + )); +} + +$f1 = new Form_Input( + 'range_from', + null, + 'text', + $pconfig['range_from'] +); + +$f1->setHelp('To'); + +$f2 = new Form_Input( + 'range_to', + null, + 'text', + $pconfig['range_to'] +); + +$f2->setHelp('From'); + +$group = new Form_Group('Range'); + +$group->add($f1); +$group->add($f2); + +$section->add($group); + +$f1 = new Form_Input( + 'prefix_from', + null, + 'text', + $pconfig['prefix_from'] +); + +$f1->setHelp('To'); + +$f2 = new Form_Input( + 'prefix_to', + null, + 'text', + $pconfig['prefix_to'] +); + +$f2->setHelp('From'); +$group = new Form_Group('Prefix Delegation Range'); + +$group->add($f1); +$group->add($f2); + +$section->add($group); + +$section->addInput(new Form_Select( + 'prefixrange_length', + 'Prefix Delegation Size', + $pconfig['prefixrange_length'], + array( + '48' => '48', + '52' => '52', + '56' => '56', + '60' => '60', + '62' => '62', + '63' => '63', + '64' => '64' + ) +))->setHelp('You can define a Prefix range here for DHCP Prefix Delegation. This allows for assigning networks to subrouters. The start and end of the range must end on boundaries of the prefix delegation size.'); + +$group = new Form_Group('DNS Servers'); + +for($i=1;$i<=4; $i++) { + $group->add(new Form_input( + 'dns' . $i, + null, + 'text', + $pconfig['dns' . $i] + ))->setHelp('DNS ' . $i); +} + +$group->setHelp('Leave blank to use the system default DNS servers,this interface\'s IP if DNS forwarder is enabled, or the servers configured on the "General" page.'); +$section->add($group); + +$section->addInput(new Form_Input( + 'domain', + 'Domain Name', + 'text', + $pconfig['domain'] +))->setHelp('The default is to use the domain name of this system as the default domain name provided by DHCP. You may specify an alternate domain name here. '); + +$section->addInput(new Form_Input( + 'domainsearchlist', + 'Domain search list', + 'text', + $pconfig['domainsearchlist'] +))->setHelp('The DHCP server can optionally provide a domain search list. Use the semicolon character as separator'); + +$section->addInput(new Form_Input( + 'deftime', + 'Default lease time', + 'text', + $pconfig['deftime'] +))->setHelp('Seconds . Used for clients that do not ask for a specific expiration time. ' . ' <br />' . + 'The default is 7200 seconds.'); + +$section->addInput(new Form_Input( + 'maxtime', + 'Max lease time', + 'text', + $pconfig['maxtime'] +))->setHelp('Maximum lease time for clients that ask for a specific expiration time.' . ' <br />' . + 'The default is 86400 seconds.'); + +$section->addInput(new Form_Checkbox( + 'dhcpv6leaseinlocaltime', + 'Time Format Change', + 'Change DHCPv6 display lease time from UTC to local time', + $pconfig['dhcpv6leaseinlocaltime'] +))->setHelp('By default DHCPv6 leases are displayed in UTC time. ' . + 'By checking this box DHCPv6 lease time will be displayed in local time and set to time zone selected. ' . + 'This will be used for all DHCPv6 interfaces lease time.'); + +$btndyndns = new Form_Button( + 'btndyndns', + 'Advanced' +); + +$btndyndns->removeClass('btn-primary')->addClass('btn-default btn-sm'); + +$section->addInput(new Form_StaticText( + 'Dynamic DNS', + $btndyndns . ' ' . 'Show dynamic DNS settings' +)); + +$section->addInput(new Form_Checkbox( + 'ddnsupdate', + 'DHCP Registration', + 'Enable registration of DHCP client names in DNS.', + $pconfig['ddnsupdate'] +)); + +$section->addInput(new Form_Input( + 'ddnsdomain', + 'DDNS Domain', + 'text', + $pconfig['ddnsdomain'] +))->setHelp('Leave blank to disable dynamic DNS registration. Enter the dynamic DNS domain which will be used to register client names in the DNS server.'); + +$section->addInput(new Form_IpAddress( + 'ddnsdomainprimary', + 'DDNS Server IP', + $pconfig['ddnsdomainprimary'] +))->setHelp('Enter the primary domain name server IP address for the dynamic domain name.'); + +$section->addInput(new Form_Input( + 'ddnsdomainkeyname', + 'DDNS Domain Key name', + 'text', + $pconfig['ddnsdomainkeyname'] +))->setHelp('Enter the dynamic DNS domain key name which will be used to register client names in the DNS server.'); + +$section->addInput(new Form_Input( + 'ddnsdomainkey', + 'DDNS Domain Key secret', + 'text', + $pconfig['ddnsdomainkey'] +))->setHelp('Enter the dynamic DNS domain key secret which will be used to register client names in the DNS server.'); + +$btnntp = new Form_Button( + 'btnntp', + 'Advanced' +); + +$btnntp->removeClass('btn-primary')->addClass('btn-default btn-sm'); + +$section->addInput(new Form_StaticText( + 'NTP servers', + $btnntp . ' ' . 'Show NTP Configuration' +)); + +$group = new Form_Group('NTP Servers'); + +$group->add(new Form_Input( + 'ntp1', + 'NTP Server 1', + 'text', + $pconfig['ntp1'], + ['placeholder' => 'NTP 1'] +)); + +$group->add(new Form_Input( + 'ntp2', + 'NTP Server 1', + 'text', + $pconfig['ntp2'], + ['placeholder' => 'NTP 2'] +)); + +$group->addClass('ntpclass'); + +$section->add($group); + +$btnldap = new Form_Button( + 'btnldap', + 'Advanced' +); + +$btnldap->removeClass('btn-primary')->addClass('btn-default btn-sm'); + +$section->addInput(new Form_StaticText( + 'LDAP', + $btnldap . ' ' . 'Show LDAP Configuration' +)); + +$section->addInput(new Form_Input( + 'ldap', + 'LDAP URI', + 'text', + $pconfig['ldap'] +)); + +$btnnetboot = new Form_Button( + 'btnnetboot', + 'Advanced' +); + +$btnnetboot->removeClass('btn-primary')->addClass('btn-default btn-sm'); + +$section->addInput(new Form_StaticText( + 'Network booting', + $btnnetboot . ' ' . 'Show Netwok booting' +)); + +$section->addInput(new Form_Checkbox( + 'shownetboot', + 'Network booting', + 'Enable Network Booting', + $pconfig['shownetboot'] +)); + +$section->addInput(new Form_Input( + 'bootfile_url', + 'Bootfile URL', + 'text', + $pconfig['bootfile_url'] +)); + +$btnadnl = new Form_Button( + 'btnadnl', + 'Advanced' +); + +$btnadnl->removeClass('btn-primary')->addClass('btn-default btn-sm'); + +$section->addInput(new Form_StaticText( + 'Additional BOOTP/DHCP Options', + $btnadnl . ' ' . 'Aditional BOOTP/DHCP Options' +)); + +$form->add($section); + +$title = 'Show Additional BOOTP/DHCP Options'; + +if($pconfig['numberoptions']) { + $counter = 0; + $last = count($pconfig['numberoptions']['item']) - 1; + + foreach($pconfig['numberoptions']['item'] as $item) { + $group = new Form_Group(null); + + $group->add(new Form_Input( + 'number' . $counter, + null, + 'text', + $item['number'] + ))->setHelp($counter == $last ? 'Number':null); + + $group->add(new Form_Input( + 'value' . $counter, + null, + 'text', + $item['value'] + ))->setHelp($counter == $last ? 'Value':null); + + $btn = new Form_Button( + 'btn' . $counter, + 'Delete', + 'services_dhcpv6.php?if=' . $if . '&act=delopt' . '&id=' . $counter + ); + + $btn->removeClass('btn-primary')->addClass('btn-danger btn-xs adnlopt'); + $group->addClass('adnlopt'); + $group->add($btn); + $section->add($group); + $counter++; + } +} + +$btnaddopt = new Form_Button( + 'btnaddopt', + 'Add Option', + 'services_dhcpv6.php?if=' . $if . '&act=addopt' +); + +$btnaddopt->removeClass('btn-primary')->addClass('btn-success btn-sm'); + +$section->addInput($btnaddopt); + +$section->addInput(new Form_Input( + 'if', + null, + 'hidden', + $if +)); + +print($form); + +print_info_box(gettext('The DNS servers entered in ') . '<a href="system.php">' . gettext(' System: General setup') . '</a>' . + gettext(' (or the ') . '<a href="services_dnsmasq.php"/>' . gettext('DNS forwarder') . '</a>, ' . gettext('if enabled) ') . + gettext('will be assigned to clients by the DHCP server.') . '<br />' . + gettext('The DHCP lease table can be viewed on the ') . '<a href="status_dhcpv6_leases.php">' . + gettext('Status: DHCPv6 leases') . '</a>' . gettext(' page.')); +?> + +<div class="panel panel-default"> + <div class="panel-heading"><h2 class="panel-title">DHCPv6 Static Mappings for this interface.</h2></div> + <div class="panel-body table-responsive"> + <table class="table table-striped table-hover table-condensed"> + <thead> + <tr> + <th><?=gettext("DUID")?></th> + <th><?=gettext("IPv6 address")?></th> + <th><?=gettext("Hostname")?></th> + <th><?=gettext("Description")?></th> + <th><!-- Buttons --></th> + </tr> + </thead> + <tbody> +<?php +if(is_array($a_maps)): + $i = 0; + foreach ($a_maps as $mapent): + if($mapent['duid'] != "" or $mapent['ipaddrv6'] != ""): +?> + <tr> + <td> + <?=htmlspecialchars($mapent['duid'])?> + </td> + <td> + <?=htmlspecialchars($mapent['ipaddrv6'])?> + </td> + <td> + <?=htmlspecialchars($mapent['hostname'])?> + </td> + <td> + <?=htmlspecialchars($mapent['descr'])?> + </td> + <td> + <a href="services_dhcpv6_edit.php?if=<?=$if?>&id=<?=$i?>" class="btn btn-info btn-xs"/>Edit</a> + <a href="services_dhcpv6.php?if=<?=$if?>&act=del&id=<?=$i?>" class="btn btn-danger btn-xs"/>Delete</a> + </td> + </tr> +<?php + endif; + $i++; + endforeach; +endif; +?> + </tbody> + </table> + </div> +</div> + +<nav class="action-buttons"> + <a href="services_dhcpv6_edit.php?if=<?=$if?>" class="btn btn-sm btn-success"/>Add</a> +</nav> + +<script> +//<![CDATA[ +events.push(function(){ + // Hides the <div> in which the specified input element lives so that the input, its label and help text are hidden + function hideInput(id, hide) { + if(hide) + $('#' + id).parent().parent('div').addClass('hidden'); + else + $('#' + id).parent().parent('div').removeClass('hidden'); + } + + // Hides the <div> in which the specified icheckbox lives so that the input, its label and help text are hidden + // Checkboxes live inside <label></label> tags so we need another parent level + function hideCheckBox(id, hide) { + if(hide) + $('#' + id).parent().parent().parent('div').addClass('hidden'); + else + $('#' + id).parent().parent().parent('div').removeClass('hidden'); + } + + // Hides all elements of the specified class. This will usually be a section or group + function hideClass(s_class, hide) { + if(hide) + $('.' + s_class).hide(); + else + $('.' + s_class).show(); + } + + function hideDDNS(hide) { + hideCheckBox('ddnsupdate', hide); + hideInput('ddnsdomain', hide); + hideInput('ddnsdomainprimary', hide); + hideInput('ddnsdomainkeyname', hide); + hideInput('ddnsdomainkey', hide); + } + + // Make the ‘Copy My MAC’ button a plain button, not a submit button + $("#btnmymac").prop('type','button'); + + // On click, copy the hidden 'mymac' text to the 'mac' input + $("#btnmymac").click(function() { + $('#mac').val('<?=$mymac?>'); + }); + + // Make the ‘tftp’ button a plain button, not a submit button + $("#btntftp").prop('type','button'); + + // Show tftp controls + $("#btntftp").click(function() { + hideInput('tftp', false); + }); + + // Make the ‘ntp’ button a plain button, not a submit button + $("#btnntp").prop('type','button'); + + // Show ntp controls + $("#btnntp").click(function() { + hideClass('ntpclass', false); + }); + + // Make the ‘ddns’ button a plain button, not a submit button + $("#btndyndns").prop('type','button'); + + // Show ddns controls + $("#btndyndns").click(function() { + hideDDNS(false); + }); + + // Make the ‘ldap’ button a plain button, not a submit button + $("#btnldap").prop('type','button'); + + // Show ldap controls + $("#btnldap").click(function() { + hideInput('ldap', false); + }); + + // Make the ‘netboot’ button a plain button, not a submit button + $("#btnnetboot").prop('type','button'); + + // Show netboot controls + $("#btnnetboot").click(function() { + hideInput('bootfile_url', false); + hideCheckBox('shownetboot', false); + }); + + // Make the ‘aditional options’ button a plain button, not a submit button + $("#btnadnl").prop('type','button'); + + // Show aditional controls + $("#btnadnl").click(function() { + hideClass('adnlopt', false); + hideInput('btnaddopt', false); + }); + + // On initial load + hideDDNS(true); + hideClass('ntpclass', true); + hideInput('tftp', true); + hideInput('ldap', true); + hideInput('bootfile_url', true); + hideCheckBox('shownetboot', true); + hideClass('adnlopt', true); + hideInput('btnaddopt', true); +}); +//]]> +</script> + +<?php include('foot.inc');
\ No newline at end of file |