Code

Fixed shareserver list
[gosa.git] / plugins / personal / environment / class_environment.inc
index c3bfcd8362c44d921cc11363e749f9e58741d4aa..248595e9b77d5b4993c87fb76fd47575bf487bd7 100644 (file)
@@ -12,7 +12,9 @@ class environment extends plugin
   var $plHeadline           = "Environment";
   var $plDescription        = "This does something";
   var $dialog               = false;    // Indicates that we are currently editing in an seperate dialog
-
+  
+  var $in_dialog            = false;
+  var $uid                  = "";
   /* Attribute definition
    */
 
@@ -93,6 +95,29 @@ class environment extends plugin
       }
     }
     
+    /* prepare LogonScripts */
+    if((isset($this->attrs['gotoLogonScript']))&&(is_array($this->attrs['gotoLogonScript']))){
+      unset($this->attrs['gotoLogonScript']['count']);
+      foreach($this->attrs['gotoLogonScript'] as $device){
+        $tmp = $tmp2 = array();
+        $tmp = split("\|",$device);
+        $tmp2['LogonName']        = $tmp[0]; 
+        $tmp2['LogonPriority']    = $tmp[2]; 
+        if(preg_match("/O/i",$tmp[1])){
+          $tmp2['LogonOverload'] = "O";
+        }else{
+          $tmp2['LogonOverload'] = "";
+        }
+        if(preg_match("/L/i",$tmp[1])){
+          $tmp2['LogonLast'] = "L";
+        }else{
+          $tmp2['LogonLast'] = "";
+        }
+        $tmp2['LogonData']        = base64_decode($tmp[3]); 
+        $this->gotoLogonScripts[$tmp[0]]=$tmp2;
+      }
+    }
+    
     /* Prepare Shares */
     if((isset($this->attrs['gotoShare']))&&(is_array($this->attrs['gotoShare']))){
       unset($this->attrs['gotoShare']['count']);
@@ -130,7 +155,7 @@ class environment extends plugin
 
     // 1. Account disabled . Editing from usermenu
     if((!isset($this->parent))&&(!$this->is_account)){
-      /* We are currently editing this tab from usermenu, but htis account is not enabled */
+      /* We are currently editing this tab from usermenu, but this account is not enabled */
       $smarty->assign("is_account",$this->is_account);
       /* Load template */
       $display .= $smarty->fetch(get_template_path('environment.tpl', TRUE));
@@ -157,10 +182,17 @@ class environment extends plugin
           $display= $this->show_header(_("Remove environment extension"),
               _("This server has environment extension enabled. You can disable it by clicking below."));
         } else {
-        // 4. Account disabled . Editing from adminmenu
-          $display= $this->show_header(_("Add environment extension"),
-              _("This server has environment extension disabled. You can enable it by clicking below."));
-          return $display;
+          if((in_array("posixAccount",$this->attrs['objectClass']))||($this->parent->by_object['posixAccount']->is_account==true)){
+            // 4. There is a PosixAccount
+            $display= $this->show_header(_("Add environment extension"),
+                _("This server has environment extension disabled. You can enable it by clicking below."));
+            return $display;
+          }else{
+            // 4. There is a PosixAccount
+            $display= $this->show_header(_("Add environment extension"),
+                _("This server has environment extension disabled. You have to setup a posix account before you can enable this feature."),TRUE,TRUE);
+            return $display;
+          }
         }
       }
     }
@@ -188,7 +220,14 @@ class environment extends plugin
       }
  
     }
-  
+    if($this->acl != "#none#"){
+      $smarty->assign("useProfileACL","");
+    }else{
+      $smarty->assign("gotoProfileFlag_CACL"," disabled ");
+      $smarty->assign("gotoProfileServer"," disabled ");
+    }
+
     /* HANDLE Profile Settings here 
      * Assign available Quota and resolution settings
      * Get all available profile server
@@ -205,7 +244,7 @@ class environment extends plugin
     }
 
     $this->gotoXResolutions = array("640x480","800x600","1024x768","1280x768","1280x1024");
-    $this->gotoProfileServers = array("none","none1");
+    $this->gotoProfileServers =$this->getShareServerList() ;
 
     $smarty->assign("gotoXResolutions",$this->gotoXResolutions);
     $smarty->assign("gotoProfileServers",$this->gotoProfileServers);
@@ -238,10 +277,28 @@ class environment extends plugin
      * Perform add Delete edit Posts 
      */
 
