X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fogroups%2Fclass_ogroupManagement.inc;h=2cb1f755a1b30980e5131e093ffeef432af61d86;hb=a55556288dcb9fd7ef67704102850a0419205f9c;hp=effe4d5e799bb1ce3b8301a398e9db944fc22272;hpb=276650eae5da9b54f28f59419c5e19278a47a9ef;p=gosa.git
diff --git a/plugins/admin/ogroups/class_ogroupManagement.inc b/plugins/admin/ogroups/class_ogroupManagement.inc
index effe4d5e7..2cb1f755a 100644
--- a/plugins/admin/ogroups/class_ogroupManagement.inc
+++ b/plugins/admin/ogroups/class_ogroupManagement.inc
@@ -31,10 +31,8 @@ class ogroupManagement extends plugin
var $obtypes= array();
var $ogroup;
- var $CopyPasteHandler ;
-
- var $enableCopyPaste = false;
-
+ var $CopyPasteHandler = NULL;
+ var $DivListOGroup = NULL;
function ogroupManagement ($config, $dn= NULL)
{
@@ -45,80 +43,28 @@ class ogroupManagement extends plugin
/* Copy & Paste enabled ?
*/
if((isset($this->config->data['MAIN']['ENABLECOPYPASTE']))&&(preg_match("/true/i",$this->config->data['MAIN']['ENABLECOPYPASTE'] ))){
- $this->enableCopyPaste = true;
+ $this->CopyPasteHandler = new CopyPasteHandler($this->config);
}
- $this->CopyPasteHandler = new CopyPasteHandler($this->config);
-
- /* Fill translation array */
- $this->obtypes= array( "posixAccount" => _("UNIX accounts"),
- "posixGroup" => _("Groups"),
- "gosaDepartment" => _("Departments"),
- "gosaApplication" => _("Applications"),
- "goServer" => _("Servers"),
- "gotoTerminal" => _("Thin Clients"),
- "gotoWorkstation" => _("Workstations"),
- "goFonHardware" => _("Phone"),
- "gotoPrinter" => _("Printer"));
- asort($this->obtypes);
-
- /* Get global filter config */
- if (!is_global("ogroupfilter")){
- $ui= get_userinfo();
- $base= get_base_from_people($ui->dn);
- $ogroupfilter= array( "usergroups" => "checked",
- "groupgroups" => "checked",
- "appgroups" => "checked",
- "depgroups" => "checked",
- "servergroups" => "checked",
- "wsgroups" => "checked",
- "prtgroups" => "checked",
- "tcgroups" => "checked",
- "fongroups" => "checked",
- "depselect" => $base,
- "regex" => "*");
- register_global("ogroupfilter", $ogroupfilter);
- }
+ /* Div lsit management */
+ $this->DivListOGroup = new divListOGroup($this->config,$this);
}
function execute()
{
- /* Call parent execute */
- plugin::execute();
+ /* Call parent execute */
+ plugin::execute();
- $_SESSION['LOCK_VARS_TO_USE'] = array("/^act$/","/^id$/","/^group_edit_/","/^group_del_/");
+ /****************
+ Variable intialisation && Check posts for commands
+ ****************/
- /* Prepare template */
- $smarty= get_smarty();
+ $_SESSION['LOCK_VARS_TO_USE'] = array("/^act$/","/^id$/","/^group_edit_/","/^group_del_/","/^item_selected/","/^remove_multiple_ogroups/");
- $ogroupfilter= get_global("ogroupfilter");
+ $smarty = get_smarty();
$s_action = "";
$s_entry = "";
- foreach( array("depselect", "regex") as $type){
- if (isset($_POST[$type])){
- $ogroupfilter[$type]= $_POST[$type];
- }
- }
- if (isset($_POST['Ogroup_dialog_posted'])){
- foreach( array("usergroups", "groupgroups", "appgroups", "depgroups",
- "servergroups", "wsgroups", "prtgroups", "tcgroups", "fongroups") as $type){
-
- if (isset($_POST[$type])) {
- $ogroupfilter[$type]= "checked";
- } else {
- $ogroupfilter[$type]= "";
- }
- }
- }
- if (isset($_GET['search'])){
- $s= mb_substr($_GET['search'], 0, 1, "UTF8")."*";
- if ($s == "**"){
- $s= "*";
- }
- $ogroupfilter['regex']= $s;
- }
-
/* Test Posts */
foreach($_POST as $key => $val){
// Post for delete
@@ -130,19 +76,8 @@ class ogroupManagement 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)){
- $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("/^dep_root.*/i",$key)){
- $s_action="root";
}elseif(preg_match("/^editPaste.*/i",$key)){
$s_action="editPaste";
}elseif(preg_match("/^copy_.*/",$key)){
@@ -151,6 +86,8 @@ class ogroupManagement extends plugin
}elseif(preg_match("/^cut_.*/",$key)){
$s_action="cut";
$s_entry = preg_replace("/^cut_/i","",$key);
+ }elseif(preg_match("/^remove_multiple_ogroups/",$key)){
+ $s_action="del_multiple";
}elseif(preg_match("/_group_edit_/",$key)){
$type = preg_replace("/_group_edit_.*$/","",$key);
$s_action="edit";
@@ -159,42 +96,6 @@ class ogroupManagement extends plugin
}
}
$s_entry = preg_replace("/_.$/","",$s_entry);
-
- /* Department changed? */
- if(isset($_POST['depselect']) && $_POST['depselect']){
- $ogroupfilter['depselect']= $_POST['depselect'];
- }
-
- /* Start for New List Managment */
- if(isset($_GET['act'])&&($_GET['act']=="dep_open")){
- $s_action="open";
- $s_entry = base64_decode($_GET['dep_id']);
- $ogroupfilter['depselect']= "".$this->config->departments[trim($s_entry)];
- }
-
- /* If Backbutton is Posted */
- if($s_action=="back"){
- $base_back = preg_replace("/^[^,]+,/","",$ogroupfilter['depselect']);
- $base_back = convert_department_dn($base_back);
-
- if(isset($this->config->departments[trim($base_back)])){
- $ogroupfilter['depselect']= $this->config->departments[trim($base_back)];
- }else{
- $ogroupfilter['depselect']= $this->config->departments["/"];
- }
- register_global("ogroupfilter", $ogroupfilter);
- }
-
- /* Homebutton is posted */
- if($s_action=="home"){
- $ogroupfilter['depselect']=(preg_replace("/^[^,]+,/","",$this->ui->dn));
- $ogroupfilter['depselect']=(preg_replace("/^[^,]+,/","",$ogroupfilter['depselect']));
- }
-
- /* root posted */
- if($s_action=="root"){
- $ogroupfilter['depselect']=($this->config->current['BASE']);
- }
// Edit if
if((isset($_GET['act']))&&($_GET['act']=="edit_entry")){
@@ -202,61 +103,115 @@ class ogroupManagement extends plugin
$s_entry = $_GET['id'];
}
- register_global("ogroupfilter", $ogroupfilter);
- $this->reload();
+ /****************
+ Copy & Paste handling
+ ****************/
- /* Check for exeeded sizelimit */
- if (($message= check_sizelimit()) != ""){
- return($message);
+ /* Display the copy & paste dialog, if it is currently open */
+ $ret = $this->copyPasteHandling($s_action,$s_entry);
+ if($ret){
+ return($ret);
}
- /* Only perform copy / paste if it is enabled
- */
- if($this->enableCopyPaste){
-
- /* Paste copied/cutted object in here
- */
- if(($s_action == "editPaste") || ($this->CopyPasteHandler->stillOpen())){
- $this->CopyPasteHandler->save_object();
- $this->CopyPasteHandler->SetVar("base",$ogroupfilter['depselect']);
- return($this->CopyPasteHandler->execute());
- }
+ /****************
+ Create a new object group
+ ****************/
+ /* New group? */
+ if ($s_action=="new"){
- /* Copy current object to CopyHandler
- */
- if($s_action == "copy"){
- $this->CopyPasteHandler->Clear();
- $dn = $this->ogrouplist[$s_entry]['dn'];
- $obj = new ogrouptabs($this->config, $this->config->data['TABS']['OGROUPTABS'], $dn);
- $objNew = new ogrouptabs($this->config, $this->config->data['TABS']['OGROUPTABS'], "new");
- $this->CopyPasteHandler->Copy($obj,$objNew);
+ /* By default we set 'dn' to 'new', all relevant plugins will
+ react on this. */
+ $this->dn= "new";
+
+ /* Create new usertab object */
+ $this->ogroup= new ogrouptabs($this->config,$this->config->data['TABS']['OGROUPTABS'], $this->dn,"ogroups");
+ $this->ogroup->set_acl_base($this->DivListOGroup->selectedBase);
+ }
+
+
+ /********************
+ Delete MULTIPLE entries requested, display confirm dialog
+ ********************/
+ if ($s_action=="del_multiple"){
+ $ids = $this->list_get_selected_items();
+ if(count($ids)){
+ foreach($ids as $id){
+ $dn = $this->ogrouplist[$id]['dn'];
+ if (($user= get_lock($dn)) != ""){
+ return(gen_locked_message ($user, $dn));
+ }
+ $this->dns[$id] = $dn;
+ }
+ $dns_names = "
"; + foreach($this->dns as $dn){ + add_lock ($dn, $this->ui->dn); + $dns_names .= $dn."\n"; + } + $dns_names .=""; + /* Lock the current entry, so nobody will edit it during deletion */ + if (count($this->dns) == 1){ + $smarty->assign("info", sprintf(_("You're about to delete the following object entry %s"), @LDAP::fix($dns_names))); + } else { + $smarty->assign("info", sprintf(_("You're about to delete the following object entries %s"), @LDAP::fix($dns_names))); + } + $smarty->assign("multiple", true); + return($smarty->fetch(get_template_path('remove.tpl', TRUE))); } + } - /* Copy current object to CopyHandler - */ - if($s_action == "cut"){ - $this->CopyPasteHandler->Clear(); - $dn = $this->ogrouplist[$s_entry]['dn']; - $obj = new ogrouptabs($this->config, $this->config->data['TABS']['OGROUPTABS'], $dn); - $this->CopyPasteHandler->Cut($obj); + /******************** + Delete MULTIPLE entries confirmed + ********************/ + + /* Confirmation for deletion has been passed. Users should be deleted. */ + if (isset($_POST['delete_multiple_ogroup_confirm'])){ + + /* Remove user by user and check acls before removeing them */ + foreach($this->dns as $key => $dn){ + + $acl = $this->ui->get_permissions($dn, "ogroups"); + if (preg_match('/d/', $acl)){ + + /* Delete request is permitted, perform LDAP action */ + $this->ogroup= new ogrouptabs($this->config,$this->config->data['TABS']['OGROUPTABS'], $dn); + $this->ogroup->delete (); + gosa_log ("Object group'".$dn."' has been removed"); + unset ($this->ogroup); + $this->ogroup= NULL; + } else { + + /* Normally this shouldn't be reached, send some extra + logs to notify the administrator */ + print_red (_("You are not allowed to delete this object group!")); + gosa_log ("Warning: '".$this->ui->uid."' tried to trick group deletion."); + } + /* Remove lock file after successfull deletion */ + del_lock ($dn); + unset($this->dns[$key]); } } - /* New group? */ - if ($s_action=="new"){ - /* By default we set 'dn' to 'new', all relevant plugins will - react on this. */ - $this->dn= "new"; + /******************** + Delete MULTIPLE entries Canceled + ********************/ - /* Create new usertab object */ - $this->ogroup= new ogrouptabs($this->config, - $this->config->data['TABS']['OGROUPTABS'], $this->dn); + /* Remove lock */ + if(isset($_POST['delete_multiple_ogroup_cancel'])){ + foreach($this->dns as $key => $dn){ + del_lock ($dn); + unset($this->dns[$key]); + } } + + /**************** + Delete object group + ****************/ + if ($s_action=="del"){ /* Get 'dn' from posted 'uid' */ @@ -264,9 +219,8 @@ class ogroupManagement extends plugin /* 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, "ogroup", $this->dn); - if (chkacl($this->acl, "delete") == ""){ + $acl = $this->ui->get_permissions($this->dn,"ogroups"); + if(preg_match("/d/",$acl)){ /* Check locking, save current plugin in 'back_plugin', so the dialog knows where to return. */ @@ -276,7 +230,8 @@ class ogroupManagement extends plugin /* 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 object group '%s'."), LDAP::fix($this->dn))); + $smarty->assign("info", sprintf(_("You're about to delete the object group '%s'."), @LDAP::fix($this->dn))); + $smarty->assign("multiple", false); return($smarty->fetch(get_template_path('remove.tpl', TRUE))); } else { @@ -286,24 +241,26 @@ class ogroupManagement extends plugin } } + + /**************** + Delete 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") == ""){ + $acl = $this->ui->get_permissions($this->dn,"ogroups"); + if(preg_match("/d/",$acl)){ /* Delete request is permitted, perform LDAP action */ $this->ogroup= new ogrouptabs($this->config, - $this->config->data['TABS']['OGROUPTABS'], $this->dn); - $this->ogroup->set_acl(array($this->acl)); + $this->config->data['TABS']['OGROUPTABS'], $this->dn); $this->ogroup->delete (); gosa_log ("Object group'".$this->dn."' has been removed"); unset ($this->ogroup); $this->ogroup= NULL; - - /* Group list has changed, reload it. */ - $this->reload (); } else { /* Normally this shouldn't be reached, send some extra @@ -318,12 +275,21 @@ class ogroupManagement extends plugin } + /**************** + Delete object group Canceled + ****************/ + /* Delete group canceled? */ if (isset($_POST['delete_cancel'])){ del_lock ($this->dn); unset($_SESSION['objectinfo']); } + + /**************** + Edit group + ****************/ + if (($s_action=="edit") && (! isset($this->ogroup->config)) ){ /* Get 'dn' from posted 'uid', must be unique */ @@ -339,18 +305,19 @@ class ogroupManagement extends plugin 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->ogroup= new ogrouptabs($this->config, $this->config->data['TABS']['OGROUPTABS'], - $this->dn); - $this->ogroup->set_acl($acl); + $this->ogroup= new ogrouptabs($this->config, $this->config->data['TABS']['OGROUPTABS'], $this->dn, "ogroups"); + $this->ogroup->set_acl_base($this->dn); $_SESSION['objectinfo']= $this->dn; } + + /**************** + Edit finished save + ****************/ + /* Finish button has been pressed */ - if ((isset($_POST['edit_finish'])) && (isset($this->ogroup->config)) ){ + if ((isset($_POST['edit_finish']) || isset($_POST['edit_apply'])) && (isset($this->ogroup->config)) ){ /* Check tabs, will feed message array */ $message= $this->ogroup->check(); @@ -362,19 +329,17 @@ class ogroupManagement extends plugin $this->ogroup->save(); gosa_log ("Object group'".$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->ogroup); - $this->ogroup= NULL; - unset ($_SESSION['objectinfo']); + if (!isset($_POST['edit_apply'])){ + /* Group has been saved successfully, remove lock from + LDAP. */ + if ($this->dn != "new"){ + del_lock ($this->dn); + } + unset ($this->ogroup); + $this->ogroup= NULL; + unset ($_SESSION['objectinfo']); + } } else { /* Ok. There seem to be errors regarding to the tab data, show message and continue as usual. */ @@ -382,14 +347,24 @@ class ogroupManagement extends plugin } } + + /**************** + Cancel edit object group + ****************/ + /* Cancel dialogs */ - if (isset($_POST['edit_cancel'])){ + if ((isset($_POST['edit_cancel'])) && (isset($this->ogroup->dn))){ del_lock ($this->ogroup->dn); unset ($this->ogroup); $this->ogroup= NULL; unset($_SESSION['objectinfo']); } + + /**************** + Display open dialogs + ****************/ + /* Show dialog if object is present */ if (isset($this->ogroup->config)){ $display= $this->ogroup->execute(); @@ -397,188 +372,55 @@ class ogroupManagement extends plugin /* Don't show buttons if tab dialog requests this */ if (!$this->ogroup->by_object[$this->ogroup->current]->dialog){ $display.= "
\n"; - $display.= "\n"; + $display.= "\n"; $display.= " \n"; + if ($this->dn != "new"){ + $display.= "\n"; + $display.= " \n"; + } $display.= "\n"; $display.= "
"; } return ($display); } - /* Prepare departments */ - $options= ""; - foreach ($this->config->idepartments as $key => $value){ - if ($ogroupfilter['depselect'] == $key){ - $options.= ""; - } else { - $options.= ""; - } - } - - - /* Create paste icon - * This icon is only displayed if copy & paste is enabled - */ - if($this->enableCopyPaste){ - $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 = "