Commit ce6a5565 authored by Franco Fichtner's avatar Franco Fichtner

dhcp: register domain-name per subnet to prevent wrong default

According to manuals and other project's code this should work as
expected, but to make sure we just advertise the name without a
default.

While there, clean up the config file generation and a few printf
bits that really shouldn't be in there.

PR: https://github.com/opnsense/core/issues/1250
parent a02b02fa
...@@ -279,10 +279,7 @@ function services_radvd_configure($blacklist = array()) ...@@ -279,10 +279,7 @@ function services_radvd_configure($blacklist = array())
/* write radvd.conf */ /* write radvd.conf */
if (!@file_put_contents("/var/etc/radvd.conf", $radvdconf)) { if (!@file_put_contents("/var/etc/radvd.conf", $radvdconf)) {
log_error("Error: cannot open radvd.conf in services_radvd_configure().\n"); log_error('Cannot open radvd.conf in services_radvd_configure()');
if (file_exists("/var/run/booting")) {
printf("Error: cannot open radvd.conf in services_radvd_configure().\n");
}
} }
if (count($radvdifs) > 0) { if (count($radvdifs) > 0) {
...@@ -427,8 +424,6 @@ function services_dhcpdv4_configure() ...@@ -427,8 +424,6 @@ function services_dhcpdv4_configure()
} }
} }
$dhcpdconf = <<<EOD $dhcpdconf = <<<EOD
option domain-name "{$config['system']['domain']}";
option ldap-server code 95 = text; option ldap-server code 95 = text;
option domain-search-list code 119 = text; option domain-search-list code 119 = text;
option arch code 93 = unsigned integer 16; # RFC4578 option arch code 93 = unsigned integer 16; # RFC4578
...@@ -547,6 +542,8 @@ EOPP; ...@@ -547,6 +542,8 @@ EOPP;
if (!empty($dhcpifconf['domain'])) { if (!empty($dhcpifconf['domain'])) {
$dnscfg .= " option domain-name \"{$dhcpifconf['domain']}\";\n"; $dnscfg .= " option domain-name \"{$dhcpifconf['domain']}\";\n";
} else {
$dnscfg .= " option domain-name \"{$config['system']['domain']}\";\n";
} }
if (!empty($dhcpifconf['domainsearchlist'])) { if (!empty($dhcpifconf['domainsearchlist'])) {
...@@ -609,7 +606,7 @@ EOPP; ...@@ -609,7 +606,7 @@ EOPP;
} }
} }
$dhcpdconf .= "subnet {$subnet} netmask {$subnetmask} {\n"; $dhcpdconf .= "\nsubnet {$subnet} netmask {$subnetmask} {\n";
// Setup pool options // Setup pool options
foreach($all_pools as $poolconf) { foreach($all_pools as $poolconf) {
...@@ -780,8 +777,8 @@ EOD; ...@@ -780,8 +777,8 @@ EOD;
} }
// Handle option, number rowhelper values // Handle option, number rowhelper values
$dhcpdconf .= "\n";
if (isset($dhcpifconf['numberoptions']['item'])) { if (isset($dhcpifconf['numberoptions']['item'])) {
$dhcpdconf .= "\n";
foreach($dhcpifconf['numberoptions']['item'] as $itemidx => $item) { foreach($dhcpifconf['numberoptions']['item'] as $itemidx => $item) {
if (empty($item['type']) || $item['type'] == "text") { if (empty($item['type']) || $item['type'] == "text") {
$dhcpdconf .= " option custom-{$dhcpif}-{$itemidx} \"{$item['value']}\";\n"; $dhcpdconf .= " option custom-{$dhcpif}-{$itemidx} \"{$item['value']}\";\n";
...@@ -825,7 +822,7 @@ EOD; ...@@ -825,7 +822,7 @@ EOD;
/* add static mappings */ /* add static mappings */
if (!empty($dhcpifconf['staticmap'])) { if (!empty($dhcpifconf['staticmap'])) {
foreach ($dhcpifconf['staticmap'] as $i => $sm) { foreach ($dhcpifconf['staticmap'] as $i => $sm) {
$dhcpdconf .= "host s_{$dhcpif}_{$i} {\n"; $dhcpdconf .= "\nhost s_{$dhcpif}_{$i} {\n";
if (!empty($sm['mac'])) { if (!empty($sm['mac'])) {
$dhcpdconf .= " hardware ethernet {$sm['mac']};\n"; $dhcpdconf .= " hardware ethernet {$sm['mac']};\n";
} }
...@@ -925,7 +922,7 @@ EOD; ...@@ -925,7 +922,7 @@ EOD;
/* write dhcpd.conf */ /* write dhcpd.conf */
if (!@file_put_contents("{$g['dhcpd_chroot_path']}/etc/dhcpd.conf", $dhcpdconf)) { if (!@file_put_contents("{$g['dhcpd_chroot_path']}/etc/dhcpd.conf", $dhcpdconf)) {
printf(gettext("Error: cannot open dhcpd.conf in services_dhcpdv4_configure().%s"), "\n"); log_error('Cannot open dhcpd.conf in services_dhcpdv4_configure()');
unset($dhcpdconf); unset($dhcpdconf);
return 1; return 1;
} }
...@@ -1124,8 +1121,6 @@ function services_dhcpdv6_configure($blacklist = array()) ...@@ -1124,8 +1121,6 @@ function services_dhcpdv6_configure($blacklist = array())
} }
$dhcpdv6conf = <<<EOD $dhcpdv6conf = <<<EOD
option domain-name "{$syscfg['domain']}";
option ldap-server code 95 = text; option ldap-server code 95 = text;
option domain-search-list code 119 = text; option domain-search-list code 119 = text;
{$custoptionsv6} {$custoptionsv6}
...@@ -1159,6 +1154,8 @@ EOD; ...@@ -1159,6 +1154,8 @@ EOD;
$dnscfgv6 = ""; $dnscfgv6 = "";
if (!empty($dhcpv6ifconf['domain'])) { if (!empty($dhcpv6ifconf['domain'])) {
$dnscfgv6 .= " option domain-name \"{$dhcpv6ifconf['domain']}\";\n"; $dnscfgv6 .= " option domain-name \"{$dhcpv6ifconf['domain']}\";\n";
} else {
$dnscfgv6 .= " option domain-name \"{$syscfg['domain']}\";\n";
} }
if (!empty($dhcpv6ifconf['domainsearchlist'])) { if (!empty($dhcpv6ifconf['domainsearchlist'])) {
...@@ -1193,10 +1190,10 @@ EOD; ...@@ -1193,10 +1190,10 @@ EOD;
} }
if (is_ipaddrv6($ifcfgipv6)) { if (is_ipaddrv6($ifcfgipv6)) {
$dhcpdv6conf .= "subnet6 {$subnetv6}/{$ifcfgsnv6}"; $dhcpdv6conf .= "\nsubnet6 {$subnetv6}/{$ifcfgsnv6}";
} else { } else {
$subnet6 = gen_subnetv6($dhcpv6ifconf['range']['from'], "64"); $subnet6 = gen_subnetv6($dhcpv6ifconf['range']['from'], "64");
$dhcpdv6conf .= "subnet6 {$subnet6}/64"; $dhcpdv6conf .= "\nsubnet6 {$subnet6}/64";
} }
$dhcpdv6conf .= " {\n"; $dhcpdv6conf .= " {\n";
...@@ -1236,8 +1233,8 @@ EOD; ...@@ -1236,8 +1233,8 @@ EOD;
} }
// Handle option, number rowhelper values // Handle option, number rowhelper values
$dhcpdv6conf .= "\n";
if (isset($dhcpv6ifconf['numberoptions']['item'])) { if (isset($dhcpv6ifconf['numberoptions']['item'])) {
$dhcpdv6conf .= "\n";
foreach($dhcpv6ifconf['numberoptions']['item'] as $itemv6idx => $itemv6) { foreach($dhcpv6ifconf['numberoptions']['item'] as $itemv6idx => $itemv6) {
$dhcpdv6conf .= " option custom-{$dhcpv6if}-{$itemv6idx} \"{$itemv6['value']}\";\n"; $dhcpdv6conf .= " option custom-{$dhcpv6if}-{$itemv6idx} \"{$itemv6['value']}\";\n";
} }
...@@ -1263,6 +1260,7 @@ EOD; ...@@ -1263,6 +1260,7 @@ EOD;
$i = 0; $i = 0;
foreach ($dhcpv6ifconf['staticmap'] as $sm) { foreach ($dhcpv6ifconf['staticmap'] as $sm) {
$dhcpdv6conf .= <<<EOD $dhcpdv6conf .= <<<EOD
host s_{$dhcpv6if}_{$i} { host s_{$dhcpv6if}_{$i} {
host-identifier option dhcp6.client-id {$sm['duid']}; host-identifier option dhcp6.client-id {$sm['duid']};
...@@ -1317,18 +1315,15 @@ EOD; ...@@ -1317,18 +1315,15 @@ EOD;
} }
if ($nsupdate) { if ($nsupdate) {
$dhcpdv6conf .= "ddns-update-style interim;\n"; $dhcpdv6conf .= "\nddns-update-style interim;\n";
$dhcpdv6conf .= services_dhcpd_zones($ddns_zones); $dhcpdv6conf .= services_dhcpd_zones($ddns_zones);
} else { } else {
$dhcpdv6conf .= "ddns-update-style none;\n"; $dhcpdv6conf .= "\nddns-update-style none;\n";
} }
/* write dhcpdv6.conf */ /* write dhcpdv6.conf */
if (!@file_put_contents("{$g['dhcpd_chroot_path']}/etc/dhcpdv6.conf", $dhcpdv6conf)) { if (!@file_put_contents("{$g['dhcpd_chroot_path']}/etc/dhcpdv6.conf", $dhcpdv6conf)) {
log_error("Error: cannot open {$g['dhcpd_chroot_path']}/etc/dhcpdv6.conf in services_dhcpdv6_configure().\n"); log_error("Cannot open {$g['dhcpd_chroot_path']}/etc/dhcpdv6.conf in services_dhcpdv6_configure()");
if (file_exists("/var/run/booting")) {
printf("Error: cannot open {$g['dhcpd_chroot_path']}/etc/dhcpdv6.conf in services_dhcpdv6_configure().\n");
}
unset($dhcpdv6conf); unset($dhcpdv6conf);
return 1; return 1;
} }
...@@ -1953,7 +1948,7 @@ function services_snmpd_configure() ...@@ -1953,7 +1948,7 @@ function services_snmpd_configure()
/* generate snmpd.conf */ /* generate snmpd.conf */
$fd = fopen("/var/etc/snmpd.conf", "w"); $fd = fopen("/var/etc/snmpd.conf", "w");
if (!$fd) { if (!$fd) {
printf(gettext("Error: cannot open snmpd.conf in services_snmpd_configure().%s"),"\n"); log_error('Cannot open snmpd.conf in services_snmpd_configure()');
return 1; return 1;
} }
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment