diff --git a/plugins/admin/groups/class_groupManagement.inc b/plugins/admin/groups/class_groupManagement.inc
index 52ff0fe26dae8d9957e61a2447115fef4266a591..fa3592cab455f84e7717bc0a130f3693c9539b13 100644 (file)
<?php
/*
- This code is part of GOsa (https://gosa.gonicus.de)
- Copyright (C) 2003 Cajus Pollmeier
-
- This program is free software; you can redistribute it and/or modify
- it under the terms of the GNU General Public License as published by
- the Free Software Foundation; either version 2 of the License, or
- (at your option) any later version.
-
- This program is distributed in the hope that it will be useful,
- but WITHOUT ANY WARRANTY; without even the implied warranty of
- MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
- GNU General Public License for more details.
-
- You should have received a copy of the GNU General Public License
- along with this program; if not, write to the Free Software
- Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-*/
+ This code is part of GOsa (https://gosa.gonicus.de)
+ Copyright (C) 2003 Cajus Pollmeier
+
+ This program is free software; you can redistribute it and/or modify
+ it under the terms of the GNU General Public License as published by
+ the Free Software Foundation; either version 2 of the License, or
+ (at your option) any later version.
+
+ This program is distributed in the hope that it will be useful,
+ but WITHOUT ANY WARRANTY; without even the implied warranty of
+ MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ GNU General Public License for more details.
+
+ You should have received a copy of the GNU General Public License
+ along with this program; if not, write to the Free Software
+ Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ */
require "tabs_group.inc";
class groupManagement extends plugin
var $ui= NULL;
var $acl= "";
+ var $CopyPasteHandler = NULL;
+ var $DivListGroup = NULL;
+
+ var $ShowPrimaryCheckBox = false;
+
function groupManagement ($config, $ui)
{
- /* Save configuration for internal use */
- $this->config= $config;
- $this->ui= $ui;
-
- /* Get global filter config */
- if (!is_global("groupfilter")){
- $base= get_base_from_people($ui->dn);
- $groupfilter= array("primarygroups" => "checked",
- "mailgroups" => "checked",
- "sambagroups" => "checked",
- "appgroups" => "checked",
- "functionalgroups" => "checked",
- "guser" => "*",
- "subsearch" => "",
- "depselect" => $base,
- "regex" => "*");
- register_global("groupfilter", $groupfilter);
- }
+ /* Save configuration for internal use */
+ $this->config= $config;
+ $this->ui= $ui;
+
+ /* Copy & Paste enabled ?*/
+ if((isset($this->config->data['MAIN']['ENABLECOPYPASTE']))&&(preg_match("/true/i",$this->config->data['MAIN']['ENABLECOPYPASTE']))){
+ $this->CopyPasteHandler = new CopyPasteHandler($this->config);
+ }
+
+ /* Detect if we have to display the primary group checkbox */
+ $tmp = "";
+ if (isset($this->config->data['MAIN']['NOPRIMARYGROUP'])){
+ $tmp = $this->config->data['MAIN']['NOPRIMARYGROUP'];
+ }
+ if(preg_match("/true/i",$tmp)|| (preg_match("/yes/",$tmp))){
+ $this->ShowPrimaryCheckBox = false;
+ } else {
+ $this->ShowPrimaryCheckBox = true;
+ }
+
+ /* Create dialog object */
+ $this->DivListGroup = new divListGroup($this->config,$this);
+ $this->DivListGroup->DisableCheckBox("ShowPrimaryGroups",$this->ShowPrimaryCheckBox);
}
function execute()
{
- /* Save data */
- $groupfilter= get_global("groupfilter");
- foreach( array("depselect", "guser", "regex") as $type){
- if (isset($_POST[$type])){
- $groupfilter[$type]= $_POST[$type];
- }
- }
- if (isset($_POST['depselect'])){
- foreach( array("primarygroups", "sambagroups", "mailgroups", "appgroups",
- "functionalgroups", "subsearch") as $type){
-
- if (isset($_POST[$type])) {
- $groupfilter[$type]= "checked";
- } else {
- $groupfilter[$type]= "";
- }
- }
- }
- if (isset($_GET['search'])){
- $s= mb_substr($_GET['search'], 0, 1, "UTF8")."*";
- if ($s == "**"){
- $s= "*";
- }
- $groupfilter['regex']= $s;
+ /* Call parent execute */
+ plugin::execute();
+
+ /* Store these posts if the current object is locked (used by somebody else)*/
+ $_SESSION['LOCK_VARS_TO_USE'] = array("/^act$/","/^id$/","/^group_edit_/","/^group_del_/");
+
+ /* Save data */
+ $s_action = "";
+ $s_entry = "";
+
+ /* Test Posts */
+ foreach($_POST as $key => $val){
+ // Post for delete
+ if(preg_match("/^group_del.*/",$key)){
+ $s_action = "del";
+ $s_entry = preg_replace("/group_".$s_action."_/i","",$key);
+ // Post for edit
+ }elseif(preg_match("/^group_edit_.*/",$key)){
+ $s_action="edit";
+ $s_entry = preg_replace("/group_".$s_action."_/i","",$key);
+ // Post for new
+ }elseif(preg_match("/^group_new.*/",$key)){
+ $s_action="new";
+ }elseif(preg_match("/^dep_home.*/i",$key)){
+ $s_action="home";
+ }elseif(preg_match("/^group_tplnew.*/i",$key)){
+ $s_action="new_tpl";
+ }elseif(preg_match("/^group_chgpw.*/i",$key)){
+ $s_action="change_pw";
+ $s_entry = preg_replace("/group_chgpw_/i","",$key);
+ }elseif(preg_match("/_group_edit_/",$key)){
+ $type = preg_replace("/_group_edit_.*$/","",$key);
+ $s_action="edit";
+ $s_entry = preg_replace("/".$type."_group_edit_/i","",$key);
+ $_POST['arg'] = $type;
+ }elseif(preg_match("/^editPaste.*/i",$key)){
+ $s_action="editPaste";
+ }elseif(preg_match("/^copy_.*/",$key)){
+ $s_action="copy";
+ $s_entry = preg_replace("/^copy_/i","",$key);
+ }elseif(preg_match("/^cut_.*/",$key)){
+ $s_action="cut";
+ $s_entry = preg_replace("/^cut_/i","",$key);
+ }
+ }
+ $s_entry = preg_replace("/_.$/","",$s_entry);
+
+ /* Check for posted gets */
+ if((isset($_GET['act'])) && ($_GET['act'] == "edit_entry")){
+ $s_entry = $_GET['id'];
+ $s_action = "edit";
+ }
+
+ $smarty= get_smarty();
+
+ /********************
+ Copy & Paste Handling ...
+ ********************/
+
+ /* Only perform copy&paste requests if it is enabled
+ */
+ if($this->CopyPasteHandler){
+ if($str = $this->copyPasteHandling($s_action,$s_entry)){
+ return $str;
+ }
+ }
+
+
+ /********************
+ Create a new group ...
+ ********************/
+
+ /* New group? */
+ if ($s_action=="new"){
+
+ /* By default we set 'dn' to 'new', all relevant plugins will
+ react on this. */
+ $this->dn= "new";
+
+ /* Create new usertab object */
+ $this->grouptab= new grouptabs($this->config, $this->config->data['TABS']['GROUPTABS'], $this->dn);
+
+ /* Set up the users ACL's for this 'dn' */
+ $acl= get_permissions ($this->DivListGroup->selectedBase, $this->ui->subtreeACL);
+ $this->grouptab->set_acl($acl);
+ }
+
+
+ /********************
+ Save Group Tab/Object Changes
+ ********************/
+
+ /* Finish group edit is triggered by the tabulator dialog, so
+ the user wants to save edited data. Check and save at this
+ point. */
+ if ((isset($_POST['edit_finish'])) && (isset($this->grouptab->config)) ){
+
+ /* Check tabs, will feed message array
+ Save, or display error message? */
+ $message= $this->grouptab->check();
+ if (count($message) == 0){
+
+ /* Save user data to ldap */
+ $this->grouptab->save();
+ gosa_log ("Group object'".$this->dn."' has been saved");
+
+ /* Group has been saved successfully, remove lock from LDAP. */
+ if ($this->dn != "new"){
+ del_lock ($this->dn);
}
- register_global("groupfilter", $groupfilter);
- $smarty= get_smarty();
+ /* There's no page reload so we have to read new users at this point. */
+ //$this->reload ();
+ unset ($this->grouptab);
+ $this->grouptab= NULL;
+ unset ($_SESSION['objectinfo']);
- /* Prepare formular */
- if (!isset($this->grouptab) &&
- !isset($_POST['new_group']) &&
- !isset($_POST['delete_group']) &&
- !isset($_POST['select_group'])){
- $this->reload();
- }
+ } else {
+ /* Ok. There seem to be errors regarding to the tab data,
+ show message and continue as usual. */
+ show_errors($message);
+ }
+ }
- /* Check for exeeded sizelimit */
- if (($message= check_sizelimit()) != ""){
- return($message);
- }
- /* New group? */
- if (isset($_POST['new_group'])){
-
- /* By default we set 'dn' to 'new', all relevant plugins will
- react on this. */
- $this->dn= "new";
-
- /* Create new usertab object */
- $this->grouptab= new grouptabs($this->config,
- $this->config->data['TABS']['GROUPTABS'], $this->dn);
- $this->grouptab->set_acl(array(':all'));
- }
-
- /* Cancel dialogs */
- if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel'])){
- del_lock ($this->grouptab->dn);
- unset ($this->grouptab);
- $this->grouptab= NULL;
- unset($_SESSION['objectinfo']);
- }
-
- /* Finish group edit is triggered by the tabulator dialog, so
- the user wants to save edited data. Check and save at this
- point. */
- if (isset($_POST['edit_finish'])){
-
- /* Check tabs, will feed message array */
- $message= $this->grouptab->check();
-
- /* Save, or display error message? */
- if (count($message) == 0){
-
- /* Save user data to ldap */
- $this->grouptab->save();
- gosa_log ("Group object'".$this->dn."' has been saved");
-
- /* Group has been saved successfully, remove lock from
- LDAP. */
- if ($this->dn != "new"){
- del_lock ($this->dn);
- }
-
- /* There's no page reload so we have to read new users at
- this point. */
- $this->reload ();
- unset ($this->grouptab);
- $this->grouptab= NULL;
- unset ($_SESSION['objectinfo']);
-
- } else {
- /* Ok. There seem to be errors regarding to the tab data,
- show message and continue as usual. */
- show_errors($message);
- }
- }
-
- /* User wants to edit data? */
- if ((isset($_POST['select_group']) || (isset($_POST['edit_helper']) && $_POST['edit_helper'] == "1")) && isset($_POST['grouplist']) && $_POST['grouplist'] != ""){
-
- /* Get 'dn' from posted 'uid', must be unique */
- $this->dn= trim($_POST['grouplist']);
-
- /* Check locking, save current plugin in 'back_plugin', so
- the dialog knows where to return. */
- if (($user= get_lock($this->dn)) != ""){
- return(gen_locked_message ($user, $this->dn));
- }
-
- /* Lock the current entry, so everyone will get the
- above dialog */
- add_lock ($this->dn, $this->ui->dn);
-
- /* Set up the users ACL's for this 'dn' */
- $acl= get_permissions ($this->dn, $this->ui->subtreeACL);
-
- /* Register grouptab to trigger edit dialog */
- $this->grouptab= new grouptabs($this->config,
- $this->config->data['TABS']['GROUPTABS'], $this->dn);
- $this->grouptab->set_acl($acl);
- $_SESSION['objectinfo']= $this->dn;
- }
-
- /* Remove user was requested */
- if (isset($_POST['delete_group']) && isset($_POST['grouplist'])){
-
- /* Get 'dn' from posted 'uid' */
- $this->dn= trim($_POST['grouplist']);
-
- /* Load permissions for selected 'dn' and check if
- we're allowed to remove this 'dn' */
- $acl= get_permissions ($this->dn, $this->ui->subtreeACL);
- $this->acl= get_module_permission($acl, "group", $this->dn);
- if (chkacl($this->acl, "delete") == ""){
-
- /* Check locking, save current plugin in 'back_plugin', so
- the dialog knows where to return. */
- if (($user= get_lock($this->dn)) != ""){
- return(gen_locked_message ($user, $this->dn));
- }
-
- /* Lock the current entry, so nobody will edit it during deletion */
- add_lock ($this->dn, $this->ui->dn);
- $smarty->assign("info", sprintf(_("You're about to delete the group '%s'."), $this->dn));
- return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
- } else {
-
- /* Obviously the user isn't allowed to delete. Show message and
- clean session. */
- print_red (_("You are not allowed to delete this group!"));
- }
- }
-
- /* Confirmation for deletion has been passed. Group should be deleted. */
- if (isset($_POST['delete_group_confirm'])){
-
- /* Some nice guy may send this as POST, so we've to check
- for the permissions again. */
- if (chkacl($this->acl, "delete") == ""){
-
- /* Delete request is permitted, perform LDAP action */
- $this->grouptab= new grouptabs($this->config,
- $this->config->data['TABS']['GROUPTABS'], $this->dn);
- $this->grouptab->set_acl(array($this->acl));
- $this->grouptab->delete ();
- gosa_log ("Group object'".$this->dn."' has been removed");
- unset ($this->grouptab);
- $this->grouptab= NULL;
-
- /* Group list has changed, reload it. */
- $this->reload ();
- } else {
-
- /* Normally this shouldn't be reached, send some extra
- logs to notify the administrator */
- print_red (_("You are not allowed to delete this group!"));
- gosa_log ("Warning: '".$this->ui->uid."' tried to trick group deletion.");
- }
-
- /* Remove lock file after successfull deletion */
- del_lock ($this->dn);
- unset($_SESSION['objectinfo']);
- }
-
-
- /* Delete group canceled? */
- if (isset($_POST['delete_cancel'])){
- del_lock ($this->dn);
- unset($_SESSION['objectinfo']);
- }
-
- /* Show tab dialog if object is present */
- if ($this->grouptab){
- $display= $this->grouptab->execute();
-
- /* Don't show buttons if tab dialog requests this */
- if (!$this->grouptab->by_object[$this->grouptab->current]->dialog){
- $display.= "<p style=\"text-align:right\">\n";
- $display.= "<input type=submit name=\"edit_finish\" value=\""._("Finish")."\">\n";
- $display.= " \n";
- $display.= "<input type=submit name=\"edit_cancel\" value=\""._("Cancel")."\">\n";
- $display.= "</p>";
- }
- return ($display);
- }
+ /********************
+ Edit existing group
+ ********************/
- /* Show main page */
- $smarty->assign("grouplist", $this->grouplist);
- $smarty->assign("search_image", get_template_path('images/search.png'));
- $smarty->assign("tree_image", get_template_path('images/tree.png'));
- $smarty->assign("infoimage", get_template_path('images/info.png'));
- $smarty->assign("launchimage", get_template_path('images/launch.png'));
- $smarty->assign("deplist", $this->config->idepartments);
- foreach( array("depselect", "guser", "regex", "primarygroups", "mailgroups",
- "appgroups", "sambagroups", "functionalgroups", "subsearch") as $type){
-
- $smarty->assign("$type", $groupfilter[$type]);
- }
-
- /* Extend if we are not using javascript */
- $smarty->assign("apply", apply_filter());
- $smarty->assign("alphabet", generate_alphabet());
- $smarty->assign("hint", print_sizelimit_warning());
-
- return($smarty->fetch(get_template_path('headpage.tpl', TRUE)));
- }
+ /* User wants to edit data? */
+ if (($s_action=="edit") && (!isset($this->grouptab-> config))){
+ /* Get 'dn' from posted 'uid', must be unique */
+ $this->dn= $this->grouplist[trim($s_entry)]['dn'];
- function reload()
- {
- /* Get config */
- $groupfilter= get_global('groupfilter');
-
- /* Set base for all searches */
- $base= $groupfilter['depselect'];
-
- /* Regex filter? */
- if ($groupfilter['regex'] != ""){
- $regex= $groupfilter['regex'];
- } else {
- $regex= "*";
- }
-
- /* User filter? */
- $filter= "";
- $error= "";
- $error2= "";
- $this->grouplist= array();
-
- /* What are primary groups? */
- $primaries= array();
- $ldap= $this->config->get_ldap_link(TRUE);
- $ldap->cd($base);
- $ldap->search("(&(uid=$regex)(!(uid=*$))(objectClass=posixAccount)(gidNumber=*))", array("gidNumber", "cn"));
- $error= $ldap->error;
- while ($attrs= $ldap->fetch()){
- $primaries[$attrs['gidNumber'][0]]= $attrs['cn'][0];
- }
- if ($groupfilter['primarygroups'] == "checked"){
- $filter.= "(&(objectClass=posixGroup)(|";
- foreach ($primaries as $gidNumber => $cn){
- $filter.= "(gidNumber=$gidNumber)";
- }
- $filter.= "))";
- }
-
- /* Set filter depending on selection */
- if ($groupfilter['appgroups'] == "checked"){
- $filter.= "(objectClass=gosaApplicationGroup)";
- }
- if ($this->config->current['SAMBAVERSION'] == 3){
- $sfilter= "(objectClass=sambaGroupMapping)";
- if ($groupfilter['sambagroups'] == "checked"){
- $filter.= "(objectClass=sambaGroupMapping)";
- }
- } else {
- $sfilter= "";
- }
- if ($groupfilter['mailgroups'] == "checked"){
- $filter.= "(objectClass=gosaMailAccount)";
- }
- if ($groupfilter['functionalgroups'] == "checked"){
- $ldap->cd($base);
- $ldap->set_size_limit($_SESSION['size_limit']);
- $ldap->search("(&(cn=$regex)(objectClass=posixGroup)(!(|(objectClass=gosaMailAccount)(objectClass=gosaApplicationGroup)$sfilter)))", array("cn", "gidNumber", "description"));
- $error2= $ldap->error;
- while ($attrs= $ldap->fetch()){
- if (!isset($primaries[$attrs['gidNumber'][0]])){
- if (isset($attrs["description"][0])){
- $this->grouplist[$attrs["dn"]]= $attrs["cn"][0]." [".
- $attrs["description"][0]."]";
- } else {
- $this->grouplist[$attrs["dn"]]= $attrs["cn"][0];
- }
- }
- }
- }
-
- /* Generate grouplist */
- if ($filter != ""){
- $filter= "(&(cn=$regex)(objectClass=posixGroup)(|$filter))";
- if ($groupfilter['guser'] != ""){
- $filter= "(&(|(memberUID=" . $groupfilter['guser'] . ")(cn=" . $groupfilter['guser'] . "))$filter)";
- }
- }
- if ($groupfilter['subsearch'] == "checked"){
- $res= get_list($this->ui->subtreeACL, "$filter", TRUE, $base, array("cn", "description", "gidNumber"), TRUE);
- } else {
- $base= get_groups_ou().$base;
- $res= get_list($this->ui->subtreeACL, "$filter", FALSE, $base, array("cn", "description", "gidNumber"), TRUE);
- }
- if (preg_match("/size limit/i", $error) || preg_match("/size limit/i", $error2)){
- $_SESSION['limit_exceeded']= TRUE;
- }
-
- foreach ($res as $value){
- if (isset($value["description"][0])){
- $this->grouplist[$value["dn"]]= $value["cn"][0]." [".
- $value["description"][0]."]";
- } else {
- $this->grouplist[$value["dn"]]= $value["cn"][0];
- }
- }
- natcasesort ($this->grouplist);
- reset ($this->grouplist);
- }
+ /* Check locking & lock entry if required */
+ $user = get_lock($this->dn);
+ if ($user != ""){
+ return(gen_locked_message ($user, $this->dn));
+ }
+ add_lock ($this->dn, $this->ui->dn);
- function remove_from_parent()
- {
- /* Optionally execute a command after we're done */
- $this->postremove();
- }
+ /* Set up the users ACL's for this 'dn' */
+ $acl= get_permissions ($this->dn, $this->ui->subtreeACL);
+ /* Register grouptab to trigger edit dialog */
+ $this->grouptab= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $this->dn);
+ $this->grouptab->set_acl($acl);
+ $_SESSION['objectinfo']= $this->dn;
+ }
- /* Save data to object */
- function save_object()
- {
- }
+ /********************
+ Delete group
+ ********************/
- /* Check values */
- function check()
+ /* Remove group was requested */
+ if ($s_action=="del"){
+
+ /* Get 'dn' from posted 'uid' */
+ $this->dn= $this->grouplist[trim($s_entry)]['dn'];
+
+ /* Load permissions for selected 'dn' and check if
+ we're allowed to remove this 'dn' */
+ $acl= get_permissions ($this->dn, $this->ui->subtreeACL);
+ $this->acl= get_module_permission($acl, "group", $this->dn);
+ if (chkacl($this->acl, "delete") == ""){
+
+ /* Check locking, save current plugin in 'back_plugin', so
+ the dialog knows where to return. */
+ if (($user= get_lock($this->dn)) != ""){
+ return(gen_locked_message ($user, $this->dn));
+ }
+
+ /* Lock the current entry, so nobody will edit it during deletion */
+ add_lock ($this->dn, $this->ui->dn);
+ $smarty->assign("info", sprintf(_("You're about to delete the group '%s'."), @LDAP::fix($this->dn)));
+ return($smarty->fetch(get_template_path('remove.tpl', TRUE)));
+
+ } else {
+
+ /* Obviously the user isn't allowed to delete. Show message and clean session. */
+ print_red (_("You are not allowed to delete this group!"));
+ }
+ }
+
+
+ /********************
+ Delete group confirmed
+ ********************/
+
+ /* Confirmation for deletion has been passed. Group should be deleted. */
+ if (isset($_POST['delete_group_confirm'])){
+
+ /* Some nice guy may send this as POST, so we've to check
+ for the permissions again. */
+ if (chkacl($this->acl, "delete") == ""){
+
+ /* Delete request is permitted, perform LDAP action */
+ $this->grouptab= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $this->dn);
+ $this->grouptab->set_acl(array($this->acl));
+ $this->grouptab->delete ();
+ gosa_log ("Group object'".$this->dn."' has been removed");
+ unset ($this->grouptab);
+ $this->grouptab= NULL;
+
+ /* Group list has changed, reload it. */
+ //$this->reload ();
+
+ } else {
+
+ /* Normally this shouldn't be reached, send some extra
+ logs to notify the administrator */
+ print_red (_("You are not allowed to delete this group!"));
+ gosa_log ("Warning: '".$this->ui->uid."' tried to trick group deletion.");
+ }
+
+ /* Remove lock file after successfull deletion */
+ del_lock ($this->dn);
+ unset($_SESSION['objectinfo']);
+ }
+
+
+ /********************
+ Delete group canceled
+ ********************/
+
+ /* Delete group canceled? */
+ if (isset($_POST['delete_cancel'])){
+ del_lock ($this->dn);
+ unset($_SESSION['objectinfo']);
+ }
+
+
+ /********************
+ A dialog was canceled
+ ********************/
+
+ /* Cancel dialogs */
+ if (isset($_POST['edit_cancel']) || isset($_POST['password_cancel'])){
+ del_lock ($this->grouptab->dn);
+ unset ($this->grouptab);
+ $this->grouptab= NULL;
+ unset($_SESSION['objectinfo']);
+ }
+
+
+ /********************
+ If there is currently a dialog open, display it
+ ********************/
+
+ /* Show tab dialog if object is present */
+ if (isset($this->grouptab->config)){
+ $display= $this->grouptab->execute();
+
+ /* Don't show buttons if tab dialog requests this */
+ if (!$this->grouptab->by_object[$this->grouptab->current]->dialog){
+ $display.= "<p style=\"text-align:right\">\n";
+ $display.= "<input type=submit name=\"edit_finish\" value=\""._("Save")."\">\n";
+ $display.= " \n";
+ $display.= "<input type=submit name=\"edit_cancel\" value=\""._("Cancel")."\">\n";
+ $display.= "</p>";
+ }
+ return ($display);
+ }
+
+ /* Display dialog with group list */
+ $this->DivListGroup->parent = $this;
+ $this->DivListGroup->execute();
+
+ /* Add departments if subsearch is disabled */
+ if(!$this->DivListGroup->SubSearch){
+ $this->DivListGroup->AddDepartments($this->DivListGroup->selectedBase,4);
+ }
+ $this->reload ();
+ $this->DivListGroup->setEntries($this->grouplist);
+ return($this->DivListGroup->Draw());
+ }
+
+ function reload($CreatePosixsList=false)
{
+ $this->grouplist = array();
+ $primaries = array();
+ $functional = array();
+ $error= $error2 = "";
+ $filter = "(objectclass=posixGroup)";
+
+ $base = $this->DivListGroup->selectedBase;
+ $Regex = $this->DivListGroup->Regex;
+ $UserRegex = $this->DivListGroup->UserRegex;
+ $SubSearch = $this->DivListGroup->SubSearch;
+ $ShowPrimaryGroups = $this->DivListGroup->ShowPrimaryGroups;
+ $ShowSambaGroups = $this->DivListGroup->ShowSambaGroups;
+ $ShowApplicationGroups = $this->DivListGroup->ShowApplicationGroups;
+ $ShowMailGroups = $this->DivListGroup->ShowMailGroups;
+ $ShowFunctionalGroups = $this->DivListGroup->ShowFunctionalGroups;
+
+ /* Prepare ldap class */
+ $ldap= $this->config->get_ldap_link();
+ $ldap->cd($base);
+ $ldap->set_size_limit($_SESSION['size_limit']);
+
+
+ /********************
+ Create filter depending on selected checkboxes
+ ********************/
+
+ /* Add application groups */
+ if ($ShowApplicationGroups){
+ $filter.= "(objectClass=gosaApplicationGroup)";
+ }
+
+ /* Add Mail Groups */
+ if ($ShowMailGroups){
+ $filter.= "(objectClass=gosaMailAccount)";
+ }
+
+ $sfilter= "";
+ if ($this->config->current['SAMBAVERSION'] == 3){
+ if (!$ShowPrimaryGroups){
+ $sfilter= "(objectClass=sambaGroupMapping)";
+ } elseif ($ShowSambaGroups){
+ $filter.= "(objectClass=sambaGroupMapping)";
+ }
+ }
+
+ /* Prepare filter for given Regex && UserRegex */
+ if ($filter != ""){
+ $filter= "(&(cn=$Regex)(objectClass=posixGroup)(|$filter))";
+ if ($UserRegex != ""){
+ $filter= "(&(|(memberUID=".$UserRegex.")(cn=".$UserRegex."))$filter)";
+ }
+ }
+
+
+ /********************
+ Collect some groupids to be able to skip primary & functional groups
+ ********************/
+
+ /* Collect primary groupIDs to show primary groups
+ if this option is enabled in gosa conf && the checkbox is checked */
+ if ($this->ShowPrimaryCheckBox){
+ $res = get_list("(&(uid=$Regex)(!(uid=*$))(objectClass=posixAccount)(gidNumber=*))", $this->ui->subtreeACL,
+ $base,array("gidNumber", "cn"), GL_SUBSEARCH);
+ foreach ($res as $attrs){
+ $primaries[$attrs['gidNumber'][0]]= $attrs['cn'][0];
+ }
+ }
+
+ /* Collect all GroupIDs from those groups which are functional.
+ Only perfrom this search if ShowFunctionalGroups is unchecked, else leave arre empty */
+ $ff = "(&(cn=$Regex)(objectClass=posixGroup)(!(|(objectClass=gosaMailAccount)(objectClass=gosaApplicationGroup)$sfilter)))";
+ $res = get_list($ff,$this->ui->subtreeACL,$base,array("gidNumber", "cn", "description"), GL_SUBSEARCH);
+ foreach($res as $attrs){
+ if (!isset($primaries[$attrs['gidNumber'][0]])){
+ $functional[$attrs['gidNumber'][0]]= $attrs['gidNumber'][0];
+ }
+ }
+
+
+ /********************
+ Search for the prepared filter
+ ********************/
+
+ /* If subsearch is activated search for subobjects too */
+ $attrs = array("cn", "description", "gidNumber", "objectClass","FAIrelease");
+
+ if ($SubSearch){
+ $res= get_list($filter, $this->ui->subtreeACL, $base, $attrs, GL_SIZELIMIT| GL_SUBSEARCH);
+ } else {
+ $res= get_list($filter, $this->ui->subtreeACL, get_groups_ou().$base, $attrs, GL_SIZELIMIT);
+ }
+
+ /* Sort values into grouplist*/
+ $tmp = $tmp2 = array();
+ foreach ($res as $value){
+ /* Skip functional groups if checkbox isn't checked */
+ if (!$ShowFunctionalGroups && isset($functional[$value['gidNumber'][0]])){
+ continue;
+ }
+
+ /* If gidNumber is in $primaries skip this entry */
+ if (($ShowPrimaryGroups) || (!$ShowPrimaryGroups && !isset($primaries[$value['gidNumber'][0]]))){
+ $tmp2[$value['cn'][0]] = $value;
+ $tmp [$value['cn'][0]] = $value['cn'][0];
+ }
+ }
+ natcasesort($tmp);
+ foreach($tmp as $name){
+ $this->grouplist[] = $tmp2[$name];
+ }
+ reset ($this->grouplist);
}
- /* Save to LDAP */
- function save()
+
+ /* Perform copy & paste requests
+ If copy&paste is in progress this returns a dialog to fix required attributes
+ */
+ function copyPasteHandling($s_action,$s_entry)
{
- /* Optionally execute a command after we're done */
- $this->postcreate();
+ /* Paste copied/cutted object in here
+ */
+ if(($s_action == "editPaste") || ($this->CopyPasteHandler->stillOpen())){
+ $this->CopyPasteHandler->save_object();
+ $this->CopyPasteHandler->SetVar("base",$this->DivListGroup->selectedBase);
+ if($str = $this->CopyPasteHandler->execute()){
+ return( $str);
+ };
+ /* Ensure that the new object is shown in the list now */
+ $this->relaod();
+ }
+
+
+ /* Copy current object to CopyHandler
+ */
+ if($s_action == "copy"){
+ $this->CopyPasteHandler->Clear();
+
+ $dn = $this->grouplist[trim($s_entry)]['dn'];
+ $acl = get_permissions ($dn, $this->ui->subtreeACL);
+
+ $obj = new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $dn);
+ $objNew = new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], "new");
+ $obj->set_acl($acl);
+ $objNew->set_acl($acl);
+ $this->CopyPasteHandler->Copy($obj,$objNew);
+ }
+
+
+ /* Copy current object to CopyHandler
+ */
+ if($s_action == "cut"){
+ $this->CopyPasteHandler->Clear();
+ $dn = $this->grouplist[trim($s_entry)]['dn'];
+ $acl= get_permissions ($dn, $this->ui->subtreeACL);
+
+ $obj= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $dn);
+ $obj->set_acl($acl);
+
+ $this->CopyPasteHandler->Cut($obj);
+ }
}
- function adapt_from_template($dn)
+ /* Save data to object */
+ function save_object()
{
+ $this->DivListGroup->save_object();
}
- function password_change_needed()
+
+ function remove_lock()
{
+ if (isset($this->grouptab->dn)){
+ del_lock ($this->grouptab->dn);
+ }
}
- function show_header($button_text, $text, $disabled= FALSE)
+
+ function remove_from_parent()
{
+ /* Optionally execute a command after we're done */
+ $this->postremove();
}
- function remove_lock()
+
+ /* Save to LDAP */
+ function save()
{
- if (isset($this->grouptab->dn)){
- del_lock ($this->grouptab->dn);
- }
+ /* Optionally execute a command after we're done */
+ $this->postcreate();
}
+ /* Unused functions */
+ function check() { }
+ function adapt_from_template($dn) { }
+ function password_change_needed() { }
+ function show_header($button_text, $text, $disabled= FALSE) { }
}
-
+// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler:
?>