Code

Added seperate list handler for gotomasses.
[gosa.git] / plugins / addons / gotomasses / class_gotomasses.inc
index ce1b6395c4ae57ebebf1e240ec1be53851a791eb..4a58ca9c8db74179e8499b15c506f28239f3e579 100644 (file)
@@ -3,7 +3,7 @@
 class gotomasses extends plugin
 {
   /* Definitions */
-  var $plHeadline     = "System mass deployment";
+  var $plHeadline     = "System deployment";
   var $plDescription  = "This does something";
 
   /* attribute list for save action */
@@ -17,20 +17,24 @@ class gotomasses extends plugin
   var $tasks = array();
   var $current =false;
   var $dialog = FALSE;
+  var $ids_to_remove = array();
+  var $divlist = NULL;
 
-  function gotomasses($config, $dn= NULL)
+  function gotomasses(&$config, $dn= NULL)
   {
-    /* Define source file */
-    $this->data_file = CONFIG_DIR."/gotomasses_machines";
-  
     /* Include config object */
-    $this->config= $config;
+    $this->config= &$config;
 
+    /* Define source file */
+    $this->data_file = CONFIG_DIR."/gotomasses_machines";
+    $file = $this->config->search("gotomasses", "STORAGE_FILE",array('menu'));
+    if(!empty($file)){
+      $this->data_file = $file;
+    }
     $this->load_gotomasses_data();
   }
 
 
-
   function execute()
   {
     $smarty = get_smarty();
@@ -39,7 +43,8 @@ class gotomasses extends plugin
      ************/
 
     $s_entry = $s_action = "";
-    $arr = array("/^edit_task_/"=>"edit","/^remove_task_/"=>"remove","/^new_task_/"=>"new_task");
+    $arr = array( "/^edit_task_/"=>"edit","/^remove_task_/"=>"remove",
+                  "/^new_task_/"=>"new_task","/^remove_multiple_task_/" => "remove_multiple");
     foreach($arr as $regex => $action){
       foreach($_POST as $name => $value){
         if(preg_match($regex,$name)){
@@ -50,15 +55,60 @@ class gotomasses extends plugin
       }
     }
 
+    /* Edit posted from list link */
+    if(isset($_GET['act']) && $_GET['act'] == "edit" && isset($_GET['id']) && isset($this->tasks[$_GET['id']])){
+      $s_action = "edit";
+      $s_entry = $_GET['id'];
+    }
+
     /************
      * List posts 
      ************/
 
+    /* Remove multiple */
+    if($s_action == "remove_multiple"){
+      if(!$this->acl_is_removeable()){
+        print_red(_("You are not allowed to remove a task."));
+      }else{
+        $this->ids_to_remove = $this->list_get_selected_items();
+        $tmp = "";
+        foreach($this->ids_to_remove as $key => $id){
+          if(isset($this->tasks[$id])){
+            $task = $this->tasks[$id];
+            $tmp.= "\n".$this->target_to_string($task);
+          }else{
+            unset($this->ids_to_remove[$key]);
+          }
+        }
+        $smarty->assign("multiple", TRUE); 
+        $smarty->assign("info",sprintf(_("Your are about to delete the following tasks: %s"),"<pre>".$tmp."</pre>"));
+        $this->current = $s_entry;
+        return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+      }
+    }
+
+    /* Remove specified tasks */
+    if(count($this->ids_to_remove) && isset($_POST['delete_multiple_confirm'])){
+      foreach($this->ids_to_remove as $id){
+        if(isset($this->tasks[$id])){
+          unset($this->tasks[$id]);
+        }
+      }
+      $this->save();
+    }
+
     /* Remove entry from list */
     if($s_action == "remove" && isset($this->tasks[$s_entry])){
-      $smarty->assign("info",_("Your are about to delete a gotomasses task."));
-      $this->current = $s_entry;
-      return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+      if(!$this->acl_is_removeable()){
+        print_red(_("You are not allowed to remove a task."));
+      }else{
+        $entry = $this->tasks[$s_entry];
+        $this->current = $s_entry;
+        $smarty->assign("info",sprintf(_("Your are about to delete the following tasks: %s"),
+                                    "<pre>".$this->target_to_string($entry)."</pre>"));
+        $smarty->assign("multiple", FALSE); 
+        return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+      }
     }
 
     /* Remove entry, remove is confirmed */
@@ -68,6 +118,11 @@ class gotomasses extends plugin
       $this->save();
     }
 
+    /* Remove aborted */
+    if(isset($_POST['delete_cancel'])){
+      $this->ids_to_remove = array();;
+    }
+
     /* Edit selected entry */
     if($s_action == "edit" && isset($this->tasks[$s_entry])){
       $entry = $this->tasks[$s_entry];
@@ -76,7 +131,7 @@ class gotomasses extends plugin
     }
 
     /* New entry */
-    if($s_action== "new_task"){
+    if($s_action== "new_task" && $this->acl_is_createable()){
       $this->dialog = new goto_task($this->config,$this);
       $this->current = -1;
     }
@@ -88,7 +143,7 @@ class gotomasses extends plugin
     }
 
     /* Close dialog */
-    if(isset($_POST['save_goto_task']) && is_object($this->dialog)){
+    if((isset($_POST['save_goto_task']) || isset($_POST['apply_goto_task'])) && is_object($this->dialog) ){
       $this->dialog->save_object();
       $msgs = $this->dialog->check();
       if(count($msgs)){
@@ -101,12 +156,14 @@ class gotomasses extends plugin
         }else{
           $this->tasks[] = $this->dialog->save();
         }
-        $this->dialog = FALSE;
-        $this->current = -1;
+        if(!isset($_POST['apply_goto_task'])){
+          $this->dialog = FALSE;
+          $this->current = -1;
+        }
         $this->save();
       }
     }
+
     /* Display dialogs if currently opened */
     if(is_object($this->dialog)){
       $this->dialog->save_object();
@@ -118,50 +175,24 @@ class gotomasses extends plugin
      * Handle Divlist 
      ************/
 
-    $plug = $_GET['plug'];
-    $divlist = new MultiSelectWindow($this->config,"GotoMasses","gotomassses");
-    $divlist->SetSummary(_("Gotomasses tasks"));
-    $divlist->SetHeadpageMode();
-    $divlist->EnableCloseButton(FALSE);
-    $divlist->EnableSaveButton(FALSE);
-    $divlist->SetInformation(_("This menu allows you to add, remove and change the properties of gotomasses tasks."));
-    
-    $header = "<div style='padding:5px'>
-                <input type='image' src='images/gotomasses_new_task.png' name='new_task' class='center'>
-               </div>";
-  
-    $divlist->SetListHeader($header);
-    $divlist->AddHeader(array("string"=>"<a href='?plug=".$plug."&amp;sort=object'>"._("Target")."</a>"));
-    $divlist->AddHeader(array("string"=>"<a href='?plug=".$plug."&amp;sort=schedule'>"._("Schedule")."</a>",
-                                      "attach"=>"style='width:100px;'"));
-    $divlist->AddHeader(array("string"=>"<a href='?plug=".$plug."&amp;sort=action'>"._("Type")."</a>",
-                                      "attach"=>"style='width:60px;'"));
-    $divlist->AddHeader(array("string"=>_("Action"),
-                                      "attach"=>"style='border-right:0px;width:40px;'"));
-    foreach($this->tasks as $key => $task){
-  
-      $action = "<input type='image' src='images/edit.png' name='edit_task_".$key."' class='center' alt='"._("Edit")."'>";
-      $action.= "<input type='image' src='images/edittrash.png' name='remove_task_".$key."' class='center' alt='"._("Reomve")."'>";
-
-      $field1 = array("string" => "<div style='width:100%;overflow:hidden;'><nobr>".$this->target_to_string($task)."</nobr></div>");
-      $field2 = array("string" => $this->time_to_string($task),"attach" => "style='width:100px;'");
-      $field3 = array("string" => $this->action_to_string($task),"attach" => "style='width:60px;'");
-      $field4 = array("string" => $action,"attach" => "style='width:40px;border-right:0px;'");
-      
-      $divlist->AddElement(array($field1,$field2,$field3,$field4));
-    }
-    return($divlist->Draw());
+    $list = new divListMasses($this->config,$this);
+    $list->SetEntries($this->tasks); 
+    return($list->Draw());
   }
 
   
   function target_to_string($data)
   {
     $ret = "";
-    foreach($data['Target'] as $target){
-      $ret .= preg_replace("/^[^:]+:/i","",$target).", ";
-    } 
+    if($data['Action'] == "initial_install"){
+      foreach($data['Initial_Target'] as $target){
+        $ret .= $target['MAC'].", ";
+      } 
+    }else{
+      foreach($data['Target'] as $target){
+        $ret .= $target.", ";
+      } 
+    }
     return(preg_replace("/, $/","",$ret));
   }
 
@@ -174,13 +205,11 @@ class gotomasses extends plugin
   
   function action_to_string($data)
   {
-    switch($data['Action']){
-
-      case 'reinstall' : return("Reinstall");break;
-      case 'install' : return("Install");break;
-      case 'reboot' : return("Restart");break;
-      case 'update' : return("Update");break;
-      default : return("Unknown");
+    $tmp = $this->get_actions();
+    if(isset($tmp[$data['Action']])){
+      return($tmp[$data['Action']]);
+    }else{
+      return(_("Unknown"));
     }
   }
 
@@ -189,12 +218,13 @@ class gotomasses extends plugin
   {
     $ui = get_userinfo();
 
-    
+    /* Check file existence */
     if(!file_exists($this->data_file) || !is_readable($this->data_file)){
       print_red(sprintf(_("Can't locate or read gotomasses storage file '%s'."),$this->data_file));
       return(FALSE);
     }
 
+    /* check if file is readable */
     $fp = @fopen($this->data_file,"r");
     if(!$fp){
       print_red(sprintf(_("Can't read gotomasses storage file '%s'."),$this->data_file));
@@ -232,7 +262,7 @@ class gotomasses extends plugin
       $row    = preg_replace('/  */umi'," ",$row);
       $parts  = split(" ",$row);
 
-      if(count($parts) != 8){
+      if(count($parts) != 10){
         print_red(_("Entry broken, skipped."));
       }else{
 
@@ -244,7 +274,22 @@ class gotomasses extends plugin
         $entry['Weekday'] = $parts[4];  
         $entry['Action']  = $parts[5];  
         $entry['OGroup']  = $parts[6];  
-        $entry['Target']  = split(",",$parts[7]);  
+        $entry['Zone']    = $parts[7];  
+        $entry['Section'] = $parts[8];  
+        if($entry['Action'] == "initial_install"){
+          $tmp2 = split(";",$parts[9]);
+          foreach($tmp2 as $target){
+            $tmp = split(",",$target);
+            $entry['Initial_Target'][]  = array(
+                          "MAC"     => $tmp[0],
+                          "IP"      => $tmp[1],
+                          "NAME"    => $tmp[2]);
+          }
+          $entry['Target']  = array();
+        }else{
+          $entry['Initial_Target']  = array();
+          $entry['Target']  = split(";",$parts[7]);
+        }
         $entry['Comment'] = $comment;  
         $this->tasks []   = $entry;
       }
@@ -255,38 +300,49 @@ class gotomasses extends plugin
   function save_gotomasses_data()
   {
     $str = "#GOsa generated file, please just modify if you realy know what you do.";
-  
     foreach($this->tasks as $task){
       $str .= "\n#".trim($task['Comment']);
-
       $str .= "\n";
-      $str .= str_pad($task['Minute'] ,5," ")." ";
-      $str .= str_pad($task['Hour']   ,5," ")." ";
-      $str .= str_pad($task['Day']    ,5," ")." ";
-      $str .= str_pad($task['Month']  ,5," ")." ";
-      $str .= str_pad($task['Weekday'],5," ")." ";
+      if($task['Action'] == "initial_install"){
+        $str .= "*     *     *     *     *     ";
+      }else{
+        $str .= str_pad($task['Minute'] ,5," ")." ";
+        $str .= str_pad($task['Hour']   ,5," ")." ";
+        $str .= str_pad($task['Day']    ,5," ")." ";
+        $str .= str_pad($task['Month']  ,5," ")." ";
+        $str .= str_pad($task['Weekday'],5," ")." ";
+      }
       $str .= str_pad($task['Action'] ,5," ")." ";
       $str .= str_pad($task['OGroup'] ,5," ")." ";
-    
-      foreach($task['Target'] as $target){
-        $str .= $target.",";
+      $str .= str_pad($task['Zone']   ,5," ")." ";
+      $str .= str_pad($task['Section'],5," ")." ";
+      if($task['Action'] == "initial_install"){
+        foreach($task['Initial_Target'] as $target){
+          $str .= trim($target['MAC']).",".trim($target['IP']).",".trim($target['NAME']).";";
+        }
+      }else{
+        foreach($task['Target'] as $target){
+          $str .= $target.";";
+        }
       }
-      $str = preg_replace("/,$/","",$str);
+      $str = preg_replace("/;$/","",$str);
     }
 
+    /* check file existence*/
     $ui = get_userinfo();
-
     if(!file_exists($this->data_file) || !is_writeable($this->data_file)){
       print_red(sprintf(_("Can't locate or write gotomasses storage file '%s'."),$this->data_file));
       return(FALSE);
     }
 
+    /* check permissions */
     $fp = @fopen($this->data_file,"w");
     if(!$fp){
       print_red(sprintf(_("Can't read gotomasses storage file '%s'."),$this->data_file));
       return(FALSE);
     }
 
+    /* Write contents */
     $str .= "\n";
     fwrite($fp,$str);
     fclose($fp);
@@ -295,8 +351,6 @@ class gotomasses extends plugin
 
   function save_object()
   {
-    if(isset($_POST['gotomasses'])){
-    }
   }
 
 
@@ -320,15 +374,30 @@ class gotomasses extends plugin
   }
 
 
+  function list_get_selected_items()
+  {
+    $ids = array();
+    foreach($_POST as $name => $value){
+      if(preg_match("/^item_selected_[0-9]*$/",$name)){
+        $id   = preg_replace("/^item_selected_/","",$name);
+        $ids[$id] = $id;
+      }
+    }
+    return($ids);
+  }
+
+
   function get_actions()
   {
     /* Prepare list of available actions */
-    $actions = array( "reboot"          => _("Reboot"),
+    $actions = array(       "reboot"          => _("Reboot"),
                             "localboot"       => _("Localboot"),
                             "halt"            => _("Halt system"),
+                            "initial_install" => _("Initial installation"),
                             "update"          => _("Update"),
                             "reinstall"       => _("(Re)Install"),
                             "rescan"          => _("Rescan"),
+                            "wake"            => _("Wake"),
                             "memcheck"        => _("Memory check"));
     return($actions);
   }