Project

General

Profile

Download (24.9 KB) Statistics
| Branch: | Tag: | Revision:
1
<?php
2
/*
3
 * system.php
4
 *
5
 * part of pfSense (https://www.pfsense.org)
6
 * Copyright (c) 2004-2018 Rubicon Communications, LLC (Netgate)
7
 * All rights reserved.
8
 *
9
 * originally based on m0n0wall (http://m0n0.ch/wall)
10
 * Copyright (c) 2003-2004 Manuel Kasper <mk@neon1.net>.
11
 * All rights reserved.
12
 *
13
 * Redistribution and use in source and binary forms, with or without
14
 * modification, are permitted provided that the following conditions are met:
15
 *
16
 * 1. Redistributions of source code must retain the above copyright notice,
17
 *    this list of conditions and the following disclaimer.
18
 *
19
 * 2. Redistributions in binary form must reproduce the above copyright
20
 *    notice, this list of conditions and the following disclaimer in
21
 *    the documentation and/or other materials provided with the
22
 *    distribution.
23
 *
24
 * 3. All advertising materials mentioning features or use of this software
25
 *    must display the following acknowledgment:
26
 *    "This product includes software developed by the pfSense Project
27
 *    for use in the pfSense® software distribution. (http://www.pfsense.org/).
28
 *
29
 * 4. The names "pfSense" and "pfSense Project" must not be used to
30
 *    endorse or promote products derived from this software without
31
 *    prior written permission. For written permission, please contact
32
 *    coreteam@pfsense.org.
33
 *
34
 * 5. Products derived from this software may not be called "pfSense"
35
 *    nor may "pfSense" appear in their names without prior written
36
 *    permission of the Electric Sheep Fencing, LLC.
37
 *
38
 * 6. Redistributions of any form whatsoever must retain the following
39
 *    acknowledgment:
40
 *
41
 * "This product includes software developed by the pfSense Project
42
 * for use in the pfSense software distribution (http://www.pfsense.org/).
43
 *
44
 * THIS SOFTWARE IS PROVIDED BY THE pfSense PROJECT ``AS IS'' AND ANY
45
 * EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
46
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
47
 * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE pfSense PROJECT OR
48
 * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
49
 * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
50
 * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
51
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
52
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
53
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
54
 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
55
 * OF THE POSSIBILITY OF SUCH DAMAGE.
56
 */
57

    
58
##|+PRIV
59
##|*IDENT=page-system-generalsetup
60
##|*NAME=System: General Setup
61
##|*DESCR=Allow access to the 'System: General Setup' page.
62
##|*MATCH=system.php*
63
##|-PRIV
64

    
65
require_once("guiconfig.inc");
66
require_once("functions.inc");
67
require_once("filter.inc");
68
require_once("shaper.inc");
69
require_once("system.inc");
70

    
71
$pconfig['hostname'] = $config['system']['hostname'];
72
$pconfig['domain'] = $config['system']['domain'];
73
$pconfig['dnsserver'] = $config['system']['dnsserver'];
74

    
75
$arr_gateways = return_gateways_array();
76

    
77
// set default columns to two if unset
78
if (!isset($config['system']['webgui']['dashboardcolumns'])) {
79
	$config['system']['webgui']['dashboardcolumns'] = 2;
80
}
81

    
82
// set default language if unset
83
if (!isset($config['system']['language'])) {
84
	$config['system']['language'] = $g['language'];
85
}
86

    
87
$dnsgw_counter = 1;
88

    
89
while (isset($config["system"]["dns{$dnsgw_counter}gw"])) {
90
	$pconfig_dnsgw_counter = $dnsgw_counter - 1;
91
	$pconfig["dnsgw{$pconfig_dnsgw_counter}"] = $config["system"]["dns{$dnsgw_counter}gw"];
92
	$dnsgw_counter++;
93
}
94

    
95
$pconfig['dnsallowoverride'] = isset($config['system']['dnsallowoverride']);
96
$pconfig['timezone'] = $config['system']['timezone'];
97
$pconfig['timeservers'] = $config['system']['timeservers'];
98
$pconfig['language'] = $config['system']['language'];
99
$pconfig['webguicss'] = $config['system']['webgui']['webguicss'];
100
$pconfig['logincss'] = $config['system']['webgui']['logincss'];
101
$pconfig['webguifixedmenu'] = $config['system']['webgui']['webguifixedmenu'];
102
$pconfig['dashboardcolumns'] = $config['system']['webgui']['dashboardcolumns'];
103
$pconfig['interfacessort'] = isset($config['system']['webgui']['interfacessort']);
104
$pconfig['webguileftcolumnhyper'] = isset($config['system']['webgui']['webguileftcolumnhyper']);
105
$pconfig['dashboardavailablewidgetspanel'] = isset($config['system']['webgui']['dashboardavailablewidgetspanel']);
106
$pconfig['systemlogsfilterpanel'] = isset($config['system']['webgui']['systemlogsfilterpanel']);
107
$pconfig['systemlogsmanagelogpanel'] = isset($config['system']['webgui']['systemlogsmanagelogpanel']);
108
$pconfig['statusmonitoringsettingspanel'] = isset($config['system']['webgui']['statusmonitoringsettingspanel']);
109
$pconfig['webguihostnamemenu'] = $config['system']['webgui']['webguihostnamemenu'];
110
$pconfig['dnslocalhost'] = isset($config['system']['dnslocalhost']);
111
//$pconfig['dashboardperiod'] = isset($config['widgets']['period']) ? $config['widgets']['period']:"10";
112
$pconfig['loginshowhost'] = isset($config['system']['webgui']['loginshowhost']);
113
$pconfig['requirestatefilter'] = isset($config['system']['webgui']['requirestatefilter']);
114

    
115
if (!$pconfig['timezone']) {
116
	if (isset($g['default_timezone']) && !empty($g['default_timezone'])) {
117
		$pconfig['timezone'] = $g['default_timezone'];
118
	} else {
119
		$pconfig['timezone'] = "Etc/UTC";
120
	}
121
}
122

    
123
if (!$pconfig['timeservers']) {
124
	$pconfig['timeservers'] = "pool.ntp.org";
125
}
126

    
127
$changedesc = gettext("System") . ": ";
128
$changecount = 0;
129

    
130
function is_timezone($elt) {
131
	return !preg_match("/\/$/", $elt);
132
}
133

    
134
if ($pconfig['timezone'] <> $_POST['timezone']) {
135
	filter_pflog_start(true);
136
}
137

    
138
$timezonelist = system_get_timezone_list();
139
$timezonedesc = $timezonelist;
140

    
141
/*
142
 * Etc/GMT entries work the opposite way to what people expect.
143
 * Ref: https://github.com/eggert/tz/blob/master/etcetera and Redmine issue 7089
144
 * Add explanatory text to entries like:
145
 * Etc/GMT+1 and Etc/GMT-1
146
 * but not:
147
 * Etc/GMT or Etc/GMT+0
148
 */