-    $this->gotoLogonScripts = array("asdf"=>"one","aaaa"=>"two","121"=>"3");
-  
-    $smarty->assign("gotoLogonScripts",$this->gotoLogonScripts);
-    $smarty->assign("gotoLogonScriptKeys",array_flip($this->gotoLogonScripts));
+    /* Dialog Save */
+    if(isset($_POST['LogonSave'])){
+      $this->dialog->save_object();
+      if(count($this->dialog->check())!=0){
+        foreach($this->dialog->check() as $msg){
+          print_red($msg);
+        }
+      }else{
+        $tmp = $this->dialog->save();
+        unset($this->dialog);
+        $this->dialog=NULL;
+        $this->is_dialog=false;
+        $this->gotoLogonScripts[$tmp['LogonName']]=$tmp; 
+      }
+    }
+    
+    /* Dialog Quit without saving */
+    if(isset($_POST['LogonCancel'])){
+      $this->is_dialog= false;
+      unset($this->dialog);
+      $this->dialog= NULL;
+    }
    
     /* Check Edit Del New Posts for a selected LogonScript */ 
     if(isset($_POST['gotoLogonScriptNew'])||isset($_POST['gotoLogonScriptEdit'])||isset($_POST['gotoLogonScriptDel'])){
@@ -258,8 +315,7 @@ class environment extends plugin
        * We only can delete if there is an entry selected.
        */
       if((isset($_POST['gotoLogonScriptDel']))&&(isset($_POST['gotoLogonScript']))){
-        $is_entry = $this->gotoLogonScripts[$_POST['gotoLogonScript']];
-        print "Deleting ".$is_entry;
+        unset($this->gotoLogonScripts[$_POST['gotoLogonScript']]);
       }
       
       /* In this case we want to edit an existing entry, we open a new Dialog to allow editing.
@@ -271,7 +327,11 @@ class environment extends plugin
         $this->dialog = new logonManagementDialog($this->config,$this->dn,$is_entry);
       }
     }
-    
+     
+    /* Append List to smarty*/
+    $smarty->assign("gotoLogonScripts",   $this->printOutLogonScripts());
+    $smarty->assign("gotoLogonScriptKeys",array_flip($this->printOutLogonScripts()));
+
     /* In this section server shares will be defined 
      * A user can select one of the given shares and a mount point
      *  and attach this combination to his setup.
@@ -422,7 +482,18 @@ class environment extends plugin
       $this->dialog->save_object();
       return ($this->dialog->execute());
     }
+    if($this->acl != "#none#"){
+      $smarty->assign("useProfileACL","");
+    }else{
+      $smarty->assign("gotoProfileFlag_CACL"," disabled ");
+      $smarty->assign("gotoProfileServerACL"," disabled ");
+    }
+
+    if(!$this->useProfile){
+      $smarty->assign("gotoProfileFlag_CACL"," disabled ");
+      $smarty->assign("gotoProfileServerACL"," disabled ");
+    }
+
     /* Als smarty vars are set. Get smarty template and generate output */
     $display.= $smarty->fetch(get_template_path('environment.tpl', TRUE,dirname(__FILE__)));
     
@@ -473,7 +544,7 @@ class environment extends plugin
     if(isset($_POST['iamposted'])){
       plugin::save_object();
       foreach($this->attributes as $s_attr){
-        if(in_array($s_attr,array("gotoShares","gotoHotplugDevices","gotoPrinters"))) continue;
+        if(in_array($s_attr,array("gotoShares","gotoHotplugDevices","gotoPrinters","gotoLogonScripts","uid"))) continue;
         if(isset($_POST[$s_attr])){
           $this->$s_attr = $_POST[$s_attr];
         }else{
@@ -499,7 +570,7 @@ class environment extends plugin
     $ldap= $this->config->get_ldap_link();
 
     $realyUsedAttrs= array();
-    
+  
     /* Save already used objectClasses */
     $ocs        = $this->attrs['objectClass'];
     unset($ocs['count']);
@@ -513,6 +584,58 @@ class environment extends plugin
 
 
     /* Save usersettings to Printer */
+
+    if(chkacl($this->acl,"gotoPrinter")!=""){
+      $this->gotoPrinters = array();
+    }  
+
+    if(count($this->gotoPrinters)==0){
+      $ldap->search("(&(objectClass=gotoPrinter)(|(gotoUserPrinter=".$this->uid.")(gotoAdminPrinter=".$this->uid.")))",array("*"));
+      while($attr = $ldap->fetch()){
+      
+        foreach($attr['gotoUserPrinter'] as $key => $user){
+          if($this->uid==$user){
+            unset($attr['gotoUserPrinter'][$key]);
+          }
+        }    
+
+        foreach($attr['gotoAdminPrinter'] as $key => $user){
+          if($this->uid==$user){
+            unset($attr['gotoAdminPrinter'][$key]);
+          }
+        }    
+
+        $attrs_used = array();
+        foreach($attr as $key=>$val){
+          if((!is_numeric($key))&&($key!="count")){
+            if(is_array($val)&&isset($val['count'])){
+              unset($val['count']);
+            }
+            $attrs_used[$key]=$val;
+          }
+        }
+        $attr= $attrs_used;
+        $tmp =array();
+        foreach($attr['gotoAdminPrinter'] as $print){
+          $tmp[]=$print;
+        }
+        $attr['gotoAdminPrinter'] = $tmp;
+
+        $tmp =array();
+        foreach($attr['gotoUserPrinter'] as $print){
+          $tmp[]=$print;
+        }
+        $attr['gotoUserPrinter'] = $tmp;
+
+        $ldap->cd($attr['dn']);
+        unset($attr['dn']);
+        $ldap->modify($attr);
+        if($ldap->get_error()!="Success"){
+          print_red("Printer saving ".$ldap->get_error());
+        }
+      }
+    }    
+
     foreach($this->gotoPrinters as $printer) {
       $ldap->cd($printer['dn']);
       $ldap->cat($printer['dn']);
@@ -537,7 +660,7 @@ class environment extends plugin
         $attribute  = "gotoAdminPrinter";
         $attribute2 = "gotoUserPrinter";
       }
-      
+
       /* If this user is already assigned to $attribute2 
        * delete user from $attribute2, to be albe to attach him to $attribute
        * A user can't be admin and normal user for one printer
@@ -548,14 +671,14 @@ class environment extends plugin
         if(in_array($this->uid,$printer[$attribute2])){ 
           $tmp = array_flip($attrs[$attribute2]);
           unset($tmp[$this->uid]);
-          $attrs[$attribute2]=$tmp;
+          $attrs[$attribute2]=array_flip($tmp);
         }
         /* If Last entry removed, clear attribute*/
         if(empty($attrs[$attribute2])){
           $attrs[$attribute2]=array();
         }
       }
-
+    
       /* Attach user to the $attribute, if he is'nt already attached
        */
       if(!isset($attrs[$attribute])){
@@ -566,20 +689,50 @@ class environment extends plugin
           $attrs[$attribute][]=$this->uid;
         }
       }
+
+      $tmp =array();
+      if(isset($attrs['gotoAdminPrinter'])){
+        foreach($attrs['gotoAdminPrinter'] as $print){
+          $tmp[]=$print;
+        }
+      }
+      $attrs['gotoAdminPrinter'] = $tmp;
+
+      $tmp =array();
+      if(isset($attrs['gotoUserPrinter'])){
+        foreach($attrs['gotoUserPrinter'] as $print){
+          $tmp[]=$print;
+        }
+      }
+      $attrs['gotoUserPrinter'] = $tmp;
+
       $ldap->cd($attrs['dn']);
       unset($attrs['dn']);
       $ldap->modify($attrs);
       if($ldap->get_error()!="Success"){
-        print_red($ldap->get_error());
+        print_red("Printer saving ".$ldap->get_error());
       }
     }
-    
+  
+    if(isset($this->attrs['gotoPrinter'])){
+      unset($this->attrs['gotoPrinter']);
+    }
     /* Prepare HotPlug devices */
     $this->attrs['gotoHotplugDevice'] = array();
     foreach($this->gotoHotplugDevices as $name => $device){
       $this->attrs['gotoHotplugDevice'][] = $device['name']."|".$device['description']."|".$device['id'];
     }
 
+    /* Prepare LogonScripts */
+    $this->attrs['gotoLogonScript'] = array();
+    foreach($this->gotoLogonScripts as $name => $script){
+      $this->attrs['gotoLogonScript'][] =   $script['LogonName']."|".
+                                            $script['LogonOverload'].$script['LogonLast']."|".
+                                            $script['LogonPriority']."|".
+                                            base64_encode($script['LogonData']); 
+    }
+
     /* Prepare Shares */
     $this->attrs['gotoShare']=array();
     foreach($this->gotoShares as $name => $share){
@@ -613,6 +766,14 @@ class environment extends plugin
       $this->attrs['gotoProfileServer']= array(); 
     }
 
+    foreach($this->attributes as $s_attr){
+      if(chkacl($this->acl,$s_attr)!="") {
+        if(isset($this->attrs[$s_attr])){
+          unset($this->attrs[$s_attr]);
+        }
+      }
+    }
+
     $ldap->cat ($this->dn);
     if ($ldap->fetch()){
       $mode= "modify";
@@ -630,9 +791,6 @@ class environment extends plugin
     $this->handle_post_events($mode);
   }
 
-
-
-
 /* This function returns all available Shares defined in this ldap 
  * There are two ways to call this function, if listboxEntry is true
  *  only name and path are attached to the array, in it is false, the whole 
@@ -644,22 +802,38 @@ class environment extends plugin
     $a_res = $ldap->search("(objectClass=goShareServer)",array("goExportEntry"));
     $return= array();
     while($entry = $ldap->fetch($a_res)){
-      $shareAttrs = split("\|",$entry['goExportEntry'][0]);
-      if($listboxEntry) { 
-        $return[$shareAttrs[0]] = $shareAttrs[0]." - ".$shareAttrs[3];
-      }else{
-        $return[$shareAttrs[0]]['name']         = $shareAttrs[0]; 
-        $return[$shareAttrs[0]]['description']  = $shareAttrs[1]; 
-        $return[$shareAttrs[0]]['type']         = $shareAttrs[2]; 
-        $return[$shareAttrs[0]]['charset']      = $shareAttrs[3]; 
-        $return[$shareAttrs[0]]['path']         = $shareAttrs[4]; 
-        $return[$shareAttrs[0]]['option']       = $shareAttrs[5]; 
+      unset($entry['goExportEntry']['count']);
+      foreach($entry['goExportEntry'] as $export){
+        $shareAttrs = split("\|",$export);
+        if($listboxEntry) { 
+          $return[$shareAttrs[0]] = $shareAttrs[0]." - ".$shareAttrs[4];
+        }else{
+          $return[$shareAttrs[0]]['name']         = $shareAttrs[0]; 
+          $return[$shareAttrs[0]]['description']  = $shareAttrs[1]; 
+          $return[$shareAttrs[0]]['type']         = $shareAttrs[2]; 
+          $return[$shareAttrs[0]]['charset']      = $shareAttrs[3]; 
+          $return[$shareAttrs[0]]['path']         = $shareAttrs[4]; 
+          $return[$shareAttrs[0]]['option']       = $shareAttrs[5]; 
+        }
       }
     }
     return($return);
   }
 
 
+/* This function returns all available ShareServer  
+ */
+  function getShareServerList()
+  {
+    $ldap= $this->config->get_ldap_link();
+    $a_res = $ldap->search("(objectClass=goShareServer)",array("goExportEntry","cn"));
+    $return= array();
+    while($entry = $ldap->fetch($a_res)){
+      $return[$entry['cn'][0]] = $entry['cn'][0];
+    }
+    return($return);
+  }
+
 /* Generate ListBox frindly output for the defined shares 
  * Possibly Add or remove an attribute here, 
  */
@@ -688,28 +862,36 @@ function printOutHotPlugDevices()
     return($a_return);
   }
 
