From a59ad3ae1bd0b9bf773120074113f4a9cf19864f Mon Sep 17 00:00:00 2001 From: tbrehm <t.brehm@ispconfig.org> Date: Wed, 09 Jun 2010 09:31:02 -0400 Subject: [PATCH] Merged revisions 1806-1811,1816 from stable. --- server/plugins-available/bind_plugin.inc.php | 19 ++++++++++++++----- 1 files changed, 14 insertions(+), 5 deletions(-) diff --git a/server/plugins-available/bind_plugin.inc.php b/server/plugins-available/bind_plugin.inc.php index 7262cc1..3c084b3 100644 --- a/server/plugins-available/bind_plugin.inc.php +++ b/server/plugins-available/bind_plugin.inc.php @@ -99,6 +99,7 @@ $records = $app->db->queryAllRecords("SELECT * FROM dns_rr WHERE zone = ".$zone['id']." AND active = 'Y'"); $tpl->setLoop('zones',$records); + $filename = escapeshellcmd($dns_config['bind_zonefiles_dir'].'/pri.'.substr($zone['origin'],0,-1)); $app->log("Writing BIND domain file: ".$filename,LOGLEVEL_DEBUG); @@ -106,6 +107,7 @@ exec('chown '.escapeshellcmd($dns_config['bind_user']).':'.escapeshellcmd($dns_config['bind_group']).' '.$filename); unset($tpl); unset($records); + unset($records_out); unset($zone); } @@ -136,9 +138,9 @@ $this->write_named_conf($data,$dns_config); //* Delete the domain file - $filename = $dns_config['bind_zonefiles_dir'].'/pri.'.substr($data['old']['origin'],0,-1); - if(is_file($filename)) unset($filename); - $app->log("Deleting BIND domain file: ".$filename,LOGLEVEL_DEBUG); + $zone_file_name = $dns_config['bind_zonefiles_dir'].'/pri.'.substr($data['old']['origin'],0,-1); + if(is_file($zone_file_name)) unlink($zone_file_name); + $app->log("Deleting BIND domain file: ".$zone_file_name,LOGLEVEL_DEBUG); //* Reload bind nameserver $app->services->restartServiceDelayed('bind','reload'); @@ -186,11 +188,18 @@ function write_named_conf($data, $dns_config) { global $app, $conf; - $tmps = $app->db->queryAllRecords("SELECT origin FROM dns_soa WHERE active = 'Y'"); + $tmps = $app->db->queryAllRecords("SELECT origin, xfer, also_notify FROM dns_soa WHERE active = 'Y'"); $zones = array(); + foreach($tmps as $tmp) { + + $options = ''; + if(trim($tmp['xfer']) != '') $options .= ' allow-transfer {'.str_replace(',',';',$tmp['xfer']).";};\n"; + if(trim($tmp['also_notify']) != '') $options .= ' also-notify {'.str_replace(',',';',$tmp['also_notify']).";};\n"; + $zones[] = array( 'zone' => substr($tmp['origin'],0,-1), - 'zonefile_path' => $dns_config['bind_zonefiles_dir'].'/pri.'.substr($tmp['origin'],0,-1) + 'zonefile_path' => $dns_config['bind_zonefiles_dir'].'/pri.'.substr($tmp['origin'],0,-1), + 'options' => $options ); } -- Gitblit v1.9.1