Code

Reverted 8064
[gosa.git] / plugins / admin / fai / class_faiPartitionTable.inc
index 64604d971970b42c4b78f5aab606f88a2a8b3d98..c85cf9ab33e11f49997054cfe9e286efffb82a78 100644 (file)
@@ -2,11 +2,6 @@
 
 class faiPartitionTable extends plugin
 {
-  /* CLI vars */
-  var $cli_summary= "Manage server basic objects";
-  var $cli_description= "Some longer text\nfor help";
-  var $cli_parameters= array("eins" => "Eins ist toll", "zwei" => "Zwei ist noch besser");
-
   /* attribute list for save action */
   var $ignore_account   = TRUE;
   var $attributes       = array("cn","description");
@@ -20,6 +15,12 @@ class faiPartitionTable extends plugin
   var $dialog           = NULL;     // a dialog, e.g. new disk dialog
 
   var $FAIstate         = "";
+  var $base             = "";
+  var $release          = "";
+  var $copy_paste_mode  = false;
+  var $cut_paste_mode  = false;
+
+  var $CopyPasteVars  = array("disks");
 
   function faiPartitionTable ($config, $dn= NULL)
   {
@@ -86,7 +87,8 @@ class faiPartitionTable extends plugin
            */
           $partition['status']="edited";
           $this->disks[$name]['partitions'][$partition['FAIpartitionNr']] = $partition; 
-        }  
+        } 
+        ksort($this->disks[$name]['partitions']);
       }
     }
     ksort($this->disks);
@@ -94,8 +96,8 @@ class faiPartitionTable extends plugin
 
   function execute()
   {
-       /* Call parent execute */
-       plugin::execute();
+    /* Call parent execute */
+    plugin::execute();
 
     /* Fill templating stuff */
     $smarty= get_smarty();
@@ -157,7 +159,7 @@ class faiPartitionTable extends plugin
     }
 
     /* Dialog saved
-     * Save given data from Dialog, if no error is occured
+     * Save given data from Dialog, if no error is occurred
      */
     if(isset($_POST['SaveDisk'])){
 
@@ -316,6 +318,19 @@ class faiPartitionTable extends plugin
     /* Call common method to give check the hook */
     $message= plugin::check();
 
+    /* If this is a new script, check if a script with this name already exists */
+    if(!empty($this->release) && ($this->copy_paste_mode || $this->cut_paste_mode) ){
+
+      /* Check if current name is already used for fai scripts in selected release */
+      $dn = 'cn='.$this->cn.",ou=disk,".$this->release;
+      $ldap = $this->config->get_ldap_link();
+      $ldap->cat($dn);
+      if($ldap->count()){
+
+        $r =convert_department_dn($this->release);;
+        $message[] = sprintf(_("Can't insert a new fai partition table named '%s' in '%s' there is already one defined with the given name."),$this->cn,$r);
+      }
+    }
     return ($message);
   }
 
@@ -331,6 +346,11 @@ class faiPartitionTable extends plugin
      * 3 : Save partitions for each disk
      */  
 
+    /* Copy & Paste : Ensure that FAIstate is copied too */
+    if($this->copy_paste_mode && preg_match("/freeze/",$this->FAIstate)){
+      $this->attrs['FAIstate'] = $this->FAIstate;
+    }
+
     $ldap = $this->config->get_ldap_link();
 
     if($this->new){
@@ -370,6 +390,11 @@ class faiPartitionTable extends plugin
       $disk_attrs['description']  =  $disk['description']; 
       $disk_attrs['objectClass']  =  array("top","FAIclass","FAIpartitionDisk");
 
+      /* We currently use the copy & paste method */
+      if($this->copy_paste_mode){
+        $disk['status'] = "new";
+      }
+
       if($disk['status']=="new"){
         $ldap->cat($disk_dn,array("objectClass"));
         if($ldap->count()){
@@ -383,7 +408,7 @@ class faiPartitionTable extends plugin
       if(isset($attrs['objectClass']) && in_array_ics("gosaAdministrativeUnitTag",$attrs['objectClass'])){
         $disk_attrs['objectClass'][] = "gosaAdministrativeUnitTag";
       }
+
       if($disk['status'] == "delete"){
         $ldap->cd($disk_dn);
         $ldap->rmdir_recursive($disk_dn);
@@ -419,7 +444,7 @@ class faiPartitionTable extends plugin
       if($disk['status']!="delete"){
 
         /* Add all partitions */
-        foreach($disk['partitions'] as $key => $partition){
+        foreach($disk['partitions'] as $part_nr => $partition){
 
           /* Create attribute array */
           $partition_attrs = array();
@@ -432,6 +457,7 @@ class faiPartitionTable extends plugin
           }
 
           /* Create partition dn and add necessary attributes */
+          $partition_attrs['FAIpartitionNr']= $part_nr;  
           $partition_dn= "FAIpartitionNr=".$partition_attrs['FAIpartitionNr'].",".$disk_dn;      
           $partition_attrs['objectClass']= array("top","FAIclass","FAIpartitionEntry");
           $partition_attrs['cn']= $partition_attrs['FAIpartitionNr'];
@@ -440,6 +466,11 @@ class faiPartitionTable extends plugin
           unset($partition_attrs['status']);
           unset($partition_attrs['old_cn']);
 
+          /* We currently use the copy & paste method */
+          if($this->copy_paste_mode){
+            $partition['status']="new";
+          }
+
           /* Check if this partition is realy new .. */
           if($partition['status']=="new"){
             $ldap->cat($partition_dn,array("objectClass"));
@@ -455,7 +486,10 @@ class faiPartitionTable extends plugin
 
           /* Collect all operations */
           if(($partition['status'] == "delete")&&($disk['status']!="new")){
-            $Todo['delete'][$partition_dn] = $partition_attrs;
+
+            $partition_dn_del = "FAIpartitionNr=".$partition['FAIpartitionNr'].",".$disk_dn;      
+
+            $Todo['delete'][$partition_dn_del] = $partition_attrs;
           }elseif($partition['status'] == "new"){
             $Todo['rest'][$partition_dn] = $partition_attrs;
           }elseif($partition['status'] == "edited"){
@@ -467,7 +501,7 @@ class faiPartitionTable extends plugin
       /* First of all, delete old entries */
       foreach($Todo['delete'] as $partition_dn => $attrs){
           $ldap->cd($partition_dn);
-          $ldap->rmdir_recursive($partition_dn);
+          $res = $ldap->rmdir_recursive($partition_dn);
           show_ldap_error($ldap->get_error(), _("Removing FAI partition table entry failed"));
       }
     
@@ -486,6 +520,15 @@ class faiPartitionTable extends plugin
           if(empty($partition_attrs['description'])){
             $partition_attrs['description']=array();
           }
+          if(empty($partition_attrs['FAIfsOptions'])){
+            $partition_attrs['FAIfsOptions']=array();
+          }
+          if(empty($partition_attrs['FAImountOptions'])){
+            $partition_attrs['FAImountOptions']=array();
+          }
+          if(empty($partition_attrs['FAIpartitionFlags'])){
+            $partition_attrs['FAIpartitionFlags']=array();
+          }
           $ldap->cd($partition_dn);
           $this->cleanup();
           $ldap->modify ($partition_attrs); 
@@ -499,14 +542,40 @@ class faiPartitionTable extends plugin
           $ldap->cd($this->config->current['BASE']);
           $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $partition_dn));
           $ldap->cd($partition_dn);
+          if (isset($partition_attrs['gosaUnitTag']) && !in_array_ics("gosaAdministrativeUnitTag",$partition_attrs['objectClass'])){
+            $partition_attrs['objectClass'][]= "gosaAdministrativeUnitTag";
+          }
           $ldap->add($partition_attrs);
           show_ldap_error($ldap->get_error(), _("Saving FAI partition table entry failed"));
         }
+        $this->handle_object_tagging($partition_dn, $this->gosaUnitTag);
       }
-      $this->handle_object_tagging($partition_dn, $this->gosaUnitTag);
     }
     $this->handle_post_events("add");
   }
+
+  
+  /* return copy & paste dialog
+   */
+  function getCopyDialog()
+  {
+    /* Ask for cn */
+    $smarty = get_smarty();
+    $smarty->assign("cn" ,$this->cn);
+    $str = $smarty->fetch(get_template_path("paste_fai_object.tpl",TRUE));
+    $ret = array();
+    $ret['string'] = $str;
+    $ret['status'] = "";
+    return($ret);
+  }
+
+  /* Get posted cn */
+  function saveCopyDialog()
+  {
+    if(isset($_POST['cn'])){
+      $this->cn = $_POST['cn'];
+    }
+  }
 }
 
 // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: