summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: b5c65d4)
raw | patch | inline | side by side (parent: b5c65d4)
author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 30 Mar 2006 11:01:07 +0000 (11:01 +0000) | ||
committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
Thu, 30 Mar 2006 11:01:07 +0000 (11:01 +0000) |
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@2930 594d385d-05f5-0310-b6e9-bd551577e9d8
plugins/admin/systems/class_servDNS.inc | patch | blob | history | |
plugins/admin/systems/class_servDNSeditZone.inc | patch | blob | history | |
plugins/admin/systems/class_termDNS.inc | patch | blob | history |
index fb0cd32417a96bc29fa8a7cb60d51f424adf829c..7bc056a17d3cf03df0014f7cb394260e7a8e6c86 100644 (file)
var $objectclasses = array("whatever");
var $RecordTypes = array();
+ var $Zones = array();
+ var $dialog = NULL;
- var $Zones = array();
- var $dialog = NULL;
-
- var $usedDNS = array();
-
- var $orig_dn = "";
+ var $orig_dn = "";
var $DNSinitially_was_account;
$this->orig_dn = $dn;
- /* All types with required attrs */
- $this->RecordTypes['aRecord'] = "aRecord"; // ok
- $this->RecordTypes['mDRecord'] = "mDRecord"; // ok
- $this->RecordTypes['mXRecord'] = "mXRecord"; // ok
- $this->RecordTypes['nSRecord'] = "nSRecord"; // ok
- $this->RecordTypes['hInfoRecord'] = "hInfoRecord"; // ok
- $this->RecordTypes['mInfoRecord'] = "mInfoRecord"; // ok
-// $this->RecordTypes['tXTRecord'] = "tXTRecord"; // ok
- $this->RecordTypes['aFSDBRecord'] = "aFSDBRecord"; // ok
- $this->RecordTypes['SigRecord'] = "SigRecord"; // ok
- $this->RecordTypes['KeyRecord'] = "KeyRecord"; // ok
- $this->RecordTypes['aAAARecord'] = "aAAARecord"; // ok
- $this->RecordTypes['LocRecord'] = "LocRecord"; // ok
- $this->RecordTypes['nXTRecord'] = "nXTRecord"; // ok
- $this->RecordTypes['sRVRecord'] = "sRVRecord"; // ok
- $this->RecordTypes['nAPTRRecord'] = "nAPTRRecord"; // ok
- $this->RecordTypes['kXRecord'] = "kXRecord"; // ok
- $this->RecordTypes['certRecord'] = "certRecord"; // ok
- $this->RecordTypes['a6Record'] = "a6Record"; // ok
- $this->RecordTypes['dSRecord'] = "dSRecord"; // ok
- $this->RecordTypes['sSHFPRecord'] = "sSHFPRecord"; // ok
- $this->RecordTypes['rRSIGRecord'] = "rRSIGRecord"; // ok
- $this->RecordTypes['nSECRecord'] = "nSECRecord"; // ok
-
- $types = array();
-
- /* Get all records */
- $ldap = $this->config->get_ldap_link();
- $ldap->cd($this->dn);
- $ldap->ls("(&(objectClass=dNSZone)(relativeDomainName=@))",$dn,array("*"));
-
- while($attrs = $ldap->fetch()){
-
- /* If relative domainname
- * Try to read dnsclass / TTl / zone
- */
- $this->usedDNS[$attrs['dn']] = $attrs['dn'];
- if((isset($attrs['tXTRecord'][0]))&&(preg_match("/zoneName\=/",$attrs['tXTRecord'][0]))){
- $zoneName= preg_replace("/zoneName\=/","",$attrs['tXTRecord'][0]);
- $z = preg_replace("/\.in\-addr\.arpa/","",$attrs['zoneName'][0]);
-
- $z = $this->FlipIp($z);
-
- $types[$zoneName]['ReverseZone'] = $z;
- $types[$zoneName]['ReverseDN'] = $attrs['dn'];
- }else{
-
- /* Generate SOA entry
- */
- if(isset($attrs['sOARecord'][0])){
- $tmp = split("\ ",$attrs['sOARecord'][0]) ;
- $tmp2 = array();
- $ar = array("0"=>"sOAprimary","1"=>"sOAmail","2"=>"sOAserial","3"=>"sOArefresh","4"=>"sOAretry","5"=>"sOAexpire","6"=>"sOAttl");
-
- /* Assign soa vars */
- foreach($ar as $key => $name){
- if(isset($tmp[$key])){
- $types[$attrs['zoneName'][0]][$name] = $tmp[$key];
- }else{
- $types[$attrs['zoneName'][0]][$name] = "";
- }
- }
- }
-
- /* Set dns Class
- */
- if(isset($attrs['dNSClass'][0])){
- $types[$attrs['zoneName'][0]]['dNSClass'] = $attrs['dNSClass'][0];
- }
-
- /* Set zone Name
- */
- if(isset($attrs['zoneName'][0])){
- $types[$attrs['zoneName'][0]]['zoneName'] = $attrs['zoneName'][0];
- }
-
- /* Create list with all used records
- */
- foreach($this->RecordTypes as $name => $value){
-
- /* If there is a record attribute
- */
- if(isset($attrs[$name])){
-
- /* get all entries
- */
- for($i = 0 ; $i < $attrs[$value]['count']; $i ++){
- $types[$attrs['zoneName'][0]]['Records'][] =array("type" =>$name,
- "inittype" =>$name,
- "value" =>$attrs[$value][$i],
- "status" =>"edited",
- "dn" =>$attrs['dn']);
- }
- }
- }
- }
- }
+ /* Get record types for zones
+ */
+ $this->RecordTypes = getDnsRecordTypes(true);
+ /* Get all zone Informations
+ */
+ $this->Zones = getDNSZoneEntries($config,$dn);
+
/* If there is at least one entry in this -> types, we have DNS enabled
*/
- $this->Zones = $types;
if(count($this->Zones) == 0){
$this->is_account = false;
}else{
$this->is_account = true;
}
-
- /* Store initally account settings
- */
$this->DNSinitially_was_account = $this->is_account;
}
- /* this is used to flip the ip address for example
- 12.3.45 -> 54.3.12
- Because some entries (like zones) are store like that 54.3.12.in-addr.arpa
- but we want to display 12.3.45.
- */
- function FlipIp($ip)
- {
- $tmp = array_reverse(split("\.",$ip));
- $new = "";
- foreach($tmp as $section){
- $new .= $section.".";
- }
- return(preg_replace("/.$/","",$new));
- }
-
function execute()
{
/* Call parent execute
$this->is_account= !$this->is_account;
}
- /* Show tab dialog headers
- */
if ($this->is_account){
$display= $this->show_header(_("Remove DNS service"),
_("This server has DNS features enabled. You can disable them by clicking below."));
return ($display);
}
- /* Edited or Added zone hould be saved saved
+
+ /* Edited or Added zone
*/
if(isset($_POST['SaveZoneChanges'])){
$this->dialog->save_object();
- /* Check if noting went wrong
+ /* Check for errors
*/
if(count($this->dialog->check())){
foreach($this->dialog->check() as $msgs){
print_red($msgs);
}
}else{
-
/* add new/edited zone
*/
$ret = $this->dialog->save();
- $ret['InitialzoneName']= $this->dialog->InitiallyZoneName;
- $ret['InitialreverseZone']= $this->dialog->InitiallyReverseZone;
- unset($this->Zones[$this->dialog->InitiallyZoneName]);
- $this->Zones[$ret['zoneName']] = $ret;
+ if(!$this->dialog->isNew){
+ unset($this->Zones[$this->dialog->OldZoneName]);
+ }
+ $this->Zones[$ret['zoneName']] = $ret;
$this->dialog = NULL;
}
}
/* Add empty new zone
*/
if(isset($_POST['AddZone'])){
- $this->dialog = new servdnseditZone($this->config,$this->dn,$this->RecordTypes);
+ $this->dialog = new servdnseditZone($this->config,$this->dn);
}
/* Check for edit zone request
$once =true;
$tmp = preg_replace("/^editZone_/","",$name);
$tmp = base64_decode(preg_replace("/_.*$/","",$tmp));
- $this->dialog= new servdnseditZone($this->config,$this->dn,$this->RecordTypes,$this->Zones[$tmp]);
+ $this->dialog= new servdnseditZone($this->config,$this->dn,$this->Zones[$tmp]);
}
/* check posts for delete zone
*/
if(preg_match("/^delZone_/",$name)&&!$once){
+
$once =true;
$tmp = preg_replace("/^delZone_/","",$name);
$tmp = base64_decode(preg_replace("/_.*$/","",$tmp));
-
- $zones = $this->getUsedZoneNames();
-
- if(isset($this->Zones[$tmp]['InitialreverseZone'])){
- $rev = $this->FlipIp($this->Zones[$tmp]['InitialreverseZone']);
- }else{
- $rev = $this->FlipIp($this->Zones[$tmp]['ReverseZone']);
- }
-
- if(isset($this->Zones[$tmp]['InitialzoneName'])){
- $tmp= $this->Zones[$tmp]['InitialzoneName'];
- }
-
- $res = array_merge(($zones[$tmp]),($zones[$rev.".in-addr.arpa"]));
-
- if(count($res)){
- $i = 2;
- $str ="";
- foreach($res as $dn){
- if($i > 0 ){
- $i --;
- $str.=$dn." ";
- }
- }
- if(count($res)> 2) $str .=" ... ";
- print_red(sprintf(_("Can't delete the selected zone, because it is still in use by these entry/entries '%s'"),trim($str)));
- }else{
-// unset($this->Zones[$tmp]);
- }
+
+ /* Initiate deletion
+ */
+ $this->RemoveZone($tmp);
}
}
}
+ /* Delete specified zone
+ */
+ function RemoveZone($id)
+ {
+ $zones = $this->getUsedZoneNames();
+
+ if(isset($this->Zones[$id]['InitialReverseZone'])){
+ $rev = FlipIp($this->Zones[$id]['InitialReverseZone']);
+ }else{
+ $rev = FlipIp($this->Zones[$id]['ReverseZone']);
+ }
+
+ $zonename = "";
+ if(isset($this->Zones[$id]['InitialzoneName'])){
+ $zonename= $this->Zones[$id]['InitialzoneName'];
+ }
+
+ $used = array();
+
+ /* Add Records which use this zoneName
+ */
+ if(isset($zones[$zonename])){
+ $used = array_merge($used,$zones[$zonename]);
+ }
+
+ /* Add Records which uses this reverse zone
+ */
+ if(isset($zones[$rev.".in-addr.arpa"])){
+ $used = array_merge($used,$zones[$rev.".in-addr.arpa"]);
+ }
+
+ /* There are still entries using this configuration
+ * Abort deletion
+ */
+ if(count($used)){
+ $i = 2;
+ $str ="";
+ foreach($used as $dn){
+ if($i > 0 ){
+ $i --;
+ $str.=$dn." ";
+ }
+ }
+
+ /* Only show 2 dns in the error message
+ */
+ if(count($used)> 2) {
+ $str .=" ... ";
+ }
+ print_red(sprintf(_("Can't delete the selected zone, because it is still in use by these entry/entries '%s'"),trim($str)));
+
+ }else{
+ unset($this->Zones[$id]);
+ }
+ }
+
+
/* This funtion returns all used Zonenames
*/
function getUsedZoneNames()
$ret = array();
$ldap = $this->config->get_ldap_link();
$ldap->cd($this->config->current['BASE']);
- $ldap->search("(&(objectClass=dNSZone)(!(relativeDomainName=@))(zoneName=*))",array("zoneName","relativeDomainName","tXTRecord"));
+ $ldap->search("(&(objectClass=dNSZone)(!(relativeDomainName=@))(zoneName=*))",array("zoneName","relativeDomainName"));
while($attr = $ldap->fetch()){
- if(preg_match("/in-addr\.arpa/",$attr['zoneName'][0])){
- $ret[$attr['zoneName'][0]][] = $attr['dn'];
- }else{
- $ret[$attr['zoneName'][0]][] = $attr['dn'];
- }
+ $ret[$attr['zoneName'][0]][] = $attr['dn'];
}
return($ret);
}
if(!$this->DNSinitially_was_account){
return;
}
-
- $ldap = $this->config->get_ldap_link();
- $ldap->cd($this->config->current['BASE']);
- foreach($this->usedDNS as $dn){
- $ldap->cd($dn);
- $ldap->rmdir_recursive($dn);
- }
-
+ print_red("Can't remove dns yet. returning without remove.");
+ return;
$ldap = $this->config->get_ldap_link();
- $ldap->cd($this->orig_dn);
- $ldap->search("(&(objectClass=dNSZone)(zoneName=*)(relativeDomainName=@))",array("relativeDomainName","zoneName"));
+ $ldap->ls("(&(objectClass=dNSZone)(zoneName=*)(relativeDomainName=@))",$this->orig_dn,array("relativeDomainName","zoneName"));
while($attr = $ldap->fetch()){
$ldap->cd($attr['dn']);
$ldap->rmDir($attr['dn']);
}
-
-
show_ldap_error($ldap->get_error());
}
- /* Save data to object */
- function save_object()
- {
- }
-
-
- /* Check supplied data */
- function check()
- {
- $message= array();
- return ($message);
- }
-
-
/* Save to LDAP */
function save()
{
- /* Ldap conenction / var initialization
- */
$ldap = $this->config->get_ldap_link();
- $ldap->cd($this->config->current['BASE']);
- $actions =array("update"=>array(),"add"=>array(),"delete"=>array());
-
- /* Generate entries for all zones, and check if they must be updated deleted added
+ $ldap->cd($this->config->current['BASE']);
+
+ /* Get differences
*/
- foreach($this->Zones as $key => $zone){
- if(isset($zone['InitialzoneName']) && ($zone['zoneName'] != $zone['InitialzoneName'])){
- $dst = "zoneName=".$zone['zoneName'].",".$this->dn;
- $src = "zoneName=".$zone['InitialzoneName'].",".$this->dn;
- $this->recursive_move($src,$dst);
-
- $tmp['zoneName'] = $zone['zoneName'];
- $ldap->search ("(&(objectClass=dNSZone)(zoneName=".$zone['InitialzoneName']."))",array("relativeDomainName"));
- while($attrs = $ldap->fetch()){
- $ldap->cd($attrs['dn']);
- $ldap->modify($tmp);
- show_ldap_error($ldap->get_error());
- }
- }
- if(isset($zone['InitialreverseZone']) &&($zone['InitialreverseZone'] != $zone['ReverseZone'])){
- $dst = "zoneName=".$zone['ReverseZone'].",".$this->dn;
- $src = "zoneName=".$zone['InitialreverseZone'].",".$this->dn;
- $this->recursive_move($src,$dst);
-
- $tmp['zoneName'] = $zone['zoneName'];
- $ldap->search ("(&(objectClass=dNSZone)(zoneName=".$zone['InitialzoneName']."))",array("relativeDomainName"));
- while($attrs = $ldap->fetch()){
- $ldap->cd($attrs['dn']);
- $ldap->modify($tmp);
- show_ldap_error($ldap->get_error());
- }
- }
-
-
- /* Get ldap syntax
- */
- $tmp = $this->generate_LDAP_entries($zone);
-
- /* Check if dn is new, or if entry was edited
- */
- foreach($tmp as $key => $values){
- if(isset($this->usedDNS[$key])){
- $actions['update'][$key]=$values;
- unset($this->usedDNS[$key]);
- }else{
- $actions['add'][$key] = $values;
- }
- }
- }
-
- /* Check which dns are not used anymore ...
+ $tmp = getDNSZoneEntriesDiff($this->config,$this->Zones,$this->orig_dn);
+
+ /* Updated zone entries if reverser or forward name has changed
+ * Must be done before moving entries, else the given dn is invalid
*/
- foreach($this->usedDNS as $key => $values){
- $actions['delete'][$key] = $values;
+ if(isset($tmp['zoneUpdates'])){
+ foreach($tmp['zoneUpdates'] as $dn => $attrs){
+ $ldap->cd($dn);
+ $ldap->modify($attrs);
+ show_ldap_error("Zone:".$ldap->get_error());
+ }
}
- /* Remove deleted zones
+ /* Delete dns
*/
- foreach($actions['delete'] as $dn => $attrs){
+ foreach($tmp['del'] as $dn => $del){
$ldap->cd($dn);
$ldap->rmdir_recursive($dn);
+ show_ldap_error("Zone:".$ldap->get_error());
}
- /* Add new zones
+ /* move follwoing entries
*/
- foreach($actions['add'] as $dn => $attrs){
- $ldap->cd($this->config->current['BASE']);
- $ldap->cd($dn);
- $ldap->add($attrs);
+ foreach($tmp['move'] as $src => $dst){
+ $this->recursive_move($src,$dst);
}
- /* Update existing entries
+ /* Add || Update new DNS entries
*/
- foreach($actions['update'] as $dn => $attrs){
+ foreach($tmp['add'] as $dn => $attrs){
$ldap->cd($dn);
- $ldap->modify ($attrs);
-
- }
-
- show_ldap_error($ldap->get_error());
- }
-
-
- /* This function generates ldap friendly output
- of all changes for a single zone (reverse and forward)
- */
- function generate_LDAP_entries($zone)
- {
- $tmp = array();
- $tmp['objectClass'] = array("top","dNSZone");
- $tmp['dNSClass'] = "IN";//$zone['dNSClass'];
- $tmp['relativeDomainName'] = "@";//$zone['relativeDomainName'];
-
- $str = "";
- foreach(array("sOAprimary","sOAmail","sOAserial","sOArefresh","sOAretry","sOAexpire","sOAttl") as $name){
- $str .= $zone[$name]." ";
- }
- $tmp['sOARecord'] = $str;
-
-
- /* Generate Record entries
- */
- $arr = array("aRecord","SigRecord","KeyRecord","aAAARecord","nSRecord","iaFSDBRecord","mInfoRecord","hInfoRecord","mXRecord","mDRecord","tXTRecord",
- "LocRecord","nXTRecord","sRVRecord","nAPTRRecord","kXRecord","certRecord","a6Record","dSRecord","sSHFPRecord","rRSIGRecord","nSECRecord");
- $aRecords = array();
- foreach($arr as $ar){
- if((isset($zone['Records']))&&(is_array($zone['Records']))){
- foreach($zone['Records'] as $type){
- if(($type['type'] == $ar)&&($type['status']!="deleted")){
- $tmp[$ar][] = $type['value'];
- }
- }
- }
- }
- /* Check if there are records removed,
- if there are some removed records, then append an array
- to ensure that these record types are deleted
- */
- if((isset($zone['Records']))&&(is_array($zone['Records']))){
- foreach($zone['Records'] as $type){
- if((isset($type['inittype']))&&($type['inittype']!="")){
- if($type['type'] != $type['inittype']){
- $tmp[$type['inittype']] = array();
- }
- }
+ $ldap->cat($dn);
+ if(count($ldap->fetch())){
+ $ldap->cd($dn);
+ $ldap->modify ($attrs);
+ }else{
+ $ldap->cd($dn);
+ $ldap->add($attrs);
}
}
-
- /* generate forward entry
- */
- $dn = "zoneName=".$zone['zoneName'].",".$this->dn;
- $tmp2[$dn] = $tmp;
- $tmp2[$dn]['zoneName'] = $zone['zoneName'];
-
- /* generate reverse entry
- */
- $dn = "zoneName=".$this->FlipIp($zone['ReverseZone']).".in-addr.arpa,".$this->dn;
- $tmp2[$dn] = $tmp;
- $tmp2[$dn]['tXTRecord'] ="zoneName=".$zone['zoneName'];
- $tmp2[$dn]['zoneName'] = $this->FlipIp($zone['ReverseZone']).".in-addr.arpa";
-
- return($tmp2);
}
}
// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
diff --git a/plugins/admin/systems/class_servDNSeditZone.inc b/plugins/admin/systems/class_servDNSeditZone.inc
index 2ab894396a8d66bfd86ade6d1b46c51cf0f3f481..9ec9c3ad0f2f66e13381be7d68081eae4825507b 100644 (file)
"sOAprimary","sOAmail","sOAserial","sOArefresh","sOAretry","sOAexpire","sOAttl");
var $objectclasses = array("whatever");
- var $RecordTypes = array();
+ var $RecordTypes = array();
var $ReverseZone = "";
- var $ReverseDN = "";
var $zoneName = "";
var $dNSClass = "IN";
- var $status = "new";
var $sOAprimary = "";
var $sOAmail = "";
var $Records = array();
var $mXRecords = array();
- var $InitiallyZoneName = "";
- var $InitiallyReverseZone = "";
- var $isNew = true;
+ var $OldZoneName = ""; // To detect changes made with this edit
+ var $OldReverseZone = "";
+
+ var $InitialReverseZone = "";
+ var $InitialzoneName = "";
var $dialog = false;
- function servdnseditZone ($config, $dn= NULL,$recordtypes,$attrs = array())
+ var $isNew = true;
+
+ function servdnseditZone ($config, $dn= NULL,$attrs = array())
{
plugin::plugin ($config, $dn);
/* All types with required attrs */
- $this->RecordTypes = $recordtypes;
+ $this->RecordTypes = getDnsRecordTypes(true);
if(!count($attrs)){
- $this->InitiallyZoneName = "";
- $this->InitiallyReverseZone = "";
- $this->isNew = true;
- $this->sOAserial = date("Ymd")."1";
+ $this->OldZoneName = "";
+ $this->OldReverseZone = "";
+ $this->isNew = true;
+ $this->sOAserial = date("Ymd")."1";
+
+ $this->InitialzoneName = "";//$attrs['InitialzoneName'];
+ $this->InitialReverseZone = "";//$attrs['InitialReverseZone'];
}else{
- $this->InitiallyZoneName = $attrs['zoneName'];
- $this->InitiallyReverseZone = $attrs['ReverseZone'];
+ $this->OldZoneName = $attrs['zoneName'];
+ $this->OldReverseZone = $attrs['ReverseZone'];
+
+ $this->InitialzoneName = $attrs['InitialzoneName'];
+ $this->InitialReverseZone = $attrs['InitialReverseZone'];
+
$this->isNew = false;
foreach($this->attributes as $value){
$this->$value = $attrs[$value];
}
- if(isset($attrs['Records'])){
- $this->Records = $attrs['Records'];
+ if(isset($attrs['RECORDS'])){
+ $this->Records = $attrs['RECORDS'];
$tmp2 = array();
$usedPrio = array();
/* Open Zone Entry Edit Dialog
*/
if(isset($_POST['EditZoneEntries'])){
- $this->dialog= new servDNSeditZoneEntries($this->config,$this->dn,$this->InitiallyZoneName,$this->FlipIp($this->InitiallyReverseZone),$this->RecordTypes);
+ $this->dialog= new servDNSeditZoneEntries($this->config,$this->dn,$this->InitialzoneName,$this->FlipIp($this->InitialReverseZone));
}
/* Save Zone Entry Edit Dialog
}
if((isset($_POST['AddMXRecord'])) && (!empty($_POST['StrMXRecord']))){
- $this->mXRecords[] = array("type"=>"mXRecord","inittype"=>"","value"=>trim($_POST['StrMXRecord']),"status"=>"new");
+ $this->mXRecords[] = array("type"=>"mXRecord","value"=>trim($_POST['StrMXRecord']));
}
/* Handle Post events */
if((preg_match("/RemoveRecord_/",$name))&&($once)){
$once = false;
$id= preg_replace("/RemoveRecord_/","",$name);
- if($this->Records[$id]['status']!= "new"){
- $this->Records[$id]['status']= "deleted";
- }else{
- unset($this->Records[$id]);
- }
+ unset($this->Records[$id]);
}
}
/* Add new Zonerecord */
if(isset($_POST['AddNewRecord'])){
- $this->Records[] = array("type"=>"aRecord","inittype"=>"","value"=>"","status"=>"new");
+ $this->Records[] = array("type"=>"aRecord","value"=>"");
}
/* Fill in values */
$message= array();
/* Check if zoneName is already in use */
$usedZones = $this->getUsedZoneNames();
- if(($this->isNew == true)||($this->zoneName != $this->InitiallyZoneName)||($this->ReverseZone != $this->InitiallyReverseZone)){
- if((isset($usedZones[$this->zoneName]))&&($this->zoneName != $this->InitiallyZoneName)){
+ if(($this->isNew == true)||($this->zoneName != $this->InitialzoneName)||($this->ReverseZone != $this->InitialReverseZone)){
+ if((isset($usedZones[$this->zoneName]))&&($this->zoneName != $this->InitialzoneName)){
$message[] =_("This zoneName is already in use");
}
- if((in_array($this->ReverseZone,$usedZones))&&($this->ReverseZone != $this->InitiallyReverseZone)){
+ if((in_array($this->ReverseZone,$usedZones))&&($this->ReverseZone != $this->InitialReverseZone)){
$message[] =_("This reverse zone is already in use");
}
}
$this->Records [] = $rec;
}
- $ret['Records'] = $this->Records;
+ $ret['RECORDS'] = $this->Records;
+
+ $ret['InitialReverseZone']= $this->InitialReverseZone;
+ $ret['InitialzoneName'] = $this->InitialzoneName;
return($ret);
}
if($entry['type'] == "mXRecord") continue;
- if($entry['status'] == "deleted") continue;
-
$changeStateForRecords.= "changeState('RecordTypeSelectedFor_".$key."');\n";
$changeStateForRecords.= "changeState('RecordValue_".$key."');\n";
$changeStateForRecords.= "changeState('RemoveRecord_".$key."');\n";
index 4439e903defdf2438beeb025e7ed3f928d33c4d6..c722bc59dbdfc187389e6437a4bd4a08c890c388 100644 (file)
/* Create diff and follow instructions
* If Account was disabled, remove account by setting exists to false
*/
- if((!$this->DNS_is_account)&&($this->DNSinitially_was_account)){
+ if((!$this->DNS_is_account)&&($this->DNSinitially_was_account)){
$this->dnsEntry['exists'] = false;
$tmp = getDNSHostEntriesDiff($this->config,$this->OrigCn,$this->dnsEntry,$this->cn);
}else{
+ $this->dnsEntry['exists'] = $this->DNS_is_account;
$tmp = getDNSHostEntriesDiff($this->config,$this->OrigCn,$this->dnsEntry,$this->cn);
}
/* Display errors
*/
if($ldap->get_error() != "Success"){
- show_ldap_error($ldap->get_error());
+ show_ldap_error("Record:".$ldap->get_error());
}
}