\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_hostlistAttributes(); $temp_array = explode(";", $attr_string); $hash_table = $_SESSION["ldap"]->attributeHostArray(); // get current page $page = $_GET["page"]; if (!$page) $page = 1; // take maximum count of host entries shown on one page out of session if ($_SESSION["config"]->get_MaxListEntries() <= 0) $max_pageentrys = 10; // default setting, if not yet set else $max_pageentrys = $_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['hst_suffix']) $hst_suffix = $_POST['hst_suffix']; // new suffix selected via combobox elseif ($_SESSION['hst_suffix']) $hst_suffix = $_SESSION['hst_suffix']; // old suffix from session else $hst_suffix = $_SESSION["config"]->get_HostSuffix(); // default suffix // generate search filter for sort links $searchfilter = ""; for ($k = 0; $k < sizeof($desc_array); $k++) { if (eregi("^([0-9a-z_\\*\\+\\-])+$", $_POST["filter" . strtolower($attr_array[$k])])) { $searchfilter = $searchfilter . "&filter" . strtolower($attr_array[$k]) . "=". $_POST["filter" . strtolower($attr_array[$k])]; } } if (! $_GET['norefresh']) { // configure search filter if ($_SESSION['config']->is_samba3()) { // Samba hosts have the attribute "sambaSamAccount" and end with "$" $filter = "(&(objectClass=sambaSamAccount) (uid=*$)"; } else { // Samba hosts have the attribute "sambaAccount" and end with "$" $filter = "(&(objectClass=sambaAccount) (uid=*$)"; } for ($k = 0; $k < sizeof($desc_array); $k++) { if (eregi("^([0-9a-z_\\*\\+\\-])+$", $_POST["filter" . strtolower($attr_array[$k])])) $filter = $filter . "(" . strtolower($attr_array[$k]) . "=" . $_POST["filter" . strtolower($attr_array[$k])] . ")"; else $_POST["filter" . strtolower($attr_array[$k])] = ""; } $filter = $filter . ")"; $attrs = $attr_array; $sr = @ldap_search($_SESSION["ldap"]->server(), $hst_suffix, $filter, $attrs); if (ldap_errno($_SESSION["ldap"]->server()) == 4) { StatusMessage("WARN", _("LDAP sizelimit exceeded, not all entries are shown."), "See README.openldap to solve this problem."); } if ($sr) { $hst_info = ldap_get_entries($_SESSION["ldap"]->server, $sr); ldap_free_result($sr); if ($hst_info["count"] == 0) StatusMessage("WARN", "", _("No Samba Hosts found!")); // delete first array entry which is "count" array_shift($hst_info); // sort rows by sort column ($sort) usort($hst_info, "cmp_array"); } else { $hst_info = array(); $_SESSION['hst_info'] = array(); StatusMessage("ERROR", _("LDAP Search failed! Please check your preferences."), _("No Samba Hosts found!")); } } else { if (sizeof($hst_info) == 0) StatusMessage("WARN", "", _("No Samba Hosts found!")); // sort rows by sort column ($sort) if ($hst_info) usort($hst_info, "cmp_array"); } echo ("\n"); echo "