Projet

Général

Profil

Télécharger (53,8 ko) Statistiques
| Branche: | Tag: | Révision:

univnautes / usr / local / www / services_dhcp.php @ e5b3335a

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") . ".</b><p><b>" . gettext("Only interfaces configured with a static IP will be shown") . ".</b></p>";
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['ddnsupdate'] = isset($dhcpdconf['ddnsupdate']);
188
	$pconfig['mac_allow'] = $dhcpdconf['mac_allow'];
189
	$pconfig['mac_deny'] = $dhcpdconf['mac_deny'];
190
	list($pconfig['ntp1'],$pconfig['ntp2']) = $dhcpdconf['ntpserver'];
191
	$pconfig['tftp'] = $dhcpdconf['tftp'];
192
	$pconfig['ldap'] = $dhcpdconf['ldap'];
193
	$pconfig['netboot'] = isset($dhcpdconf['netboot']);
194
	$pconfig['nextserver'] = $dhcpdconf['nextserver'];
195
	$pconfig['filename'] = $dhcpdconf['filename'];
196
	$pconfig['rootpath'] = $dhcpdconf['rootpath'];
197
	$pconfig['netmask'] = $dhcpdconf['netmask'];
198
	$pconfig['numberoptions'] = $dhcpdconf['numberoptions'];
