Code

Updated post handling
authorhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 29 Jul 2010 12:14:16 +0000 (12:14 +0000)
committerhickert <hickert@594d385d-05f5-0310-b6e9-bd551577e9d8>
Thu, 29 Jul 2010 12:14:16 +0000 (12:14 +0000)
git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@19220 594d385d-05f5-0310-b6e9-bd551577e9d8

gosa-core/plugins/admin/ogroups/class_ogroup.inc

index 5cb4ff83743749bc06ec2e6fd02b8b74185b7a10..9f15817e6b603b5b2be63e504be2b98c05b58b6f 100644 (file)
@@ -75,780 +75,775 @@ class ogroup extends plugin
     var $attributes= array("cn", "description", "gosaGroupObjects","member");
     var $objectclasses= array("top", "gosaGroupOfNames");
 
-  function ogroup (&$config, $dn= NULL)
-  {
-    plugin::plugin ($config, $dn);
+    function ogroup (&$config, $dn= NULL)
+    {
+        plugin::plugin ($config, $dn);
 
-    $this->trustModeDialog = new trustModeDialog($this->config, $this->dn,NULL);
-    $this->trustModeDialog->setAcl('ogroups/ogroup');
+        $this->trustModeDialog = new trustModeDialog($this->config, $this->dn,NULL);
+        $this->trustModeDialog->setAcl('ogroups/ogroup');
 
-    $this->orig_dn= $dn;
+        $this->orig_dn= $dn;
 
-    $this->member = array();
+        $this->member = array();
 
-    /* Load member objects */
-    if (isset($this->attrs['member'])){
-      foreach ($this->attrs['member'] as $key => $value){
-        if ("$key" != "count"){
-          $value= @LDAP::convert($value);
-          $this->member["$value"]= "$value";
+        /* Load member objects */
+        if (isset($this->attrs['member'])){
+            foreach ($this->attrs['member'] as $key => $value){
+                if ("$key" != "count"){
+                    $value= @LDAP::convert($value);
+                    $this->member["$value"]= "$value";
+                }
+            }
         }
-      }
-    }
-    $this->is_account= TRUE;
-
-    /* Set base */
-    if ($this->dn == "new"){
-      $ui = get_userinfo();
-      $this->base= dn2base(session::global_is_set("CurrentMainBase")?"cn=dummy,".session::global_get("CurrentMainBase"):$ui->dn);
-    } else {
-      $this->base= preg_replace("/^[^,]+,".preg_quote(get_ou("group", "ogroupRDN"), '/')."/i","",$this->dn);
-    }
-
-    /* Detect all workstations, which are already assigned to an object group  
-        - Those objects will be hidden in the add object dialog.
-        - Check() will complain if such a system is assigned to this object group.
-     */ 
-    $base = $this->config->current['BASE'];
-    $res    = get_list("(|(objectClass=gotoWorkstation)(objectClass=gotoTerminal))","none" , 
-        $base, array("dn"),GL_NO_ACL_CHECK|GL_SUBSEARCH);
-    $ws_dns = array();
-    foreach($res as $data){
-      $ws_dns[] = $data['dn'];
-    }
-    $res=get_list("(&(member=*)(objectClass=gosaGroupOfNames))","none",
-        $base, array("dn","member", "gosaGroupObjects"),GL_NO_ACL_CHECK|GL_SUBSEARCH);
-    $this->used_workstations = array();
-    foreach($res as $og){
-      if($og['dn'] == $this->dn) continue;
-      $test = array_intersect($ws_dns,$og['member']);
-      if(($og['gosaGroupObjects'] == "[W]" || $og['gosaGroupObjects'] == "[T]") && count($test)){
-        $this->used_workstations = array_merge($this->used_workstations,$test);
-      }
-    }
+        $this->is_account= TRUE;
 
-    $this->orig_cn = $this->cn;
-    $this->orig_base = $this->base;
-
-    /* Get global filter config */
-    if (!session::is_set("sysfilter")){
-      $ui= get_userinfo();
-      $base= get_base_from_people($ui->dn);
-      $sysfilter= array( "depselect"       => $base,
-          "regex"           => "*");
-      session::set("sysfilter", $sysfilter);
-    }
+        /* Set base */
+        if ($this->dn == "new"){
+            $ui = get_userinfo();
+            $this->base= dn2base(session::global_is_set("CurrentMainBase")?"cn=dummy,".session::global_get("CurrentMainBase"):$ui->dn);
+        } else {
+            $this->base= preg_replace("/^[^,]+,".preg_quote(get_ou("group", "ogroupRDN"), '/')."/i","",$this->dn);
+        }
 
-    /* Instanciate base selector */
-    $this->baseSelector= new baseSelector($this->get_allowed_bases(), $this->base);
-    $this->baseSelector->setSubmitButton(false);
-    $this->baseSelector->setHeight(300);
-    $this->baseSelector->update(true);
-    
-    // Prepare lists
-    $this->memberListing = new sortableListing();
-    $this->memberListing->setDeleteable(true);
-    $this->memberListing->setInstantDelete(true);
-    $this->memberListing->setEditable(false);
-    $this->memberListing->setWidth("100%");
-    $this->memberListing->setHeight("300px");
-    $this->memberListing->setHeader(array("~",_("Name")));
-    $this->memberListing->setColspecs(array('20px','*','20px'));
-    $this->memberListing->setDefaultSortColumn(1);
-
-    $this->reload();
-  }
-
-  function AddDelMembership($NewMember = false){
-
-      if($NewMember){
-
-          // Ensure that we definitely know the new members attributes.
-          //  - Fetch unknown objects here. 
-          if(!isset($this->memberList[$NewMember])){
-
-              $ldap = $this->config->get_ldap_link();
-              $ldap->cd($this->config->current['BASE']);
-              $ldap->cat($NewMember);
-              $attrs = $ldap->fetch();
-              $this->objcache[$NewMember] = $attrs;
-          }
-
-          /* Add member and force reload */
-          $this->member[$NewMember]= $NewMember;
-
-
-      $this->memberList[$NewMember]= $this->objcache[$NewMember];
-      unset ($this->objects[$NewMember]);
-      reset ($this->memberList);
-      $this->reload(); 
-    }else{
-
-        // Act on list modifications 
-        $this->memberListing->save_object();
-        $action = $this->memberListing->getAction();
-        if($action['action'] == 'delete'){
-            foreach($action['targets'] as $id){
-                $value = $this->memberListing->getKey($id);
-                $this->objects["$value"]= $this->memberList[$value];                  
-                unset ($this->memberList["$value"]);                                  
-                unset ($this->member["$value"]);                                      
+        /* Detect all workstations, which are already assigned to an object group  
+           - Those objects will be hidden in the add object dialog.
+           - Check() will complain if such a system is assigned to this object group.
+         */ 
+        $base = $this->config->current['BASE'];
+        $res    = get_list("(|(objectClass=gotoWorkstation)(objectClass=gotoTerminal))","none" , 
+                $base, array("dn"),GL_NO_ACL_CHECK|GL_SUBSEARCH);
+        $ws_dns = array();
+        foreach($res as $data){
+            $ws_dns[] = $data['dn'];
+        }
+        $res=get_list("(&(member=*)(objectClass=gosaGroupOfNames))","none",
+                $base, array("dn","member", "gosaGroupObjects"),GL_NO_ACL_CHECK|GL_SUBSEARCH);
+        $this->used_workstations = array();
+        foreach($res as $og){
+            if($og['dn'] == $this->dn) continue;
+            $test = array_intersect($ws_dns,$og['member']);
+            if(($og['gosaGroupObjects'] == "[W]" || $og['gosaGroupObjects'] == "[T]") && count($test)){
+                $this->used_workstations = array_merge($this->used_workstations,$test);
             }
-            $this->reload();
-        }
-
-
-      /* Add objects to group */
-      if (isset($_POST['objectSelect_save']) && $this->objectSelect instanceOf objectSelect){
-        $objects = $this->objectSelect->save();
-        $skipped = FALSE;
-        foreach($objects as $object){
-          $dn = $object['dn'];
-
-          // Do not add existing members twice!
-          if(isset($this->member["$dn"])){
-              continue;
-          }
-
-          $tmp = "";
-          foreach($this->memberList as $obj){
-            $tmp .= $obj['type'];
-          }
-
-          $type  = $this->getObjectType($object);
-          $name= $this->getObjectName($object);
-
-          /* Fill array */
-          if (isset($object["description"][0])){
-            $object= array("text" => "$name [".$object["description"][0]."]", "type" => "$type");
-          } elseif (isset($object["uid"][0])) {
-            $object= array("text" => "$name [".$object["uid"][0]."]", "type" => "$type");
-          } else {
-            $object= array("text" => "$name", "type" => "$type");
-          }
-
-          if(preg_match("/T/",$tmp) && $type == "W"){
-            $skipped =TRUE;
-          }elseif(preg_match("/W/",$tmp) && $type == "T"){
-            $skipped =TRUE;
-          }else{
-
-            $this->memberList["$dn"]= $object;
-            $this->member["$dn"]= $dn;
-            reset ($this->memberList);
-          }
         }
-        if($skipped){
-          msg_dialog::display(_("Information"), _("You cannot combine terminals and workstations in one object group!"), INFO_DIALOG);
+
+        $this->orig_cn = $this->cn;
+        $this->orig_base = $this->base;
+
+        /* Get global filter config */
+        if (!session::is_set("sysfilter")){
+            $ui= get_userinfo();
+            $base= get_base_from_people($ui->dn);
+            $sysfilter= array( "depselect"       => $base,
+                    "regex"           => "*");
+            session::set("sysfilter", $sysfilter);
         }
-        $this->objectSelect= FALSE;
-        $this->dialog= FALSE;
+
+        /* Instanciate base selector */
+        $this->baseSelector= new baseSelector($this->get_allowed_bases(), $this->base);
+        $this->baseSelector->setSubmitButton(false);
+        $this->baseSelector->setHeight(300);
+        $this->baseSelector->update(true);
+
+        // Prepare lists
+        $this->memberListing = new sortableListing();
+        $this->memberListing->setDeleteable(true);
+        $this->memberListing->setInstantDelete(true);
+        $this->memberListing->setEditable(false);
+        $this->memberListing->setWidth("100%");
+        $this->memberListing->setHeight("300px");
+        $this->memberListing->setHeader(array("~",_("Name")));
+        $this->memberListing->setColspecs(array('20px','*','20px'));
+        $this->memberListing->setDefaultSortColumn(1);
+
         $this->reload();
-      }
     }
-  }
 
-  function execute()
-  {
-    /* Call parent execute */
-    plugin::execute();
+    function AddDelMembership($NewMember = false){
 
-    if(!$this->view_logged){
-      $this->view_logged = TRUE;
-      new log("view","ogroups/".get_class($this),$this->dn);
-    }
+        if($NewMember){
 
+            // Ensure that we definitely know the new members attributes.
+            //  - Fetch unknown objects here. 
+            if(!isset($this->memberList[$NewMember])){
 
-    /* Do we represent a valid group? */
-    if (!$this->is_account){
-      $display= "<img alt=\"\" src=\"images/small-error.png\" align=\"middle\">&nbsp;<b>".
-        msgPool::noValidExtension("object group")."</b>";
-      return ($display);
-    }
+                $ldap = $this->config->get_ldap_link();
+                $ldap->cd($this->config->current['BASE']);
+                $ldap->cat($NewMember);
+                $attrs = $ldap->fetch();
+                $this->objcache[$NewMember] = $attrs;
+            }
 
+            /* Add member and force reload */
+            $this->member[$NewMember]= $NewMember;
 
-    /* Load templating engine */
-    $smarty= get_smarty();
 
+            $this->memberList[$NewMember]= $this->objcache[$NewMember];
+            unset ($this->objects[$NewMember]);
+            reset ($this->memberList);
+            $this->reload(); 
+        }else{
 
-    $tmp = $this->plInfo();
-    foreach($tmp['plProvidedAcls'] as $name => $translation){
-      $smarty->assign($name."ACL",$this->getacl($name));
-    }
+            // Act on list modifications 
+            $this->memberListing->save_object();
+            $action = $this->memberListing->getAction();
+            if($action['action'] == 'delete'){
+                foreach($action['targets'] as $id){
+                    $value = $this->memberListing->getKey($id);
+                    $this->objects["$value"]= $this->memberList[$value];                  
+                    unset ($this->memberList["$value"]);                                  
+                    unset ($this->member["$value"]);                                      
+                }
+                $this->reload();
+            }
 
-    /***********
-     * Trusts 
-     ***********/
 
-    // Handle trust mode dialog
-    $this->dialog = FALSE;
-    $trustModeDialog = $this->trustModeDialog->execute();
-    if($this->trustModeDialog->trustSelect){
-        $this->dialog = TRUE;
-        return($trustModeDialog);
+            /* Add objects to group */
+            if (isset($_POST['objectSelect_save']) && $this->objectSelect instanceOf objectSelect){
+                $objects = $this->objectSelect->save();
+                $skipped = FALSE;
+                foreach($objects as $object){
+                    $dn = $object['dn'];
+
+                    // Do not add existing members twice!
+                    if(isset($this->member["$dn"])){
+                        continue;
+                    }
+
+                    $tmp = "";
+                    foreach($this->memberList as $obj){
+                        $tmp .= $obj['type'];
+                    }
+
+                    $type  = $this->getObjectType($object);
+                    $name= $this->getObjectName($object);
+
+                    /* Fill array */
+                    if (isset($object["description"][0])){
+                        $object= array("text" => "$name [".$object["description"][0]."]", "type" => "$type");
+                    } elseif (isset($object["uid"][0])) {
+                        $object= array("text" => "$name [".$object["uid"][0]."]", "type" => "$type");
+                    } else {
+                        $object= array("text" => "$name", "type" => "$type");
+                    }
+
+                    if(preg_match("/T/",$tmp) && $type == "W"){
+                        $skipped =TRUE;
+                    }elseif(preg_match("/W/",$tmp) && $type == "T"){
+                        $skipped =TRUE;
+                    }else{
+
+                        $this->memberList["$dn"]= $object;
+                        $this->member["$dn"]= $dn;
+                        reset ($this->memberList);
+                    }
+                }
+                if($skipped){
+                    msg_dialog::display(_("Information"), _("You cannot combine terminals and workstations in one object group!"), INFO_DIALOG);
+                }
+                $this->objectSelect= FALSE;
+                $this->dialog= FALSE;
+                $this->reload();
+            }
+        }
     }
-    $smarty->assign("trustModeDialog",$trustModeDialog);
 
-    /***********
-     * Ende - Trusts 
-     ***********/
+    function execute()
+    {
+        /* Call parent execute */
+        plugin::execute();
 
+        if(!$this->view_logged){
+            $this->view_logged = TRUE;
+            new log("view","ogroups/".get_class($this),$this->dn);
+        }
 
-    /* Add objects? */
-    if (isset($_POST["edit_membership"])){
-      $this->objectSelect= new objectSelect($this->config, get_userinfo());
-    }
 
-    /* Add objects finished? */
-    if (isset($_POST["objectSelect_cancel"])){
-      $this->objectSelect= FALSE;
-    }
+        /* Do we represent a valid group? */
+        if (!$this->is_account){
+            $display= "<img alt=\"\" src=\"images/small-error.png\" align=\"middle\">&nbsp;<b>".
+                msgPool::noValidExtension("object group")."</b>";
+            return ($display);
+        }
 
-    /* Manage object add dialog */
-    if ($this->objectSelect){
-      session::set('filterBlacklist', array('dn'=> $this->member));
-      $this->dialog= TRUE;
-      return($this->objectSelect->execute());
-    }
 
-    /* Bases / Departments */
-      if ((isset($_POST['base'])) && ($this->acl_is_moveable())){
-        $this->base= $_POST['base'];
-      }
-
-    /* Assemble combine string */
-    if ($this->gosaGroupObjects == "[]"){
-      $smarty->assign("combinedObjects", _("none"));
-    } elseif (strlen($this->gosaGroupObjects) > 4){
-      $smarty->assign("combinedObjects", "<font color=red>"._("too many different objects!")."</font>");
-    } else {
-      $conv= array(   "U" => _("users"),
-          "G" => _("groups"),
-          "A" => _("applications"),
-          "D" => _("departments"),
-          "S" => _("servers"),
-          "W" => _("workstations"),
-          "O" => _("winstations"),
-          "T" => _("terminals"),
-          "F" => _("phones"),
-          "P" => _("printers"));
-
-      $type= preg_replace('/[\[\]]/', '', $this->gosaGroupObjects);
-      $p1= $conv[$type[0]];
-      error_reporting(0);
-      if (isset($type[1]) && preg_match('/[UGADSFOWTP]/', $type[1])){
-        $p2= $conv[$type[1]];
-        $smarty->assign("combinedObjects", sprintf("'%s' and '%s'", $p1, $p2));
-      } else {
-        $smarty->assign("combinedObjects", "$p1");
-      }
-      error_reporting(E_ALL | E_STRICT);
-    }
+        /* Load templating engine */
+        $smarty= get_smarty();
 
-    /* Assign variables */
-    $smarty->assign("base", $this->baseSelector->render());
 
+        $tmp = $this->plInfo();
+        foreach($tmp['plProvidedAcls'] as $name => $translation){
+            $smarty->assign($name."ACL",$this->getacl($name));
+        }
 
+        /***********
+         * Trusts 
+         ***********/
 
-    $this->memberListing->setAcl($this->getacl("member"));
-    $data = $lData = array();
-    foreach($this->member as $key => $dn){
-        $image = 'images/lists/element.png';
-        $name = $dn;
-        if(isset($this->memberList[$dn])){
-            $name  = $this->memberList[$dn]['text'];
-            if(isset($this->typeToImage[$this->memberList[$dn]['type']])){
-                $image = $this->typeToImage[$this->memberList[$dn]['type']];
-            }
+        // Handle trust mode dialog
+        $this->dialog = FALSE;
+        $trustModeDialog = $this->trustModeDialog->execute();
+        if($this->trustModeDialog->trustSelect){
+            $this->dialog = TRUE;
+            return($trustModeDialog);
         }
-        $data[$key] = $dn;
-        $lData[$key] = array('data'=> array(image($image),$name));
-    }
-    $this->memberListing->setListData($data,$lData);
-    $this->memberListing->update();
-    $smarty->assign("memberList",$this->memberListing->render());
+        $smarty->assign("trustModeDialog",$trustModeDialog);
 
-    /* Fields */
-    foreach ($this->attributes as $val){
-      $smarty->assign("$val", $this->$val);
-    }
+        /***********
+         * Ende - Trusts 
+         ***********/
 
-    return ($smarty->fetch (get_template_path('generic.tpl', TRUE)));
-  }
 
+        /* Add objects? */
+        if (isset($_POST["edit_membership"])){
+            $this->objectSelect= new objectSelect($this->config, get_userinfo());
+        }
 
-  function set_acl_base($base)
-  {
-    plugin::set_acl_base($base);
-    $this->trustModeDialog->set_acl_base($base);
-  }
+        /* Add objects finished? */
+        if (isset($_POST["objectSelect_cancel"])){
+            $this->objectSelect= FALSE;
+        }
 
+        /* Manage object add dialog */
+        if ($this->objectSelect){
+            session::set('filterBlacklist', array('dn'=> $this->member));
+            $this->dialog= TRUE;
+            return($this->objectSelect->execute());
+        }
 
-  /* Save data to object */
-  function save_object()
-  {
-    /* Save additional values for possible next step */
-    if (isset($_POST['ogroupedit'])){
+        /* Assemble combine string */
+        if ($this->gosaGroupObjects == "[]"){
+            $smarty->assign("combinedObjects", _("none"));
+        } elseif (strlen($this->gosaGroupObjects) > 4){
+            $smarty->assign("combinedObjects", "<font color=red>"._("too many different objects!")."</font>");
+        } else {
+            $conv= array(   "U" => _("users"),
+                    "G" => _("groups"),
+                    "A" => _("applications"),
+                    "D" => _("departments"),
+                    "S" => _("servers"),
+                    "W" => _("workstations"),
+                    "O" => _("winstations"),
+                    "T" => _("terminals"),
+                    "F" => _("phones"),
+                    "P" => _("printers"));
+
+            $type= preg_replace('/[\[\]]/', '', $this->gosaGroupObjects);
+            $p1= $conv[$type[0]];
+            error_reporting(0);
+            if (isset($type[1]) && preg_match('/[UGADSFOWTP]/', $type[1])){
+                $p2= $conv[$type[1]];
+                $smarty->assign("combinedObjects", sprintf("'%s' and '%s'", $p1, $p2));
+            } else {
+                $smarty->assign("combinedObjects", "$p1");
+            }
+            error_reporting(E_ALL | E_STRICT);
+        }
+
+        /* Assign variables */
+        $smarty->assign("base", $this->baseSelector->render());
 
-      $this->trustModeDialog->save_object();
 
-      /* Create a base backup and reset the
-         base directly after calling plugin::save_object();
-         Base will be set seperatly a few lines below */
-      $base_tmp = $this->base;
-      plugin::save_object();
-      $this->base = $base_tmp;
 
-      /* Refresh base */
-      if ($this->acl_is_moveable($this->base)){
-        if (!$this->baseSelector->update()) {
-          msg_dialog::display(_("Error"), msgPool::permMove(), ERROR_DIALOG);
+        $this->memberListing->setAcl($this->getacl("member"));
+        $data = $lData = array();
+        foreach($this->member as $key => $dn){
+            $image = 'images/lists/element.png';
+            $name = $dn;
+            if(isset($this->memberList[$dn])){
+                $name  = $this->memberList[$dn]['text'];
+                if(isset($this->typeToImage[$this->memberList[$dn]['type']])){
+                    $image = $this->typeToImage[$this->memberList[$dn]['type']];
+                }
+            }
+            $data[$key] = $dn;
+            $lData[$key] = array('data'=> array(image($image),$name));
         }
-        if ($this->base != $this->baseSelector->getBase()) {
-          $this->base= $this->baseSelector->getBase();
-          $this->is_modified= TRUE;
+        $this->memberListing->setListData($data,$lData);
+        $this->memberListing->update();
+        $smarty->assign("memberList",$this->memberListing->render());
+
+        /* Fields */
+        foreach ($this->attributes as $val){
+            $smarty->assign("$val", set_post($this->$val));
         }
-      }
 
+        return ($smarty->fetch (get_template_path('generic.tpl', TRUE)));
     }
-  }
-
-
-  /* (Re-)Load objects */
-  function reload()
-  {
-    /*###########
-      Variable initialisation 
-      ###########*/
-
-    $this->objects                = array();
-    $this->ui                     = get_userinfo();
-    $filter                       = "";
-    $objectClasses                = array();
-    
-    $ogfilter               = session::get("ogfilter");
-    $regex                  = $ogfilter['regex'];
-
-    $ldap= $this->config->get_ldap_link();
-    $ldap->cd ($ogfilter['dselect']);
-
-
-    /*###########
-      Generate Filter 
-      ###########*/
-
-    $p_f= array("accounts"=> array("OBJ"=>"user", "CLASS"=>"gosaAccount"    ,
-          "DN"=> get_people_ou()           ,"ACL" => "users"), 
-        "groups"          => array("OBJ"=>"group", "CLASS"=>"posixGroup"     ,
-          "DN"=> get_groups_ou('ogroupRDN') ,"ACL" => "groups"), 
-        "departments"     => array("OBJ"=>"department", "CLASS"=>"gosaDepartment" ,
-          "DN"=> ""                        ,"ACL" => "department"), 
-        "servers"         => array("OBJ"=>"servgeneric", "CLASS"=>"goServer"       ,
-          "DN"=> get_ou("servgeneric", "serverRDN")        ,"ACL" => "server"),
-        "workstations"    => array("OBJ"=>"workgeneric", "CLASS"=>"gotoWorkstation",
-          "DN"=> get_ou("workgeneric", "workstationRDN")   ,"ACL" => "workstation"),
-        "winstations"     => array("OBJ"=>"wingeneric", "CLASS"=>"opsiClient",        
-          "DN"=> get_ou("wingeneric", 'sambaMachineAccountRDN')     ,"ACL" => "winstation"),
-        "terminals"       => array("OBJ"=>"termgeneric", "CLASS"=>"gotoTerminal"   ,
-          "DN"=> get_ou("termgeneric", "terminalRDN")      ,"ACL" => "terminal"),
-        "printers"        => array("OBJ"=>"printgeneric", "CLASS"=>"gotoPrinter"    ,
-          "DN"=> get_ou("printgeneric", "printerRDN")       ,"ACL" => "printer"),
-        "phones"          => array("OBJ"=>"phoneGeneric", "CLASS"=>"goFonHardware"  ,
-          "DN"=> get_ou("phoneGeneric", "phoneRDN")         ,"ACL" => "phone"));
-
-
-    /* Allow searching for applications, if we are not using release managed applications 
-      */
-    if(!$this->IsReleaseManagementActivated()){
-      $p_f[      "applications"]    = array("OBJ"=>"application", "CLASS"=>"gosaApplication",
-          "DN"=> get_ou("application", "applicationRDN")   ,"ACL" => "application"); 
+
+
+    function set_acl_base($base)
+    {
+        plugin::set_acl_base($base);
+        $this->trustModeDialog->set_acl_base($base);
     }
-           
-    /*###########
-      Perform search for selected objectClasses & regex to fill list with objects   
-      ###########*/
 
-    $Get_list_flags = 0;
-    if($ogfilter['subtrees'] == "checked"){
-      $Get_list_flags |= GL_SUBSEARCH;
-    }    
 
-    foreach($p_f as $post_name => $data){
+    /* Save data to object */
+    function save_object()
+    {
+        /* Save additional values for possible next step */
+        if (isset($_POST['ogroupedit'])){
 
-      if($ogfilter[$post_name] == "checked" && class_available($data['OBJ'])){
+            $this->trustModeDialog->save_object();
 
-        if($ogfilter['subtrees']){
-          $base =  $ogfilter['dselect'];
-        }else{
-          $base =  $data['DN'].$ogfilter['dselect'];
-        }
-   
-         
-        $filter = "(&(objectClass=".$data['CLASS'].")(|(uid=$regex)(cn=$regex)(ou=$regex)))";
-        $res    = get_list($filter, $data['ACL']  , $base, 
-                    array("description", "objectClass", "sn", "givenName", "uid","ou","cn"),$Get_list_flags);
-
-        /* fetch results and append them to the list */
-        foreach($res as $attrs){
-
-          /* Skip workstations which are already assigned to an object group.
-           */
-          if ($this->gosaGroupObjects == "[W]" || $this->gosaGroupObjects == "[T]"){
-            if(in_array($attrs['dn'],$this->used_workstations)){
-              continue;
-            }
-          }
+            /* Create a base backup and reset the
+               base directly after calling plugin::save_object();
+               Base will be set seperatly a few lines below */
+            $base_tmp = $this->base;
+            plugin::save_object();
+            $this->base = $base_tmp;
 
-          $type= $this->getObjectType($attrs);
-          $name= $this->getObjectName($attrs);
+            /* Refresh base */
+            if ($this->acl_is_moveable($this->base)){
+                if (!$this->baseSelector->update()) {
+                    msg_dialog::display(_("Error"), msgPool::permMove(), ERROR_DIALOG);
+                }
+                if ($this->base != $this->baseSelector->getBase()) {
+                    $this->base= $this->baseSelector->getBase();
+                    $this->is_modified= TRUE;
+                }
+            }
 
-          /* Fill array */
-          if (isset($attrs["description"][0])){
-            $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
-          } elseif (isset($attrs["uid"][0])) {
-            $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["uid"][0]."]", "type" => "$type");
-          } else {
-            $this->objects[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
-          }
         }
-      }
     }
-    reset ($this->objects);
 
-    
-    /*###########
-      Build member list and try to detect obsolete entries 
-      ###########*/
 
-    $this->memberList = array();
-  
-    /* Walk through all single member entry */
-    foreach($this->member as $dn){
+    /* (Re-)Load objects */
+    function reload()
+    {
+        /*###########
+          Variable initialisation 
+###########*/
+
+        $this->objects                = array();
+        $this->ui                     = get_userinfo();
+        $filter                       = "";
+        $objectClasses                = array();
+
+        $ogfilter               = session::get("ogfilter");
+        $regex                  = $ogfilter['regex'];
+
+        $ldap= $this->config->get_ldap_link();
+        $ldap->cd ($ogfilter['dselect']);
+
+
+        /*###########
+          Generate Filter 
+###########*/
+
+        $p_f= array("accounts"=> array("OBJ"=>"user", "CLASS"=>"gosaAccount"    ,
+                    "DN"=> get_people_ou()           ,"ACL" => "users"), 
+                "groups"          => array("OBJ"=>"group", "CLASS"=>"posixGroup"     ,
+                    "DN"=> get_groups_ou('ogroupRDN') ,"ACL" => "groups"), 
+                "departments"     => array("OBJ"=>"department", "CLASS"=>"gosaDepartment" ,
+                    "DN"=> ""                        ,"ACL" => "department"), 
+                "servers"         => array("OBJ"=>"servgeneric", "CLASS"=>"goServer"       ,
+                    "DN"=> get_ou("servgeneric", "serverRDN")        ,"ACL" => "server"),
+                "workstations"    => array("OBJ"=>"workgeneric", "CLASS"=>"gotoWorkstation",
+                    "DN"=> get_ou("workgeneric", "workstationRDN")   ,"ACL" => "workstation"),
+                "winstations"     => array("OBJ"=>"wingeneric", "CLASS"=>"opsiClient",        
+                    "DN"=> get_ou("wingeneric", 'sambaMachineAccountRDN')     ,"ACL" => "winstation"),
+                "terminals"       => array("OBJ"=>"termgeneric", "CLASS"=>"gotoTerminal"   ,
+                    "DN"=> get_ou("termgeneric", "terminalRDN")      ,"ACL" => "terminal"),
+                "printers"        => array("OBJ"=>"printgeneric", "CLASS"=>"gotoPrinter"    ,
+                    "DN"=> get_ou("printgeneric", "printerRDN")       ,"ACL" => "printer"),
+                "phones"          => array("OBJ"=>"phoneGeneric", "CLASS"=>"goFonHardware"  ,
+                    "DN"=> get_ou("phoneGeneric", "phoneRDN")         ,"ACL" => "phone"));
+
+
+        /* Allow searching for applications, if we are not using release managed applications 
+         */
+        if(!$this->IsReleaseManagementActivated()){
+            $p_f[      "applications"]    = array("OBJ"=>"application", "CLASS"=>"gosaApplication",
+                    "DN"=> get_ou("application", "applicationRDN")   ,"ACL" => "application"); 
+        }
 
-      /* The dn for the current member can't be resolved 
-         it seams that this entry was removed 
-       */ 
-      /* Try to resolv the entry again, if it still fails, display error msg */
-      $ldap->cat($dn, array("cn", "sn", "givenName", "ou", "description", "objectClass", "macAddress"));
+        /*###########
+          Perform search for selected objectClasses & regex to fill list with objects   
+###########*/
+
+        $Get_list_flags = 0;
+        if($ogfilter['subtrees'] == "checked"){
+            $Get_list_flags |= GL_SUBSEARCH;
+        }    
+
+        foreach($p_f as $post_name => $data){
+
+            if($ogfilter[$post_name] == "checked" && class_available($data['OBJ'])){
+
+                if($ogfilter['subtrees']){
+                    $base =  $ogfilter['dselect'];
+                }else{
+                    $base =  $data['DN'].$ogfilter['dselect'];
+                }
+
+
+                $filter = "(&(objectClass=".$data['CLASS'].")(|(uid=$regex)(cn=$regex)(ou=$regex)))";
+                $res    = get_list($filter, $data['ACL']  , $base, 
+                        array("description", "objectClass", "sn", "givenName", "uid","ou","cn"),$Get_list_flags);
+
+                /* fetch results and append them to the list */
+                foreach($res as $attrs){
+
+                    /* Skip workstations which are already assigned to an object group.
+                     */
+                    if ($this->gosaGroupObjects == "[W]" || $this->gosaGroupObjects == "[T]"){
+                        if(in_array($attrs['dn'],$this->used_workstations)){
+                            continue;
+                        }
+                    }
+
+                    $type= $this->getObjectType($attrs);
+                    $name= $this->getObjectName($attrs);
+
+                    /* Fill array */
+                    if (isset($attrs["description"][0])){
+                        $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
+                    } elseif (isset($attrs["uid"][0])) {
+                        $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["uid"][0]."]", "type" => "$type");
+                    } else {
+                        $this->objects[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
+                    }
+                }
+            }
+        }
+        reset ($this->objects);
 
-      /* It has failed, add entry with type flag I (Invalid)*/
-      if (!$ldap->success()){
-        $this->memberList[$dn]= array('text' => _("Non existing dn:")." ".LDAP::fix($dn),"type" => "I");
 
-      } else {
+        /*###########
+          Build member list and try to detect obsolete entries 
+###########*/
 
-        /* Append this entry to our all object list */
+        $this->memberList = array();
 
-        /* Fetch object */
-        $attrs= $ldap->fetch();
+        /* Walk through all single member entry */
+        foreach($this->member as $dn){
 
-        $type= $this->getObjectType($attrs);
-        $name= $this->getObjectName($attrs);
+            /* The dn for the current member can't be resolved 
+               it seams that this entry was removed 
+             */ 
+            /* Try to resolv the entry again, if it still fails, display error msg */
+            $ldap->cat($dn, array("cn", "sn", "givenName", "ou", "description", "objectClass", "macAddress"));
 
-        if (isset($attrs["description"][0])){
-          $this->objcache[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
-        } elseif (isset($attrs["uid"][0])) {
-          $this->objcache[$attrs["dn"]]= array("text" => "$name [".$attrs["uid"][0]."]", "type" => "$type");
-        } else {
-          $this->objcache[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
+            /* It has failed, add entry with type flag I (Invalid)*/
+            if (!$ldap->success()){
+                $this->memberList[$dn]= array('text' => _("Non existing dn:")." ".LDAP::fix($dn),"type" => "I");
+
+            } else {
+
+                /* Append this entry to our all object list */
+
+                /* Fetch object */
+                $attrs= $ldap->fetch();
+
+                $type= $this->getObjectType($attrs);
+                $name= $this->getObjectName($attrs);
+
+                if (isset($attrs["description"][0])){
+                    $this->objcache[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
+                } elseif (isset($attrs["uid"][0])) {
+                    $this->objcache[$attrs["dn"]]= array("text" => "$name [".$attrs["uid"][0]."]", "type" => "$type");
+                } else {
+                    $this->objcache[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
+                }
+                $this->objcache[$attrs["dn"]]['objectClass']  = $attrs['objectClass'];
+
+                if(isset($attrs['macAddress'][0])){
+                    $this->objcache[$attrs["dn"]]['macAddress']  = $attrs['macAddress'][0];
+                }else{
+                    $this->objcache[$attrs["dn"]]['macAddress']  = "";
+                }
+
+                if(isset($attrs['uid'])){
+                    $this->objcache[$attrs["dn"]]['uid']          = $attrs['uid'];
+                }
+
+                /* Fill array */
+                if (isset($attrs["description"][0])){
+                    $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
+                } else {
+                    $this->objects[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
+                }
+
+                $this->memberList[$dn]= $this->objects[$attrs["dn"]];
+            }
         }
-        $this->objcache[$attrs["dn"]]['objectClass']  = $attrs['objectClass'];
+        reset ($this->memberList);
 
-        if(isset($attrs['macAddress'][0])){
-          $this->objcache[$attrs["dn"]]['macAddress']  = $attrs['macAddress'][0];
-        }else{
-          $this->objcache[$attrs["dn"]]['macAddress']  = "";
+        /* Assemble types of currently combined objects */
+        $objectTypes= "";
+        foreach ($this->memberList as $dn => $desc){
+
+            /* Invalid object? */
+            if ($desc['type'] == 'I'){
+                continue;
+            }
+
+            /* Fine. Add to list. */
+            if (!preg_match('/'.$desc['type'].'/', $objectTypes)){
+                $objectTypes.= $desc['type'];
+            }
         }
+        $this->gosaGroupObjects= "[$objectTypes]";
+    }
+
 
-        if(isset($attrs['uid'])){
-          $this->objcache[$attrs["dn"]]['uid']          = $attrs['uid'];
+    function getObjectType($attrs)
+    {
+        $type= "I";
+
+        foreach($this->typeToClass as $index => $class){
+            if (in_array($class, $attrs['objectClass'])){
+                $type= $index;
+                break;
+            }
         }
+        return ($type);
+    }
+
 
-        /* Fill array */
-        if (isset($attrs["description"][0])){
-          $this->objects[$attrs["dn"]]= array("text" => "$name [".$attrs["description"][0]."]", "type" => "$type");
+    function getObjectName($attrs)
+    {
+        /* Person? */
+        $name =""; 
+        if (in_array('gosaAccount', $attrs['objectClass'])){
+            if(isset($attrs['sn']) && isset($attrs['givenName'])){
+                $name= $attrs['sn'][0].", ".$attrs['givenName'][0];
+            } else {
+                $name= $attrs['uid'][0];
+            }
         } else {
-          $this->objects[$attrs["dn"]]= array("text" => "$name", "type" => "$type");
+            if(isset($attrs["cn"][0])) {
+                $name= $attrs['cn'][0];
+            } else {
+                $name= $attrs['ou'][0];
+            }
         }
 
-        $this->memberList[$dn]= $this->objects[$attrs["dn"]];
-      }
+        return ($name);
     }
-    reset ($this->memberList);
 
-    /* Assemble types of currently combined objects */
-    $objectTypes= "";
-    foreach ($this->memberList as $dn => $desc){
 
-      /* Invalid object? */
-      if ($desc['type'] == 'I'){
-        continue;
-      }
+    function check()
+    {
+        /* Call common method to give check the hook */
+        $message= plugin::check();
 
-      /* Fine. Add to list. */
-      if (!preg_match('/'.$desc['type'].'/', $objectTypes)){
-        $objectTypes.= $desc['type'];
-      }
-    }
-    $this->gosaGroupObjects= "[$objectTypes]";
-  }
+        /* Permissions for that base? */
+        if ($this->base != ""){
+            $new_dn= 'cn='.$this->cn.','.get_ou("group", "ogroupRDN").$this->base;
+        } else {
+            $new_dn= $this->dn;
+        }
 
+        /* Check if we have workstations assigned, that are already assigned to
+           another object group.  */
+        if ($this->gosaGroupObjects == "[W]" || $this->gosaGroupObjects == "[T]" ) {
+            $test =array_intersect($this->used_workstations,$this->member); 
+            if(count($test)){
+                $str = "";
+                foreach($test as $dn){
+                    $str .= "<li>".$dn."</li>";
+                }
+                $message[] = sprintf(_("These systems are already configured by other object groups and cannot be added:")."<br><ul>%s</ul>",$str);
+            }
+        }
 
-  function getObjectType($attrs)
-  {
-    $type= "I";
+        $ldap = $this->config->get_ldap_link();
+        if(LDAP::fix($this->dn) != LDAP::fix($new_dn)){
+            $ldap->cat ($new_dn, array('dn'));
+        }
 
-    foreach($this->typeToClass as $index => $class){
-      if (in_array($class, $attrs['objectClass'])){
-        $type= $index;
-        break;
-      }
-    }
-    return ($type);
-  }
-
-
-  function getObjectName($attrs)
-  {
-    /* Person? */
-    $name =""; 
-    if (in_array('gosaAccount', $attrs['objectClass'])){
-      if(isset($attrs['sn']) && isset($attrs['givenName'])){
-        $name= $attrs['sn'][0].", ".$attrs['givenName'][0];
-      } else {
-        $name= $attrs['uid'][0];
-      }
-    } else {
-      if(isset($attrs["cn"][0])) {
-        $name= $attrs['cn'][0];
-      } else {
-        $name= $attrs['ou'][0];
-      }
-    }
+        if($ldap->count() !=0){
+            $message[]= msgPool::duplicated(_("Name"));
+        } 
 
-    return ($name);
-  }
+        // Check if a wrong base was supplied
+        if(!$this->baseSelector->checkLastBaseUpdate()){
+            $message[]= msgPool::check_base();;
+        } 
 
+        /* Set new acl base */
+        if($this->dn == "new") {
+            $this->set_acl_base($this->base);
+        }
 
-  function check()
-  {
-    /* Call common method to give check the hook */
-    $message= plugin::check();
+        /* must: cn */
+        if ($this->cn == ""){
+            $message[]= msgPool::required(_("Name"));
+        }
 
-    /* Permissions for that base? */
-    if ($this->base != ""){
-      $new_dn= 'cn='.$this->cn.','.get_ou("group", "ogroupRDN").$this->base;
-    } else {
-      $new_dn= $this->dn;
-    }
+        if (preg_match('/[=,+<>#;]/', $this->cn)) { 
+            $message[] = msgPool::invalid(_("Name"), $this->cn, "/[^=+,<>#;]/"); 
+        } 
 
-    /* Check if we have workstations assigned, that are already assigned to
-        another object group.  */
-    if ($this->gosaGroupObjects == "[W]" || $this->gosaGroupObjects == "[T]" ) {
-      $test =array_intersect($this->used_workstations,$this->member); 
-      if(count($test)){
-        $str = "";
-        foreach($test as $dn){
-          $str .= "<li>".$dn."</li>";
-        }
-        $message[] = sprintf(_("These systems are already configured by other object groups and cannot be added:")."<br><ul>%s</ul>",$str);
-      }
-    }
+        /* To many different object types? */
+        if (strlen($this->gosaGroupObjects) > 4){
+            $message[]= _("You can combine two different object types at maximum, only!");
+        }
 
-    $ldap = $this->config->get_ldap_link();
-    if(LDAP::fix($this->dn) != LDAP::fix($new_dn)){
-      $ldap->cat ($new_dn, array('dn'));
-    }
-    
-    if($ldap->count() !=0){
-      $message[]= msgPool::duplicated(_("Name"));
-    } 
-
-    // Check if a wrong base was supplied
-    if(!$this->baseSelector->checkLastBaseUpdate()){
-      $message[]= msgPool::check_base();;
-    } 
-
-    /* Set new acl base */
-    if($this->dn == "new") {
-      $this->set_acl_base($this->base);
-    }
+        /* Check if we are allowed to create or move this object 
+         */
+        if($this->orig_dn == "new" && !$this->acl_is_createable($this->base)){
+            $message[] = msgPool::permCreate();
+        }elseif($this->orig_dn != "new" && $this->base != $this->orig_base && !$this->acl_is_moveable($this->base)){
+            $message[] = msgPool::permMove();
+        }
 
-    /* must: cn */
-    if ($this->cn == ""){
-      $message[]= msgPool::required(_("Name"));
+        return ($message);
     }
 
-    if (preg_match('/[=,+<>#;]/', $this->cn)) { 
-      $message[] = msgPool::invalid(_("Name"), $this->cn, "/[^=+,<>#;]/"); 
-    } 
 
-    /* To many different object types? */
-    if (strlen($this->gosaGroupObjects) > 4){
-      $message[]= _("You can combine two different object types at maximum, only!");
-    }
+    /* Save to LDAP */
+    function save()
+    {
+        plugin::save();
 
-    /* Check if we are allowed to create or move this object 
-     */
-    if($this->orig_dn == "new" && !$this->acl_is_createable($this->base)){
-      $message[] = msgPool::permCreate();
-    }elseif($this->orig_dn != "new" && $this->base != $this->orig_base && !$this->acl_is_moveable($this->base)){
-      $message[] = msgPool::permMove();
-    }
+        /* Move members to target array */
+        $this->attrs['member'] =array();
+        foreach ($this->member as $key => $desc){
+            $this->attrs['member'][]= LDAP::fix($key);
+        }
 
-    return ($message);
-  }
+        $ldap= $this->config->get_ldap_link();
 
+        /* New accounts need proper 'dn', propagate it to remaining objects */
+        if ($this->dn == 'new'){
+            $this->dn= 'cn='.$this->cn.','.get_ou("group", "ogroupRDN").$this->base;
+        }
 
-  /* Save to LDAP */
-  function save()
-  {
-    plugin::save();
+        /* Save data. Using 'modify' implies that the entry is already present, use 'add' for
+           new entries. So do a check first... */
+        $ldap->cat ($this->dn, array('dn'));
+        if ($ldap->fetch()){
+            /* Modify needs array() to remove values :-( */
+            if (!count ($this->member)){
+                $this->attrs['member']= array();
+            }
+            $mode= "modify";
 
-    /* Move members to target array */
-    $this->attrs['member'] =array();
-    foreach ($this->member as $key => $desc){
-      $this->attrs['member'][]= LDAP::fix($key);
-    }
+        } else {
+            $mode= "add";
+            $ldap->cd($this->config->current['BASE']);
+            $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $this->dn));
+        }
 
-    $ldap= $this->config->get_ldap_link();
 
-    /* New accounts need proper 'dn', propagate it to remaining objects */
-    if ($this->dn == 'new'){
-      $this->dn= 'cn='.$this->cn.','.get_ou("group", "ogroupRDN").$this->base;
-    }
+        /* Write back to ldap */
+        $ldap->cd($this->dn);
+        $this->cleanup();
+        $ldap->$mode($this->attrs);
 
-    /* Save data. Using 'modify' implies that the entry is already present, use 'add' for
-       new entries. So do a check first... */
-    $ldap->cat ($this->dn, array('dn'));
-    if ($ldap->fetch()){
-      /* Modify needs array() to remove values :-( */
-      if (!count ($this->member)){
-        $this->attrs['member']= array();
-      }
-      $mode= "modify";
-
-    } else {
-      $mode= "add";
-      $ldap->cd($this->config->current['BASE']);
-      $ldap->create_missing_trees(preg_replace('/^[^,]+,/', '', $this->dn));
-    }
+        if($mode == "add"){
+            new log("create","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+        }else{
+            new log("modify","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+        }
 
+        /* Trigger post signal */
+        $this->handle_post_events($mode);
 
-    /* Write back to ldap */
-    $ldap->cd($this->dn);
-    $this->cleanup();
-    $ldap->$mode($this->attrs);
+        $ret= 0;
+        if (!$ldap->success()){
+            msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, 0, get_class()));
+            $ret= 1;
+        }else{
+            $this->trustModeDialog->dn = $this->dn;
+            $this->trustModeDialog->save();
+        }
 
-    if($mode == "add"){
-      new log("create","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
-    }else{
-      new log("modify","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
+        return ($ret);
     }
 
-    /* Trigger post signal */
-    $this->handle_post_events($mode);
+    function remove_from_parent()
+    {
+        plugin::remove_from_parent();
+
+        $ldap= $this->config->get_ldap_link();
+        $ldap->rmdir($this->dn);
+        if (!$ldap->success()){
+            msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, 0, get_class()));
+        }
+
+        new log("remove","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
 
-    $ret= 0;
-    if (!$ldap->success()){
-      msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, 0, get_class()));
-      $ret= 1;
-    }else{
-      $this->trustModeDialog->dn = $this->dn;
-      $this->trustModeDialog->save();
+        /* Trigger remove signal */
+        $this->handle_post_events("remove");
     }
 
-    return ($ret);
-  }
 
-  function remove_from_parent()
-  {
-    plugin::remove_from_parent();
+    function PrepareForCopyPaste($source)
+    {
+        plugin::PrepareForCopyPaste($source);
+
+        /* Reload tabs */
+        $this->parent->reload($this->gosaGroupObjects );
 
-    $ldap= $this->config->get_ldap_link();
-    $ldap->rmdir($this->dn);
-    if (!$ldap->success()){
-      msg_dialog::display(_("LDAP error"), msgPool::ldaperror($ldap->get_error(), $this->dn, 0, get_class()));
+        $this->trustModeDialog->PrepareForCopyPaste($source);
+
+        /* Reload plugins */ 
+        foreach($this->parent->by_object as $name => $class ){
+            if(get_class($this) != $name) {
+                $this->parent->by_object[$name]->PrepareForCopyPaste($source);
+            }
+        }
+
+        $source_o = new ogroup ($this->config, $source['dn']);
+        foreach(array("member","gosaGroupObjects")  as $attr){
+            $this->$attr = $source_o->$attr;
+        }
     }
 
-    new log("remove","ogroups/".get_class($this),$this->dn,array_keys($this->attrs),$ldap->get_error());
-
-    /* Trigger remove signal */
-    $this->handle_post_events("remove");
-  }
-
-  
-  function PrepareForCopyPaste($source)
-  {
-    plugin::PrepareForCopyPaste($source);
-
-    /* Reload tabs */
-    $this->parent->reload($this->gosaGroupObjects );
-    
-    $this->trustModeDialog->PrepareForCopyPaste($source);
-   
-    /* Reload plugins */ 
-    foreach($this->parent->by_object as $name => $class ){
-      if(get_class($this) != $name) {
-        $this->parent->by_object[$name]->PrepareForCopyPaste($source);
-      }
+
+    function getCopyDialog()
+    {
+        $smarty = get_smarty();
+        $smarty->assign("cn",  set_post($this->cn));
+        $str = $smarty->fetch(get_template_path("paste_generic.tpl",TRUE,dirname(__FILE__)));
+        $ret = array();
+        $ret['string'] = $str;
+        $ret['status'] = "";
+        return($ret);
     }
 
-    $source_o = new ogroup ($this->config, $source['dn']);
-    foreach(array("member","gosaGroupObjects")  as $attr){
-      $this->$attr = $source_o->$attr;
+    function saveCopyDialog()
+    {
+        if(isset($_POST['cn'])){
+            $this->cn = get_post('cn');
+        }
     }
-  }
-
-
-  function getCopyDialog()
-  {
-    $smarty = get_smarty();
-    $smarty->assign("cn",     $this->cn);
-    $str = $smarty->fetch(get_template_path("paste_generic.tpl",TRUE,dirname(__FILE__)));
-    $ret = array();
-    $ret['string'] = $str;
-    $ret['status'] = "";
-    return($ret);
-  }
-
-  function saveCopyDialog()
-  {
-    if(isset($_POST['cn'])){
-      $this->cn = $_POST['cn'];
+
+
+    function IsReleaseManagementActivated()
+    {
+        return($this->config->pluginEnabled("faiManagement"));
+    }
+
+
+    static function plInfo()
+    {
+        return (array(
+                    "plShortName"   => _("Generic"),
+                    "plDescription" => _("Object group generic"),
+                    "plSelfModify"  => FALSE,
+                    "plDepends"     => array(),
+                    "plPriority"    => 1,
+                    "plSection"     => array("administration"),
+                    "plRequirements"=> array(
+                        'ldapSchema' => array('gosaGroupOfNames' => '>=2.7'),
+                        'onFailureDisablePlugin' => array(get_class(), 'ogroupManagement')
+                        ),
+                    "plCategory"    => array("ogroups" => array("description"  => _("Object groups"),
+                            "objectClass"  => "gosaGroupOfNames")),
+                    "plProvidedAcls"=> array(
+                        "cn"                => _("Name"),
+                        "base"              => _("Base"),
+                        "description"       => _("Description"),
+                        "accessTo"          => _("Sytem trust"),
+                        "member"            => _("Member"))
+                    ));
     }
-  }
-
-
-  function IsReleaseManagementActivated()
-  {
-    return($this->config->pluginEnabled("faiManagement"));
-  }
-
-
-  static function plInfo()
-  {
-    return (array(
-          "plShortName"   => _("Generic"),
-          "plDescription" => _("Object group generic"),
-          "plSelfModify"  => FALSE,
-          "plDepends"     => array(),
-          "plPriority"    => 1,
-          "plSection"     => array("administration"),
-          "plRequirements"=> array(
-              'ldapSchema' => array('gosaGroupOfNames' => '>=2.7'),
-              'onFailureDisablePlugin' => array(get_class(), 'ogroupManagement')
-              ),
-          "plCategory"    => array("ogroups" => array("description"  => _("Object groups"),
-                                                      "objectClass"  => "gosaGroupOfNames")),
-          "plProvidedAcls"=> array(
-            "cn"                => _("Name"),
-            "base"              => _("Base"),
-            "description"       => _("Description"),
-            "accessTo"          => _("Sytem trust"),
-            "member"            => _("Member"))
-          ));
-  }
 }
 
 // vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: