X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fgroups%2Fclass_groupManagement.inc;h=f1c1f14d1e8a57b4c89bd2d1057b3fae47d15a72;hb=085f720b1543c1735bed00f5974007d13d0f92b4;hp=a48df89c1fbe3221cf8507fa253cd01fe717d558;hpb=8f2fafb6aa972a212c23415c1c8f06a6692efb0b;p=gosa.git
diff --git a/plugins/admin/groups/class_groupManagement.inc b/plugins/admin/groups/class_groupManagement.inc
index a48df89c1..f1c1f14d1 100644
--- a/plugins/admin/groups/class_groupManagement.inc
+++ b/plugins/admin/groups/class_groupManagement.inc
@@ -24,7 +24,6 @@ class groupManagement extends plugin
/* Definitions */
var $plHeadline= "Groups";
var $plDescription= "This does something";
- var $departments = array();
/* Dialog attributes */
var $grouptab= NULL;
@@ -33,6 +32,9 @@ class groupManagement extends plugin
var $acl= "";
var $CopyPasteHandler = NULL;
+ var $DivListGroup = NULL;
+
+ var $ShowPrimaryCheckBox = false;
function groupManagement ($config, $ui)
{
@@ -40,27 +42,21 @@ class groupManagement extends plugin
$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);
}
- /* 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" => "",
- "regex" => "*");
- register_global("groupfilter", $groupfilter);
- }
- if(!isset($_SESSION['CurrentMainBase'])){
- $base = get_base_from_people($ui->dn);
- $_SESSION['CurrentMainBase'] = $base;
+ /* Detect if we have to display the primary group checkbox */
+ if (isset($this->config->data['MAIN']['NOPRIMARYGROUP'])){
+ $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()
@@ -68,44 +64,13 @@ class groupManagement extends plugin
/* 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 */
- $groupfilter= get_global("groupfilter");
$s_action = "";
$s_entry = "";
- if (!isset($this->grouptab)){
- foreach( array( "guser", "regex") as $type){
- if (isset($_POST[$type])){
- $groupfilter[$type]= $_POST[$type];
- }
- }
- if(isset($_POST['CurrentMainBase'])){
- $_SESSION['CurrentMainBase'] = $_POST['CurrentMainBase'];
- }
- if (isset($_POST['regex'])){
- 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;
- }
- register_global("groupfilter", $groupfilter);
- }
-
-
/* Test Posts */
foreach($_POST as $key => $val){
// Post for delete
@@ -117,8 +82,6 @@ class groupManagement extends plugin
$s_action="edit";
$s_entry = preg_replace("/group_".$s_action."_/i","",$key);
// Post for new
- }elseif(preg_match("/^dep_back.*/i",$key)){
- $s_action="back";
}elseif(preg_match("/^group_new.*/",$key)){
$s_action="new";
}elseif(preg_match("/^dep_home.*/i",$key)){
@@ -128,8 +91,6 @@ class groupManagement extends plugin
}elseif(preg_match("/^group_chgpw.*/i",$key)){
$s_action="change_pw";
$s_entry = preg_replace("/group_chgpw_/i","",$key);
- }elseif(preg_match("/^dep_root.*/i",$key)){
- $s_action="root";
}elseif(preg_match("/_group_edit_/",$key)){
$type = preg_replace("/_group_edit_.*$/","",$key);
$s_action="edit";
@@ -147,58 +108,17 @@ class groupManagement extends plugin
}
$s_entry = preg_replace("/_.$/","",$s_entry);
- /* Start for New List Managment */
- if(isset($_GET['act'])&&($_GET['act']=="dep_open")){
- $s_action="open";
- $s_entry = base64_decode($_GET['dep_id']);
- $_SESSION['CurrentMainBase']= "".$this->config->departments[trim($s_entry)];
- }
-
- // Edit if
- if((isset($_GET['act']))&&($_GET['act']=="edit_entry")){
- $s_action ="edit";
- $s_entry = $_GET['id'];
- }
-
- /* Department changed? */
- if(isset($_POST['CurrentMainBase']) && $_POST['CurrentMainBase']){
- $_SESSION['CurrentMainBase']= $_POST['CurrentMainBase'];
- }
-
- /* Homebutton is posted */
- if($s_action=="home"){
- //FIXME: This will not work if we've no subdirs (like i.e. ou=people)? See
- // class_userManagement.inc for a fix.
- $_SESSION['CurrentMainBase']= (preg_replace("/^[^,]+,/","",$this->ui->dn));
- $_SESSION['CurrentMainBase']= (preg_replace("/^[^,]+,/","",$_SESSION['CurrentMainBase']));
- }
-
- if($s_action=="root"){
- $_SESSION['CurrentMainBase']=($this->config->current['BASE']);
+ /* Check for posted gets */
+ if((isset($_GET['act'])) && ($_GET['act'] == "edit_entry")){
+ $s_entry = $_GET['id'];
+ $s_action = "edit";
}
- /* If Backbutton is Posted */
- if($s_action == "back"){
- $base_back= preg_replace("/^[^,]+,/","",$_SESSION['CurrentMainBase']);
- $base_back= convert_department_dn($base_back);
-
- if(isset($this->config->departments[trim($base_back)])){
- $_SESSION['CurrentMainBase']= $this->config->departments[trim($base_back)];
- }else{
- $_SESSION['CurrentMainBase']= $this->config->departments["/"];
- }
- }
- register_global("groupfilter", $groupfilter);
-
$smarty= get_smarty();
- /* Prepare formular */
- $this->reload();
-
- /* Check for exeeded sizelimit */
- if (($message= check_sizelimit()) != ""){
- return($message);
- }
+ /********************
+ Copy & Paste Handling ...
+ ********************/
/* Only perform copy&paste requests if it is enabled
*/
@@ -208,6 +128,11 @@ class groupManagement extends plugin
}
}
+
+ /********************
+ Create a new group ...
+ ********************/
+
/* New group? */
if ($s_action=="new"){
@@ -216,45 +141,39 @@ class groupManagement extends plugin
$this->dn= "new";
/* Create new usertab object */
- $this->grouptab= new grouptabs($this->config,
- $this->config->data['TABS']['GROUPTABS'], $this->dn);
+ $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 ($_SESSION['CurrentMainBase'], $this->ui->subtreeACL);
+ $acl= get_permissions ($this->DivListGroup->selectedBase, $this->ui->subtreeACL);
$this->grouptab->set_acl($acl);
}
- /* 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']);
- }
+
+ /********************
+ 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 */
+ /* Check tabs, will feed message array
+ Save, or display error message? */
$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. */
+ /* 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 ();
+ /* 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']);
@@ -266,37 +185,41 @@ class groupManagement extends plugin
}
}
+
+ /********************
+ Edit existing group
+ ********************/
+
/* 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'];
- /* Check locking, save current plugin in 'back_plugin', so
- the dialog knows where to return. */
-
+ /* Check locking & lock entry if required */
$user = get_lock($this->dn);
-
if ($user != ""){
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= new grouptabs($this->config,$this->config->data['TABS']['GROUPTABS'], $this->dn);
$this->grouptab->set_acl($acl);
$_SESSION['objectinfo']= $this->dn;
}
- /* Remove user was requested */
+
+ /********************
+ Delete group
+ ********************/
+
+ /* Remove group was requested */
if ($s_action=="del"){
+
/* Get 'dn' from posted 'uid' */
$this->dn= $this->grouplist[trim($s_entry)]['dn'];
@@ -316,14 +239,19 @@ class groupManagement extends plugin
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. */
+ } 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'])){
@@ -332,8 +260,7 @@ class groupManagement extends plugin
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= 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");
@@ -341,7 +268,8 @@ class groupManagement extends plugin
$this->grouptab= NULL;
/* Group list has changed, reload it. */
- $this->reload ();
+ //$this->reload ();
+
} else {
/* Normally this shouldn't be reached, send some extra
@@ -356,11 +284,33 @@ class groupManagement extends plugin
}
+ /********************
+ 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)){
@@ -377,334 +327,141 @@ class groupManagement extends plugin
return ($display);
}
- /* Prepare departments */
- $options= "";
- foreach ($this->config->idepartments as $key => $value){
- if ($_SESSION['CurrentMainBase'] == $key){
- $options.= "";
- } else {
- $options.= "";
- }
- }
-
- /* Create paste icon
- */
- if($this->CopyPasteHandler){
- $Copy_Paste = " ";
- if($this->CopyPasteHandler->isCurrentObjectPastAble()){
- if($this->CopyPasteHandler->isCurrentCutted()){
- $img = "images/cutpaste.png";
- }else{
- $img = "images/copypaste.png";
- }
- $Copy_Paste .= " ";
- }else{
- $Copy_Paste .= "
";
- }
- }else{
- $Copy_Paste ="";
- }
-
- // Managment
- $listhead = "