-/* Generates ListBox frienly output of used printer devices 
- * Append ' - admin' if printer is used in admin mode
- */
-function printOutPrinterDevices()
+  /* Generates ListBox frienly output of used printer devices 
  * Append ' - admin' if printer is used in admin mode
  */
+  function printOutPrinterDevices()
   {
-  $a_return = array();
-  if(is_array($this->gotoPrinters)){
-    foreach($this->gotoPrinters as $printer){
+    $a_return = array();
+    if(is_array($this->gotoPrinters)){
+      foreach($this->gotoPrinters as $printer){
         if($printer['mode'] == "admin"){
-         $a_return[$printer['cn'][0]]= $printer['cn'][0]." - "._("Admin");
+          $a_return[$printer['cn'][0]]= $printer['cn'][0]." - "._("Admin");
         }else{
-         $a_return[$printer['cn'][0]]= $printer['cn'][0]; 
+          $a_return[$printer['cn'][0]]= $printer['cn'][0]; 
         }
       }
     }
-  return($a_return);
+    return($a_return);
   }
 
-
-
-
-
+  /* Generates ListBox frienly output of used logonscripts 
+   */
+  function printOutLogonScripts()
+  {
+    $a_return = array();
+    if(is_array($this->gotoLogonScripts)){
+      foreach($this->gotoLogonScripts as $script){
+        $a_return[$script['LogonName']]= $script['LogonPriority']." - ".$script['LogonName']; 
+      }
+    }
+    return($a_return);
+  }
 }