Project

General

Profile

Download (56.1 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/* $Id$ */
3
/*
4
	services_dhcp.php
5
	part of m0n0wall (http://m0n0.ch/wall)
6

    
7
	Copyright (C) 2003-2004 Manuel Kasper <mk@neon1.net>.
8
	All rights reserved.
9

    
10
	Redistribution and use in source and binary forms, with or without
11
	modification, are permitted provided that the following conditions are met:
12

    
13
	1. Redistributions of source code must retain the above copyright notice,
14
	   this list of conditions and the following disclaimer.
15

    
16
	2. Redistributions in binary form must reproduce the above copyright
17
	   notice, this list of conditions and the following disclaimer in the
18
	   documentation and/or other materials provided with the distribution.
19

    
20
	THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESS OR IMPLIED WARRANTIES,
21
	INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY
22
	AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
23
	AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
24
	OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
25
	SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
26
	INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
27
	CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
28
	ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
29
	POSSIBILITY OF SUCH DAMAGE.
30
*/
31
/*
32
	pfSense_BUILDER_BINARIES:	/bin/rm
33
	pfSense_MODULE:	interfaces
34
*/
35

    
36
##|+PRIV
37
##|*IDENT=page-services-dhcpserver
38
##|*NAME=Services: DHCP server page
39
##|*DESCR=Allow access to the 'Services: DHCP server' page.
40
##|*MATCH=services_dhcp.php*
41
##|-PRIV
42

    
43
require("guiconfig.inc");
44
require_once("filter.inc");
45

    
46
if(!$g['services_dhcp_server_enable']) {
47
	Header("Location: /");
48
	exit;
49
}
50

    
51
/* This function will remove entries from dhcpd.leases that would otherwise
52
 * overlap with static DHCP reservations. If we don't clean these out,
53
 * then DHCP will print a warning in the logs about a duplicate lease
54
 */
55
function dhcp_clean_leases() {
56
	global $g, $config;
57
	$leasesfile = "{$g['dhcpd_chroot_path']}/var/db/dhcpd.leases";
58
	if (!file_exists($leasesfile))
59
		return;
60
	/* Build list of static MACs */
61
	$staticmacs = array();
62
	foreach($config['interfaces'] as $ifname => $ifarr)
63
		if (is_array($config['dhcpd'][$ifname]['staticmap']))
64
			foreach($config['dhcpd'][$ifname]['staticmap'] as $static)
65
				$staticmacs[] = $static['mac'];
66
	/* Read existing leases */
67
	$leases_contents = explode("\n", file_get_contents($leasesfile));
68
	$newleases_contents = array();
69
	$i=0;
70
	while ($i < count($leases_contents)) {
71
		/* Find a lease definition */
72
		if (substr($leases_contents[$i], 0, 6) == "lease ") {
73
			$templease = array();
74
			$thismac = "";
75
			/* Read to the end of the lease declaration */
76
			do {
77
				if (substr($leases_contents[$i], 0, 20) == "  hardware ethernet ")
78
					$thismac = substr($leases_contents[$i], 20, 17);
79
				$templease[] = $leases_contents[$i];
80
				$i++;
81
			} while ($leases_contents[$i-1] != "}");
82
			/* Check for a matching MAC address and if not present, keep it. */
83
			if (! in_array($thismac, $staticmacs))
84
				$newleases_contents = array_merge($newleases_contents, $templease);
85
		} else {
86
			/* It's a line we want to keep, copy it over. */
87
			$newleases_contents[] = $leases_contents[$i];
88
			$i++;
89
		}
90
	}
91
	/* Write out the new leases file */
92
	$fd = fopen($leasesfile, 'w');
93
	fwrite($fd, implode("\n", $newleases_contents));
94
	fclose($fd);
95
}
96

    
97
$if = $_GET['if'];
98
if (!empty($_POST['if']))
99
	$if = $_POST['if'];
100

    
101
/* if OLSRD is enabled, allow WAN to house DHCP. */
102
if($config['installedpackages']['olsrd']) {
103
	foreach($config['installedpackages']['olsrd']['config'] as $olsrd) {
104
			if($olsrd['enable']) {
105
				$is_olsr_enabled = true;
106
				break;
107
			}
108
	}
109
}
110

    
111
if (!$_GET['if'])
112
	$savemsg = "<b>" . gettext("The DHCP Server can only be enabled on interfaces configured with static IP addresses") . ".<p>" . gettext("Only interfaces configured with a static IP will be shown") . ".</p></b>";
113

    
114
$iflist = get_configured_interface_with_descr();
115

    
116
/* set the starting interface */
117
if (!$if || !isset($iflist[$if])) {
118
	foreach ($iflist as $ifent => $ifname) {
119
		$oc = $config['interfaces'][$ifent];
120
		if ((is_array($config['dhcpd'][$ifent]) && !isset($config['dhcpd'][$ifent]['enable']) && (!is_ipaddrv4($oc['ipaddr']))) ||
121
			(!is_array($config['dhcpd'][$ifent]) && (!is_ipaddrv4($oc['ipaddr']))))
122
			continue;
123
		$if = $ifent;
124
		break;
125
	}
126
}
127

    
128
$act = $_GET['act'];
129
if (!empty($_POST['act']))
130
	$act = $_POST['act'];
131

    
132
$a_pools = array();
133

    
134
if (is_array($config['dhcpd'][$if])){
135
	$pool = $_GET['pool'];
136
	if (is_numeric($_POST['pool']))
137
		$pool = $_POST['pool'];
138

    
139
	// If we have a pool but no interface name, that's not valid. Redirect away.
140
	if (is_numeric($pool) && empty($if)) {
141
		header("Location: services_dhcp.php");
142
		exit;
143
	}
144

    
145
	if (!is_array($config['dhcpd'][$if]['pool']))
146
		$config['dhcpd'][$if]['pool'] = array();
147
	$a_pools = &$config['dhcpd'][$if]['pool'];
148

    
149
	if (is_numeric($pool) && $a_pools[$pool])
150
		$dhcpdconf = &$a_pools[$pool];
151
	elseif ($act == "newpool")
152
		$dhcpdconf = array();
153
	else
154
		$dhcpdconf = &$config['dhcpd'][$if];
155
}
156
if (is_array($dhcpdconf)) {
157
	// Global Options
158
	if (!is_numeric($pool) && !($act == "newpool")) {
159
		$pconfig['enable'] = isset($dhcpdconf['enable']);
160
		$pconfig['staticarp'] = isset($dhcpdconf['staticarp']);
161
		// No reason to specify this per-pool, per the dhcpd.conf man page it needs to be in every
162
		//   pool and should be specified in every pool both nodes share, so we'll treat it as global
163
		$pconfig['failover_peerip'] = $dhcpdconf['failover_peerip'];
164
		$pconfig['dhcpleaseinlocaltime'] = $dhcpdconf['dhcpleaseinlocaltime'];
165
		if (!is_array($dhcpdconf['staticmap']))
166
			$dhcpdconf['staticmap'] = array();
167
		$a_maps = &$dhcpdconf['staticmap'];
168
	} else {
169
		// Options that exist only in pools
170
		$pconfig['descr'] = $dhcpdconf['descr'];
171
	}
172

    
173
	// Options that can be global or per-pool.
174
	if (is_array($dhcpdconf['range'])) {
175
		$pconfig['range_from'] = $dhcpdconf['range']['from'];
176
		$pconfig['range_to'] = $dhcpdconf['range']['to'];
177
	}
178
	$pconfig['deftime'] = $dhcpdconf['defaultleasetime'];
179
	$pconfig['maxtime'] = $dhcpdconf['maxleasetime'];
180
	$pconfig['gateway'] = $dhcpdconf['gateway'];
181
	$pconfig['domain'] = $dhcpdconf['domain'];
182
	$pconfig['domainsearchlist'] = $dhcpdconf['domainsearchlist'];
183
	list($pconfig['wins1'],$pconfig['wins2']) = $dhcpdconf['winsserver'];
184
	list($pconfig['dns1'],$pconfig['dns2']) = $dhcpdconf['dnsserver'];
185
	$pconfig['denyunknown'] = isset($dhcpdconf['denyunknown']);
186
	$pconfig['ddnsdomain'] = $dhcpdconf['ddnsdomain'];
187
	$pconfig['ddnsdomainprimary'] = $dhcpdconf['ddnsdomainprimary'];
188
	$pconfig['ddnsdomainkeyname'] = $dhcpdconf['ddnsdomainkeyname'];
189
	$pconfig['ddnsdomainkey'] = $dhcpdconf['ddnsdomainkey'];
190
	$pconfig['ddnsupdate'] = isset($dhcpdconf['ddnsupdate']);
191
	$pconfig['mac_allow'] = $dhcpdconf['mac_allow'];
192
	$pconfig['mac_deny'] = $dhcpdconf['mac_deny'];
193
	list($pconfig['ntp1'],$pconfig['ntp2']) = $dhcpdconf['ntpserver'];
194
	$pconfig['tftp'] = $dhcpdconf['tftp'];
195
	$pconfig['ldap'] = $dhcpdconf['ldap'];
196
	$pconfig['netboot'] = isset($dhcpdconf['netboot']);
197
	$pconfig['nextserver'] = $dhcpdconf['nextserver'];
198
	$pconfig['filename'] = $dhcpdconf['filename'];
199
	$pconfig['filename32'] = $dhcpdconf['filename32'];
200
	$pconfig['filename64'] = $dhcpdconf['filename64'];
201
	$pconfig['rootpath'] = $dhcpdconf['rootpath'];
202
	$pconfig['netmask'] = $dhcpdconf['netmask'];
203
	$pconfig['numberoptions'] = $dhcpdconf['numberoptions'];
204
}
205

    
206
$ifcfgip = $config['interfaces'][$if]['ipaddr'];
207
$ifcfgsn = $config['interfaces'][$if]['subnet'];
208

    
209
function validate_partial_mac_list($maclist) {
210
	$macs = explode(',', $maclist);
211

    
212
	// Loop through and look for invalid MACs.
213
	foreach ($macs as $mac)
214
		if (!is_macaddr($mac, true))
215
			return false;
216
	return true;
217
}
218

    
219
if ($_POST) {
220

    
221
	unset($input_errors);
222

    
223
	$pconfig = $_POST;
224

    
225
	$numberoptions = array();
226
	for($x=0; $x<99; $x++) {
227
		if(isset($_POST["number{$x}"]) && ctype_digit($_POST["number{$x}"])) {
228
			$numbervalue = array();
229
			$numbervalue['number'] = htmlspecialchars($_POST["number{$x}"]);
230
			$numbervalue['type'] = htmlspecialchars($_POST["itemtype{$x}"]);
231
			$numbervalue['value'] = str_replace('&quot;', '"', htmlspecialchars($_POST["value{$x}"]));
232
			$numberoptions['item'][] = $numbervalue;
233
		}
234
	}
235
	// Reload the new pconfig variable that the forum uses.
236
	$pconfig['numberoptions'] = $numberoptions;
237

    
238
	/* input validation */
239
	if ($_POST['enable'] || is_numeric($pool) || $act == "newpool") {
240
		$reqdfields = explode(" ", "range_from range_to");
241
		$reqdfieldsn = array(gettext("Range begin"),gettext("Range end"));
242

    
243
		do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
244

    
245
		if (($_POST['range_from'] && !is_ipaddrv4($_POST['range_from'])))
246
			$input_errors[] = gettext("A valid range must be specified.");
247
		if (($_POST['range_to'] && !is_ipaddrv4($_POST['range_to'])))
248
			$input_errors[] = gettext("A valid range must be specified.");
249
		if (($_POST['gateway'] && $_POST['gateway'] != "none" && !is_ipaddrv4($_POST['gateway'])))
250
			$input_errors[] = gettext("A valid IP address must be specified for the gateway.");
251
		if (($_POST['wins1'] && !is_ipaddrv4($_POST['wins1'])) || ($_POST['wins2'] && !is_ipaddrv4($_POST['wins2'])))
252
			$input_errors[] = gettext("A valid IP address must be specified for the primary/secondary WINS servers.");
253
		$parent_ip = get_interface_ip($_POST['if']);
254
		if (is_ipaddrv4($parent_ip) && $_POST['gateway'] && $_POST['gateway'] != "none") {
255
			$parent_sn = get_interface_subnet($_POST['if']);
256
			if(!ip_in_subnet($_POST['gateway'], gen_subnet($parent_ip, $parent_sn) . "/" . $parent_sn) && !ip_in_interface_alias_subnet($_POST['if'], $_POST['gateway']))
257
				$input_errors[] = sprintf(gettext("The gateway address %s does not lie within the chosen interface's subnet."), $_POST['gateway']);
258
		}
259
		if (($_POST['dns1'] && !is_ipaddrv4($_POST['dns1'])) || ($_POST['dns2'] && !is_ipaddrv4($_POST['dns2'])))
260
			$input_errors[] = gettext("A valid IP address must be specified for the primary/secondary DNS servers.");
261

    
262
		if ($_POST['deftime'] && (!is_numeric($_POST['deftime']) || ($_POST['deftime'] < 60)))
263
				$input_errors[] = gettext("The default lease time must be at least 60 seconds.");
264

    
265
		if (isset($config['captiveportal']) && is_array($config['captiveportal'])) {
266
			$deftime = 7200; // Default value if it's empty
267
			if (is_numeric($_POST['deftime']))
268
				$deftime = $_POST['deftime'];
269

    
270
			foreach ($config['captiveportal'] as $cpZone => $cpdata) {
271
				if (!isset($cpdata['enable']))
272
					continue;
273
				if (!isset($cpdata['timeout']) || !is_numeric($cpdata['timeout']))
274
					continue;
275
				$cp_ifs = explode(',', $cpdata['interface']);
276
				if (!in_array($if, $cp_ifs))
277
					continue;
278
				if ($cpdata['timeout'] > $deftime)
279
					$input_errors[] = sprintf(gettext(
280
						"The Captive Portal zone '%s' has Hard Timeout parameter set to a value bigger than Default lease time (%s)."), $cpZone, $deftime);
281
			}
282
		}
283

    
284
		if ($_POST['maxtime'] && (!is_numeric($_POST['maxtime']) || ($_POST['maxtime'] < 60) || ($_POST['maxtime'] <= $_POST['deftime'])))
285
			$input_errors[] = gettext("The maximum lease time must be at least 60 seconds and higher than the default lease time.");
286
		if (($_POST['ddnsdomain'] && !is_domain($_POST['ddnsdomain'])))
287
			$input_errors[] = gettext("A valid domain name must be specified for the dynamic DNS registration.");
288
		if (($_POST['ddnsdomain'] && !is_ipaddrv4($_POST['ddnsdomainprimary'])))
289
			$input_errors[] = gettext("A valid primary domain name server IP address must be specified for the dynamic domain name.");
290
		if (($_POST['ddnsdomainkey'] && !$_POST['ddnsdomainkeyname']) ||
291
			($_POST['ddnsdomainkeyname'] && !$_POST['ddnsdomainkey']))
292
			$input_errors[] = gettext("You must specify both a valid domain key and key name.");
293
		if ($_POST['domainsearchlist']) {
294
			$domain_array=preg_split("/[ ;]+/",$_POST['domainsearchlist']);
295
			foreach ($domain_array as $curdomain) {
296
				if (!is_domain($curdomain)) {
297
					$input_errors[] = gettext("A valid domain search list must be specified.");
298
					break;
299
				}
300
			}
301
		}
302

    
303
		// Validate MACs
304
		if (!empty($_POST['mac_allow']) && !validate_partial_mac_list($_POST['mac_allow']))
305
			$input_errors[] = gettext("If you specify a mac allow list, it must contain only valid partial MAC addresses.");
306
		if (!empty($_POST['mac_deny']) && !validate_partial_mac_list($_POST['mac_deny']))
307
			$input_errors[] = gettext("If you specify a mac deny list, it must contain only valid partial MAC addresses.");
308

    
309
		if (($_POST['ntp1'] && !is_ipaddrv4($_POST['ntp1'])) || ($_POST['ntp2'] && !is_ipaddrv4($_POST['ntp2'])))
310
			$input_errors[] = gettext("A valid IP address must be specified for the primary/secondary NTP servers.");
311
		if (($_POST['domain'] && !is_domain($_POST['domain'])))
312
			$input_errors[] = gettext("A valid domain name must be specified for the DNS domain.");
313
		if ($_POST['tftp'] && !is_ipaddrv4($_POST['tftp']) && !is_domain($_POST['tftp']) && !is_URL($_POST['tftp']))
314
			$input_errors[] = gettext("A valid IP address or hostname must be specified for the TFTP server.");
315
		if (($_POST['nextserver'] && !is_ipaddrv4($_POST['nextserver'])))
316
			$input_errors[] = gettext("A valid IP address must be specified for the network boot server.");
317

    
318
		if(gen_subnet($ifcfgip, $ifcfgsn) == $_POST['range_from'])
319
			$input_errors[] = gettext("You cannot use the network address in the starting subnet range.");
320
		if(gen_subnet_max($ifcfgip, $ifcfgsn) == $_POST['range_to'])
321
			$input_errors[] = gettext("You cannot use the broadcast address in the ending subnet range.");
322

    
323
		// Disallow a range that includes the virtualip
324
		if (is_array($config['virtualip']['vip'])) {
325
			foreach($config['virtualip']['vip'] as $vip) {
326
				if($vip['interface'] == $if)
327
					if($vip['subnet'] && is_inrange_v4($vip['subnet'], $_POST['range_from'], $_POST['range_to']))
328
						$input_errors[] = sprintf(gettext("The subnet range cannot overlap with virtual IP address %s."),$vip['subnet']);
329
			}
330
		}
331

    
332
		$noip = false;
333
		if(is_array($a_maps))
334
			foreach ($a_maps as $map)
335
				if (empty($map['ipaddr']))
336
					$noip = true;
337
		if ($_POST['staticarp'] && $noip)
338
			$input_errors[] = "Cannot enable static ARP when you have static map entries without IP addresses. Ensure all static maps have IP addresses and try again.";
339

    
340
		if(is_array($pconfig['numberoptions']['item'])) {
341
			foreach ($pconfig['numberoptions']['item'] as $numberoption) {
342
				if ( $numberoption['type'] == 'text' && strstr($numberoption['value'], '"') )
343
					$input_errors[] = gettext("Text type cannot include quotation marks.");
344
				else if ( $numberoption['type'] == 'string' && !preg_match('/^"[^"]*"$/', $numberoption['value']) && !preg_match('/^[0-9a-f]{2}(?:\:[0-9a-f]{2})*$/i', $numberoption['value']) )
345
					$input_errors[] = gettext("String type must be enclosed in quotes like \"this\" or must be a series of octets specified in hexadecimal, separated by colons, like 01:23:45:67:89:ab:cd:ef");
346
				else if ( $numberoption['type'] == 'boolean' && $numberoption['value'] != 'true' && $numberoption['value'] != 'false' && $numberoption['value'] != 'on' && $numberoption['value'] != 'off' )
347
					$input_errors[] = gettext("Boolean type must be true, false, on, or off.");
348
				else if ( $numberoption['type'] == 'unsigned integer 8' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 255) )
349
					$input_errors[] = gettext("Unsigned 8-bit integer type must be a number in the range 0 to 255.");
350
				else if ( $numberoption['type'] == 'unsigned integer 16' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 65535) )
351
					$input_errors[] = gettext("Unsigned 16-bit integer type must be a number in the range 0 to 65535.");
352
				else if ( $numberoption['type'] == 'unsigned integer 32' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 4294967295) )
353
					$input_errors[] = gettext("Unsigned 32-bit integer type must be a number in the range 0 to 4294967295.");
354
				else if ( $numberoption['type'] == 'signed integer 8' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -128 || $numberoption['value'] > 127) )
355
					$input_errors[] = gettext("Signed 8-bit integer type must be a number in the range -128 to 127.");
356
				else if ( $numberoption['type'] == 'signed integer 16' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -32768 || $numberoption['value'] > 32767) )
357
					$input_errors[] = gettext("Signed 16-bit integer type must be a number in the range -32768 to 32767.");
358
				else if ( $numberoption['type'] == 'signed integer 32' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -2147483648 || $numberoption['value'] > 2147483647) )
359
					$input_errors[] = gettext("Signed 32-bit integer type must be a number in the range -2147483648 to 2147483647.");
360
				else if ( $numberoption['type'] == 'ip-address' && !is_ipaddrv4($numberoption['value']) && !is_hostname($numberoption['value']) )
361
					$input_errors[] = gettext("IP address or host type must be an IP address or host name.");
362
			}
363
		}
364

    
365
		if (!$input_errors) {
366
			/* make sure the range lies within the current subnet */
367
			$subnet_start = ip2ulong(long2ip32(ip2long($ifcfgip) & gen_subnet_mask_long($ifcfgsn)));
368
			$subnet_end = ip2ulong(long2ip32(ip2long($ifcfgip) | (~gen_subnet_mask_long($ifcfgsn))));
369

    
370
			if ((ip2ulong($_POST['range_from']) < $subnet_start) || (ip2ulong($_POST['range_from']) > $subnet_end) ||
371
			    (ip2ulong($_POST['range_to']) < $subnet_start) || (ip2ulong($_POST['range_to']) > $subnet_end)) {
372
				$input_errors[] = gettext("The specified range lies outside of the current subnet.");
373
			}
374

    
375
			if (ip2ulong($_POST['range_from']) > ip2ulong($_POST['range_to']))
376
				$input_errors[] = gettext("The range is invalid (first element higher than second element).");
377

    
378
			if (is_numeric($pool) || ($act == "newpool")) {
379
				$rfrom = $config['dhcpd'][$if]['range']['from'];
380
				$rto = $config['dhcpd'][$if]['range']['to'];
381

    
382
				if (is_inrange_v4($_POST['range_from'], $rfrom, $rto) || is_inrange_v4($_POST['range_to'], $rfrom, $rto))
383
					$input_errors[] = gettext("The specified range must not be within the DHCP range for this interface.");
384
			}
385

    
386
			foreach ($a_pools as $id => $p) {
387
				if (is_numeric($pool) && ($id == $pool))
388
					continue;
389

    
390
				if (is_inrange_v4($_POST['range_from'], $p['range']['from'], $p['range']['to']) ||
391
				    is_inrange_v4($_POST['range_to'], $p['range']['from'], $p['range']['to'])) {
392
					$input_errors[] = gettext("The specified range must not be within the range configured on a DHCP pool for this interface.");
393
					break;
394
				}
395
			}
396

    
397
			/* make sure that the DHCP Relay isn't enabled on this interface */
398
			if (isset($config['dhcrelay']['enable']) && (stristr($config['dhcrelay']['interface'], $if) !== false))
399
				$input_errors[] = sprintf(gettext("You must disable the DHCP relay on the %s interface before enabling the DHCP server."),$iflist[$if]);
400

    
401
			$dynsubnet_start = ip2ulong($_POST['range_from']);
402
			$dynsubnet_end = ip2ulong($_POST['range_to']);
403
			if (is_array($a_maps)) {
404
				foreach ($a_maps as $map) {
405
					if (empty($map['ipaddr']))
406
						continue;
407
					if ((ip2ulong($map['ipaddr']) > $dynsubnet_start) &&
408
						(ip2ulong($map['ipaddr']) < $dynsubnet_end)) {
409
						$input_errors[] = sprintf(gettext("The DHCP range cannot overlap any static DHCP mappings."));
410
						break;
411
					}
412
				}
413
			}
414
		}