149
foreach ($timezonedesc as $idx => $desc) {
150
	if (substr($desc, 0, 7) != "Etc/GMT" || substr($desc, 8, 1) == "0") {
151
		continue;
152
	}
153

    
154
	$direction = substr($desc, 7, 1);
155

    
156
	switch ($direction) {
157
	case '-':
158
		$direction_str = gettext('AHEAD of');
159
		break;
160
	case '+':
161
		$direction_str = gettext('BEHIND');
162
		break;
163
	default:
164
		continue;
165
	}
166

    
167
	$hr_offset = substr($desc, 8);
168
	$timezonedesc[$idx] = $desc . " " .
169
	    sprintf(ngettext('(%1$s hour %2$s GMT)', '(%1$s hours %2$s GMT)', $hr_offset), $hr_offset, $direction_str);
170
}
171

    
172
$multiwan = false;
173
$interfaces = get_configured_interface_list();
174
foreach ($interfaces as $interface) {
175
	if (interface_has_gateway($interface)) {
176
		$multiwan = true;
177
	}
178
}
179

    
180
if ($_POST) {
181

    
182
	$changecount++;
183

    
184
	unset($input_errors);
185
	$pconfig = $_POST;
186

    
187
	/* input validation */
188
	$reqdfields = explode(" ", "hostname domain");
189
	$reqdfieldsn = array(gettext("Hostname"), gettext("Domain"));
190

    
191
	do_input_validation($_POST, $reqdfields, $reqdfieldsn, $input_errors);
192

    
193
	if ($_POST['hostname']) {
194
		if (!is_hostname($_POST['hostname'])) {
195
			$input_errors[] = gettext("The hostname can only contain the characters A-Z, 0-9 and '-'. It may not start or end with '-'.");
196
		} else {
197
			if (!is_unqualified_hostname($_POST['hostname'])) {
198
				$input_errors[] = gettext("A valid hostname is specified, but the domain name part should be omitted");
199
			}
200
		}
201
	}
202
	if ($_POST['domain'] && !is_domain($_POST['domain'])) {
203
		$input_errors[] = gettext("The domain may only contain the characters a-z, 0-9, '-' and '.'.");
204
	}
205
	validate_webguicss_field($input_errors, $_POST['webguicss']);
206
	validate_webguifixedmenu_field($input_errors, $_POST['webguifixedmenu']);
207
	validate_webguihostnamemenu_field($input_errors, $_POST['webguihostnamemenu']);
208
	validate_dashboardcolumns_field($input_errors, $_POST['dashboardcolumns']);
209

    
210
	$dnslist = $ignore_posted_dnsgw = array();
211

    
212
	$dnscounter = 0;
213
	$dnsname = "dns{$dnscounter}";
214

    
215
	while (isset($_POST[$dnsname])) {
216
		$dnsgwname = "dnsgw{$dnscounter}";
217
		$dnslist[] = $_POST[$dnsname];
218

    
219
		if (($_POST[$dnsname] && !is_ipaddr($_POST[$dnsname]))) {
220
			$input_errors[] = sprintf(gettext("A valid IP address must be specified for DNS server %s."), $dnscounter+1);
221
		} else {
222
			if (($_POST[$dnsgwname] <> "") && ($_POST[$dnsgwname] <> "none")) {
223
				// A real gateway has been selected.
224
				if (is_ipaddr($_POST[$dnsname])) {
225
					if ((is_ipaddrv4($_POST[$dnsname])) && (validate_address_family($_POST[$dnsname], $_POST[$dnsgwname]) === false)) {
226
						$input_errors[] = sprintf(gettext('The IPv6 gateway "%1$s" can not be specified for IPv4 DNS server "%2$s".'), $_POST[$dnsgwname], $_POST[$dnsname]);
227
					}
228
					if ((is_ipaddrv6($_POST[$dnsname])) && (validate_address_family($_POST[$dnsname], $_POST[$dnsgwname]) === false)) {
229
						$input_errors[] = sprintf(gettext('The IPv4 gateway "%1$s" can not be specified for IPv6 DNS server "%2$s".'), $_POST[$dnsgwname], $_POST[$dnsname]);
230
					}
231
				} else {
232
					// The user selected a gateway but did not provide a DNS address. Be nice and set the gateway back to "none".
233
					$ignore_posted_dnsgw[$dnsgwname] = true;
234
				}
235
			}
236
		}
237
		$dnscounter++;
238
		$dnsname = "dns{$dnscounter}";
239
	}
240

    
241
	if (count(array_filter($dnslist)) != count(array_unique(array_filter($dnslist)))) {
242
		$input_errors[] = gettext('Each configured DNS server must have a unique IP address. Remove the duplicated IP.');
243
	}
244

    
245
	$dnscounter = 0;
246
	$dnsname = "dns{$dnscounter}";
247

    
248
	$direct_networks_list = explode(" ", filter_get_direct_networks_list());
249
	while (isset($_POST[$dnsname])) {
250
		$dnsgwname = "dnsgw{$dnscounter}";
251
		if ($_POST[$dnsgwname] && ($_POST[$dnsgwname] <> "none")) {
252
			foreach ($direct_networks_list as $direct_network) {
253
				if (ip_in_subnet($_POST[$dnsname], $direct_network)) {
254
					$input_errors[] = sprintf(gettext("A gateway can not be assigned to DNS '%s' server which is on a directly connected network."), $_POST[$dnsname]);
255
				}
256
			}
257
		}
258
		$dnscounter++;
259
		$dnsname = "dns{$dnscounter}";
260
	}
261

    
262
	# it's easy to have a little too much whitespace in the field, clean it up for the user before processing.
263
	$_POST['timeservers'] = preg_replace('/[[:blank:]]+/', ' ', $_POST['timeservers']);
264
	$_POST['timeservers'] = trim($_POST['timeservers']);
265
	foreach (explode(' ', $_POST['timeservers']) as $ts) {
266
		if (!is_domain($ts)) {
267
			$input_errors[] = gettext("A NTP Time Server name may only contain the characters a-z, 0-9, '-' and '.'.");
268
		}
269
	}
270

    
271
	if ($input_errors) {
272
		// Put the user-entered list back into place so it will be redisplayed for correction.
273
		$pconfig['dnsserver'] = $dnslist;
274
	} else {
275
		update_if_changed("hostname", $config['system']['hostname'], $_POST['hostname']);
276
		update_if_changed("domain", $config['system']['domain'], $_POST['domain']);
277
		update_if_changed("timezone", $config['system']['timezone'], $_POST['timezone']);
278
		update_if_changed("NTP servers", $config['system']['timeservers'], strtolower($_POST['timeservers']));
279

    
280
		if ($_POST['language'] && $_POST['language'] != $config['system']['language']) {
281
			$config['system']['language'] = $_POST['language'];
282
			set_language();
283
		}
284

    
285
		unset($config['system']['webgui']['interfacessort']);
286
		$config['system']['webgui']['interfacessort'] = $_POST['interfacessort'] ? true : false;
287

    
288
		unset($config['system']['webgui']['webguileftcolumnhyper']);
289
		$config['system']['webgui']['webguileftcolumnhyper'] = $_POST['webguileftcolumnhyper'] ? true : false;
290

    
291
		unset($config['system']['webgui']['dashboardavailablewidgetspanel']);
292
		$config['system']['webgui']['dashboardavailablewidgetspanel'] = $_POST['dashboardavailablewidgetspanel'] ? true : false;
293

    
294
		unset($config['system']['webgui']['systemlogsfilterpanel']);
295
		$config['system']['webgui']['systemlogsfilterpanel'] = $_POST['systemlogsfilterpanel'] ? true : false;
296

    
297
		unset($config['system']['webgui']['systemlogsmanagelogpanel']);
298
		$config['system']['webgui']['systemlogsmanagelogpanel'] = $_POST['systemlogsmanagelogpanel'] ? true : false;
299

    
300
		unset($config['system']['webgui']['statusmonitoringsettingspanel']);
301
		$config['system']['webgui']['statusmonitoringsettingspanel'] = $_POST['statusmonitoringsettingspanel'] ? true : false;
302

    
303
//		if ($_POST['dashboardperiod']) {
304
//			$config['widgets']['period'] = $_POST['dashboardperiod'];
305
//		}
306

    
307
		if ($_POST['webguicss']) {
308
			$config['system']['webgui']['webguicss'] = $_POST['webguicss'];
309
		} else {
310
			unset($config['system']['webgui']['webguicss']);
311
		}
312

    
313
		$config['system']['webgui']['roworderdragging'] = $_POST['roworderdragging'] ? true:false;
314

    
315
		if ($_POST['logincss']) {
316
			$config['system']['webgui']['logincss'] = $_POST['logincss'];
317
		} else {
318
			unset($config['system']['webgui']['logincss']);
319
		}
320

    
321
		$config['system']['webgui']['loginshowhost'] = $_POST['loginshowhost'] ? true:false;
322

    
323
		if ($_POST['webguifixedmenu']) {
324
			$config['system']['webgui']['webguifixedmenu'] = $_POST['webguifixedmenu'];
325
		} else {
326
			unset($config['system']['webgui']['webguifixedmenu']);
327
		}
328

    
329
		if ($_POST['webguihostnamemenu']) {
330
			$config['system']['webgui']['webguihostnamemenu'] = $_POST['webguihostnamemenu'];
331
		} else {
332
			unset($config['system']['webgui']['webguihostnamemenu']);
333
		}
334

    
335
		if ($_POST['dashboardcolumns']) {
336
			$config['system']['webgui']['dashboardcolumns'] = $_POST['dashboardcolumns'];
337
		} else {
338
			unset($config['system']['webgui']['dashboardcolumns']);
339
		}
340

    
341
		$config['system']['webgui']['requirestatefilter'] = $_POST['requirestatefilter'] ? true : false;
342

    
343
		/* XXX - billm: these still need updating after figuring out how to check if they actually changed */
344
		$olddnsservers = $config['system']['dnsserver'];
345
		unset($config['system']['dnsserver']);
346

    
347
		$dnscounter = 0;
348
		$dnsname = "dns{$dnscounter}";
349

    
350
		while (isset($_POST[$dnsname])) {
351
			if ($_POST[$dnsname]) {
352
				$config['system']['dnsserver'][] = $_POST[$dnsname];
353
			}
354
			$dnscounter++;
355
			$dnsname = "dns{$dnscounter}";
356
		}
357

    
358
		// Remember the new list for display also.
359
		$pconfig['dnsserver'] = $config['system']['dnsserver'];
360

    
361
		$olddnsallowoverride = $config['system']['dnsallowoverride'];
362

    
363
		unset($config['system']['dnsallowoverride']);
364
		$config['system']['dnsallowoverride'] = $_POST['dnsallowoverride'] ? true : false;
365

    
366
		if ($_POST['dnslocalhost'] == "yes") {
367
			$config['system']['dnslocalhost'] = true;
368
		} else {
369
			unset($config['system']['dnslocalhost']);
370
		}
371

    
372
		/* which interface should the dns servers resolve through? */
373
		$dnscounter = 0;
374
		// The $_POST array key of the DNS IP (starts from 0)
375
		$dnsname = "dns{$dnscounter}";
376
		$outdnscounter = 0;
377
		while (isset($_POST[$dnsname])) {
378
			// The $_POST array key of the corresponding gateway (starts from 0)
379
			$dnsgwname = "dnsgw{$dnscounter}";
380
			// The numbering of DNS GW entries in the config starts from 1
381
			$dnsgwconfigcounter = $dnscounter + 1;
382
			// So this is the array key of the DNS GW entry in $config['system']
383
			$dnsgwconfigname = "dns{$dnsgwconfigcounter}gw";
384

    
385
			$olddnsgwname = $config['system'][$dnsgwconfigname];
386

    
387
			if ($ignore_posted_dnsgw[$dnsgwname]) {
388
				$thisdnsgwname = "none";
389
			} else {
390
				$thisdnsgwname = $pconfig[$dnsgwname];
391
			}
392

    
393
			// "Blank" out the settings for this index, then we set them below using the "outdnscounter" index.
394
			$config['system'][$dnsgwconfigname] = "none";
395
			$pconfig[$dnsgwname] = "none";
396
			$pconfig[$dnsname] = "";
397

    
398
			if ($_POST[$dnsname]) {
399
				// Only the non-blank DNS servers were put into the config above.
400
				// So we similarly only add the corresponding gateways sequentially to the config (and to pconfig), as we find non-blank DNS servers.
401
				// This keeps the DNS server IP and corresponding gateway "lined up" when the user blanks out a DNS server IP in the middle of the list.
402

    
403
				// The $pconfig array key of the DNS IP (starts from 0)
404
				$outdnsname = "dns{$outdnscounter}";
405
				// The $pconfig array key of the corresponding gateway (starts from 0)
406
				$outdnsgwname = "dnsgw{$outdnscounter}";
407
				// The numbering of DNS GW entries in the config starts from 1
408
				$outdnsgwconfigcounter = $outdnscounter + 1;
409
				// So this is the array key of the output DNS GW entry in $config['system']
410
				$outdnsgwconfigname = "dns{$outdnsgwconfigcounter}gw";
411

    
412
				$pconfig[$outdnsname] = $_POST[$dnsname];
413
				if ($_POST[$dnsgwname]) {
414
					$config['system'][$outdnsgwconfigname] = $thisdnsgwname;
415
					$pconfig[$outdnsgwname] = $thisdnsgwname;
416
				} else {
417
					// Note: when no DNS GW name is chosen, the entry is set to "none", so actually this case never happens.
418
					unset($config['system'][$outdnsgwconfigname]);
419
					$pconfig[$outdnsgwname] = "";
420
				}
421
				$outdnscounter++;
422
			}
423
			if (($olddnsgwname != "") && ($olddnsgwname != "none") && (($olddnsgwname != $thisdnsgwname) || ($olddnsservers[$dnscounter] != $_POST[$dnsname]))) {
424
				// A previous DNS GW name was specified. It has now gone or changed, or the DNS server address has changed.
425
				// Remove the route. Later calls will add the correct new route if needed.
426
				if (is_ipaddrv4($olddnsservers[$dnscounter])) {
427
					mwexec("/sbin/route delete " . escapeshellarg($olddnsservers[$dnscounter-1]));
428
				} else if (is_ipaddrv6($olddnsservers[$dnscounter])) {
429
					mwexec("/sbin/route delete -inet6 " . escapeshellarg($olddnsservers[$dnscounter-1]));
430
				}
431
			}
432

    
433
			$dnscounter++;
434
			// The $_POST array key of the DNS IP (starts from 0)
435
			$dnsname = "dns{$dnscounter}";
436
		}
437

    
438
		if ($changecount > 0) {
439
			write_config($changedesc);
440
		}
441

    
442
		$retval = 0;
443
		$retval = system_hostname_configure();
444
		$retval |= system_hosts_generate();
445
		$retval |= system_resolvconf_generate();
446
		if (isset($config['dnsmasq']['enable'])) {
447
			$retval |= services_dnsmasq_configure();
448
		} elseif (isset($config['unbound']['enable'])) {
449
			$retval |= services_unbound_configure();
450
		}
451
		$retval |= system_timezone_configure();
452
		$retval |= system_ntp_configure();
453

    
454
		if ($olddnsallowoverride != $config['system']['dnsallowoverride']) {
455
			$retval |= send_event("service reload dns");
456
		}
457

    
458
		// Reload the filter - plugins might need to be run.
459
		$retval |= filter_configure();
460

    
461
		$savemsg = get_std_save_message($retval);
462
	}
463

    
464
	unset($ignore_posted_dnsgw);
465
}
466

    
467
$pgtitle = array(gettext("System"), gettext("General Setup"));
468
include("head.inc");
469

    
470
if ($input_errors) {
471
	print_input_errors($input_errors);
472
}
473

    
474
if ($savemsg) {
475
	print_info_box($savemsg, 'success');
476
}
477
?>
478
<div id="container">
479
<?php
480

    
481
$form = new Form;
482
$section = new Form_Section('System');
483
$section->addInput(new Form_Input(
484
	'hostname',
485
	'*Hostname',
486
	'text',
487
	$pconfig['hostname'],
488
	['placeholder' => 'pfSense']
489
))->setHelp('Name of the firewall host, without domain part');
490

    
491
$section->addInput(new Form_Input(
492
	'domain',
493
	'*Domain',
494
	'text',
495
	$pconfig['domain'],
496
	['placeholder' => 'mycorp.com, home, office, private, etc.']
497
))->setHelp('Do not use \'.local\' as the final part of the domain (TLD), The \'.local\' domain is %1$swidely used%2$s by '.
498
	'mDNS (including Avahi and Apple OS X\'s Bonjour/Rendezvous/Airprint/Airplay), and some Windows systems and networked devices. ' .
499
	'These will not network correctly if the router uses \'.local\'. Alternatives such as \'.local.lan\' or \'.mylocal\' are safe.',
500
	 ['<a target="_blank" href="https://www.unbound.net/pipermail/unbound-users/2011-March/001735.html">',
501
	 '</a>']);
