listhosts\n"; echo "\n"; echo "
\n"; listPrintJavaScript(); // 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 = listGetAttributeHostArray(); // get current page if (isset($_GET["page"])) $page = $_GET["page"]; else $page = 1; // take maximum count of host 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]); } } // get sorting column if (isset($_GET["sort"])) $sort = $_GET["sort"]; else $sort = strtolower($attr_array[0]); // check search suffix if ($_POST['suffix']) $suffix = $_POST['suffix']; // new suffix selected via combobox elseif ($_SESSION[$scope . '_suffix']) $suffix = $_SESSION[$scope . '_suffix']; // old suffix from session else $suffix = $_SESSION["config"]->get_HostSuffix(); // default suffix $refresh = true; if (isset($_GET['norefresh'])) $refresh = false; if (isset($_POST['refresh'])) $refresh = true; if ($refresh) { // configure search filter $module_filter = get_ldap_filter("host"); // basic filter is provided by modules $filter = "(&" . $module_filter . ")"; $attrs = $attr_array; $sr = @ldap_search($_SESSION["ldap"]->server(), $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 hosts found!")); } } $filter = listBuildFilter($_POST, $attr_array); $info = listFilterAccounts($info, $filter); if (sizeof($info) == 0) StatusMessage("WARN", "", _("No hosts 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 = ""; } echo ("\n"); echo "