199
}
200

    
201
$ifcfgip = $config['interfaces'][$if]['ipaddr'];
202
$ifcfgsn = $config['interfaces'][$if]['subnet'];
203

    
204
function validate_partial_mac_list($maclist) {
205
	$macs = explode(',', $maclist);
206

    
207
	// Loop through and look for invalid MACs.
208
	foreach ($macs as $mac)
209
		if (!is_macaddr($mac, true))
210
			return false;
211
	return true;
212
}
213

    
214
if (isset($_POST['submit'])) {
215

    
216
	unset($input_errors);
217

    
218
	$pconfig = $_POST;
219

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

    
233
	/* input validation */
234
	if ($_POST['enable'] || is_numeric($pool) || $act == "newpool") {
235
		$reqdfields = explode(" ", "range_from range_to");
236
		$reqdfieldsn = array(gettext("Range begin"),gettext("Range end"));
237

    
238
		do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
239

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

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

    
260
		if (isset($config['captiveportal']) && is_array($config['captiveportal'])) {
261
			$deftime = 7200; // Default value if it's empty
262
			if (is_numeric($_POST['deftime']))
263
				$deftime = $_POST['deftime'];
264

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

    
279
		if ($_POST['maxtime'] && (!is_numeric($_POST['maxtime']) || ($_POST['maxtime'] < 60) || ($_POST['maxtime'] <= $_POST['deftime'])))
280
			$input_errors[] = gettext("The maximum lease time must be at least 60 seconds and higher than the default lease time.");
281
		if (($_POST['ddnsdomain'] && !is_domain($_POST['ddnsdomain'])))
282
			$input_errors[] = gettext("A valid domain name must be specified for the dynamic DNS registration.");
283
		if ($_POST['domainsearchlist']) {
284
			$domain_array=preg_split("/[ ;]+/",$_POST['domainsearchlist']);
285
			foreach ($domain_array as $curdomain) {
286
				if (!is_domain($curdomain)) {
287
					$input_errors[] = gettext("A valid domain search list must be specified.");
288
					break;
289
				}
290
			}
291
		}
292

    
293
		// Validate MACs
294
		if (!empty($_POST['mac_allow']) && !validate_partial_mac_list($_POST['mac_allow']))
295
			$input_errors[] = gettext("If you specify a mac allow list, it must contain only valid partial MAC addresses.");
296
		if (!empty($_POST['mac_deny']) && !validate_partial_mac_list($_POST['mac_deny']))
297
			$input_errors[] = gettext("If you specify a mac deny list, it must contain only valid partial MAC addresses.");
298

    
299
		if (($_POST['ntp1'] && !is_ipaddrv4($_POST['ntp1'])) || ($_POST['ntp2'] && !is_ipaddrv4($_POST['ntp2'])))
300
			$input_errors[] = gettext("A valid IP address must be specified for the primary/secondary NTP servers.");
301
		if (($_POST['domain'] && !is_domain($_POST['domain'])))
302
			$input_errors[] = gettext("A valid domain name must be specified for the DNS domain.");
303
		if ($_POST['tftp'] && !is_ipaddrv4($_POST['tftp']) && !is_domain($_POST['tftp']) && !is_URL($_POST['tftp']))
304
			$input_errors[] = gettext("A valid IP address or hostname must be specified for the TFTP server.");
305
		if (($_POST['nextserver'] && !is_ipaddrv4($_POST['nextserver'])))
306
			$input_errors[] = gettext("A valid IP address must be specified for the network boot server.");
307

    
308
		if(gen_subnet($ifcfgip, $ifcfgsn) == $_POST['range_from'])
309
			$input_errors[] = gettext("You cannot use the network address in the starting subnet range.");
310
		if(gen_subnet_max($ifcfgip, $ifcfgsn) == $_POST['range_to'])
311
			$input_errors[] = gettext("You cannot use the broadcast address in the ending subnet range.");
312

    
313
		// Disallow a range that includes the virtualip
314
		if (is_array($config['virtualip']['vip'])) {
315
			foreach($config['virtualip']['vip'] as $vip) {
316
				if($vip['interface'] == $if)
317
					if($vip['subnet'] && is_inrange_v4($vip['subnet'], $_POST['range_from'], $_POST['range_to']))
318
						$input_errors[] = sprintf(gettext("The subnet range cannot overlap with virtual IP address %s."),$vip['subnet']);
319
			}
320
		}
321

    
322
		$noip = false;
323
		if(is_array($a_maps))
324
			foreach ($a_maps as $map)
325
				if (empty($map['ipaddr']))
326
					$noip = true;
327
		if ($_POST['staticarp'] && $noip)
328
			$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.";
329

    
330
		if(is_array($pconfig['numberoptions']['item'])) {
331
			foreach ($pconfig['numberoptions']['item'] as $numberoption) {
332
				if ( $numberoption['type'] == 'text' && strstr($numberoption['value'], '"') )
333
					$input_errors[] = gettext("Text type cannot include quotation marks.");
334
				else if ( $numberoption['type'] == 'string' && !preg_match('/^"[^"]*"$/', $numberoption['value']) && !preg_match('/^[0-9a-f]{2}(?:\:[0-9a-f]{2})*$/i', $numberoption['value']) )
335
					$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");
336
				else if ( $numberoption['type'] == 'boolean' && $numberoption['value'] != 'true' && $numberoption['value'] != 'false' && $numberoption['value'] != 'on' && $numberoption['value'] != 'off' )
337
					$input_errors[] = gettext("Boolean type must be true, false, on, or off.");
338
				else if ( $numberoption['type'] == 'unsigned integer 8' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 255) )
339
					$input_errors[] = gettext("Unsigned 8-bit integer type must be a number in the range 0 to 255.");
340
				else if ( $numberoption['type'] == 'unsigned integer 16' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 65535) )
341
					$input_errors[] = gettext("Unsigned 16-bit integer type must be a number in the range 0 to 65535.");
342
				else if ( $numberoption['type'] == 'unsigned integer 32' && (!is_numeric($numberoption['value']) || $numberoption['value'] < 0 || $numberoption['value'] > 4294967295) )
343
					$input_errors[] = gettext("Unsigned 32-bit integer type must be a number in the range 0 to 4294967295.");
344
				else if ( $numberoption['type'] == 'signed integer 8' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -128 || $numberoption['value'] > 127) )
345
					$input_errors[] = gettext("Signed 8-bit integer type must be a number in the range -128 to 127.");
346
				else if ( $numberoption['type'] == 'signed integer 16' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -32768 || $numberoption['value'] > 32767) )
347
					$input_errors[] = gettext("Signed 16-bit integer type must be a number in the range -32768 to 32767.");
348
				else if ( $numberoption['type'] == 'signed integer 32' && (!is_numeric($numberoption['value']) || $numberoption['value'] < -2147483648 || $numberoption['value'] > 2147483647) )
349
					$input_errors[] = gettext("Signed 32-bit integer type must be a number in the range -2147483648 to 2147483647.");
350
				else if ( $numberoption['type'] == 'ip-address' && !is_ipaddrv4($numberoption['value']) && !is_hostname($numberoption['value']) )
351
					$input_errors[] = gettext("IP address or host type must be an IP address or host name.");
352
			}
353
		}
