diff --git a/plugins/admin/groups/class_groupManagement.inc b/plugins/admin/groups/class_groupManagement.inc
index 680d36a3c7cd358d50dea0056c3977c8dcaaa699..78d37b445ede1772e3f37aabffee78aaf344a59e 100644 (file)
function execute()
{
function execute()
{
+ /* Call parent execute */
+// plugin::execute();
+
/* Save data */
$groupfilter= get_global("groupfilter");
$s_action = "";
/* Save data */
$groupfilter= get_global("groupfilter");
$s_action = "";
$s_action="open";
$s_entry = base64_decode($_GET['dep_id']);
$groupfilter['depselect']= "".$this->config->departments[trim($s_entry)];
$s_action="open";
$s_entry = base64_decode($_GET['dep_id']);
$groupfilter['depselect']= "".$this->config->departments[trim($s_entry)];
- $this->reload();
}
// Edit if
}
// Edit if
/* Department changed? */
if(isset($_POST['depselect']) && $_POST['depselect']){
$groupfilter['depselect']= $_POST['depselect'];
/* Department changed? */
if(isset($_POST['depselect']) && $_POST['depselect']){
$groupfilter['depselect']= $_POST['depselect'];
- $this->reload();
}
/* Homebutton is posted */
if($s_action=="home"){
$groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$this->ui->dn));
$groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$groupfilter['depselect']));
}
/* Homebutton is posted */
if($s_action=="home"){
$groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$this->ui->dn));
$groupfilter['depselect']= (preg_replace("/^[^,]+,/","",$groupfilter['depselect']));
- $this->reload();
}
if($s_action=="root"){
$groupfilter['depselect']=($this->config->current['BASE']);
}
if($s_action=="root"){
$groupfilter['depselect']=($this->config->current['BASE']);
- $this->reload();
}
/* If Backbutton is Posted */
}
/* If Backbutton is Posted */
}else{
$groupfilter['depselect']= $this->config->departments["/"];
}
}else{
$groupfilter['depselect']= $this->config->departments["/"];
}
- $this->reload();
}
register_global("groupfilter", $groupfilter);
$smarty= get_smarty();
/* Prepare formular */
}
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()) != ""){
/* Check for exeeded sizelimit */
if (($message= check_sizelimit()) != ""){
// Managment
$listhead = "<div style='background:#F0F0F9;padding:5px;'>".
// Managment
$listhead = "<div style='background:#F0F0F9;padding:5px;'>".
- " <input type='image' align='middle' src='images/list_back.png' title='"._("Go up one department")."' alt='"._("Up")."' name='dep_back'> ".
- " <input type='image' src='images/list_root.png' align='middle' title='"._("Go to root department")."' name='dep_root' alt='"._("Root")."'> ".
- " <input type='image' align='middle' src='images/list_home.png' title='"._("Go to users department")."'
- alt='"._("Home")."' name='dep_home'> ".
- " <img src='images/list_seperator.png' align='middle' alt='' height='16' width='1'> ".
- " <input type='image' align='middle' src='images/list_new_group.png' title='"._("Create new group")."'
- alt='"._("New")."' name='group_new'> ".
- " <img src='images/list_seperator.png' align='middle' alt='' height='16' width='1'> ".
+ " <input type='image' class='center' src='images/list_back.png' title='"._("Go up one department")."' alt='"._("Up")."' name='dep_back'> ".
+ " <input type='image' class='center' src='images/list_root.png' title='"._("Go to root department")."' name='dep_root' alt='"._("Root")."'> ".
+ " <input type='image' class='center' src='images/list_home.png' title='"._("Go to users department")."' alt='"._("Home")."' name='dep_home'> ".
+ " <img class='center' src='images/list_seperator.png' alt='' height='16' width='1'> ".
+ " <input type='image' class='center' src='images/list_new_group.png' title='"._("Create new group")."' alt='"._("New")."' name='group_new'> ".
+ " <img class='center' src='images/list_seperator.png' alt='' height='16' width='1'> ".
_("Current base")." <select name='depselect' onChange='mainform.submit()'>$options</select>".
_("Current base")." <select name='depselect' onChange='mainform.submit()'>$options</select>".
- " <input type='image' src='images/list_submit.png' align='middle' title='"._("Submit department")."' name='submit_department' alt='"._("Submit")."'> ".
+ " <input type='image' class='center' src='images/list_submit.png' title='"._("Submit department")."' name='submit_department' alt='"._("Submit")."'> ".
"</div>";
"</div>";
$mailimg = "<img src='images/mailto.png' alt='M' title='"._("Mail") ."'>";
$sambaimg = "<img src='images/select_winstation.png' alt='S' title='"._("Samba") ."'>";
$applimg = "<img src='images/select_application.png' alt='A' title='"._("Application")."'>";
$mailimg = "<img src='images/mailto.png' alt='M' title='"._("Mail") ."'>";
$sambaimg = "<img src='images/select_winstation.png' alt='S' title='"._("Samba") ."'>";
$applimg = "<img src='images/select_application.png' alt='A' title='"._("Application")."'>";
- $phoneimg = "<img src='images/select_phone.png' alt='Ph' title='"._("Phone") ."'>";
+ $phoneimg = "<img src='images/select_phone.png' alt='Ph' title='"._("Phone") ."'>";
+ $envimg = "<img src='images/network.png' alt='E' title='"._("Environment") ."'>";
// Space
// Space
- $empty = "<img src='images/nothing.png' style='width:16px;height:16px;' alt=''>";
+ $empty = "<img src='images/empty.png' style='width:16px;height:16px;' alt=''>";
- $divlist = new divlist();
+ $divlist = new divlist("groupstab");
$divlist->SetHeader(array(
$divlist->SetHeader(array(
- array("string" => " "),
- array("string" => _("Groupname")." / "._("Department")),
- array("string" => _("Properties"), "attach" => "style='width:100px;'"),
- array("string" => _("Actions") ,"attach" => "style='border:none'")
+ 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->SetSummary(_("This table displays all groups, in the selected tree."));
- $divlist->SetEntriesPerPage(20);
+ $divlist->SetEntriesPerPage(0);
foreach($this->departments as $key=> $val){
foreach($this->departments as $key=> $val){
- $field1 = array("string" => "<img src='images/folder.png' alt='department'>");
- $field2 = array("string" => sprintf($linkopen,base64_encode($key),$val));
- $field3 = array("string" => " ");
- $field4 = array("string" => " ","attach"=>"style='text-align:right;border:none'");
+ 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" => "<img src='images/".$non_empty."folder.png' alt='department'>", "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));
}
$divlist->AddEntry(array($field1,$field2,$field3,$field4));
}
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("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;
}
}else{
$posix=$mail=$samba=$appl=$phone=$empty;
}
}else{
$desc = " - [ ".$val['description'][0]." ]";
}
}else{
$desc = " - [ ".$val['description'][0]." ]";
}
- $field1 = array("string" => sprintf($userimg,$val['dn']),"attach"=>"style='width:20px;align:middle;'");
- $field2 = array("string" => sprintf($editlink,$key,($val['cn']['0'].$desc)),"attach"=>$title);
- $field3 = array("string" => $posix." ".$mail." ".$samba." ".$appl." ".$phone);
- $field4 = array("string" => preg_replace("/%KEY%/", $key, $actions),"attach"=>"style='text-align:right;border:none;width:32px;'");
+ $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));
}
$divlist->AddEntry(array($field1,$field2,$field3,$field4));
}
$smarty->assign("grouplisthead", $listhead);
$smarty->assign("grouplist", $divlist->DrawList());
$smarty->assign("search_image", get_template_path('images/search.png'));
$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("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'));
return($smarty->fetch(get_template_path('headpage.tpl', TRUE)));
}
return($smarty->fetch(get_template_path('headpage.tpl', TRUE)));
}
-
- function reload()
+ function reload($CreatePosixsList=false)
{
/* Get config */
$groupfilter= get_global('groupfilter');
{
/* Get config */
$groupfilter= get_global('groupfilter');
}
/* User filter? */
}
/* User filter? */
- $filter= "";
+ $filter= "(objectclass=posixGroup)";
$error= "";
$error2= "";
$this->grouplist= array();
/* What are primary groups? */
$primaries= array();
$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"));
$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];
}
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.= "))";
- } else {
- $filter.= "(&(objectClass=posixGroup)(!(|";
- foreach ($primaries as $gidNumber => $cn){
- $filter.= "(gidNumber=$gidNumber)";
- }
- $filter.= ")))";
- }
-
-
/* Set filter depending on selection */
$sfilter= "";
if ($groupfilter['appgroups'] == "checked"){
/* Set filter depending on selection */
$sfilter= "";
if ($groupfilter['appgroups'] == "checked"){
if ($groupfilter['mailgroups'] == "checked"){
$filter.= "(objectClass=gosaMailAccount)";
}
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]])){
- $this->grouplist[$attrs['gidNumber'][0]]= $attrs;
- }
+ $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];
}
}
}
}
- /* NEW LIST MANAGMENT
+ /*
* We also need to search for the departments
* So we are able to navigate like in konquerer
*/
* We also need to search for the departments
* So we are able to navigate like in konquerer
*/
- $base2 = preg_replace("/ou=people,/i","",$base);
-
- $res3 = get_list2($this->ui->subtreeACL, "(&(|(ou=$regex)(description=$regex))(objectClass=gosaDepartment))",
- TRUE, $base2, array("ou", "description"), TRUE);
- $this->departments= array();
- foreach ($res3 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];
+ /* 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];
+ }
}
}
}
}
-
- /* END NEW LIST MANAGMENT
+ /* Ende department generation
*/
*/
-
-
-
-
/* Generate grouplist */
if ($filter != ""){
$filter= "(&(cn=$regex)(objectClass=posixGroup)(|$filter))";
/* Generate grouplist */
if ($filter != ""){
$filter= "(&(cn=$regex)(objectClass=posixGroup)(|$filter))";
$filter= "(&(|(memberUID=" . $groupfilter['guser'] . ")(cn=" . $groupfilter['guser'] . "))$filter)";
}
}
$filter= "(&(|(memberUID=" . $groupfilter['guser'] . ")(cn=" . $groupfilter['guser'] . "))$filter)";
}
}
+
+ /* Depending on $CreatePosixsList we have to create different lists */
+
if ($groupfilter['subsearch'] == "checked"){
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);
} else {
$base= get_groups_ou().$base;
$res= get_list($this->ui->subtreeACL, "$filter", FALSE, $base, array("cn", "description", "gidNumber"), TRUE);
}
foreach ($res as $value){
}
foreach ($res as $value){
- $this->grouplist[$value['gidNumber'][0]]= $value;
+ if ($groupfilter['functionalgroups'] != "checked" && isset($functional[$value['gidNumber'][0]])){
+ continue;
+ }
+ if ($groupfilter['primarygroups'] == "checked"){
+ $this->grouplist[$value['gidNumber'][0]]= $value;
+ } else {
+ if (!isset($primaries[$value['gidNumber'][0]])){
+ $this->grouplist[$value['gidNumber'][0]]= $value;
+ }
+ }
}
}
- reset ($this->grouplist);
+ $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);
+ }
}
function remove_from_parent()
}
function remove_from_parent()