From 142acd1c6dfd870b64cf1c40068fff6b734f82c9 Mon Sep 17 00:00:00 2001 From: hickert Date: Wed, 10 May 2006 06:06:20 +0000 Subject: [PATCH] Added divlist dialog for groups git-svn-id: https://oss.gonicus.de/repositories/gosa/trunk@3241 594d385d-05f5-0310-b6e9-bd551577e9d8 --- plugins/admin/groups/class_divListGroup.inc | 273 ++++++++++++++++++++ 1 file changed, 273 insertions(+) create mode 100644 plugins/admin/groups/class_divListGroup.inc diff --git a/plugins/admin/groups/class_divListGroup.inc b/plugins/admin/groups/class_divListGroup.inc new file mode 100644 index 000000000..2fcf6e527 --- /dev/null +++ b/plugins/admin/groups/class_divListGroup.inc @@ -0,0 +1,273 @@ +parent = $parent; + $this->ui = get_userinfo(); + + /* Set default base */ + if(!isset($_SESSION['CurrentMainBase'])){ + $_SESSION['CurrentMainBase'] = $this->config->current['BASE']; + } + $this->selectedBase = $_SESSION['CurrentMainBase']; + + /* Set list strings */ + $this->SetTitle(_("List of groups")); + $this->SetSummary(_("List of groups")); + $this->EnableAplhabet (true); + + /* Result page will look like a headpage */ + $this->SetHeadpageMode(); + $this->SetInformation(_("This menu allows you to add, edit and remove selected groups. ". + "You may want to use the range selector on top of the group listbox, when working with a large number of groups.")); + + /* Disable buttonsm */ + $this->EnableCloseButton(false); + $this->EnableSaveButton (false); + + /* set Page header */ + $this->AddHeader(array("string"=>" ","attach"=>"style='width:20px;'")); + $this->AddHeader(array("string"=>_("Groupname / Department"))); + $this->AddHeader(array("string"=>_("Properties"),"attach"=>"style='width:136px;'")); + $this->AddHeader(array("string"=>_("Actions"),"attach"=>"style='width:80px;border-right:0px;'")); + + /* Text ,Value ,Name ,Is selected */ + $this->AddCheckBox("ShowPrimaryGroups", _("Select to see groups that are primary groups of users"), _("Show primary groups"), true); + $this->AddCheckBox("ShowSambaGroups", _("Select to see groups that have samba groups mappings"), _("Show samba groups"), true); + $this->AddCheckBox("ShowApplicationGroups", _("Select to see groups that have applications configured"), _("Show application groups"),true); + $this->AddCheckBox("ShowMailGroups", _("Select to see groups that have mail settings"), _("Show mail groups"), true); + $this->AddCheckBox("ShowFunctionalGroups", _("Select to see normal groups that have only functional aspects"), _("Show functional groups"), true); + $this->AddCheckBox(SEPERATOR); + + /* Add SubSearch checkbox */ + $this->AddCheckBox("SubSearch", _("Select to search search within subtres"), _("Subsearch"), true); + + /* Name ,Text ,Default , Connect with alphabet */ + $this->AddRegex ("Regex", _("Regular expression for matching group names"), "*" , true); + $this->AddRegex ("UserRegex", _("User name of which groups are shown"), "*" , false, "images/search_user.png"); + } + + + function GenHeader() + { + /* Prepare departments, + which are shown in the listbox on top of the listbox + */ + $options= ""; + foreach ($this->config->idepartments as $key => $value){ + if ($this->selectedBase == $key){ + $options.= ""; + } else { + $options.= ""; + } + } + + if($this->parent->CopyPasteHandler){ + $Copy_Paste = "  "; + if($this->parent->CopyPasteHandler->isCurrentObjectPastAble()){ + if($this->parent->CopyPasteHandler->isCurrentCutted()){ + $img = "images/cutpaste.png"; + }else{ + $img = "images/copypaste.png"; + } + $Copy_Paste .= " "; + }else{ + $Copy_Paste .= ""._("Can "; + } + }else{ + $Copy_Paste =""; + } + + // Managment + $listhead = " +
". + "  ". + "  ". + "  ". + "  ". + "  ". + "  ". + $Copy_Paste. + "  ". + _("Base")." ". + "  ". + "
"; + + $this->SetListHeader($listhead); + } + + function execute() + { + $this->ClearElementsList(); + $this->GenHeader(); + } + + function setEntries($groups) + { + // Defining Links + $linkopen = "%s"; + + // image Buttons + $editlink = "%s"; + $userimg = "User"; + + /* Assign extension images */ + $posiximg = ""; + $mailimg = ""; + $sambaimg = ""; + $applimg = ""; + $phoneimg = ""; + $envimg = ""; + + // Space + $empty = ""; + + if($this->parent->CopyPasteHandler){ + $actions = " "; + $actions.= " "; + $actions.= ""; + $actions.= ""; + }else{ + $actions = ""; + $actions.= ""; + } + + // User and Template Images + $editlink = "%s"; + + // Test Every Entry and generate divlist Array + foreach($groups as $key => $val){ + + $posix=$mail=$samba=$appl=$phone=$enviro=$empty; + + if(isset($val['objectClass'])){ + if(in_array("posixGroup", $val['objectClass'])) $posix = $posiximg; + if(in_array("gosaMailAccount", $val['objectClass'])) $mail = $mailimg; + if(in_array("sambaGroupMapping", $val['objectClass'])) $samba = $sambaimg; + if(in_array("gosaApplicationGroup", $val['objectClass'])) $appl = $applimg; + if(in_array("goFonPickupGroup", $val['objectClass'])) $phone = $phoneimg; + if(in_array("gotoEnvironment", $val['objectClass'])) $enviro= $envimg; + } + + $title = "title='dn: ".@LDAP::fix($val['dn'])."'"; + + if(!isset($val['description'][0])){ + $desc = ""; + }else{ + $desc = " - [ ".$val['description'][0]." ]"; + } + + /* FAIrelease tag from groupApplications */ + if(isset($val['FAIrelease'][0])){ + $desc .= " (".$val['FAIrelease'][0].")"; + } + + $field1 = array("string" => sprintf($userimg,$val['dn']), "attach" => "style='text-align:center;width:20px;'"); + $field2 = array("string" => sprintf($editlink,$key,($val['cn']['0'].$desc)), "attach" => "style='' ".$title); + $field3 = array("string" => preg_replace("/%KEY%/", $key, $posix." ".$enviro." ".$mail." ".$samba." ".$appl." ".$phone), "attach" => "style='width:136px;'"); + $field4 = array("string" => preg_replace("/%KEY%/", $key, $actions), "attach" => "style='width:80px;border-right:0px;text-align:right;'"); + + $this->AddElement(array($field1,$field2,$field3,$field4)); + } + } + + function Save() + { + MultiSelectWindow :: Save(); + } + + function save_object() + { + /* Save automatic created POSTs like regex, checkboxes */ + MultiSelectWindow::save_object(); + + $s_action =""; + foreach($_POST as $key => $value){ + if(preg_match("/^dep_back.*/i",$key)){ + $s_action="back"; + }elseif(preg_match("/^dep_root.*/",$key)){ + $s_action="root"; + }elseif(preg_match("/^dep_home.*/i",$key)){ + $s_action="home"; + } + } + + /* Save base selection from headpage selectbox*/ + if(isset($_POST['CurrentMainBase'])){ + $this->selectedBase = $_POST['CurrentMainBase']; + } + + /* Homebutton is posted */ + if($s_action=="home"){ + $ui= get_userinfo(); + $this->selectedBase=(preg_replace("/^[^,]+,/","",$ui->dn)); + $this->selectedBase=(preg_replace("/^[^,]+,/","",$this->selectedBase)); + } + + /* Open selected department + this is posted by the parent class MultiSelectWindow */ + if(isset($_GET['act'])&& ($_GET['act'] == "dep_open")){ + $s_entry = base64_decode($_GET['dep_id']); + $this->selectedBase = $this->config->departments[trim($s_entry)]; + } + + /* back to the roots ^^ */ + if($s_action=="root"){ + $this->selectedBase=($this->config->current['BASE']); + } + + /* If Backbutton is Posted */ + if($s_action=="back"){ + $base_back = preg_replace("/^[^,]+,/","",$this->selectedBase); + $base_back = convert_department_dn($base_back); + if(isset($this->config->departments[trim($base_back)])){ + $this->selectedBase= $this->config->departments[trim($base_back)]; + }else{ + $this->selectedBase= $this->config->departments["/"]; + } + } + + $_SESSION['CurrentMainBase'] = $this->selectedBase; + } +} +// vim:tabstop=2:expandtab:shiftwidth=2:filetype=php:syntax:ruler: +?> -- 2.30.2