fixed bug with identical missing suffixes,
create missing suffixes recursivly
This commit is contained in:
parent
a032ba1e2c
commit
8ddcc29855
|
@ -41,27 +41,85 @@ if ($_POST['add_suff'] || $_POST['cancel']) {
|
||||||
$new_suff = $_POST['new_suff'];
|
$new_suff = $_POST['new_suff'];
|
||||||
$new_suff = str_replace("\\'", "", $new_suff);
|
$new_suff = str_replace("\\'", "", $new_suff);
|
||||||
$new_suff = explode(";", $new_suff);
|
$new_suff = explode(";", $new_suff);
|
||||||
// add entry
|
// add entries
|
||||||
for ($i = 0; $i < sizeof($new_suff); $i++) {
|
for ($i = 0; $i < sizeof($new_suff); $i++) {
|
||||||
|
// check if entry is already present
|
||||||
|
$info = @ldap_search($_SESSION['ldap']->server, $new_suff[$i], "", array());
|
||||||
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
|
if ($res) continue;
|
||||||
$suff = $new_suff[$i];
|
$suff = $new_suff[$i];
|
||||||
// generate DN and attributes
|
// generate DN and attributes
|
||||||
$tmp = explode(",", $suff);
|
$tmp = explode(",", $suff);
|
||||||
$name = explode("=", $tmp[0]);
|
$name = explode("=", $tmp[0]);
|
||||||
array_shift($tmp);
|
array_shift($tmp);
|
||||||
$end = implode(",", $tmp);
|
$end = implode(",", $tmp);
|
||||||
if ($name[0] != "ou") {
|
if ($name[0] != "ou") { // add root entry
|
||||||
|
$attr = array();
|
||||||
|
$attr[$name[0]] = $name[1];
|
||||||
|
$attr['objectClass'] = 'organization';
|
||||||
|
$dn = $suff;
|
||||||
|
if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
|
||||||
$fail[] = $suff;
|
$fail[] = $suff;
|
||||||
continue;
|
continue;
|
||||||
}
|
}
|
||||||
else {
|
}
|
||||||
|
else { // add organizational unit
|
||||||
$name = $name[1];
|
$name = $name[1];
|
||||||
$attr = array();
|
$attr = array();
|
||||||
$attr['objectClass'] = "organizationalunit";
|
$attr['objectClass'] = "organizationalunit";
|
||||||
$attr['ou'] = $name;
|
$attr['ou'] = $name;
|
||||||
$dn = "ou=" . $name . "," . $end;
|
$dn = $suff;
|
||||||
|
if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
|
||||||
|
// check if we have to add parent entries
|
||||||
|
if (ldap_errno($_SESSION['ldap']->server()) == 32) {
|
||||||
|
$temp = explode(",", $suff);
|
||||||
|
$subsuffs = array();
|
||||||
|
// make list of subsuffixes
|
||||||
|
for ($k = 0; $k < sizeof($temp); $k++) {
|
||||||
|
$part = explode("=", $temp[$k]);
|
||||||
|
if ($part[0] == "ou") $subsuffs[] = implode(",", array_slice($temp, $k));
|
||||||
|
else {
|
||||||
|
$subsuffs[] = implode(",", array_slice($temp, $k));
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
// create missing entries
|
||||||
|
for ($k = sizeof($subsuffs) - 1; $k >= 0; $k--) {
|
||||||
|
// check if subsuffix is present
|
||||||
|
$info = @ldap_search($_SESSION['ldap']->server, $subsuffs[$k], "", array());
|
||||||
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
|
if (!$res) {
|
||||||
|
$suffarray = explode(",", $subsuffs[$k]);
|
||||||
|
$headarray = explode("=", $suffarray[0]);
|
||||||
|
if ($headarray[0] == "ou") { // add ou entry
|
||||||
|
$attr = array();
|
||||||
|
$attr['objectClass'] = 'organizationalunit';
|
||||||
|
$attr['ou'] = $headarray[1];
|
||||||
|
$dn = $subsuffs[$k];
|
||||||
if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
|
if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
|
||||||
$fail[] = $suff;
|
$fail[] = $suff;
|
||||||
$error[] = ldap_error($_SESSION['ldap']->server());
|
$error[] = ldap_error($_SESSION['ldap']->server());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else { // add root entry
|
||||||
|
$attr = array();
|
||||||
|
$attr['objectClass'] = 'organization';
|
||||||
|
$attr[$headarray[0]] = $headarray[1];
|
||||||
|
$dn = $subsuffs[$k];
|
||||||
|
if (!@ldap_add($_SESSION['ldap']->server(), $dn, $attr)) {
|
||||||
|
$fail[] = $suff;
|
||||||
|
$error[] = ldap_error($_SESSION['ldap']->server());
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
$fail[] = $suff;
|
||||||
|
$error[] = ldap_error($_SESSION['ldap']->server());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -29,22 +29,22 @@ $new_suffs = array();
|
||||||
if ($conf->get_UserSuffix() && ($conf->get_UserSuffix() != "")) {
|
if ($conf->get_UserSuffix() && ($conf->get_UserSuffix() != "")) {
|
||||||
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_UserSuffix(), "", array());
|
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_UserSuffix(), "", array());
|
||||||
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
if (!$res) $new_suffs[] = $conf->get_UserSuffix();
|
if (!$res && !in_array($conf->get_UserSuffix(), $new_suffs)) $new_suffs[] = $conf->get_UserSuffix();
|
||||||
}
|
}
|
||||||
if ($conf->get_GroupSuffix() && ($conf->get_GroupSuffix() != "")) {
|
if ($conf->get_GroupSuffix() && ($conf->get_GroupSuffix() != "")) {
|
||||||
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_GroupSuffix(), "", array());
|
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_GroupSuffix(), "", array());
|
||||||
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
if (!$res) $new_suffs[] = $conf->get_GroupSuffix();
|
if (!$res && !in_array($conf->get_GroupSuffix(), $new_suffs)) $new_suffs[] = $conf->get_GroupSuffix();
|
||||||
}
|
}
|
||||||
if ($conf->get_HostSuffix() && ($conf->get_HostSuffix() != "")) {
|
if ($conf->get_HostSuffix() && ($conf->get_HostSuffix() != "")) {
|
||||||
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_HostSuffix(), "", array());
|
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_HostSuffix(), "", array());
|
||||||
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
if (!$res) $new_suffs[] = $conf->get_HostSuffix();
|
if (!$res && !in_array($conf->get_HostSuffix(), $new_suffs)) $new_suffs[] = $conf->get_HostSuffix();
|
||||||
}
|
}
|
||||||
if ($conf->get_DomainSuffix() && ($conf->get_DomainSuffix() != "")) {
|
if ($conf->get_DomainSuffix() && ($conf->get_DomainSuffix() != "")) {
|
||||||
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_DomainSuffix(), "", array());
|
$info = @ldap_search($_SESSION['ldap']->server, $conf->get_DomainSuffix(), "", array());
|
||||||
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
$res = @ldap_get_entries($_SESSION['ldap']->server, $info);
|
||||||
if (!$res) $new_suffs[] = $conf->get_DomainSuffix();
|
if (!$res && !in_array($conf->get_DomainSuffix(), $new_suffs)) $new_suffs[] = $conf->get_DomainSuffix();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ($_SESSION['config']->is_samba3()) {
|
if ($_SESSION['config']->is_samba3()) {
|
||||||
|
|
Loading…
Reference in New Issue