415
	}
416

    
417
	if (!$input_errors) {
418
		if (!is_numeric($pool)) {
419
			if ($act == "newpool") {
420
				$dhcpdconf = array();
421
			} else {
422
				if (!is_array($config['dhcpd'][$if]))
423
					$config['dhcpd'][$if] = array();
424
				$dhcpdconf = $config['dhcpd'][$if];
425
			}
426
		} else {
427
			if (is_array($a_pools[$pool])) {
428
				$dhcpdconf = $a_pools[$pool];
429
			} else {
430
				// Someone specified a pool but it doesn't exist. Punt.
431
				header("Location: services_dhcp.php");
432
				exit;
433
			}
434
		}
435
		if (!is_array($dhcpdconf['range']))
436
			$dhcpdconf['range'] = array();
437

    
438
		$dhcpd_enable_changed = false;
439

    
440
		// Global Options
441
		if (!is_numeric($pool) && !($act == "newpool")) {
442
			$old_dhcpd_enable = isset($dhcpdconf['enable']);
443
			$new_dhcpd_enable = ($_POST['enable']) ? true : false;
444
			if ($old_dhcpd_enable != $new_dhcpd_enable) {
445
				/* DHCP has been enabled or disabled. The pf ruleset will need to be rebuilt to allow or disallow DHCP. */
446
				$dhcpd_enable_changed = true;
447
			}
448
			$dhcpdconf['enable'] = $new_dhcpd_enable;
449
			$dhcpdconf['staticarp'] = ($_POST['staticarp']) ? true : false;
450
			$previous = $dhcpdconf['failover_peerip'];
451
			if($previous <> $_POST['failover_peerip'])
452
				mwexec("/bin/rm -rf /var/dhcpd/var/db/*");
453
			$dhcpdconf['failover_peerip'] = $_POST['failover_peerip'];
454
			$dhcpdconf['dhcpleaseinlocaltime'] = $_POST['dhcpleaseinlocaltime'];
455
		} else {
456
			// Options that exist only in pools
457
			$dhcpdconf['descr'] = $_POST['descr'];
458
		}
459

    
460
		// Options that can be global or per-pool.
461
		$dhcpdconf['range']['from'] = $_POST['range_from'];
462
		$dhcpdconf['range']['to'] = $_POST['range_to'];
463
		$dhcpdconf['defaultleasetime'] = $_POST['deftime'];
464
		$dhcpdconf['maxleasetime'] = $_POST['maxtime'];
465
		$dhcpdconf['netmask'] = $_POST['netmask'];
466

    
467
		unset($dhcpdconf['winsserver']);
468
		if ($_POST['wins1'])
469
			$dhcpdconf['winsserver'][] = $_POST['wins1'];
470
		if ($_POST['wins2'])
471
			$dhcpdconf['winsserver'][] = $_POST['wins2'];
472

    
473
		unset($dhcpdconf['dnsserver']);
474
		if ($_POST['dns1'])
475
			$dhcpdconf['dnsserver'][] = $_POST['dns1'];
476
		if ($_POST['dns2'])
477
			$dhcpdconf['dnsserver'][] = $_POST['dns2'];
478

    
479
		$dhcpdconf['gateway'] = $_POST['gateway'];
480
		$dhcpdconf['domain'] = $_POST['domain'];
481
		$dhcpdconf['domainsearchlist'] = $_POST['domainsearchlist'];
482
		$dhcpdconf['denyunknown'] = ($_POST['denyunknown']) ? true : false;
483
		$dhcpdconf['ddnsdomain'] = $_POST['ddnsdomain'];
484
		$dhcpdconf['ddnsdomainprimary'] = $_POST['ddnsdomainprimary'];
485
		$dhcpdconf['ddnsdomainkeyname'] = $_POST['ddnsdomainkeyname'];
486
		$dhcpdconf['ddnsdomainkey'] = $_POST['ddnsdomainkey'];
487
		$dhcpdconf['ddnsupdate'] = ($_POST['ddnsupdate']) ? true : false;
488
		$dhcpdconf['mac_allow'] = $_POST['mac_allow'];
489
		$dhcpdconf['mac_deny'] = $_POST['mac_deny'];
490

    
491
		unset($dhcpdconf['ntpserver']);
492
		if ($_POST['ntp1'])
493
			$dhcpdconf['ntpserver'][] = $_POST['ntp1'];
494
		if ($_POST['ntp2'])
495
			$dhcpdconf['ntpserver'][] = $_POST['ntp2'];
496

    
497
		$dhcpdconf['tftp'] = $_POST['tftp'];
498
		$dhcpdconf['ldap'] = $_POST['ldap'];
499
		$dhcpdconf['netboot'] = ($_POST['netboot']) ? true : false;
500
		$dhcpdconf['nextserver'] = $_POST['nextserver'];
501
		$dhcpdconf['filename'] = $_POST['filename'];
502
		$dhcpdconf['filename32'] = $_POST['filename32'];
503
		$dhcpdconf['filename64'] = $_POST['filename64'];
504
		$dhcpdconf['rootpath'] = $_POST['rootpath'];
505

    
506
		// Handle the custom options rowhelper
507
		if(isset($dhcpdconf['numberoptions']['item']))
508
			unset($dhcpdconf['numberoptions']['item']);
509

    
510
		$dhcpdconf['numberoptions'] = $numberoptions;
511

    
512
		if (is_numeric($pool) && is_array($a_pools[$pool])) {
513
			$a_pools[$pool] = $dhcpdconf;
514
		} elseif ($act == "newpool") {
515
			$a_pools[] = $dhcpdconf;
516
		} else {
517
			$config['dhcpd'][$if] = $dhcpdconf;
518
		}
519

    
520
		write_config();
521

    
522
		$retval = 0;
523
		$retvaldhcp = 0;
524
		$retvaldns = 0;
525
		/* Stop DHCP so we can cleanup leases */
526
		killbyname("dhcpd");
527
		dhcp_clean_leases();
528
		/* dnsmasq_configure calls dhcpd_configure */
529
		/* no need to restart dhcpd twice */
530
		if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstatic']))	{
531
			$retvaldns = services_dnsmasq_configure();
532
			if ($retvaldns == 0) {
533
				clear_subsystem_dirty('hosts');
534
				clear_subsystem_dirty('staticmaps');
535
			}
536
		} else {
537
			$retvaldhcp = services_dhcpd_configure();
538
			if ($retvaldhcp == 0)
539
				clear_subsystem_dirty('staticmaps');
540
		}
541
		if ($dhcpd_enable_changed)
542
			$retvalfc = filter_configure();
543

    
544
		if($retvaldhcp == 1 || $retvaldns == 1 || $retvalfc == 1)
545
			$retval = 1;
546
		$savemsg = get_std_save_message($retval);
547
	}
548
}
549

    
550
if ($act == "delpool") {
551
	if ($a_pools[$_GET['id']]) {
552
		unset($a_pools[$_GET['id']]);
553
		write_config();
554
		header("Location: services_dhcp.php?if={$if}");
555
		exit;
556
	}
557
}
558

    
559
if ($act == "del") {
560
	if ($a_maps[$_GET['id']]) {
561
		unset($a_maps[$_GET['id']]);
562
		write_config();
563
		if(isset($config['dhcpd'][$if]['enable'])) {
564
			mark_subsystem_dirty('staticmaps');
565
			if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstatic']))
566
				mark_subsystem_dirty('hosts');
567
		}
568
		header("Location: services_dhcp.php?if={$if}");
569
		exit;
570
	}
571
}
572

    
573
$pgtitle = array(gettext("Services"),gettext("DHCP server"));
574
$shortcut_section = "dhcp";
575

    
576
include("head.inc");
577

    
578
?>
579

    
580
<script type="text/javascript" src="/javascript/row_helper.js">
581
</script>
582

    
583
<script type="text/javascript">
584
	function itemtype_field(fieldname, fieldsize, n) {
585
		return '<select name="' + fieldname + n + '" class="formselect" id="' + fieldname + n + '"><?php
586
			$customitemtypes = array('text' => gettext('Text'), 'string' => gettext('String'), 'boolean' => gettext('Boolean'),
587
				'unsigned integer 8' => gettext('Unsigned 8-bit integer'), 'unsigned integer 16' => gettext('Unsigned 16-bit integer'), 'unsigned integer 32' => gettext('Unsigned 32-bit integer'),
588
				'signed integer 8' => gettext('Signed 8-bit integer'), 'signed integer 16' => gettext('Signed 16-bit integer'), 'signed integer 32' => gettext('Signed 32-bit integer'), 'ip-address' => gettext('IP address or host'));
589
			foreach ($customitemtypes as $typename => $typedescr) {
590
				echo "<option value=\"{$typename}\">{$typedescr}</option>";
591
			}
592
		?></select>';
593
	}
594

    
595
	rowname[0] = "number";
596
	rowtype[0] = "textbox";
597
	rowsize[0] = "10";
598
	rowname[1] = "itemtype";
599
	rowtype[1] = itemtype_field;
600
	rowname[2] = "value";
601
	rowtype[2] = "textbox";
602
	rowsize[2] = "40";
603
</script>
604

    
605
<script type="text/javascript" language="JavaScript">
606
	function enable_change(enable_over) {
607
		var endis;
608
		<?php if (is_numeric($pool) || ($act == "newpool")): ?>
609
			enable_over = true;
610
		<?php endif; ?>
611
		endis = !(document.iform.enable.checked || enable_over);
612
		<?php if (is_numeric($pool) || ($act == "newpool")): ?>
613
			document.iform.descr.disabled = endis;
614
		<?php endif; ?>
615
		document.iform.range_from.disabled = endis;
616
		document.iform.range_to.disabled = endis;
617
		document.iform.wins1.disabled = endis;
618
		document.iform.wins2.disabled = endis;
619
		document.iform.dns1.disabled = endis;
620
		document.iform.dns2.disabled = endis;
621
		document.iform.deftime.disabled = endis;
622
		document.iform.maxtime.disabled = endis;
623
		document.iform.gateway.disabled = endis;
624
		document.iform.failover_peerip.disabled = endis;
625
		document.iform.domain.disabled = endis;
626
		document.iform.domainsearchlist.disabled = endis;
627
		document.iform.staticarp.disabled = endis;
628
		document.iform.dhcpleaseinlocaltime.disabled = endis;
629
		document.iform.ddnsdomain.disabled = endis;
630
		document.iform.ddnsdomainprimary.disabled = endis;
631
		document.iform.ddnsdomainkeyname.disabled = endis;
632
		document.iform.ddnsdomainkey.disabled = endis;
633
		document.iform.ddnsupdate.disabled = endis;
634
		document.iform.mac_allow.disabled = endis;
635
		document.iform.mac_deny.disabled = endis;
636
		document.iform.ntp1.disabled = endis;
637
		document.iform.ntp2.disabled = endis;
638
		document.iform.tftp.disabled = endis;
639
		document.iform.ldap.disabled = endis;
640
		document.iform.netboot.disabled = endis;
641
		document.iform.nextserver.disabled = endis;
642
		document.iform.filename.disabled = endis;
643
		document.iform.filename32.disabled = endis;
644
		document.iform.filename64.disabled = endis;
645
		document.iform.rootpath.disabled = endis;
646
		document.iform.denyunknown.disabled = endis;
647
	}
648

    
649
	function show_shownumbervalue() {
650
		document.getElementById("shownumbervaluebox").innerHTML='';
651
		aodiv = document.getElementById('shownumbervalue');
652
		aodiv.style.display = "block";
653
	}
654

    
655
	function show_ddns_config() {
656
		document.getElementById("showddnsbox").innerHTML='';
657
		aodiv = document.getElementById('showddns');
658
		aodiv.style.display = "block";
659
	}
660

    
661
	function show_maccontrol_config() {
662
		document.getElementById("showmaccontrolbox").innerHTML='';
663
		aodiv = document.getElementById('showmaccontrol');
664
		aodiv.style.display = "block";
665
	}
666

    
667
	function show_ntp_config() {
668
		document.getElementById("showntpbox").innerHTML='';
669
		aodiv = document.getElementById('showntp');
670
		aodiv.style.display = "block";
671
	}
672

    
673
	function show_tftp_config() {
674
		document.getElementById("showtftpbox").innerHTML='';
675
		aodiv = document.getElementById('showtftp');
676
		aodiv.style.display = "block";
677
	}
678

    
679
	function show_ldap_config() {
680
		document.getElementById("showldapbox").innerHTML='';
681
		aodiv = document.getElementById('showldap');
682
		aodiv.style.display = "block";
683
	}
684

    
685
	function show_netboot_config() {
686
		document.getElementById("shownetbootbox").innerHTML='';
687
		aodiv = document.getElementById('shownetboot');
688
		aodiv.style.display = "block";
689
	}
690
</script>
691

    
692
<body link="#0000CC" vlink="#0000CC" alink="#0000CC">
693
<?php include("fbegin.inc"); ?>
694
<form action="services_dhcp.php" method="post" name="iform" id="iform">
695
<?php if ($input_errors) print_input_errors($input_errors); ?>
696
<?php if ($savemsg) print_info_box($savemsg); ?>
697
<?php
698
	if (isset($config['dhcrelay']['enable'])) {
699
		echo gettext("DHCP Relay is currently enabled. Cannot enable the DHCP Server service while the DHCP Relay is enabled on any interface.");
700
		include("fend.inc");
701
		echo "</body>";
702
		echo "</html>";
703
		exit;
704
	}
705
?>
706
<?php if (is_subsystem_dirty('staticmaps')): ?><p>
707
<?php 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."));?><br>
708
<?php endif; ?>
709
<table width="100%" border="0" cellpadding="0" cellspacing="0">
710
<tr><td>
711
<?php
712
	/* active tabs */
713
	$tab_array = array();
714
	$tabscounter = 0;
715
	$i = 0;
716
	foreach ($iflist as $ifent => $ifname) {
717
		$oc = $config['interfaces'][$ifent];
718
		if ((is_array($config['dhcpd'][$ifent]) && !isset($config['dhcpd'][$ifent]['enable']) && (!is_ipaddrv4($oc['ipaddr']))) ||
719
			(!is_array($config['dhcpd'][$ifent]) && (!is_ipaddrv4($oc['ipaddr']))))
720
			continue;
721
		if ($ifent == $if)
722
			$active = true;
723
		else
724
			$active = false;
725
		$tab_array[] = array($ifname, $active, "services_dhcp.php?if={$ifent}");
726
		$tabscounter++;
727
	}
728
	if ($tabscounter == 0) {
729
		echo "</td></tr></table></form>";
730
		include("fend.inc");
731
		echo "</body>";
732
		echo "</html>";
733
		exit;
734
	}
735
	display_top_tabs($tab_array);
736
?>
737
</td></tr>
738
<tr>
739
<td>
740
	<div id="mainarea">
741
		<table class="tabcont" width="100%" border="0" cellpadding="6" cellspacing="0">
742
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
743
			<tr>
744
			<td width="22%" valign="top" class="vtable">&nbsp;</td>
745
			<td width="78%" class="vtable">
746
				<input name="enable" type="checkbox" value="yes" <?php if ($pconfig['enable']) echo "checked"; ?> onClick="enable_change(false)">
747
			<strong><?php printf(gettext("Enable DHCP server on " .
748
			"%s " .
749
			"interface"),htmlspecialchars($iflist[$if]));?></strong></td>
750
			</tr>
751
			<?php else: ?>
752
			<tr>
753
				<td colspan="2" class="listtopic"><?php echo gettext("Editing Pool-Specific Options. To return to the Interface, click its tab above."); ?></td>
754
			</tr>
755
			<?php endif; ?>
756
			<tr>
757
			<td width="22%" valign="top" class="vtable">&nbsp;</td>
758
			<td width="78%" class="vtable">
759
				<input name="denyunknown" id="denyunknown" type="checkbox" value="yes" <?php if ($pconfig['denyunknown']) echo "checked"; ?>>
760
				<strong><?=gettext("Deny unknown clients");?></strong><br>
761
				<?=gettext("If this is checked, only the clients defined below will get DHCP leases from this server. ");?></td>
762
			</tr>
763
			<?php if (is_numeric($pool) || ($act == "newpool")): ?>
764
				<tr>
765
				<td width="22%" valign="top" class="vncell"><?=gettext("Pool Description");?></td>
766
				<td width="78%" class="vtable">
767
					<input name="descr" type="text" class="formfld unknown" id="descr" size="20" value="<?=htmlspecialchars($pconfig['descr']);?>">
768
				</td>
769
				</tr>
770
			<?php endif; ?>
771
			<tr>
772
			<td width="22%" valign="top" class="vncellreq"><?=gettext("Subnet");?></td>
773
			<td width="78%" class="vtable">
774
				<?=gen_subnet($ifcfgip, $ifcfgsn);?>
775
			</td>
776
			</tr>
777
			<tr>
778
			<td width="22%" valign="top" class="vncellreq"><?=gettext("Subnet mask");?></td>
779
			<td width="78%" class="vtable">
780
				<?=gen_subnet_mask($ifcfgsn);?>
781
			</td>
782
			</tr>
783
			<tr>
784
			<td width="22%" valign="top" class="vncellreq"><?=gettext("Available range");?></td>
785
			<td width="78%" class="vtable">
786
			<?php
787
				$range_from = ip2long(long2ip32(ip2long($ifcfgip) & gen_subnet_mask_long($ifcfgsn)));
788
				$range_from++;
789
				echo long2ip32($range_from);
790
			?>
791
			-
792
			<?php
793
				$range_to = ip2long(long2ip32(ip2long($ifcfgip) | (~gen_subnet_mask_long($ifcfgsn))));
794
				$range_to--;
795
				echo long2ip32($range_to);
796
			?>
797
			<?php if (is_numeric($pool) || ($act == "newpool")): ?>
798
				<br/>In-use DHCP Pool Ranges:
799
				<?php if (is_array($config['dhcpd'][$if]['range'])): ?>
800
					<br/><?php echo $config['dhcpd'][$if]['range']['from']; ?>-<?php echo $config['dhcpd'][$if]['range']['to']; ?>
801
				<?php endif; ?>
802
				<?php foreach ($a_pools as $p): ?>
803
					<?php if (is_array($p['range'])): ?>
804
					<br/><?php echo $p['range']['from']; ?>-<?php echo $p['range']['to']; ?>
805
					<?php endif; ?>
806
				<?php endforeach; ?>
807
			<?php endif; ?>
808
			</td>
809
			</tr>
810
			<?php if($is_olsr_enabled): ?>
811
			<tr>
812
			<td width="22%" valign="top" class="vncellreq"><?=gettext("Subnet Mask");?></td>
813
			<td width="78%" class="vtable">
814
				<select name="netmask" class="formselect" id="netmask">
815
				<?php
816
				for ($i = 32; $i > 0; $i--) {
817
					if($i <> 31) {
818
						echo "<option value=\"{$i}\" ";
819
						if ($i == $pconfig['netmask']) echo "selected";
820
						echo ">" . $i . "</option>";
821
					}
822
				}
823
				?>
824
				</select>
825
			</td>
826
			</tr>
827
			<?php endif; ?>
828
			<tr>
829
			<td width="22%" valign="top" class="vncellreq"><?=gettext("Range");?></td>
830
			<td width="78%" class="vtable">
831
				<input name="range_from" type="text" class="formfld unknown" id="range_from" size="20" value="<?=htmlspecialchars($pconfig['range_from']);?>">
832
				&nbsp;<?=gettext("to"); ?>&nbsp; <input name="range_to" type="text" class="formfld unknown" id="range_to" size="20" value="<?=htmlspecialchars($pconfig['range_to']);?>">
833
			</td>
834
			</tr>
835
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
836
			<tr>
837
			<td width="22%" valign="top" class="vncell"><?=gettext("Additional Pools");?></td>
838
			<td width="78%" class="vtable">
839
				<?php echo gettext("If you need additional pools of addresses inside of this subnet outside the above Range, they may be specified here."); ?>
840
				<table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0">
841
				<tr>
842
					<td width="35%" class="listhdrr"><?=gettext("Pool Start");?></td>
843
					<td width="35%" class="listhdrr"><?=gettext("Pool End");?></td>
844
					<td width="20%" class="listhdrr"><?=gettext("Description");?></td>
845
					<td width="10%" class="list">
846
					<table border="0" cellspacing="0" cellpadding="1">
847
					<tr>
848
					<td valign="middle" width="17"></td>
849
					<td valign="middle"><a href="services_dhcp.php?if=<?=htmlspecialchars($if);?>&act=newpool"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
850
					</tr>
851
					</table>
852
					</td>
853
				</tr>
854
					<?php if(is_array($a_pools)): ?>
855
					<?php $i = 0; foreach ($a_pools as $poolent): ?>
856
					<?php if(!empty($poolent['range']['from']) && !empty($poolent['range']['to'])): ?>
857
				<tr>
858
				<td class="listlr" ondblclick="document.location='services_dhcp.php?if=<?=htmlspecialchars($if);?>&pool=<?=$i;?>';">
859
					<?=htmlspecialchars($poolent['range']['from']);?>
860
				</td>
861
				<td class="listr" ondblclick="document.location='services_dhcp.php?if=<?=htmlspecialchars($if);?>&pool=<?=$i;?>';">
862
					<?=htmlspecialchars($poolent['range']['to']);?>&nbsp;
863
				</td>
864
				<td class="listr" ondblclick="document.location='services_dhcp.php?if=<?=htmlspecialchars($if);?>&pool=<?=$i;?>';">
865
					<?=htmlspecialchars($poolent['descr']);?>&nbsp;
866
				</td>
867
				<td valign="middle" nowrap class="list">
868
					<table border="0" cellspacing="0" cellpadding="1">
869
					<tr>
870
					<td valign="middle"><a href="services_dhcp.php?if=<?=htmlspecialchars($if);?>&pool=<?=$i;?>"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_e.gif" width="17" height="17" border="0"></a></td>
871
					<td valign="middle"><a href="services_dhcp.php?if=<?=htmlspecialchars($if);?>&act=delpool&id=<?=$i;?>" onclick="return confirm('<?=gettext("Do you really want to delete this pool?");?>')"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" width="17" height="17" border="0"></a></td>
872
					</tr>
873
					</table>
874
				</td>
875
				</tr>
876
				<?php endif; ?>
877
				<?php $i++; endforeach; ?>
878
				<?php endif; ?>
879
				<tr>
880
				<td class="list" colspan="3"></td>
881
				<td class="list">
882
					<table border="0" cellspacing="0" cellpadding="1">
883
					<tr>
884
					<td valign="middle" width="17"></td>
885
					<td valign="middle"><a href="services_dhcp.php?if=<?=htmlspecialchars($if);?>&act=newpool"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
886
					</tr>
887
					</table>
888
				</td>
889
				</tr>
890
				</table>
891
			</td>
892
			</tr>
893
			<?php endif; ?>
894
			<tr>
895
			<td width="22%" valign="top" class="vncell"><?=gettext("WINS servers");?></td>
896
			<td width="78%" class="vtable">
897
				<input name="wins1" type="text" class="formfld unknown" id="wins1" size="20" value="<?=htmlspecialchars($pconfig['wins1']);?>"><br>
898
				<input name="wins2" type="text" class="formfld unknown" id="wins2" size="20" value="<?=htmlspecialchars($pconfig['wins2']);?>">
899
			</td>
900
			</tr>
901
			<tr>
902
			<td width="22%" valign="top" class="vncell"><?=gettext("DNS servers");?></td>
903
			<td width="78%" class="vtable">
904
				<input name="dns1" type="text" class="formfld unknown" id="dns1" size="20" value="<?=htmlspecialchars($pconfig['dns1']);?>"><br>
905
				<input name="dns2" type="text" class="formfld unknown" id="dns2" size="20" value="<?=htmlspecialchars($pconfig['dns2']);?>"><br>
906
				<?=gettext("NOTE: leave blank to use the system default DNS servers - this interface's IP if DNS forwarder is enabled, otherwise the servers configured on the General page.");?>
907
			</td>
908
			</tr>
909
			<tr>
910
			<td width="22%" valign="top" class="vncell"><?=gettext("Gateway");?></td>
911
			<td width="78%" class="vtable">
912
				<input name="gateway" type="text" class="formfld host" id="gateway" size="20" value="<?=htmlspecialchars($pconfig['gateway']);?>"><br>
913
				<?=gettext("The default is to use the IP on this interface of the firewall as the gateway. Specify an alternate gateway here if this is not the correct gateway for your network. Type \"none\" for no gateway assignment.");?>
914
			</td>
915
			</tr>
916
			<tr>
917
			<td width="22%" valign="top" class="vncell"><?=gettext("Domain name");?></td>
918
			<td width="78%" class="vtable">
919
				<input name="domain" type="text" class="formfld unknown" id="domain" size="20" value="<?=htmlspecialchars($pconfig['domain']);?>"><br>
920
				<?=gettext("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.");?>
921
			</td>
922
			</tr>
923
			<tr>
924
			<td width="22%" valign="top" class="vncell"><?=gettext("Domain search list");?></td>
925
			<td width="78%" class="vtable">
926
				<input name="domainsearchlist" type="text" class="formfld unknown" id="domainsearchlist" size="20" value="<?=htmlspecialchars($pconfig['domainsearchlist']);?>"><br>
927
				<?=gettext("The DHCP server can optionally provide a domain search list. Use the semicolon character as separator ");?>
928
			</td>
929
			</tr>
930
			<tr>
931
			<td width="22%" valign="top" class="vncell"><?=gettext("Default lease time");?></td>
932
			<td width="78%" class="vtable">
933
				<input name="deftime" type="text" class="formfld unknown" id="deftime" size="10" value="<?=htmlspecialchars($pconfig['deftime']);?>">
934
				<?=gettext("seconds");?><br>
935
				<?=gettext("This is used for clients that do not ask for a specific " .
936
				"expiration time."); ?><br>
937
				<?=gettext("The default is 7200 seconds.");?>
938
			</td>
939
			</tr>
940
			<tr>
941
			<td width="22%" valign="top" class="vncell"><?=gettext("Maximum lease time");?></td>
942
			<td width="78%" class="vtable">
943
				<input name="maxtime" type="text" class="formfld unknown" id="maxtime" size="10" value="<?=htmlspecialchars($pconfig['maxtime']);?>">
944
				<?=gettext("seconds");?><br>
945
				<?=gettext("This is the maximum lease time for clients that ask".
946
				" for a specific expiration time."); ?><br>
947
				<?=gettext("The default is 86400 seconds.");?>
948
			</td>
949
			</tr>
950
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
951
			<tr>
952
			<td width="22%" valign="top" class="vncell"><?=gettext("Failover peer IP:");?></td>
953
			<td width="78%" class="vtable">
954
				<input name="failover_peerip" type="text" class="formfld host" id="failover_peerip" size="20" value="<?=htmlspecialchars($pconfig['failover_peerip']);?>"><br>
955
				<?=gettext("Leave blank to disable.  Enter the interface IP address of the other machine.  Machines must be using CARP. Interface's advskew determines whether the DHCPd process is Primary or Secondary. Ensure one machine's advskew<20 (and the other is >20).");?>
956
			</td>
957
			</tr>
958
			<?php endif; ?>
959
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
960
			<tr>
961
			<td width="22%" valign="top" class="vncell"><?=gettext("Static ARP");?></td>
962
			<td width="78%" class="vtable">
963
				<table>
964
					<tr>
965
					<td>
966
						<input valign="middle" type="checkbox" value="yes" name="staticarp" id="staticarp" <?php if($pconfig['staticarp']) echo " checked"; ?>>&nbsp;
967
					</td>
968
					<td><b><?=gettext("Enable Static ARP entries");?></b></td>
969
					</tr>
970
					<tr>
971
					<td>&nbsp;</td>
972
					<td>
973
						<span class="red"><strong><?=gettext("Note:");?></strong></span> <?=gettext("This option persists even if DHCP server is disabled. Only the machines listed below will be able to communicate with the firewall on this NIC.");?>
974
					</td>
975
					</tr>
976
				</table>
977
			</td>
978
			</tr>
979
			<?php endif; ?>
980
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
981
			<tr>
982
				<td width="22%" valign="top" class="vncell"><?=gettext("Time format change"); ?></td>
983
				<td width="78%" class="vtable">
984
				<table>
985
					<tr>
986
					<td>
987
						<input name="dhcpleaseinlocaltime" type="checkbox" id="dhcpleaseinlocaltime" value="yes" <?php if ($pconfig['dhcpleaseinlocaltime']) echo "checked"; ?>>
988
					</td>
989
					<td>
990
						<strong>
991
							<?=gettext("Change DHCP display lease time from UTC to local time."); ?>
992
						</strong>
993
					</td>
994
					</tr>
995
					<tr>
996
					<td>&nbsp;</td>
997
					<td>
998
						<span class="red"><strong><?=gettext("Note:");?></strong></span> <?=gettext("By default DHCP leases are displayed in UTC time.  By checking this
999
						box DHCP lease time will be displayed in local time and set to time zone selected.  This will be used for all DHCP interfaces lease time."); ?>
1000
					</td>
1001
					</tr>
1002
				</table>
1003
				</td>
1004
			</tr>
1005
			<?php endif; ?>
1006
			<tr>
1007
			<td width="22%" valign="top" class="vncell"><?=gettext("Dynamic DNS");?></td>
1008
			<td width="78%" class="vtable">
1009
				<div id="showddnsbox">
1010
					<input type="button" onClick="show_ddns_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show Dynamic DNS");?></a>
1011
				</div>
1012
				<div id="showddns" style="display:none">
1013
					<input valign="middle" type="checkbox" value="yes" name="ddnsupdate" id="ddnsupdate" <?php if($pconfig['ddnsupdate']) echo " checked"; ?>>&nbsp;
1014
					<b><?=gettext("Enable registration of DHCP client names in DNS.");?></b><br />
1015
					<p>
1016
					<input name="ddnsdomain" type="text" class="formfld unknown" id="ddnsdomain" size="20" value="<?=htmlspecialchars($pconfig['ddnsdomain']);?>"><br />
1017
					<?=gettext("Note: Leave blank to disable dynamic DNS registration.");?><br />
1018
					<?=gettext("Enter the dynamic DNS domain which will be used to register client names in the DNS server.");?>
1019
					<input name="ddnsdomainprimary" type="text" class="formfld unknown" id="ddnsdomainprimary" size="20" value="<?=htmlspecialchars($pconfig['ddnsdomainprimary']);?>"><br>
1020
					<?=gettext("Enter the primary domain name server IP address for the dynamic domain name.");?><br />
1021
					<input name="ddnsdomainkeyname" type="text" class="formfld unknown" id="ddnsdomainkeyname" size="20" value="<?=htmlspecialchars($pconfig['ddnsdomainkeyname']);?>"><br />
1022
					<?=gettext("Enter the dynamic DNS domain key name which will be used to register client names in the DNS server.");?>
1023
					<input name="ddnsdomainkey" type="text" class="formfld unknown" id="ddnsdomainkey" size="20" value="<?=htmlspecialchars($pconfig['ddnsdomainkey']);?>"><br />
1024
					<?=gettext("Enter the dynamic DNS domain key secret which will be used to register client names in the DNS server.");?>
1025
				</div>
1026
			</td>
1027
			</tr>
1028
			<tr>
1029
			<td width="22%" valign="top" class="vncell"><?=gettext("MAC Address Control");?></td>
1030
			<td width="78%" class="vtable">
1031
				<div id="showmaccontrolbox">
1032
					<input type="button" onClick="show_maccontrol_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show MAC Address Control");?></a>
1033
				</div>
1034
				<div id="showmaccontrol" style="display:none">
1035
					<input name="mac_allow" type="text" class="formfld unknown" id="mac_allow" size="20" value="<?=htmlspecialchars($pconfig['mac_allow']);?>"><br />
1036
					<?=gettext("Enter a list of partial MAC addresses to allow, comma separated, no spaces, such as ");?>00:00:00,01:E5:FF
1037
					<input name="mac_deny" type="text" class="formfld unknown" id="mac_deny" size="20" value="<?=htmlspecialchars($pconfig['mac_deny']);?>"><br />
1038
					<?=gettext("Enter a list of partial MAC addresses to deny access, comma separated, no spaces, such as ");?>00:00:00,01:E5:FF
1039
				</div>
1040
			</td>
1041
			</tr>
1042
			<tr>
1043
			<td width="22%" valign="top" class="vncell"><?=gettext("NTP servers");?></td>
1044
			<td width="78%" class="vtable">
1045
				<div id="showntpbox">
1046
					<input type="button" onClick="show_ntp_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show NTP configuration");?></a>
1047
				</div>
1048
				<div id="showntp" style="display:none">
1049
					<input name="ntp1" type="text" class="formfld unknown" id="ntp1" size="20" value="<?=htmlspecialchars($pconfig['ntp1']);?>"><br>
1050
					<input name="ntp2" type="text" class="formfld unknown" id="ntp2" size="20" value="<?=htmlspecialchars($pconfig['ntp2']);?>">
1051
				</div>
1052
			</td>
1053
			</tr>
1054
			<tr>
1055
			<td width="22%" valign="top" class="vncell"><?=gettext("TFTP server");?></td>
1056
			<td width="78%" class="vtable">
1057
			<div id="showtftpbox">
1058
				<input type="button" onClick="show_tftp_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show TFTP configuration");?></a>
1059
			</div>
1060
			<div id="showtftp" style="display:none">
1061
				<input name="tftp" type="text" class="formfld unknown" id="tftp" size="50" value="<?=htmlspecialchars($pconfig['tftp']);?>"><br>
1062
				<?=gettext("Leave blank to disable.  Enter a full hostname or IP for the TFTP server.");?>
1063
			</div>
1064
			</td>
1065
			</tr>
1066
			<tr>
1067
			<td width="22%" valign="top" class="vncell"><?=gettext("LDAP URI");?></td>
1068
			<td width="78%" class="vtable">
1069
				<div id="showldapbox">
1070
					<input type="button" onClick="show_ldap_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show LDAP configuration");?></a>
1071
				</div>
1072
				<div id="showldap" style="display:none">
1073
					<input name="ldap" type="text" class="formfld unknown" id="ldap" size="80" value="<?=htmlspecialchars($pconfig['ldap']);?>"><br>
1074
					<?=gettext("Leave blank to disable.  Enter a full URI for the LDAP server in the form ldap://ldap.example.com/dc=example,dc=com");?>
1075
				</div>
1076
			</td>
1077
			</tr>
1078
			<tr>
1079
			<td width="22%" valign="top" class="vncell"><?=gettext("Enable network booting");?></td>
1080
			<td width="78%" class="vtable">
1081
				<div id="shownetbootbox">
1082
					<input type="button" onClick="show_netboot_config()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show Network booting");?></a>
1083
				</div>
1084
				<div id="shownetboot" style="display:none">
1085
					<input valign="middle" type="checkbox" value="yes" name="netboot" id="netboot" <?php if($pconfig['netboot']) echo " checked"; ?>>&nbsp;
1086
					<b><?=gettext("Enables network booting.");?></b>
1087
					<p>
1088
					<?=gettext("Enter the IP of the"); ?> <b><?=gettext("next-server"); ?></b>
1089
					<input name="nextserver" type="text" class="formfld unknown" id="nextserver" size="20" value="<?=htmlspecialchars($pconfig['nextserver']);?>"><br>
1090
					<?=gettext("and the default bios filename");?>
1091
						<input name="filename" type="text" class="formfld unknown" id="filename" size="20" value="<?=htmlspecialchars($pconfig['filename']);?>"><br>
1092
					<?=gettext("and the UEFI 32bit filename  ");?>
1093
						<input name="filename32" type="text" class="formfld unknown" id="filename32" size="20" value="<?=htmlspecialchars($pconfig['filename32']);?>"><br>
1094
					<?=gettext("and the UEFI 64bit filename  ");?>
1095
						<input name="filename64" type="text" class="formfld unknown" id="filename64" size="20" value="<?=htmlspecialchars($pconfig['filename64']);?>"><br>
1096
					<?=gettext("Note: You need both a filename and a boot server configured for this to work!");?>
1097
					<?=gettext("You will need all three filenames and a boot server configured for UEFI to work!");?>
1098
					<p>
1099
					<?=gettext("Enter the"); ?> <b><?=gettext("root-path"); ?></b>-<?=gettext("string");?>
1100
					<input name="rootpath" type="text" class="formfld unknown" id="rootpath" size="90" value="<?=htmlspecialchars($pconfig['rootpath']);?>"><br>
1101
					<?=gettext("Note: string-format: iscsi:(servername):(protocol):(port):(LUN):targetname");?>
1102
				</div>
1103
			</td>
1104
			</tr>
1105
			<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
1106
			<tr>
1107
			<td width="22%" valign="top" class="vncell"><?=gettext("Additional BOOTP/DHCP Options");?></td>
1108
			<td width="78%" class="vtable">
1109
				<div id="shownumbervaluebox">
1110
					<input type="button" onClick="show_shownumbervalue()" value="<?=gettext("Advanced");?>"></input> - <?=gettext("Show Additional BOOTP/DHCP Options");?></a>
1111
				</div>
1112
				<div id="shownumbervalue" style="display:none">
1113
				<table id="maintable">
1114
				<tbody>
1115
				<tr>
1116
				<td colspan="3">
1117
					<div style="padding:5px; margin-top: 16px; margin-bottom: 16px; border:1px dashed #000066; background-color: #ffffff; color: #000000; font-size: 8pt;" id="itemhelp">
