X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fogroups%2Fclass_ogroupManagement.inc;h=09fba6b173dcf135311ce696315d78d20da52384;hb=99b0a430dfa6d1cfad04ccf0302e1fbff0b02e28;hp=f84780301f85f212677e4e36426ffe96bfce8882;hpb=499264302e95e77353af67b4c0adecb026dd2eb0;p=gosa.git diff --git a/plugins/admin/ogroups/class_ogroupManagement.inc b/plugins/admin/ogroups/class_ogroupManagement.inc index f84780301..09fba6b17 100644 --- a/plugins/admin/ogroups/class_ogroupManagement.inc +++ b/plugins/admin/ogroups/class_ogroupManagement.inc @@ -31,81 +31,40 @@ class ogroupManagement extends plugin var $obtypes= array(); var $ogroup; + var $CopyPasteHandler = NULL; + var $DivListOGroup = NULL; + function ogroupManagement ($config, $dn= NULL) { /* Include config object */ $this->config= $config; $this->ui= get_userinfo(); - /* 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); + /* 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); } + + /* 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 @@ -117,80 +76,54 @@ 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)){ + $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); }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; } - } $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")){ $s_action ="edit"; $s_entry = $_GET['id']; } - register_global("ogroupfilter", $ogroupfilter); - $this->reload(); + /**************** + Copy & Paste handling + ****************/ + + /* Only perform copy / paste if it is enabled + */ - /* 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); } + /**************** + Create a new object group + ****************/ + /* New group? */ if ($s_action=="new"){ @@ -200,9 +133,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' */ @@ -222,7 +160,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 { @@ -232,6 +170,11 @@ class ogroupManagement extends plugin } } + + /**************** + Delete confirmed + ****************/ + /* Confirmation for deletion has been passed. Group should be deleted. */ if (isset($_POST['delete_group_confirm'])){ @@ -241,15 +184,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 @@ -264,12 +204,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 */ @@ -295,6 +244,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)) ){ @@ -314,9 +268,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']); @@ -328,14 +279,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(); @@ -343,7 +304,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.= "
"; @@ -351,132 +312,22 @@ class ogroupManagement extends plugin return ($display); } - /* Prepare departments */ - $options= ""; - foreach ($this->config->idepartments as $key => $value){ - if ($ogroupfilter['depselect'] == $key){ - $options.= ""; - } else { - $options.= ""; - } - } - - // Managment - $listhead = "