354

    
355
		if (!$input_errors) {
356
			/* make sure the range lies within the current subnet */
357
			$subnet_start = ip2ulong(long2ip32(ip2long($ifcfgip) & gen_subnet_mask_long($ifcfgsn)));
358
			$subnet_end = ip2ulong(long2ip32(ip2long($ifcfgip) | (~gen_subnet_mask_long($ifcfgsn))));
359

    
360
			if ((ip2ulong($_POST['range_from']) < $subnet_start) || (ip2ulong($_POST['range_from']) > $subnet_end) ||
361
			    (ip2ulong($_POST['range_to']) < $subnet_start) || (ip2ulong($_POST['range_to']) > $subnet_end)) {
362
				$input_errors[] = gettext("The specified range lies outside of the current subnet.");
363
			}
364

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

    
368
			if (is_numeric($pool) || ($act == "newpool")) {
369
				$rfrom = $config['dhcpd'][$if]['range']['from'];
370
				$rto = $config['dhcpd'][$if]['range']['to'];
371

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

    
376
			foreach ($a_pools as $id => $p) {
377
				if (is_numeric($pool) && ($id == $pool))
378
					continue;
379

    
380
				if (is_inrange_v4($_POST['range_from'], $p['range']['from'], $p['range']['to']) ||
381
				    is_inrange_v4($_POST['range_to'], $p['range']['from'], $p['range']['to'])) {
382
					$input_errors[] = gettext("The specified range must not be within the range configured on a DHCP pool for this interface.");
383
					break;
384
				}
385
			}
386

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

    
391
			$dynsubnet_start = ip2ulong($_POST['range_from']);
392
			$dynsubnet_end = ip2ulong($_POST['range_to']);
393
			if (is_array($a_maps)) {
394
				foreach ($a_maps as $map) {
395
					if (empty($map['ipaddr']))
396
						continue;
397
					if ((ip2ulong($map['ipaddr']) > $dynsubnet_start) &&
398
						(ip2ulong($map['ipaddr']) < $dynsubnet_end)) {
399
						$input_errors[] = sprintf(gettext("The DHCP range cannot overlap any static DHCP mappings."));
400
						break;
401
					}
402
				}
403
			}
404
		}
405
	}
406

    
407
	if (!$input_errors) {
408
		if (!is_numeric($pool)) {
409
			if ($act == "newpool") {
410
				$dhcpdconf = array();
411
			} else {
412
				if (!is_array($config['dhcpd'][$if]))
413
					$config['dhcpd'][$if] = array();
414
				$dhcpdconf = $config['dhcpd'][$if];
415
			}
416
		} else {
417
			if (is_array($a_pools[$pool])) {
418
				$dhcpdconf = $a_pools[$pool];
419
			} else {
420
				// Someone specified a pool but it doesn't exist. Punt.
421
				header("Location: services_dhcp.php");
422
				exit;
423
			}
424
		}
425
		if (!is_array($dhcpdconf['range']))
426
			$dhcpdconf['range'] = array();
427

    
428
		$dhcpd_enable_changed = false;
429

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

    
450
		// Options that can be global or per-pool.
451
		$dhcpdconf['range']['from'] = $_POST['range_from'];
452
		$dhcpdconf['range']['to'] = $_POST['range_to'];
453
		$dhcpdconf['defaultleasetime'] = $_POST['deftime'];
454
		$dhcpdconf['maxleasetime'] = $_POST['maxtime'];
455
		$dhcpdconf['netmask'] = $_POST['netmask'];
456

    
457
		unset($dhcpdconf['winsserver']);
458
		if ($_POST['wins1'])
459
			$dhcpdconf['winsserver'][] = $_POST['wins1'];
460
		if ($_POST['wins2'])
461
			$dhcpdconf['winsserver'][] = $_POST['wins2'];
462

    
463
		unset($dhcpdconf['dnsserver']);
464
		if ($_POST['dns1'])
465
			$dhcpdconf['dnsserver'][] = $_POST['dns1'];
466
		if ($_POST['dns2'])
467
			$dhcpdconf['dnsserver'][] = $_POST['dns2'];
468

    
469
		$dhcpdconf['gateway'] = $_POST['gateway'];
470
		$dhcpdconf['domain'] = $_POST['domain'];
471
		$dhcpdconf['domainsearchlist'] = $_POST['domainsearchlist'];
472
		$dhcpdconf['denyunknown'] = ($_POST['denyunknown']) ? true : false;
473
		$dhcpdconf['ddnsdomain'] = $_POST['ddnsdomain'];
474
		$dhcpdconf['ddnsupdate'] = ($_POST['ddnsupdate']) ? true : false;
475
		$dhcpdconf['mac_allow'] = $_POST['mac_allow'];
476
		$dhcpdconf['mac_deny'] = $_POST['mac_deny'];
477

    
478
		unset($dhcpdconf['ntpserver']);
479
		if ($_POST['ntp1'])
480
			$dhcpdconf['ntpserver'][] = $_POST['ntp1'];
481
		if ($_POST['ntp2'])
482
			$dhcpdconf['ntpserver'][] = $_POST['ntp2'];
483

    
484
		$dhcpdconf['tftp'] = $_POST['tftp'];
485
		$dhcpdconf['ldap'] = $_POST['ldap'];
486
		$dhcpdconf['netboot'] = ($_POST['netboot']) ? true : false;
487
		$dhcpdconf['nextserver'] = $_POST['nextserver'];
488
		$dhcpdconf['filename'] = $_POST['filename'];
489
		$dhcpdconf['rootpath'] = $_POST['rootpath'];
490

    
491
		// Handle the custom options rowhelper
492
		if(isset($dhcpdconf['numberoptions']['item']))
493
			unset($dhcpdconf['numberoptions']['item']);
494

    
495
		$dhcpdconf['numberoptions'] = $numberoptions;
496

    
497
		if (is_numeric($pool) && is_array($a_pools[$pool])) {
498
			$a_pools[$pool] = $dhcpdconf;
499
		} elseif ($act == "newpool") {
500
			$a_pools[] = $dhcpdconf;
501
		} else {
502
			$config['dhcpd'][$if] = $dhcpdconf;
503
		}
504

    
505
		write_config();
506
	}
