0) { metaRefresh("../delete.php?type=group"); exit; } } // PDF for selected groups elseif ($_POST['pdf_group']){ // search for checkboxes $groups = array_keys($_POST, "on"); $list = array(); // load groups from LDAP for ($i = 0; $i < sizeof($groups); $i++) { $_SESSION["accountPDF-$i"] = new accountContainer("group", "accountPDF-$i"); $_SESSION["accountPDF-$i"]->load_account($groups[$i]); $list[$i] = $_SESSION["accountPDF-$i"]; } if (sizeof($list) > 0) { createModulePDF($list, "group"); exit; } } // PDF for all groups elseif ($_POST['pdf_all']){ $list = array(); for ($i = 0; $i < sizeof($_SESSION['grp_info']); $i++) { $_SESSION["accountPDF-$i"] = new accountContainer("group", "accountPDF-$i"); $_SESSION["accountPDF-$i"]->load_account($_SESSION['grp_info'][$i]['dn']); $list[$i] = $_SESSION["accountPDF-$i"]; } if (sizeof($list) > 0) { createModulePDF($list, "group"); exit; } } } echo $_SESSION['header']; echo "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 // 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 $module_filter = get_ldap_filter("group"); // basic filter is provided by modules $filter = "(&" . $module_filter; 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(), $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) { $grp_info = ldap_get_entries($_SESSION["ldap"]->server, $sr); ldap_free_result($sr); if ($grp_info["count"] == 0) StatusMessage("WARN", "", _("No Groups found!")); // delete first array entry which is "count" unset($grp_info['count']); // sort rows by sort column ($sort) $grp_info = listSort($sort, $attr_array, $grp_info); } else { $grp_info = array(); $_SESSION['grp_info'] = array(); StatusMessage("ERROR", _("LDAP Search failed! Please check your preferences."), _("No Groups found!")); } } else { if (sizeof($grp_info) == 0) StatusMessage("WARN", "", _("No Groups found!")); // sort rows by sort column ($sort) if ($grp_info) $grp_info =listSort($sort, $attr_array, $grp_info); } echo ("
\n"); // draw navigation bar if group accounts were found if (sizeof($grp_info) > 0) { listDrawNavigationBar(sizeof($grp_info), $max_page_entries, $page, $sort, $searchFilter, "group", _("%s group(s) found")); echo ("
"); } // print group table header echo "\n"; echo ""; // table header for ($k = 0; $k < sizeof($desc_array); $k++) { if (strtolower($attr_array[$k]) == $sort) { echo ""; } else echo ""; } echo "\n"; // print filter row echo ""; // print input boxes for filters for ($k = 0; $k < sizeof ($desc_array); $k++) { echo ""; } echo "\n"; // calculate which rows to show $table_begin = ($page - 1) * $max_page_entries; if (($page * $max_page_entries) > sizeof($grp_info)) $table_end = sizeof($grp_info); else $table_end = ($page * $max_page_entries); if (sizeof($grp_info) > 0) { // print group list for ($i = $table_begin; $i < $table_end; $i++) { echo(""); if ($_GET['selectall'] == "yes") { echo " "; } else { echo " "; } echo (" "); for ($k = 0; $k < sizeof($attr_array); $k++) { echo (""); } echo("\n"); } // display select all link $colspan = sizeof($attr_array) + 1; echo "\n"; echo "\n"; echo "\n"; echo "\n"; } echo ("
" . $desc_array[$k] . "" . $desc_array[$k] . "
"; echo ""; echo ""; echo (""); echo "
" . _("Edit") . ""); // print all attribute entries seperated by "; " if (sizeof($grp_info[$i][strtolower($attr_array[$k])]) > 0) { // delete first array entry which is "count" if (is_array($grp_info[$i][strtolower($attr_array[$k])])) unset($grp_info[$i][strtolower($attr_array[$k])]['count']); // generate links for group members if (strtolower($attr_array[$k]) == "memberuid") { // sort array sort($grp_info[$i][strtolower($attr_array[$k])]); // make a link for each member of the group $linklist = array(); for ($d = 0; $d < sizeof($grp_info[$i][strtolower($attr_array[$k])]); $d++) { $user = $grp_info[$i][strtolower($attr_array[$k])][$d]; // user name $linklist[$d] = "" . $user . ""; } echo implode("; ", $linklist); } // print all other attributes else { if (is_array($grp_info[$i][strtolower($attr_array[$k])])) { // delete "count" entry unset($grp_info[$i][strtolower($attr_array[$k])]['count']); // sort array sort($grp_info[$i][strtolower($attr_array[$k])]); echo utf8_decode(implode("; ", $grp_info[$i][strtolower($attr_array[$k])])); } else echo utf8_decode($grp_info[$i][strtolower($attr_array[$k])]); } } echo ("
\"select " . "" . _("Select all") . "
"); echo ("
"); // draw navigation bar if group accounts were found if (sizeof($grp_info) > 0) { listDrawNavigationBar(sizeof($grp_info), $max_page_entries, $page, $sort, $searchFilter, "group", _("%s group(s) found")); echo ("
\n"); } if (! $_GET['norefresh']) { // generate list of possible suffixes $grp_units = $_SESSION['ldap']->search_units($_SESSION["config"]->get_GroupSuffix()); } // print combobox with possible sub-DNs if (sizeof($grp_units) > 1) { echo ("

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

\n"); echo ("

 

\n"); } echo ("\n"); if (sizeof($grp_info) > 0) { echo ("\n"); echo ("


\n"); echo "
PDF\n"; echo ("\n"); echo " "; echo ("\n"); echo "
"; } echo ("
\n"); echo "\n"; // save variables to session $_SESSION['grp_info'] = $grp_info; $_SESSION['grp_units'] = $grp_units; $_SESSION['grp_suffix'] = $grp_suffix; ?>