listgroups.php: group members can be edited
ldap.php: added function to get DNs for user names
This commit is contained in:
parent
cbd96fadc9
commit
a730567c22
|
@ -154,7 +154,21 @@ class Ldap{
|
||||||
function close() {
|
function close() {
|
||||||
ldap_close($this->server);
|
ldap_close($this->server);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// searches LDAP for a specific user name
|
||||||
|
// and returns its DN entry
|
||||||
|
function search_username($name) {
|
||||||
|
// users have the attribute "posixAccount" or "sambaAccount" and uid $name
|
||||||
|
$filter = "(&(|(objectClass=posixAccount) (objectClass=sambaAccount)) (uid=$name))";
|
||||||
|
$attrs = array();
|
||||||
|
$sr = ldap_search($this->server, $this->conf->get_UserSuffix(), $filter, $attrs);
|
||||||
|
$info = ldap_get_entries($this->server, $sr);
|
||||||
|
// return only first DN entry
|
||||||
|
$ret = $info[0]["dn"];
|
||||||
|
ldap_free_result($sr);
|
||||||
|
return $ret;
|
||||||
|
}
|
||||||
|
|
||||||
// returns the LDAP connection handle
|
// returns the LDAP connection handle
|
||||||
function server() {
|
function server() {
|
||||||
return $this->server;
|
return $this->server;
|
||||||
|
|
|
@ -29,7 +29,7 @@ include_once("ldap.php");
|
||||||
session_save_path("../sess");
|
session_save_path("../sess");
|
||||||
@session_start();
|
@session_start();
|
||||||
|
|
||||||
echo "<html><head><title>hjhj</title>\n";
|
echo "<html><head><title>listgroups</title>\n";
|
||||||
echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n";
|
echo "<link rel=\"stylesheet\" type=\"text/css\" href=\"../style/layout.css\">\n";
|
||||||
echo "</head><body>\n";
|
echo "</head><body>\n";
|
||||||
echo "<script src=\"./functions.js\" type=\"text/javascript\" language=\"javascript\"></script>\n";
|
echo "<script src=\"./functions.js\" type=\"text/javascript\" language=\"javascript\"></script>\n";
|
||||||
|
@ -92,7 +92,25 @@ for ($i = 0; $i < sizeof($info)-1; $i++) { // ignore last entry in array which i
|
||||||
// print all attribute entries seperated by "; "
|
// print all attribute entries seperated by "; "
|
||||||
if (sizeof($info[$i][strtolower($attr_array[$k])]) > 0) {
|
if (sizeof($info[$i][strtolower($attr_array[$k])]) > 0) {
|
||||||
array_shift($info[$i][strtolower($attr_array[$k])]);
|
array_shift($info[$i][strtolower($attr_array[$k])]);
|
||||||
echo implode("; ", $info[$i][strtolower($attr_array[$k])]);
|
// generate links for group members
|
||||||
|
if (strtolower($attr_array[$k]) == "memberuid") {
|
||||||
|
$linklist = array();
|
||||||
|
for ($d = 0; $d < sizeof($info[$i][strtolower($attr_array[$k])]); $d++) {
|
||||||
|
$user = $info[$i][strtolower($attr_array[$k])][$d]; // user name
|
||||||
|
$dn = $_SESSION["ldap"]->search_username($user); // DN entry
|
||||||
|
// if user was found in LDAP make link, otherwise just print name
|
||||||
|
if ($dn) {
|
||||||
|
$linklist[$d] = "<a href=../templates/account.php?type=user&DN=\"" . $dn . "\" >" .
|
||||||
|
$info[$i][strtolower($attr_array[$k])][$d] . "</a>";
|
||||||
|
}
|
||||||
|
else $linklist[$d] = $user;
|
||||||
|
}
|
||||||
|
echo implode("; ", $linklist);
|
||||||
|
}
|
||||||
|
// print all other attributes
|
||||||
|
else {
|
||||||
|
echo implode("; ", $info[$i][strtolower($attr_array[$k])]);
|
||||||
|
}
|
||||||
}
|
}
|
||||||
echo ("</td>");
|
echo ("</td>");
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue