summary | shortlog | log | commit | commitdiff | tree
raw | patch | inline | side by side (parent: e5b2749)
raw | patch | inline | side by side (parent: e5b2749)
| author | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
| Wed, 12 Sep 2007 06:56:13 +0000 (06:56 +0000) | ||
| committer | hickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8> | |
| Wed, 12 Sep 2007 06:56:13 +0000 (06:56 +0000) | 
- Removed 'Add Ptrrecord' icon
- Hide Reverse entries.
- Automatically update and add ptrrecords
git-svn-id: https://oss.gonicus.de/repositories/gosa/branches/2.5@7273 594d385d-05f5-0310-b6e9-bd551577e9d8
- Hide Reverse entries.
- Automatically update and add ptrrecords
git-svn-id: https://oss.gonicus.de/repositories/gosa/branches/2.5@7273 594d385d-05f5-0310-b6e9-bd551577e9d8
| plugins/admin/systems/class_servDNSeditZoneEntries.inc | patch | blob | history | 
diff --git a/plugins/admin/systems/class_servDNSeditZoneEntries.inc b/plugins/admin/systems/class_servDNSeditZoneEntries.inc
index f317e1fb62ad191fa28ef9f5916ff72b8b896ea6..c63aa2b7fae02a12412da6b3cbad0876410a5270 100644 (file)
     if(isset($this->RecordTypes['nSRecord'])){
       unset($this->RecordTypes['nSRecord']);
     }
+    /* Remove nSRecord from listed types */
+    if(isset($this->RecordTypes['pTRRecord'])){
+      unset($this->RecordTypes['pTRRecord']);
+    }
     $this->dn           = "zoneName=".getNameFromMix($zoneObject['InitialzoneName']).",".$dn; 
     $this->zoneName     = $zoneObject['InitialzoneName'];
   {
     plugin::execute();
-
+    print_a($this->Devices);
     /* Fill templating stuff */
     $smarty= get_smarty();
     /* Check posts for operations ...  
      */
     $once = true;
+    $ptr_updates = array();
     foreach($_POST as $name => $value){
       /* Add a new Record in given object  
           unset($this->Devices[$Name]['RECORDS'][$RecordID]);
         }
       }
-
-      /* Add PTR record 
-       */
-      if((preg_match("/^AddPtr_/",$name)) && ($once)){
-        $once   = false;
-        if(isset($this->Devices[$Name]['RECORDS'][$RecordID])){
-          $tmp = $this->Devices[$Name]['RECORDS'][$RecordID];
-          $ip = $tmp['value'];
-          $match = preg_replace("/^[^\/]*+\//","",$this->reverseName);
-          $ip = preg_replace("/^".normalizePreg($match)."/","",$ip);
-          $ip = preg_replace("/^\./","",$ip);
-          $tmp['type'] = "pTRRecord";
-          $tmp['value'] = $ip;
-          $this->Devices[$Name]['RECORDS'][] = $tmp;
-        }
-      }
     }
     /* Possible attributes posted 
        */          
       if(preg_match("/ValueSelection_/",$name)){
         if(isset($this->Devices[$Name]['RECORDS'][$RecordID])){
+         
+          /* Update value */ 
+          $old = $this->Devices[$Name]['RECORDS'][$RecordID]['value'];
           $this->Devices[$Name]['RECORDS'][$RecordID]['value'] = $value;
+
+          /* Handle pTRRecord */
+          if(!isset($ptr_updates[$Name]) && $this->Devices[$Name]['RECORDS'][$RecordID]['type'] == "aRecord"){
+    
+            $found = false;
+            $ip = $value;
+            $match = preg_replace("/^[^\/]*+\//","",$this->reverseName);
+            $ip = preg_replace("/^".normalizePreg($match)."/","",$ip);
+            $ip = preg_replace("/^\./","",$ip);
+
+            foreach($this->Devices[$Name]['RECORDS'] as $key => $dev){
+              if($dev['type'] == "pTRRecord"){
+                $ptr_updates[$Name] = $Name;
+                $this->Devices[$Name]['RECORDS'][$key]['value'] = $ip;
+                $found = true;
+                break;
+              }
+            }
+            if(!$found){
+              $dev = array('type'=> 'pTRRecord', 'value' => $ip);
+              $this->Devices[$Name]['RECORDS'][] = $dev;
+            }
+          }
         }
       }
     $str.= "<table cellspacing='0' cellpadding='0'>";
     foreach($obj['RECORDS'] as $id => $record){
+      /* Skip not selectable entries */
+      if(!isset($this->RecordTypes [$record['type']])) {
+        continue;
+      }
+
       /* Create unique post name
        */
       $name = base64_encode($objKey)."|".$id;
           <input type='image' name='RemoveRecord_".$name."' src='images/edittrash.png'      alt='"._("Remove")."' title='"._("Remove")."'>
         ";
-        if($record['type'] == "aRecord"){
-          $str .="<input type='image' name='AddPtr_".$name."' src='images/network.png' 
-                    alt='"._("Add PTR")."' title='"._("Add PTR record")."'>";
-        }else{
-          $str .= "<img src='images/empty.png' alt=''>";
-        }
+#        if($record['type'] == "aRecord"){
+#          $str .="<input type='image' name='AddPtr_".$name."' src='images/network.png' 
+#                    alt='"._("Add PTR")."' title='"._("Add PTR record")."'>";
+#        }else{
+#          $str .= "<img src='images/empty.png' alt=''>";
+#        }
       $str.=
         "</td>
![[tokkee]](http://tokkee.org/images/avatar.png)