507
}
508

    
509
if (isset($_POST['submit']) || isset($_POST['apply'])) {
510
	$retval = 0;
511
	$retvaldhcp = 0;
512
	$retvaldns = 0;
513
	/* Stop DHCP so we can cleanup leases */
514
	killbyname("dhcpd");
515
	dhcp_clean_leases();
516
	/* dnsmasq_configure calls dhcpd_configure */
517
	/* no need to restart dhcpd twice */
518
	if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstatic']))	{
519
		$retvaldns = services_dnsmasq_configure();
520
		if ($retvaldns == 0) {
521
			clear_subsystem_dirty('hosts');
522
			clear_subsystem_dirty('staticmaps');
523
		}
524
	} else {
525
		$retvaldhcp = services_dhcpd_configure();
526
		if ($retvaldhcp == 0)
527
			clear_subsystem_dirty('staticmaps');
528
	}
529
	if ($dhcpd_enable_changed)
530
		$retvalfc = filter_configure();
531

    
532
	if($retvaldhcp == 1 || $retvaldns == 1 || $retvalfc == 1)
533
		$retval = 1;
534
	$savemsg = get_std_save_message($retval);
535
}
536

    
537
if ($act == "delpool") {
538
	if ($a_pools[$_GET['id']]) {
539
		unset($a_pools[$_GET['id']]);
540
		write_config();
541
		header("Location: services_dhcp.php?if={$if}");
542
		exit;
543
	}
544
}
545

    
546
if ($act == "del") {
547
	if ($a_maps[$_GET['id']]) {
548
		unset($a_maps[$_GET['id']]);
549
		write_config();
550
		if(isset($config['dhcpd'][$if]['enable'])) {
551
			mark_subsystem_dirty('staticmaps');
552
			if (isset($config['dnsmasq']['enable']) && isset($config['dnsmasq']['regdhcpstatic']))
553
				mark_subsystem_dirty('hosts');
554
		}
555
		header("Location: services_dhcp.php?if={$if}");
556
		exit;
557
	}
558
}
559

    
560
$pgtitle = array(gettext("Services"),gettext("DHCP server"));
561
$shortcut_section = "dhcp";
562

    
563
include("head.inc");
564

    
565
?>
566

    
567
<body link="#0000CC" vlink="#0000CC" alink="#0000CC">
568

    
569
<script type="text/javascript" src="/javascript/row_helper.js">
570
</script>
571

    
572
<script type="text/javascript">
573
//<![CDATA[
574
	function itemtype_field(fieldname, fieldsize, n) {
575
		return '<select name="' + fieldname + n + '" class="formselect" id="' + fieldname + n + '"><?php
576
			$customitemtypes = array('text' => gettext('Text'), 'string' => gettext('String'), 'boolean' => gettext('Boolean'),
577
				'unsigned integer 8' => gettext('Unsigned 8-bit integer'), 'unsigned integer 16' => gettext('Unsigned 16-bit integer'), 'unsigned integer 32' => gettext('Unsigned 32-bit integer'),
578
				'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'));
579
			foreach ($customitemtypes as $typename => $typedescr) {
580
				echo "<option value=\"{$typename}\">{$typedescr}</option>";
581
			}
582
		?></select>';
583
	}
584

    
585
	rowname[0] = "number";
586
	rowtype[0] = "textbox";
587
	rowsize[0] = "10";
588
	rowname[1] = "itemtype";
589
	rowtype[1] = itemtype_field;
590
	rowname[2] = "value";
591
	rowtype[2] = "textbox";
592
	rowsize[2] = "40";
593
//]]>
594
</script>
595

    
596
<script type="text/javascript" language="JavaScript">
597
	function enable_change(enable_over) {
598
		var endis;
599
		<?php if (is_numeric($pool) || ($act == "newpool")): ?>
600
			enable_over = true;
601
		<?php endif; ?>
602
		endis = !(document.iform.enable.checked || enable_over);
603
		<?php if (is_numeric($pool) || ($act == "newpool")): ?>
604
			document.iform.descr.disabled = endis;
605
		<?php endif; ?>
606
		document.iform.range_from.disabled = endis;
607
		document.iform.range_to.disabled = endis;
608
		document.iform.wins1.disabled = endis;
609
		document.iform.wins2.disabled = endis;
610
		document.iform.dns1.disabled = endis;
611
		document.iform.dns2.disabled = endis;
612
		document.iform.deftime.disabled = endis;
613
		document.iform.maxtime.disabled = endis;
614
		document.iform.gateway.disabled = endis;
615
		document.iform.failover_peerip.disabled = endis;
616
		document.iform.domain.disabled = endis;
617
		document.iform.domainsearchlist.disabled = endis;
618
		document.iform.staticarp.disabled = endis;
619
		document.iform.dhcpleaseinlocaltime.disabled = endis;
620
		document.iform.ddnsdomain.disabled = endis;
621
		document.iform.ddnsupdate.disabled = endis;
622
		document.iform.mac_allow.disabled = endis;
623
		document.iform.mac_deny.disabled = endis;
624
		document.iform.ntp1.disabled = endis;
625
		document.iform.ntp2.disabled = endis;
626
		document.iform.tftp.disabled = endis;
627
		document.iform.ldap.disabled = endis;
628
		document.iform.netboot.disabled = endis;
629
		document.iform.nextserver.disabled = endis;
630
		document.iform.filename.disabled = endis;
631
		document.iform.rootpath.disabled = endis;
632
		document.iform.denyunknown.disabled = endis;
633
	}
634

    
635
	function show_shownumbervalue() {
636
		document.getElementById("shownumbervaluebox").innerHTML='';
637
		aodiv = document.getElementById('shownumbervalue');
638
		aodiv.style.display = "block";
639
	}
640

    
641
	function show_ddns_config() {
642
		document.getElementById("showddnsbox").innerHTML='';
643
		aodiv = document.getElementById('showddns');
644
		aodiv.style.display = "block";
645
	}
646

    
647
	function show_maccontrol_config() {
648
		document.getElementById("showmaccontrolbox").innerHTML='';
649
		aodiv = document.getElementById('showmaccontrol');
650
		aodiv.style.display = "block";
651
	}
652

    
653
	function show_ntp_config() {
654
		document.getElementById("showntpbox").innerHTML='';
655
		aodiv = document.getElementById('showntp');
656
		aodiv.style.display = "block";
657
	}
658

    
659
	function show_tftp_config() {
660
		document.getElementById("showtftpbox").innerHTML='';
661
		aodiv = document.getElementById('showtftp');
662
		aodiv.style.display = "block";
663
	}
664

    
665
	function show_ldap_config() {
666
		document.getElementById("showldapbox").innerHTML='';
667
		aodiv = document.getElementById('showldap');
668
		aodiv.style.display = "block";
669
	}
670

    
671
	function show_netboot_config() {
672
		document.getElementById("shownetbootbox").innerHTML='';
673
		aodiv = document.getElementById('shownetboot');
674
		aodiv.style.display = "block";
675
	}
676
</script>
677

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

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