X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fogroups%2Fclass_ogroupManagement.inc;h=728c79c510c3d24edba264b06760859c6d3a46c1;hb=bff18a7c96f757ca1aefdff3ab57dc385d69b5dc;hp=ecd339518092184daf300a95273ecaa78b891b6e;hpb=055a967741a682b4bca6f28410dcaaebf9145a4a;p=gosa.git diff --git a/plugins/admin/ogroups/class_ogroupManagement.inc b/plugins/admin/ogroups/class_ogroupManagement.inc index ecd339518..728c79c51 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_/"); - $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,13 @@ 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)){ @@ -159,42 +99,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,49 +106,48 @@ class ogroupManagement extends plugin $s_entry = $_GET['id']; } - register_global("ogroupfilter", $ogroupfilter); - - $this->reload(); - /* Check for exeeded sizelimit */ - if (($message= check_sizelimit()) != ""){ - return($message); - } + /**************** + Copy & Paste handling + ****************/ /* 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()); - } - /* 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); + /******************** + Copy & Paste Handling ... + ********************/ + + /* Only perform copy&paste requests if it is enabled + */ + /* Get 'dn' from posted 'uid' */ + if(in_array_ics($s_action,array("editPaste","cut","copy")) || (isset($this->CopyPasteHandler) && $this->CopyPasteHandler->stillOpen())){ + + if(isset($this->ogrouplist[trim($s_entry)]['dn'])){ + $dn= $this->ogrouplist[trim($s_entry)]['dn']; + }else{ + $dn = $this->DivListOGroup->selectedBase; } + $acl= get_permissions ($dn, $this->ui->subtreeACL); + $acl= get_module_permission($acl, "ogroup", $dn); - /* 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); + if($acl != "#all#"){ + print_red (_("You are not allowed to execute this method!")); + }else{ + /* Display the copy & paste dialog, if it is currently open */ + $ret = $this->copyPasteHandling($s_action,$s_entry); + if($ret){ + return($ret); + } } } + /**************** + Create a new object group + ****************/ + /* New group? */ if ($s_action=="new"){ @@ -254,9 +157,14 @@ class ogroupManagement extends plugin /* Create new usertab object */ $this->ogroup= new ogrouptabs($this->config, - $this->config->data['TABS']['OGROUPTABS'], $this->dn); + $this->config->data['TABS']['OGROUPTABS'], $this->dn); } + + /**************** + Delete object group + ****************/ + if ($s_action=="del"){ /* Get 'dn' from posted 'uid' */ @@ -276,7 +184,7 @@ 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))); return($smarty->fetch(get_template_path('remove.tpl', TRUE))); } else { @@ -286,6 +194,11 @@ class ogroupManagement extends plugin } } + + /**************** + Delete confirmed + ****************/ + /* Confirmation for deletion has been passed. Group should be deleted. */ if (isset($_POST['delete_group_confirm'])){ @@ -295,15 +208,12 @@ class ogroupManagement extends plugin /* Delete request is permitted, perform LDAP action */ $this->ogroup= new ogrouptabs($this->config, - $this->config->data['TABS']['OGROUPTABS'], $this->dn); + $this->config->data['TABS']['OGROUPTABS'], $this->dn); $this->ogroup->set_acl(array($this->acl)); $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 +228,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 */ @@ -349,6 +268,11 @@ class ogroupManagement extends plugin $_SESSION['objectinfo']= $this->dn; } + + /**************** + Edit finished save + ****************/ + /* Finish button has been pressed */ if ((isset($_POST['edit_finish'])) && (isset($this->ogroup->config)) ){ @@ -368,9 +292,6 @@ class ogroupManagement extends plugin 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']); @@ -382,14 +303,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,7 +328,7 @@ 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"; $display.= "\n"; $display.= "
"; @@ -405,171 +336,22 @@ class ogroupManagement extends plugin return ($display); } - /* Prepare departments */ - $options= ""; - foreach ($this->config->idepartments as $key => $value){ - if ($ogroupfilter['depselect'] == $key){ - $options.= ""; - } else { - $options.= ""; - } - } + /**************** + Display list + ****************/ - /* 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 = "