X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=plugins%2Fadmin%2Fgroups%2Fclass_groupManagement.inc;h=78d37b445ede1772e3f37aabffee78aaf344a59e;hb=7e68c67af1268fc0815d95eb2c43525bdba8dffd;hp=080f38a6b186ba2a3d69bcb8cb5d11907f3b1b71;hpb=19d9c60ab7303bc8c933f176b5624f2d210e6e73;p=gosa.git
diff --git a/plugins/admin/groups/class_groupManagement.inc b/plugins/admin/groups/class_groupManagement.inc
index 080f38a6b..78d37b445 100644
--- a/plugins/admin/groups/class_groupManagement.inc
+++ b/plugins/admin/groups/class_groupManagement.inc
@@ -24,6 +24,7 @@ class groupManagement extends plugin
/* Definitions */
var $plHeadline= "Groups";
var $plDescription= "This does something";
+ var $departments = array();
/* Dialog attributes */
var $grouptab= NULL;
@@ -55,15 +56,22 @@ class groupManagement extends plugin
function execute()
{
+ /* Call parent execute */
+// plugin::execute();
+
/* Save data */
$groupfilter= get_global("groupfilter");
- if (isset($_POST['ignore'])){
+ $s_action = "";
+ $s_entry = "";
+
+
+ if (!isset($this->grouptab)){
foreach( array("depselect", "guser", "regex") as $type){
if (isset($_POST[$type])){
$groupfilter[$type]= $_POST[$type];
}
}
- if (isset($_POST['depselect'])){
+ if (isset($_POST['regex'])){
foreach( array("primarygroups", "sambagroups", "mailgroups", "appgroups",
"functionalgroups", "subsearch") as $type){
@@ -84,15 +92,80 @@ class groupManagement extends plugin
register_global("groupfilter", $groupfilter);
}
+
+ /* Test Posts */
+ foreach($_POST as $key => $val){
+ // Post for delete
+ if(preg_match("/group_del.*/",$key)){
+ $s_action = "del";
+ $s_entry = preg_replace("/group_".$s_action."_/i","",$key);
+ // Post for edit
+ }elseif(preg_match("/group_edit_.*/",$key)){
+ $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";
+ }
+ }
+ $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']);
+ $groupfilter['depselect']= "".$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['depselect']) && $_POST['depselect']){
+ $groupfilter['depselect']= $_POST['depselect'];
+ }
+
+ /* Homebutton is posted */
+ if($s_action=="home"){
+ $groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$this->ui->dn));
+ $groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$groupfilter['depselect']));
+ }
+
+ if($s_action=="root"){
+ $groupfilter['depselect']=($this->config->current['BASE']);
+ }
+
+ /* If Backbutton is Posted */
+ if($s_action == "back"){
+ $base_back= preg_replace("/^[^,]+,/","",$groupfilter['depselect']);
+ $base_back= convert_department_dn($base_back);
+
+ if(isset($this->config->departments[trim($base_back)])){
+ $groupfilter['depselect']= $this->config->departments[trim($base_back)];
+ }else{
+ $groupfilter['depselect']= $this->config->departments["/"];
+ }
+ }
+ register_global("groupfilter", $groupfilter);
+
$smarty= get_smarty();
/* Prepare formular */
- if (!isset($this->grouptab) &&
- !isset($_POST['new_group']) &&
- !isset($_POST['delete_group']) &&
- !isset($_POST['select_group'])){
- $this->reload();
- }
+ $this->reload();
/* Check for exeeded sizelimit */
if (($message= check_sizelimit()) != ""){
@@ -100,7 +173,7 @@ class groupManagement extends plugin
}
/* New group? */
- if (isset($_POST['new_group'])){
+ if ($s_action=="new"){
/* By default we set 'dn' to 'new', all relevant plugins will
react on this. */
@@ -156,10 +229,10 @@ class groupManagement extends plugin
}
/* User wants to edit data? */
- if ((isset($_POST['select_group']) || (isset($_POST['edit_helper']) && $_POST['edit_helper'] == "1")) && isset($_POST['grouplist']) && $_POST['grouplist'] != ""){
+ if ($s_action=="edit"){
/* Get 'dn' from posted 'uid', must be unique */
- $this->dn= trim($_POST['grouplist']);
+ $this->dn= $this->grouplist[trim($s_entry)]['dn'];
/* Check locking, save current plugin in 'back_plugin', so
the dialog knows where to return. */
@@ -182,10 +255,9 @@ class groupManagement extends plugin
}
/* Remove user was requested */
- if (isset($_POST['delete_group']) && isset($_POST['grouplist'])){
-
+ if ($s_action=="del"){
/* Get 'dn' from posted 'uid' */
- $this->dn= trim($_POST['grouplist']);
+ $this->dn= $this->grouplist[trim($s_entry)]['dn'];
/* Load permissions for selected 'dn' and check if
we're allowed to remove this 'dn' */
@@ -264,16 +336,122 @@ class groupManagement extends plugin
return ($display);
}
+ /* Prepare departments */
+ $options= "";
+ foreach ($this->config->idepartments as $key => $value){
+ if ($groupfilter['depselect'] == $key){
+ $options.= "";
+ } else {
+ $options.= "";
+ }
+ }
+
+ // Managment
+ $listhead = "
";
+
+
+ $actions = "";
+ $actions.= "";
+
+ // Defining Links
+ $linkopen = "%s";
+
+ // image Buttons
+ $editlink = "%s";
+ $userimg = "";
+
+ // Extension images
+ $posiximg = "";
+ $mailimg = "";
+ $sambaimg = "";
+ $applimg = "";
+ $phoneimg = "";
+ $envimg = "";
+ // Space
+ $empty = "";
+
+
+ $divlist = new divlist("groupstab");
+ $divlist->SetHeader(array(
+ array("string" => " ", "attach" => "style='text-align:center;width:20px;'"),
+ array("string" => _("Groupname")." / "._("Department"), "attach" => "style=''"),
+ array("string" => _("Properties"), "attach" => "style='width:136px;'"),
+ array("string" => _("Actions"), "attach" => "style='width:60px;border-right:0px;text-align:right;'")
+ ));
+
+ $divlist->SetSummary(_("This table displays all groups, in the selected tree."));
+ $divlist->SetEntriesPerPage(0);
+
+ foreach($this->departments as $key=> $val){
+
+ if(!isset($this->config->departments[trim($key)])){
+ $this->config->departments[trim($key)]="";
+ }
+
+ $non_empty="";
+ $keys= str_replace("/","\/",$key);
+ foreach($this->config->departments as $keyd=>$vald ){
+ if(preg_match("/".$keys."\/.*/",$keyd)){
+ $non_empty="full";
+ }
+ }
+
+
+ $field1 = array("string" => "", "attach" => "style='text-align:center;width:20px;'");
+ $field2 = array("string" => sprintf($linkopen,base64_encode($key),$val), "attach" => "style=''");
+ $field3 = array("string" => " ", "attach" => "style='width:136px;'");
+ $field4 = array("string" => " ", "attach" => "style='width:60px;border-right:0px;text-align:right;'");
+
+ $divlist->AddEntry(array($field1,$field2,$field3,$field4));
+ }
+
+ foreach($this->grouplist as $key => $val){
+
+ if(isset($val['objectClass'])){
+ if(in_array("posixGroup", $val['objectClass'])) $posix = $posiximg; else $posix = $empty;
+ if(in_array("gosaMailAccount", $val['objectClass'])) $mail = $mailimg; else $mail = $empty;
+ if(in_array("sambaGroupMapping", $val['objectClass'])) $samba = $sambaimg; else $samba = $empty;
+ if(in_array("gosaApplicationGroup", $val['objectClass'])) $appl = $applimg; else $appl = $empty;
+ if(in_array("goFonPickupGroup", $val['objectClass'])) $phone = $phoneimg; else $phone = $empty;
+ if(in_array("gotoEnvironment", $val['objectClass'])) $enviro= $envimg; else $enviro = $empty;
+ }else{
+ $posix=$mail=$samba=$appl=$phone=$empty;
+ }
+
+ $title = "title='gid : ".$key." - dn : ".$val['dn']."'";
+
+ if(!isset($val['description'][0])){
+ $desc = "";
+ }else{
+ $desc = " - [ ".$val['description'][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" => $posix." ".$enviro." ".$mail." ".$samba." ".$appl." ".$phone, "attach" => "style='width:136px;'");
+ $field4 = array("string" => preg_replace("/%KEY%/", $key, $actions), "attach" => "style='width:60px;border-right:0px;text-align:right;'");
+
+ $divlist->AddEntry(array($field1,$field2,$field3,$field4));
+ }
+
/* Show main page */
- $smarty->assign("grouplist", $this->grouplist);
+ $smarty->assign("grouplisthead", $listhead);
+ $smarty->assign("grouplist", $divlist->DrawList());
$smarty->assign("search_image", get_template_path('images/search.png'));
+ $smarty->assign("searchu_image", get_template_path('images/search_user.png'));
$smarty->assign("tree_image", get_template_path('images/tree.png'));
$smarty->assign("infoimage", get_template_path('images/info.png'));
$smarty->assign("launchimage", get_template_path('images/launch.png'));
$smarty->assign("deplist", $this->config->idepartments);
- foreach( array("depselect", "guser", "regex", "primarygroups", "mailgroups",
- "appgroups", "sambagroups", "functionalgroups", "subsearch") as $type){
-
+ foreach( array("depselect", "guser", "regex", "primarygroups", "mailgroups","appgroups", "sambagroups", "functionalgroups", "subsearch") as $type){
$smarty->assign("$type", $groupfilter[$type]);
}
@@ -285,8 +463,7 @@ class groupManagement extends plugin
return($smarty->fetch(get_template_path('headpage.tpl', TRUE)));
}
-
- function reload()
+ function reload($CreatePosixsList=false)
{
/* Get config */
$groupfilter= get_global('groupfilter');
@@ -302,59 +479,73 @@ class groupManagement extends plugin
}
/* User filter? */
- $filter= "";
+ $filter= "(objectclass=posixGroup)";
$error= "";
$error2= "";
$this->grouplist= array();
/* What are primary groups? */
$primaries= array();
- $ldap= $this->config->get_ldap_link(TRUE);
+ $ldap= $this->config->get_ldap_link();
$ldap->cd($base);
$ldap->search("(&(uid=$regex)(!(uid=*$))(objectClass=posixAccount)(gidNumber=*))", array("gidNumber", "cn"));
- $error= $ldap->error;
+ show_ldap_error($ldap->get_error());
while ($attrs= $ldap->fetch()){
$primaries[$attrs['gidNumber'][0]]= $attrs['cn'][0];
}
- if ($groupfilter['primarygroups'] == "checked"){
- $filter.= "(&(objectClass=posixGroup)(|";
- foreach ($primaries as $gidNumber => $cn){
- $filter.= "(gidNumber=$gidNumber)";
- }
- $filter.= "))";
- }
/* Set filter depending on selection */
+ $sfilter= "";
if ($groupfilter['appgroups'] == "checked"){
$filter.= "(objectClass=gosaApplicationGroup)";
}
if ($this->config->current['SAMBAVERSION'] == 3){
- $sfilter= "(objectClass=sambaGroupMapping)";
- if ($groupfilter['sambagroups'] == "checked"){
+ if ($groupfilter['primarygroups'] != "checked"){
+ $sfilter= "(objectClass=sambaGroupMapping)";
+ } elseif ($groupfilter['sambagroups'] == "checked"){
$filter.= "(objectClass=sambaGroupMapping)";
}
- } else {
- $sfilter= "";
}
+
if ($groupfilter['mailgroups'] == "checked"){
$filter.= "(objectClass=gosaMailAccount)";
}
- if ($groupfilter['functionalgroups'] == "checked"){
- $ldap->cd($base);
- $ldap->set_size_limit($_SESSION['size_limit']);
- $ldap->search("(&(cn=$regex)(objectClass=posixGroup)(!(|(objectClass=gosaMailAccount)(objectClass=gosaApplicationGroup)$sfilter)))", array("cn", "gidNumber", "description"));
- $error2= $ldap->error;
- while ($attrs= $ldap->fetch()){
- if (!isset($primaries[$attrs['gidNumber'][0]])){
- if (isset($attrs["description"][0])){
- $this->grouplist[$attrs["dn"]]= $attrs["cn"][0]." [".
- $attrs["description"][0]."]";
- } else {
- $this->grouplist[$attrs["dn"]]= $attrs["cn"][0];
- }
+ $functional= array();
+ $ldap->cd(get_groups_ou().$base);
+ $ldap->set_size_limit($_SESSION['size_limit']);
+ $ldap->search("(&(cn=$regex)(objectClass=posixGroup)(!(|(objectClass=gosaMailAccount)(objectClass=gosaApplicationGroup)$sfilter)))", array("cn", "gidNumber", "description"));
+ $error2= $ldap->error;
+ while ($attrs= $ldap->fetch()){
+ if (!isset($primaries[$attrs['gidNumber'][0]])){
+ $functional[$attrs['gidNumber'][0]]= $attrs['gidNumber'][0];
+ }
+ }
+
+ /*
+ * We also need to search for the departments
+ * So we are able to navigate like in konquerer
+ */
+
+ /* Only needed if we are in GroupManagement */
+ if(!$CreatePosixsList){
+ $res3 = get_list2($this->ui->subtreeACL, "(&(|(ou=$regex)(description=$regex))(objectClass=gosaDepartment))",
+ FALSE, $base, array("ou", "description"), TRUE);
+ $this->departments= array();
+ $tmp = array();
+ foreach ($res3 as $value){
+ $tmp[strtolower($value['dn']).$value['dn']]=$value;
+ }
+ ksort($tmp);
+ foreach($tmp as $value){
+ if($value["description"][0]!=".."){
+ $this->departments[$value['dn']]=convert_department_dn2($value['dn'])." - [".$value["description"][0]."]";
+ }else{
+ $this->departments[$value['dn']]=$value["description"][0];
}
}
}
+ /* Ende department generation
+ */
/* Generate grouplist */
if ($filter != ""){
@@ -363,8 +554,11 @@ class groupManagement extends plugin
$filter= "(&(|(memberUID=" . $groupfilter['guser'] . ")(cn=" . $groupfilter['guser'] . "))$filter)";
}
}
+
+ /* Depending on $CreatePosixsList we have to create different lists */
+
if ($groupfilter['subsearch'] == "checked"){
- $res= get_list($this->ui->subtreeACL, "$filter", TRUE, $base, array("cn", "description", "gidNumber"), TRUE);
+ $res= get_list($this->ui->subtreeACL, "$filter", FALSE, $base, array("cn", "description", "gidNumber"), TRUE);
} else {
$base= get_groups_ou().$base;
$res= get_list($this->ui->subtreeACL, "$filter", FALSE, $base, array("cn", "description", "gidNumber"), TRUE);
@@ -374,15 +568,53 @@ class groupManagement extends plugin
}
foreach ($res as $value){
- if (isset($value["description"][0])){
- $this->grouplist[$value["dn"]]= $value["cn"][0]." [".
- $value["description"][0]."]";
+ if ($groupfilter['functionalgroups'] != "checked" && isset($functional[$value['gidNumber'][0]])){
+ continue;
+ }
+ if ($groupfilter['primarygroups'] == "checked"){
+ $this->grouplist[$value['gidNumber'][0]]= $value;
} else {
- $this->grouplist[$value["dn"]]= $value["cn"][0];
+ if (!isset($primaries[$value['gidNumber'][0]])){
+ $this->grouplist[$value['gidNumber'][0]]= $value;
+ }
+ }
+ }
+
+ $tmp=array();
+
+ /* If true ; this result is used for posix tab, group membership selection. */
+ if($CreatePosixsList){
+
+ /* Addd to array */
+ foreach($this->grouplist as $tkey => $val ){
+ $tmp[strtolower($val['cn'][0]).$val['cn'][0]]=$val;
+ }
+
+ /* Sort index */
+ ksort($tmp);
+
+ /* Recreate index array[dn]=cn[description]*/
+ $this->grouplist=array();
+ foreach($tmp as $val){
+ if(isset($val['description'])){
+ $this->grouplist[$val['dn']]=$val['cn'][0]." [".$val['description'][0]."]";
+ }else{
+ $this->grouplist[$val['dn']]=$val['cn'][0];
+ }
+ }
+ }else{
+
+ /* Create result for group management listbox*/
+ foreach($this->grouplist as $tkey => $val ){
+ $tmp[strtolower($val['cn'][0]).$val['cn'][0]]=$val;
+ }
+ ksort($tmp);
+ $this->grouplist=array();
+ foreach($tmp as $val){
+ $this->grouplist[]=$val;
}
+ reset ($this->grouplist);
}
- natcasesort ($this->grouplist);
- reset ($this->grouplist);
}
function remove_from_parent()