listgroups\n"; echo "\n"; echo "
\n"; echo "\n"; // generate attribute-description table $attr_array = array(); // list of LDAP attributes to show $desc_array = array(); // list of descriptions for the attributes $attr_string = $_SESSION["config"]->get_grouplistAttributes(); $temp_array = explode(";", $attr_string); $hash_table = listGetAttributeGroupArray(); // get current page $page = $_GET["page"]; if (!$page) $page = 1; // take maximum count of group entries shown on one page out of session if ($_SESSION["config"]->get_MaxListEntries() <= 0) $max_page_entries = 10; // default setting, if not yet set else $max_page_entries = $_SESSION["config"]->get_MaxListEntries(); // generate column attributes and descriptions for ($i = 0; $i < sizeof($temp_array); $i++) { // if value is predifined, look up description in hash_table if (substr($temp_array[$i],0,1) == "#") { $attr = strtolower(substr($temp_array[$i],1)); $attr_array[$i] = $attr; if ($hash_table[$attr]) $desc_array[] = strtoupper($hash_table[$attr]); else $desc_array[] = strtoupper($attr); } // if not predefined, the attribute is seperated by a ":" from description else { $attr = explode(":", $temp_array[$i]); $attr_array[$i] = $attr[0]; if ($attr[1]) $desc_array[$i] = strtoupper($attr[1]); else $desc_array[$i] = strtoupper($attr[0]); } } // check search suffix if ($_POST['grp_suffix']) $grp_suffix = $_POST['grp_suffix']; // new suffix selected via combobox elseif ($_SESSION['grp_suffix']) $grp_suffix = $_SESSION['grp_suffix']; // old suffix from session else $grp_suffix = $_SESSION["config"]->get_GroupSuffix(); // default suffix $refresh = true; if ($_GET['norefresh']) $refresh = false; if ($_POST['refresh']) $refresh = true; if ($refresh) { // configure search filter $module_filter = get_ldap_filter("group"); // basic filter is provided by modules $filter = "(&" . $module_filter . ")"; $attrs = $attr_array; $sr = @ldap_search($_SESSION["ldap"]->server(), $grp_suffix, $filter, $attrs); if (ldap_errno($_SESSION["ldap"]->server()) == 4) { StatusMessage("WARN", _("LDAP sizelimit exceeded, not all entries are shown."), _("See README.openldap.txt to solve this problem.")); } if ($sr) { $info = ldap_get_entries($_SESSION["ldap"]->server, $sr); ldap_free_result($sr); // delete first array entry which is "count" unset($info['count']); // save results $_SESSION[$scope . 'info'] = $info; } else { $info = array(); $_SESSION[$scope . 'info'] = array(); StatusMessage("ERROR", _("LDAP Search failed! Please check your preferences."), _("No groups found!")); } } $filter = listBuildFilter($_POST, $attr_array); $info = listFilterAccounts($info, $filter); if (sizeof($info) == 0) StatusMessage("WARN", "", _("No groups found!")); // sort rows by sort column ($sort) if ($info) $info = listSort($sort, $attr_array, $info); // build filter URL $searchFilter = array(); $filterAttributes = array_keys($filter); for ($i = 0; $i < sizeof($filterAttributes); $i++) { $searchFilter[] = "filter" . $filterAttributes[$i] . "=" . $filter[$filterAttributes[$i]]['original']; } if (sizeof($searchFilter) > 0) { $searchFilter = "&" . implode("&", $searchFilter); } else { $searchFilter = ""; } echo ("\n"); echo "