502

    
503
$form->add($section);
504

    
505
$section = new Form_Section('DNS Server Settings');
506

    
507
if (!is_array($pconfig['dnsserver'])) {
508
	$pconfig['dnsserver'] = array();
509
}
510

    
511
$dnsserver_count = count($pconfig['dnsserver']);
512
$dnsserver_num = 0;
513
$dnsserver_help = gettext("Address") . '<br/>' . gettext("Enter IP addresses to be used by the system for DNS resolution.") . " " .
514
	gettext("These are also used for the DHCP service, DNS Forwarder and DNS Resolver when it has DNS Query Forwarding enabled.");
515
$dnsgw_help = gettext("Gateway") . '<br/>'. gettext("Optionally select the gateway for each DNS server.") . " " .
516
	gettext("When using multiple WAN connections there should be at least one unique DNS server per gateway.");
517

    
518
// If there are no DNS servers, make an empty entry for initial display.
519
if ($dnsserver_count == 0) {
520
	$pconfig['dnsserver'][] = '';
521
}
522

    
523
foreach ($pconfig['dnsserver'] as $dnsserver) {
524

    
525
	$is_last_dnsserver = ($dnsserver_num == $dnsserver_count - 1);
526
	$group = new Form_Group($dnsserver_num == 0 ? 'DNS Servers':'');
527
	$group->addClass('repeatable');
528

    
529
	$group->add(new Form_Input(
530
		'dns' . $dnsserver_num,
531
		'DNS Server',
532
		'text',
533
		$dnsserver
534
	))->setHelp(($is_last_dnsserver) ? $dnsserver_help:null);
535

    
536
	if ($multiwan)	{
537
		$options = array('none' => 'none');
538

    
539
		foreach ($arr_gateways as $gwname => $gwitem) {
540
			if ((is_ipaddrv4(lookup_gateway_ip_by_name($pconfig[$dnsgw])) && (is_ipaddrv6($gwitem['gateway'])))) {
541
				continue;
542
			}
543

    
544
			if ((is_ipaddrv6(lookup_gateway_ip_by_name($pconfig[$dnsgw])) && (is_ipaddrv4($gwitem['gateway'])))) {
545
				continue;
546
			}
547

    
548
			$options[$gwname] = $gwname.' - '.$gwitem['friendlyiface'].' - '.$gwitem['gateway'];
549
		}
550

    
551
		$group->add(new Form_Select(
552
			'dnsgw' . $dnsserver_num,
553
			'Gateway',
554
			$pconfig['dnsgw' . $dnsserver_num],
555
			$options
556
		))->setHelp(($is_last_dnsserver) ? $dnsgw_help:null);;
557
	}
558

    
559
	$group->add(new Form_Button(
560
		'deleterow' . $dnsserver_num,
561
		'Delete',
562
		null,
563
		'fa-trash'
564
	))->addClass('btn-warning');
565

    
566
	$section->add($group);
567
	$dnsserver_num++;
568
}
569

    
570
$section->addInput(new Form_Button(
571
	'addrow',
572
	'Add DNS Server',
573
	null,
574
	'fa-plus'
575
))->addClass('btn-success addbtn');
576

    
577
$section->addInput(new Form_Checkbox(
578
	'dnsallowoverride',
579
	'DNS Server Override',
580
	'Allow DNS server list to be overridden by DHCP/PPP on WAN',
581
	$pconfig['dnsallowoverride']
582
))->setHelp(sprintf(gettext('If this option is set, %s will use DNS servers '.
583
	'assigned by a DHCP/PPP server on WAN for its own purposes (including '.
584
	'the DNS Forwarder/DNS Resolver). However, they will not be assigned to DHCP '.
585
	'clients.'), $g['product_name']));
586

    
587
$section->addInput(new Form_Checkbox(
588
	'dnslocalhost',
589
	'Disable DNS Forwarder',
590
	'Do not use the DNS Forwarder/DNS Resolver as a DNS server for the firewall',
591
	$pconfig['dnslocalhost']
592
))->setHelp('By default localhost (127.0.0.1) will be used as the first DNS '.
593
	'server where the DNS Forwarder or DNS Resolver is enabled and set to '.
594
	'listen on localhost, so system can use the local DNS service to perform '.
595
	'lookups. Checking this box omits localhost from the list of DNS servers in resolv.conf.');
596

    
597
$form->add($section);
598

    
599
$section = new Form_Section('Localization');
600

    
601
$section->addInput(new Form_Select(
602
	'timezone',
603
	'*Timezone',
604
	$pconfig['timezone'],
605
	array_combine($timezonelist, $timezonedesc)
606
))->setHelp('Select the timezone or location within the timezone to be used by this system. '.
607
	'Usually choose a "Continent/City". Only choose a special or "Etc" entry if you understand why you need to use it.');
608

    
609
$section->addInput(new Form_Input(
610
	'timeservers',
611
	'Timeservers',
612
	'text',
613
	$pconfig['timeservers']
614
))->setHelp('Use a space to separate multiple hosts (only one required). '.
615
	'Remember to set up at least one DNS server if a host name is entered here!');
