diff options
author | Scott Ullrich <sullrich@pfsense.org> | 2005-08-27 21:50:27 +0000 |
---|---|---|
committer | Scott Ullrich <sullrich@pfsense.org> | 2005-08-27 21:50:27 +0000 |
commit | 4cab31d08db0314b3fa69d83f7a20ee54c8d2f9d (patch) | |
tree | a63eb320ffe7dc809a868b8aafb6197682183d98 /usr | |
parent | 18547c5dd36e69452db72098f444e0eddf38175c (diff) | |
download | pfsense-4cab31d08db0314b3fa69d83f7a20ee54c8d2f9d.zip pfsense-4cab31d08db0314b3fa69d83f7a20ee54c8d2f9d.tar.gz |
Add DNS server options specific for each DHCP subnet
Diffstat (limited to 'usr')
-rwxr-xr-x | usr/local/www/services_dhcp.php | 20 |
1 files changed, 19 insertions, 1 deletions
diff --git a/usr/local/www/services_dhcp.php b/usr/local/www/services_dhcp.php index f6c3139..04de15c 100755 --- a/usr/local/www/services_dhcp.php +++ b/usr/local/www/services_dhcp.php @@ -55,6 +55,7 @@ $pconfig['deftime'] = $config['dhcpd'][$if]['defaultleasetime']; $pconfig['maxtime'] = $config['dhcpd'][$if]['maxleasetime']; $pconfig['gateway'] = $config['dhcpd'][$if]['gateway']; list($pconfig['wins1'],$pconfig['wins2']) = $config['dhcpd'][$if]['winsserver']; +list($pconfig['dns1'],$pconfig['dns2']) = $config['dhcpd'][$if]['dns']; $pconfig['enable'] = isset($config['dhcpd'][$if]['enable']); $pconfig['denyunknown'] = isset($config['dhcpd'][$if]['denyunknown']); $pconfig['staticarp'] = isset($config['dhcpd'][$if]['staticarp']); @@ -104,7 +105,10 @@ if ($_POST) { if (($_POST['gateway'] && !is_ipaddr($_POST['gateway']))) $input_errors[] = "A valid IP address must be specified for the gateway."; if (($_POST['wins1'] && !is_ipaddr($_POST['wins1'])) || ($_POST['wins2'] && !is_ipaddr($_POST['wins2']))) { - $input_errors[] = "A valid IP address must be specified for the primary/secondary WINS server."; + $input_errors[] = "A valid IP address must be specified for the primary/secondary WINS servers."; + } + if (($_POST['dns1'] && !is_ipaddr($_POST['dns1'])) || ($_POST['dns2'] && !is_ipaddr($_POST['dns2']))) { + $input_errors[] = "A valid IP address must be specified for the primary/secondary DNS servers."; } if ($_POST['deftime'] && (!is_numeric($_POST['deftime']) || ($_POST['deftime'] < 60))) { $input_errors[] = "The default lease time must be at least 60 seconds."; @@ -146,6 +150,12 @@ if ($_POST) { $config['dhcpd'][$if]['winsserver'][] = $_POST['wins1']; if ($_POST['wins2']) $config['dhcpd'][$if]['winsserver'][] = $_POST['wins2']; + + if ($_POST['dns1']) + $config['dhcpd'][$if]['dns1'][] = $_POST['wins1']; + if ($_POST['dns2']) + $config['dhcpd'][$if]['dns2'][] = $_POST['wins2']; + $config['dhcpd'][$if]['gateway'] = $_POST['gateway']; @@ -189,6 +199,8 @@ function enable_change(enable_over) { document.iform.range_to.disabled = endis; document.iform.wins1.disabled = endis; document.iform.wins2.disabled = endis; + document.iform.dns1.disabled = endis; + document.iform.dns2.disabled = endis; document.iform.deftime.disabled = endis; document.iform.maxtime.disabled = endis; document.iform.gateway.disabled = endis; @@ -278,6 +290,12 @@ function enable_change(enable_over) { <input name="wins1" type="text" class="formfld" id="wins1" size="20" value="<?=htmlspecialchars($pconfig['wins1']);?>"><br> <input name="wins2" type="text" class="formfld" id="wins2" size="20" value="<?=htmlspecialchars($pconfig['wins2']);?>"></td> </tr> + <tr> + <td width="22%" valign="top" class="vncell">DNS servers</td> + <td width="78%" class="vtable"> + <input name="dns1" type="text" class="formfld" id="dns1" size="20" value="<?=htmlspecialchars($pconfig['dns1']);?>"><br> + <input name="dns2" type="text" class="formfld" id="dns2" size="20" value="<?=htmlspecialchars($pconfig['dns2']);?>"></td> + </tr> <tr> <td width="22%" valign="top" class="vncell">Gateway</td> <td width="78%" class="vtable"> |