get_groupSuffix(); $filter = "objectClass=posixGroup"; $attrs = array("cn", "gidNumber"); $sr = @ldap_search($_SESSION["ldap"]->server(), $suffix, $filter, $attrs); if ($sr) { $info = @ldap_get_entries($_SESSION["ldap"]->server(), $sr); unset($info['count']); // delete count entry for ($i = 0; $i < sizeof($info); $i++) { $trans_primary_hash[$info[$i]['gidnumber'][0]] = $info[$i]['cn'][0]; } $_SESSION['trans_primary_hash'] = $trans_primary_hash; } } $info = $_SESSION[$scope . 'info']; $usr_units = $_SESSION['usr_units']; listDoPost($scope); echo $_SESSION['header']; echo "listusers\n"; echo "\n"; echo "\n"; echo "\n"; $page = $_GET["page"]; if (!$page) $page = 1; // take maximum count of user 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 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_userlistAttributes(); $temp_array = explode(";", $attr_string); $hash_table = listGetAttributeUserArray(); // 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]); } } $sort = $_GET["sort"]; if (!$sort) $sort = strtolower($attr_array[0]); // check search suffix if ($_POST['usr_suffix']) $usr_suffix = $_POST['usr_suffix']; // new suffix selected via combobox elseif ($_SESSION['usr_suffix']) $usr_suffix = $_SESSION['usr_suffix']; // old suffix from session else $usr_suffix = $_SESSION["config"]->get_UserSuffix(); // default suffix // configure search filter for LDAP $module_filter = get_ldap_filter("user"); // basic filter is provided by modules $filter = "(&" . $module_filter . ")"; $refresh = true; if ($_GET['norefresh']) $refresh = false; if ($_POST['refresh']) $refresh = true; if ($refresh) { $attrs = $attr_array; $sr = @ldap_search($_SESSION["ldap"]->server(), $usr_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 { $_SESSION[$scope . 'info'] = array(); $info = array(); StatusMessage("ERROR", _("LDAP Search failed! Please check your preferences."), _("No users found!")); } } $filter = listBuildFilter($_POST, $attr_array); $info = listFilterAccounts($info, $filter); if (sizeof($info) == 0) StatusMessage("WARN", "", _("No users found!")); // sort rows by sort column ($sort) if ($info) { $info = listSort($sort, $attr_array, $info); $_SESSION[$scope . 'info'] = $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 = ""; } $user_count = sizeof($info); echo ("
\n"); // display table only if users exist in LDAP if ($user_count != 0) { // create navigation bar on top of user table listDrawNavigationBar($user_count, $max_page_entries, $page, $sort, $searchFilter . "&trans_primary=" . $trans_primary, "user", _("%s user(s) found")); echo ("
"); } // account table head listPrintTableHeader("user", $searchFilter . "&trans_primary=" . $trans_primary, $desc_array, $attr_array, $_POST, $sort); // calculate which rows to show $table_begin = ($page - 1) * $max_page_entries; if (($page * $max_page_entries) > sizeof($info)) $table_end = sizeof($info); else $table_end = ($page * $max_page_entries); if ($user_count != 0) { // translate GIDs and resort array if selected if ($trans_primary == "on") { // translate GIDs for ($i = 0; $i < sizeof($info); $i++) { if ($trans_primary_hash[$info[$i]['gidnumber'][0]]) { $info[$i]['gidnumber'][0] = $trans_primary_hash[$info[$i]['gidnumber'][0]]; } } // resort if needed if ($sort == "gidnumber") { $info = listSort($sort, $attr_array, $info); $_SESSION[$scope . 'info'] = $info; } } // print user list for ($i = $table_begin; $i < $table_end; $i++) { echo("\n"); // checkboxes if selectall = "yes" if ($_GET['selectall'] == "yes") { echo "\n\n\n"; } else { echo "\n\n\n"; } echo ("\n" . _("Edit") . "\n\n"); for ($k = 0; $k < sizeof($attr_array); $k++) { echo ("\n"); // print attribute values if (sizeof($info[$i][strtolower($attr_array[$k])]) > 0) { if (is_array($info[$i][strtolower($attr_array[$k])])) { // delete first array entry which is "count" unset($info[$i][strtolower($attr_array[$k])]['count']); // sort array sort($info[$i][strtolower($attr_array[$k])]); // print all attribute entries seperated by "; " echo implode("; ", $info[$i][strtolower($attr_array[$k])]) . "\n"; } else echo $info[$i][strtolower($attr_array[$k])] . "\n"; } echo ("\n"); } echo("\n"); } // display select all link $colspan = sizeof($attr_array) + 1; echo "\n"; echo "\"select\n"; echo " " . "" . _("Select all") . "\n"; echo "\n"; } echo ("\n"); echo ("
"); if ($user_count != 0) { listDrawNavigationBar($user_count, $max_page_entries, $page, $sort, $searchFilter . "&trans_primary=" . $trans_primary, "user", _("%s user(s) found")); echo ("
"); } if (! $_GET['norefresh']) { // generate list of possible suffixes $usr_units = $_SESSION['ldap']->search_units($_SESSION["config"]->get_UserSuffix()); } // print combobox with possible sub-DNs if (sizeof($usr_units) > 1) { echo ("

\n"); echo ("" . _("Suffix") . ": "); echo ("\n"); echo (""); echo ("

\n"); } // show translate GID to group name box if there is a column with gidnumber if (in_array("gidnumber", $attr_array)) { echo "

\n"; echo "" . _("Translate GID number to group name") . ": "; if ($trans_primary == "on") { echo ""; } else echo ""; echo ("  "); echo "

\n"; } echo ("

 

\n"); // new/delete/PDF buttons echo ("\n"); if ($user_count != 0) { echo ("\n"); echo ("


\n"); echo "
PDF\n"; echo ("" . _('PDF structure') . ":      \n"; echo ("\n"); echo " "; echo ("\n"); echo "
"; } echo ("

 

\n"); echo ("
\n"); echo "\n"; // save variables to session $_SESSION['usr_units'] = $usr_units; $_SESSION['usr_suffix'] = $usr_suffix; ?>