1118
					<?=gettext("Enter the DHCP option number and the value for each item you would like to include in the DHCP lease information.  For a list of available options please visit this"); ?> <a href="http://www.iana.org/assignments/bootp-dhcp-parameters/" target="_new"><?=gettext("URL"); ?></a>
1119
					</div>
1120
				</td>
1121
				</tr>
1122
				<tr>
1123
				<td><div id="onecolumn"><?=gettext("Number");?></div></td>
1124
				<td><div id="twocolumn"><?=gettext("Type");?></div></td>
1125
				<td><div id="threecolumn"><?=gettext("Value");?></div></td>
1126
				</tr>
1127
				<?php $counter = 0; ?>
1128
				<?php
1129
					if($pconfig['numberoptions'])
1130
						foreach($pconfig['numberoptions']['item'] as $item):
1131
				?>
1132
					<?php
1133
						$number = $item['number'];
1134
						$itemtype = $item['type'];
1135
						$value = $item['value'];
1136
					?>
1137
				<tr>
1138
				<td>
1139
					<input autocomplete="off" name="number<?php echo $counter; ?>" type="text" class="formfld unknown" id="number<?php echo $counter; ?>" size="10" value="<?=htmlspecialchars($number);?>" />
1140
				</td>
1141
				<td>
1142
					<select name="itemtype<?php echo $counter; ?>" class="formselect" id="itemtype<?php echo $counter; ?>">
1143
					<?php
1144
					foreach ($customitemtypes as $typename => $typedescr) {
1145
						echo "<option value=\"{$typename}\" ";
1146
						if ($itemtype == $typename) echo "selected";
1147
						echo ">" . $typedescr . "</option>";
1148
					}
1149
					?>
1150
					</select>
1151
				</td>
1152
				<td>
1153
					<input autocomplete="off" name="value<?php echo $counter; ?>" type="text" class="formfld unknown" id="value<?php echo $counter; ?>" size="40" value="<?=htmlspecialchars($value);?>" />
1154
				</td>
1155
				<td>
1156
					<a onclick="removeRow(this); return false;" href="#"><img border="0" src="/themes/<?echo $g['theme'];?>/images/icons/icon_x.gif" /></a>
1157
				</td>
1158
				</tr>
1159
				<?php $counter++; ?>
1160
				<?php endforeach; ?>
1161
				</tbody>
1162
				<tfoot>
1163
				</tfoot>
1164
				</table>
1165
				<a onclick="javascript:addRowTo('maintable', 'formfldalias'); return false;" href="#">
1166
					<img border="0" src="/themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" alt="" title="<?=gettext("add another entry");?>" />
1167
				</a>
1168
				<script type="text/javascript">
1169
					field_counter_js = 3;
1170
					rows = 1;
1171
					totalrows = <?php echo $counter; ?>;
1172
					loaded = <?php echo $counter; ?>;
1173
				</script>
1174
				</div>
1175

    
1176
				</td>
1177
			</tr>
1178
			<?php endif; ?>
1179
			<tr>
1180
			<td width="22%" valign="top">&nbsp;</td>
1181
			<td width="78%">
1182
				<?php if ($act == "newpool"): ?>
1183
				<input type="hidden" name="act" value="newpool">
1184
				<?php endif; ?>
1185
				<?php if (is_numeric($pool)): ?>
1186
				<input type="hidden" name="pool" value="<?php echo $pool; ?>">
1187
				<?php endif; ?>
1188
				<input name="if" type="hidden" value="<?=htmlspecialchars($if);?>">
1189
				<input name="Submit" type="submit" class="formbtn" value="<?=gettext("Save");?>" onclick="enable_change(true)">
1190
			</td>
1191
			</tr>
1192
			<tr>
1193
			<td width="22%" valign="top">&nbsp;</td>
1194
			<td width="78%"> <p><span class="vexpl"><span class="red"><strong><?=gettext("Note:");?><br>
1195
				</strong></span><?=gettext("The DNS servers entered in"); ?> <a href="system.php"><?=gettext("System: " .
1196
				"General setup"); ?></a> <?=gettext("(or the"); ?> <a href="services_dnsmasq.php"><?=gettext("DNS " .
1197
				"forwarder"); ?></a>, <?=gettext("if enabled)"); ?> </span><span class="vexpl"><?=gettext("will " .
1198
				"be assigned to clients by the DHCP server."); ?><br>
1199
				<br>
1200
				<?=gettext("The DHCP lease table can be viewed on the"); ?> <a href="status_dhcp_leases.php"><?=gettext("Status: " .
1201
				"DHCP leases"); ?></a> <?=gettext("page."); ?><br>
1202
				</span></p>
1203
			</td>
1204
			</tr>
1205
		</table>
1206
		<?php if (!is_numeric($pool) && !($act == "newpool")): ?>
1207
		<table class="tabcont" width="100%" border="0" cellpadding="0" cellspacing="0">
1208
		<tr>
1209
			<td colspan="5" valign="top" class="listtopic"><?=gettext("DHCP Static Mappings for this interface.");?></td>
1210
			<td>&nbsp;</td>
1211
		</tr>
1212
		<tr>
1213
			<td width="7%" class="listhdrr"><?=gettext("Static ARP");?></td>
1214
			<td width="18%" class="listhdrr"><?=gettext("MAC address");?></td>
1215
			<td width="15%" class="listhdrr"><?=gettext("IP address");?></td>
1216
			<td width="20%" class="listhdrr"><?=gettext("Hostname");?></td>
1217
			<td width="30%" class="listhdr"><?=gettext("Description");?></td>
1218
			<td width="10%" class="list">
1219
			<table border="0" cellspacing="0" cellpadding="1">
1220
			<tr>
1221
			<td valign="middle" width="17"></td>
1222
			<td valign="middle"><a href="services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
1223
			</tr>
1224
			</table>
1225
			</td>
1226
		</tr>
1227
			<?php if(is_array($a_maps)): ?>
1228
			<?php $i = 0; foreach ($a_maps as $mapent): ?>
1229
			<?php if($mapent['mac'] <> "" or $mapent['ipaddr'] <> ""): ?>
1230
		<tr>
1231
		<td align="center" class="listlr" ondblclick="document.location='services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>';">
1232
			<?php if (isset($mapent['arp_table_static_entry'])): ?>
1233
				<img src="./themes/<?= $g['theme']; ?>/images/icons/icon_alert.gif" alt="ARP Table Static Entry" width="17" height="17" border="0">
1234
			<?php endif; ?>
1235
		</td>
1236
		<td class="listlr" ondblclick="document.location='services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>';">
1237
			<?=htmlspecialchars($mapent['mac']);?>
1238
		</td>
1239
		<td class="listr" ondblclick="document.location='services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>';">
1240
			<?=htmlspecialchars($mapent['ipaddr']);?>&nbsp;
1241
		</td>
1242
		<td class="listr" ondblclick="document.location='services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>';">
1243
			<?=htmlspecialchars($mapent['hostname']);?>&nbsp;
1244
		</td>
1245
		<td class="listbg" ondblclick="document.location='services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>';">
1246
			<?=htmlspecialchars($mapent['descr']);?>&nbsp;
1247
		</td>
1248
		<td valign="middle" nowrap class="list">
1249
			<table border="0" cellspacing="0" cellpadding="1">
1250
			<tr>
1251
			<td valign="middle"><a href="services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>&id=<?=$i;?>"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_e.gif" width="17" height="17" border="0"></a></td>
1252
			<td valign="middle"><a href="services_dhcp.php?if=<?=htmlspecialchars($if);?>&act=del&id=<?=$i;?>" onclick="return confirm('<?=gettext("Do you really want to delete this mapping?");?>')"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_x.gif" width="17" height="17" border="0"></a></td>
1253
			</tr>
1254
			</table>
1255
		</td>
1256
		</tr>
1257
		<?php endif; ?>
1258
		<?php $i++; endforeach; ?>
1259
		<?php endif; ?>
1260
		<tr>
1261
		<td class="list" colspan="5"></td>
1262
		<td class="list">
1263
			<table border="0" cellspacing="0" cellpadding="1">
1264
			<tr>
1265
			<td valign="middle" width="17"></td>
1266
			<td valign="middle"><a href="services_dhcp_edit.php?if=<?=htmlspecialchars($if);?>"><img src="./themes/<?= $g['theme']; ?>/images/icons/icon_plus.gif" width="17" height="17" border="0"></a></td>
1267
			</tr>
1268
			</table>
1269
		</td>
1270
		</tr>
1271
		</table>
1272
		<?php endif; ?>
1273
	</div>
1274
</td>
1275
</tr>
1276
</table>
1277
</form>
1278
<script language="JavaScript">
1279
<!--
1280
enable_change(false);
1281
//-->
1282
</script>
1283
<?php include("fend.inc"); ?>
1284
</body>
1285
</html>
(148-148/251)