616

    
617
$section->addInput(new Form_Select(
618
	'language',
619
	'*Language',
620
	$pconfig['language'],
621
	get_locale_list()
622
))->setHelp('Choose a language for the webConfigurator');
623

    
624
$form->add($section);
625

    
626
$section = new Form_Section('webConfigurator');
627

    
628
gen_webguicss_field($section, $pconfig['webguicss']);
629
gen_webguifixedmenu_field($section, $pconfig['webguifixedmenu']);
630
gen_webguihostnamemenu_field($section, $pconfig['webguihostnamemenu']);
631
gen_dashboardcolumns_field($section, $pconfig['dashboardcolumns']);
632
gen_interfacessort_field($section, $pconfig['interfacessort']);
633
gen_associatedpanels_fields(
634
	$section,
635
	$pconfig['dashboardavailablewidgetspanel'],
636
	$pconfig['systemlogsfilterpanel'],
637
	$pconfig['systemlogsmanagelogpanel'],
638
	$pconfig['statusmonitoringsettingspanel']);
639
gen_requirestatefilter_field($section, $pconfig['requirestatefilter']);
640
gen_webguileftcolumnhyper_field($section, $pconfig['webguileftcolumnhyper']);
641

    
642
$section->addInput(new Form_Select(
643
	'logincss',
644
	'Login page color',
645
	$pconfig['logincss'],
646
	["1e3f75;" => gettext("Blue"), "003300" => gettext("Green"), "770101" => gettext("Red"),
647
	 "4b1263" => gettext("Purple"), "424142" => gettext("Gray"), "333333" => gettext("Dark gray"),
648
	 "633215" => gettext("Brown" ), "bf7703" => gettext("Orange")]
649
))->setHelp('Choose a color for the login page');
650

    
651
$section->addInput(new Form_Checkbox(
652
	'loginshowhost',
653
	'Login hostname',
654
	'Show hostname on login banner',
655
	$pconfig['loginshowhost']
656
));
657
/*
658
$section->addInput(new Form_Input(
659
	'dashboardperiod',
660
	'Dashboard update period',
661
	'number',
662
	$pconfig['dashboardperiod'],
663
	['min' => '5', 'max' => '600']
664
))->setHelp('Time in seconds between dashboard widget updates. Small values cause ' .
665
			'more frequent updates but increase the load on the web server. ' .
666
			'Minimum is 5 seconds, maximum 600 seconds');
667
*/
668
$form->add($section);
669

    
670
print $form;
671

    
672
$csswarning = sprintf(gettext("%sUser-created themes are unsupported, use at your own risk."), "<br />");
673

    
674
?>
675
</div>
676

    
677
<script type="text/javascript">
678
//<![CDATA[
679
events.push(function() {
680

    
681
	function setThemeWarning() {
682
		if ($('#webguicss').val().startsWith("pfSense")) {
683
			$('#csstxt').html("").addClass("text-default");
684
		} else {
685
			$('#csstxt').html("<?=$csswarning?>").addClass("text-danger");
686
		}
687
	}
688

    
689
	$('#webguicss').change(function() {
690
		setThemeWarning();
691
	});
692

    
693
	setThemeWarning();
694

    
695
	// Suppress "Delete row" button if there are fewer than two rows
696
	checkLastRow();
697
});
698
//]]>
699
</script>
700

    
701
<?php
702
include("foot.inc");
703
?>
(189-189/230)