X-Git-Url: https://git.tokkee.org/?a=blobdiff_plain;f=gosa-core%2Fplugins%2Fadmin%2Fgroups%2Fclass_divListGroup.inc;h=2ee9518e86b05ae1c04993a459963255f9ef569a;hb=049d82cc1f343b829bcfdcb751a0b2222d3d7f15;hp=b557de966d0457b8c3d49a8020018c26bf43184f;hpb=5c175d7d7d49a74eadb375979bc60dac021a69c2;p=gosa.git diff --git a/gosa-core/plugins/admin/groups/class_divListGroup.inc b/gosa-core/plugins/admin/groups/class_divListGroup.inc index b557de966..2ee9518e8 100644 --- a/gosa-core/plugins/admin/groups/class_divListGroup.inc +++ b/gosa-core/plugins/admin/groups/class_divListGroup.inc @@ -70,7 +70,7 @@ class divListGroup extends MultiSelectWindow } /* Toggle all selected / deselected */ - $chk = ""; /* set Page header */ @@ -104,69 +104,15 @@ class divListGroup extends MultiSelectWindow function GenHeader() { - /* Prepare departments, - which are shown in the listbox on top of the listbox - */ - $options= ""; - - - /* Get all departments within this subtree */ $ui= get_userinfo(); $first = ""; $found = FALSE; $base = $this->config->current['BASE']; - - - - /* Add base */ - $tmp = array(); - $tmp[] = array("dn"=>$this->config->current['BASE']); - $tmp= array_merge($tmp,get_list("(&(|(ou=*)(description=*))(objectClass=gosaDepartment))", $this->module, $base, - array("ou", "description"), GL_SIZELIMIT | GL_SUBSEARCH)); - - $deps = array(); - foreach($tmp as $tm){ - $deps[$tm['dn']] = $tm['dn']; - } - - /* Load possible departments */ - $ui= get_userinfo(); - $tdeps= $ui->get_module_departments("groups"); - $ids = $this->config->idepartments; - $first = ""; - $found = FALSE; - foreach($ids as $dep => $name){ - if(isset($deps[$dep]) && in_array_ics($dep, $tdeps)){ - - /* Keep first base dn in mind, we could need this - * info if no valid base was found - */ - if(empty($first)) { - $first = $dep['dn']; - } - - $value = $ids[$dep]; - if ($this->selectedBase == $dep){ - $found = TRUE; - $options.= ""; - } else { - $options.= ""; - } - } - } - - /* The currently used base is not visible with your acl setup. - * Set base to first useable base. - */ - if(!$found){ - $this->selectedBase = $first; - } + $options = $this->create_department_list($this->module); /* Get acls */ - $acls = $ui->get_permissions($this->selectedBase,"groups/group"); - $acl_all= $ui->has_complete_category_acls($this->selectedBase,"groups"); - + $acl = $ui->get_permissions($this->selectedBase,"groups/group"); /* Add default header */ $listhead = MultiSelectWindow::get_default_header(); @@ -176,15 +122,13 @@ class divListGroup extends MultiSelectWindow "  "; - - /* Create Layers menu */ + /* Create Layers menu */ $s = ".|"._("Actions")."|\n"; - $s .= "..|". - " "._("Create")."|\n"; - /* Append create options */ - if(preg_match("/c/",$acl_all)) { + if(preg_match("/c/",$acl)) { + $s .= "..|". + " "._("Create")."|\n"; $s.= "...|". " "._("Group")."|group_new|\n"; } @@ -208,27 +152,13 @@ class divListGroup extends MultiSelectWindow } /* Add multiple copy & cut icons */ - if(is_object($this->parent->CopyPasteHandler) && preg_match("/(c.*w|w.*c)/",$acl_all)){ - $s.= "..|---|\n"; - $s.= "..|". - " "._("Copy")."|"."multiple_copy_systems|\n"; - $s.= "..|". - " "._("Cut")."|"."multiple_cut_systems|\n"; - - if($this->parent->CopyPasteHandler->entries_queued()){ - $img = ""; - $s.="..|".$img." "._("Paste")."|editPaste|\n"; - }else{ - $img = ""; - $s.="..|".$img." "._("Paste")."\n"; - } - } + $acl_all= $ui->has_complete_category_acls($this->selectedBase,"groups"); - /* Add snapshot icons */ - if(preg_match("/(c.*w|w.*c)/",$acl_all)){ - $s .= "..|---|\n"; - $s .= $this->get_snapshot_header(TRUE); - } + /* Add Copy & Paste header */ + $s .= $this->parent->get_copypaste_header($this->selectedBase,$this->module); + + /* Add snapshot functionality */ + $s .= $this->parent->get_snapshot_header($this->selectedBase,$this->module); $this->SetDropDownHeaderMenu($s); @@ -243,9 +173,6 @@ class divListGroup extends MultiSelectWindow function setEntries($groups) { - // Defining Links - $linkopen = "%s"; - // image Buttons $editlink = "%s"; $userimg = "User"; @@ -259,7 +186,7 @@ class divListGroup extends MultiSelectWindow /* Assign extension images */ $posiximg = ""; - $mailimg = ""; $sambaimg = ""; @@ -278,48 +205,60 @@ class divListGroup extends MultiSelectWindow $ui = get_userinfo(); + /* Fetch all application menu entries + */ + $base = get_groups_ou().$this->selectedBase; + $ldap = $this->config->get_ldap_link(); + $ldap->cd ($base); + $ldap->search("(objectClass=gotoMenuEntry)",array("dn")); + $configured_apps = array(); + while($entry = $ldap->fetch()){ + $dn = preg_replace("/^.*(cn=[^,]+,".preg_quote(get_groups_ou(), '/').")/","\\1",$entry['dn']); + $configured_apps[$dn] = $dn; + } + // Test Every Entry and generate divlist Array foreach($groups as $key => $val){ /* Create action icons - copy & paste icons */ $acl = $ui->get_permissions($val['dn'],"groups/group"); - $acl_all= $ui->has_complete_category_acls($val['dn'],"groups"); + $acl_all = $ui->has_complete_category_acls($val['dn'],"groups"); $actions= ""; - if(($this->parent->CopyPasteHandler) && preg_match("/(c.*w|w.*c)/",$acl_all)){ - $actions.= " "; - $actions.= " "; - } + + /* Add copy & cut functionality */ + $actions.= $this->parent->get_copypaste_action($val['dn'],"groups","group"); /* Add edit icon */ $actions.= ""; /* Add snapshot functionality */ - if(preg_match("/(c.*w|w.*c)/", $acl_all)){ - $actions.= $this->GetSnapShotActions($val['dn']); - } - + $actions.= $this->parent->get_snapshot_action($val['dn'],$this->module); + if(preg_match("/d/",$acl)){ $actions.= ""; + }else{ + $actions.= " "; } - $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='".preg_replace('/ /', ' ', @LDAP::fix($val['dn']))."'"; + if(isset($configured_apps[$val['dn']])){ + $appl = $applimg; + } + + $title = "title='".preg_replace('/ /', ' ', LDAP::fix($val['dn']))."'"; if(!isset($val['description'][0])){ $desc = "";