2015-06-15 17:12:59 -04:00
|
|
|
<?php
|
|
|
|
|
|
|
|
|
|
class treeNode extends stdclass
|
|
|
|
|
{
|
|
|
|
|
public $text = "";
|
|
|
|
|
public $cls = "";
|
|
|
|
|
public $leaf = false;
|
|
|
|
|
public $checked = false;
|
|
|
|
|
public $children = array();
|
|
|
|
|
public $id = "";
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
try {
|
|
|
|
|
header("Content-Type: application/json;");
|
|
|
|
|
|
|
|
|
|
switch ($_REQUEST["m"]) {
|
|
|
|
|
case "loadDepartments":
|
|
|
|
|
global $ldapAdvanced;
|
|
|
|
|
global $departments;
|
|
|
|
|
global $terminatedOu;
|
|
|
|
|
global $baseDN;
|
|
|
|
|
|
|
|
|
|
$ldapAdvanced = getLDAPAdvanceInstance($_REQUEST["authUid"]);
|
2017-12-04 13:25:35 +00:00
|
|
|
$RBAC = RBAC::getSingleton();
|
|
|
|
|
$authenticationSource = $RBAC->authSourcesObj->load($_REQUEST["authUid"]);
|
2015-06-15 17:12:59 -04:00
|
|
|
$baseDN = $authenticationSource["AUTH_SOURCE_BASE_DN"];
|
|
|
|
|
$departments = $ldapAdvanced->searchDepartments();
|
|
|
|
|
$terminatedOu = $ldapAdvanced->getTerminatedOu();
|
|
|
|
|
$nodes = lookForChildrenDeps("");
|
2022-06-06 16:56:29 -04:00
|
|
|
die(json_encode($nodes));
|
2015-06-15 17:12:59 -04:00
|
|
|
break;
|
|
|
|
|
case "saveDepartments":
|
2017-12-04 13:25:35 +00:00
|
|
|
$depsToCheck = ($_REQUEST['departmentsDN'] != '') ? explode('|', $_REQUEST['departmentsDN']) : [];
|
2015-06-15 17:12:59 -04:00
|
|
|
$depsToCheck = array_map("urldecode", $depsToCheck);
|
|
|
|
|
$depsToUncheck = getDepartmentsToUncheck($depsToCheck);
|
2017-12-04 13:25:35 +00:00
|
|
|
$RBAC = RBAC::getSingleton();
|
|
|
|
|
$authenticationSource = $RBAC->authSourcesObj->load($_REQUEST["authUid"]);
|
2015-06-15 17:12:59 -04:00
|
|
|
$ldapAdvanced = getLDAPAdvanceInstance($_REQUEST["authUid"]);
|
|
|
|
|
|
2016-04-20 19:46:20 -04:00
|
|
|
foreach ($depsToCheck as $departmentDn) {
|
|
|
|
|
$departmentUid = $ldapAdvanced->getDepUidIfExistsDN($departmentDn);
|
|
|
|
|
if ($departmentUid == '') {
|
|
|
|
|
if (strcasecmp($departmentDn, $authenticationSource['AUTH_SOURCE_BASE_DN']) == 0) {
|
|
|
|
|
$departmentTitle = 'ROOT (' . $authenticationSource['AUTH_SOURCE_BASE_DN'] . ')';
|
|
|
|
|
$parentUid = '';
|
|
|
|
|
} else {
|
2022-11-24 09:46:41 -04:00
|
|
|
$ous = custom_ldap_explode_dn($departmentDn);
|
|
|
|
|
$departmentCurrent = array_shift($ous);
|
|
|
|
|
$parentDn = implode(',', $ous);
|
|
|
|
|
$ous = explode('=', $departmentCurrent);
|
|
|
|
|
$departmentTitle = trim($ous[1]);
|
2016-04-20 19:46:20 -04:00
|
|
|
$parentUid = $ldapAdvanced->getDepUidIfExistsDN($parentDn);
|
2022-11-24 09:46:41 -04:00
|
|
|
if (str_ireplace($authenticationSource['AUTH_SOURCE_BASE_DN'], '', $parentDn) != '' && $parentUid == '') {
|
2016-04-20 19:46:20 -04:00
|
|
|
$response = new stdClass();
|
2017-12-04 13:25:35 +00:00
|
|
|
$response->status = 'ERROR';
|
2016-04-20 19:46:20 -04:00
|
|
|
$response->message = G::LoadTranslation(
|
2017-12-04 13:25:35 +00:00
|
|
|
'ID_DEPARTMENT_CHECK_PARENT_DEPARTMENT',
|
|
|
|
|
[$parentDn, $departmentTitle]
|
2016-04-20 19:46:20 -04:00
|
|
|
);
|
2022-06-06 16:56:29 -04:00
|
|
|
echo json_encode($response);
|
2016-04-20 19:46:20 -04:00
|
|
|
exit(0);
|
|
|
|
|
}
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
|
2022-11-24 09:46:41 -04:00
|
|
|
$departmentUid = $ldapAdvanced->getDepartmentUidByTitle($departmentTitle);
|
2016-04-20 19:46:20 -04:00
|
|
|
$department = new Department();
|
2022-11-24 09:46:41 -04:00
|
|
|
if ($departmentUid === '') {
|
|
|
|
|
$data = [
|
|
|
|
|
'DEP_TITLE' => stripslashes($departmentTitle),
|
|
|
|
|
'DEP_PARENT' => $parentUid,
|
|
|
|
|
'DEP_LDAP_DN' => $departmentDn,
|
|
|
|
|
'DEP_REF_CODE' => ''
|
|
|
|
|
];
|
|
|
|
|
$departmentUid = $department->create($data);
|
|
|
|
|
if ($departmentUid === false) {
|
|
|
|
|
$response = new stdClass();
|
|
|
|
|
$response->status = 'ERROR';
|
|
|
|
|
$response->message = G::LoadTranslation('ID_DEPARTMENT_ERROR_CREATE');
|
|
|
|
|
echo json_encode($response);
|
|
|
|
|
exit(0);
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
$data = $department->Load($departmentUid);
|
|
|
|
|
$data['DEP_LDAP_DN'] = $departmentDn;
|
|
|
|
|
$department->update($data);
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
2022-11-24 09:46:41 -04:00
|
|
|
if (count($depsToUncheck) > 0) {
|
2016-04-20 19:46:20 -04:00
|
|
|
$baseDnLength = strlen($authenticationSource['AUTH_SOURCE_BASE_DN']);
|
|
|
|
|
foreach ($depsToUncheck as $departmentDn) {
|
|
|
|
|
$departmentUid = $ldapAdvanced->getDepUidIfExistsDN($departmentDn);
|
2022-11-24 09:46:41 -04:00
|
|
|
if ($departmentUid != '' &&
|
2016-04-20 19:46:20 -04:00
|
|
|
strcasecmp(
|
2022-11-24 09:46:41 -04:00
|
|
|
substr($departmentDn, strlen($departmentDn) - $baseDnLength),
|
2016-04-20 19:46:20 -04:00
|
|
|
$authenticationSource['AUTH_SOURCE_BASE_DN']
|
|
|
|
|
) == 0
|
|
|
|
|
) {
|
|
|
|
|
$department = new Department();
|
2022-11-24 09:46:41 -04:00
|
|
|
$data = $department->Load($departmentUid);
|
|
|
|
|
$data['DEP_LDAP_DN'] = '';
|
|
|
|
|
$department->update($data);
|
2016-04-20 19:46:20 -04:00
|
|
|
if (!isset($authenticationSource['AUTH_SOURCE_DATA']['DEPARTMENTS_TO_UNASSIGN'])) {
|
|
|
|
|
$authenticationSource['AUTH_SOURCE_DATA']['DEPARTMENTS_TO_UNASSIGN'] = [];
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
2016-04-20 19:46:20 -04:00
|
|
|
$authenticationSource['AUTH_SOURCE_DATA']['DEPARTMENTS_TO_UNASSIGN'][] = $departmentUid;
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$RBAC->authSourcesObj->update($authenticationSource);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$response = new stdclass();
|
|
|
|
|
$response->status = "OK";
|
2022-11-24 09:46:41 -04:00
|
|
|
if ($ldapAdvanced->checkDuplicateDepartmentTitles()) {
|
|
|
|
|
$response->warning = G::LoadTranslation("ID_IT_WAS_IDENTIFIED_DUPLICATED_DEPARTMENTS_PLEASE_REMOVE_THESE_DEPARTMENTS");
|
|
|
|
|
}
|
2022-06-06 16:56:29 -04:00
|
|
|
die(json_encode($response));
|
2015-06-15 17:12:59 -04:00
|
|
|
break;
|
|
|
|
|
case "loadGroups":
|
|
|
|
|
global $ldapAdvanced;
|
|
|
|
|
global $groups;
|
|
|
|
|
|
|
|
|
|
$ldapAdvanced = getLDAPAdvanceInstance($_REQUEST["authUid"]);
|
|
|
|
|
$groups = $ldapAdvanced->searchGroups();
|
|
|
|
|
$nodes = lookForChildrenGroups();
|
2022-06-06 16:56:29 -04:00
|
|
|
die(json_encode($nodes));
|
2015-06-15 17:12:59 -04:00
|
|
|
break;
|
|
|
|
|
case "saveGroups":
|
|
|
|
|
$groupsToCheck = explode("|", $_REQUEST["groupsDN"]);
|
|
|
|
|
$groupsToCheck = array_map("urldecode", $groupsToCheck);
|
|
|
|
|
$groupsToUncheck = getGroupsToUncheck($groupsToCheck);
|
2017-12-04 13:25:35 +00:00
|
|
|
$RBAC = RBAC::getSingleton();
|
|
|
|
|
$authenticationSource = $RBAC->authSourcesObj->load($_REQUEST["authUid"]);
|
2015-06-15 17:12:59 -04:00
|
|
|
$ldapAdvanced = getLDAPAdvanceInstance($_REQUEST["authUid"]);
|
|
|
|
|
|
|
|
|
|
foreach ($groupsToCheck as $groupDN) {
|
|
|
|
|
$ous = custom_ldap_explode_dn($groupDN);
|
|
|
|
|
$currentGroup = array_shift($ous);
|
|
|
|
|
$groupAux = explode("=", $currentGroup);
|
|
|
|
|
$groupTitle = isset($groupAux[1]) ? trim($groupAux[1]) : "";
|
2021-01-11 11:08:50 -04:00
|
|
|
$groupTitle = stripslashes($groupTitle);
|
|
|
|
|
if (empty($groupTitle)) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
$groupUid = $ldapAdvanced->getGroupUidByTitle($groupTitle);
|
|
|
|
|
$groupwf = new Groupwf();
|
|
|
|
|
if ($groupUid === "") {
|
|
|
|
|
$group = [
|
|
|
|
|
"GRP_TITLE" => $groupTitle,
|
|
|
|
|
"GRP_LDAP_DN" => $groupDN
|
|
|
|
|
];
|
|
|
|
|
$groupwf->create($group);
|
|
|
|
|
} else {
|
|
|
|
|
$group = $groupwf->Load($groupUid);
|
|
|
|
|
$group["GRP_LDAP_DN"] = $groupDN;
|
|
|
|
|
$groupwf->update($group);
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (count($groupsToUncheck) > 0) {
|
|
|
|
|
foreach ($groupsToUncheck as $groupDN) {
|
2021-01-11 11:08:50 -04:00
|
|
|
$ous = custom_ldap_explode_dn($groupDN);
|
|
|
|
|
$currentGroup = array_shift($ous);
|
|
|
|
|
$groupAux = explode("=", $currentGroup);
|
|
|
|
|
$groupTitle = isset($groupAux[1]) ? trim($groupAux[1]) : "";
|
|
|
|
|
$groupTitle = stripslashes($groupTitle);
|
|
|
|
|
if (empty($groupTitle)) {
|
|
|
|
|
continue;
|
|
|
|
|
}
|
|
|
|
|
$groupUid = $ldapAdvanced->getGroupUidByTitle($groupTitle);
|
|
|
|
|
if ($groupUid != "") {
|
|
|
|
|
$groupwf = new Groupwf();
|
|
|
|
|
$group = $groupwf->Load($groupUid);
|
|
|
|
|
$group["GRP_LDAP_DN"] = "";
|
|
|
|
|
$groupwf->update($group);
|
2015-06-15 17:12:59 -04:00
|
|
|
if (!isset($authenticationSource["AUTH_SOURCE_DATA"]["GROUPS_TO_UNASSIGN"])) {
|
2022-11-24 09:46:41 -04:00
|
|
|
$authenticationSource["AUTH_SOURCE_DATA"]["GROUPS_TO_UNASSIGN"] = [];
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
2021-01-11 11:08:50 -04:00
|
|
|
$authenticationSource["AUTH_SOURCE_DATA"]["GROUPS_TO_UNASSIGN"][] = $groupUid;
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
$RBAC->authSourcesObj->update($authenticationSource);
|
|
|
|
|
}
|
|
|
|
|
$response = new stdclass();
|
|
|
|
|
$response->status = "OK";
|
2021-01-11 11:08:50 -04:00
|
|
|
if ($ldapAdvanced->checkDuplicateTitles()) {
|
|
|
|
|
$response->warning = G::LoadTranslation("ID_IT_WAS_IDENTIFIED_DUPLICATED_GROUPS_PLEASE_REMOVE_THESE_GROUPS");
|
|
|
|
|
}
|
2022-06-06 16:56:29 -04:00
|
|
|
die(json_encode($response));
|
2015-06-15 17:12:59 -04:00
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
} catch (Exception $error) {
|
|
|
|
|
$response = new stdclass();
|
|
|
|
|
$response->status = "ERROR";
|
|
|
|
|
$response->message = $error->getMessage();
|
|
|
|
|
|
2022-06-06 16:56:29 -04:00
|
|
|
die(json_encode($response));
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getLDAPAdvanceInstance($authUid)
|
|
|
|
|
{
|
2017-12-04 13:25:35 +00:00
|
|
|
$RBAC = RBAC::getSingleton();
|
2017-08-11 15:54:49 -04:00
|
|
|
$ldapAdvanced = new LdapAdvanced();
|
2015-06-15 17:12:59 -04:00
|
|
|
$ldapAdvanced->sAuthSource = $authUid;
|
|
|
|
|
$ldapAdvanced->sSystem = $RBAC->sSystem;
|
|
|
|
|
|
|
|
|
|
return $ldapAdvanced;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getDepartments($parent)
|
|
|
|
|
{
|
|
|
|
|
global $departments;
|
|
|
|
|
global $terminatedOu;
|
|
|
|
|
global $baseDN;
|
|
|
|
|
|
|
|
|
|
$parentDepartments = $departments;
|
|
|
|
|
$childDepartments = $departments;
|
|
|
|
|
$currentDepartments = array();
|
|
|
|
|
|
|
|
|
|
foreach ($parentDepartments as $key => $val) {
|
|
|
|
|
if (strtolower($val["dn"]) != strtolower($parent)) {
|
|
|
|
|
if ((strtolower($val["parent"]) == strtolower($parent)) && (strtolower($val["ou"]) != strtolower($terminatedOu))) {
|
|
|
|
|
$node = array();
|
|
|
|
|
$node["DEP_UID"] = $val["ou"];
|
|
|
|
|
$node["DEP_TITLE"] = $val["ou"];
|
|
|
|
|
$node["DEP_USERS"] = $val["users"];
|
|
|
|
|
$node["DEP_DN"] = $val["dn"];
|
|
|
|
|
$node["HAS_CHILDREN"] = false;
|
|
|
|
|
$departments[$key]["hasChildren"] = false;
|
|
|
|
|
|
|
|
|
|
foreach ($childDepartments as $key2 => $val2) {
|
|
|
|
|
if (strtolower($val2["parent"]) == strtolower($val["dn"])) {
|
|
|
|
|
$node["HAS_CHILDREN"] = true;
|
|
|
|
|
$departments[$key]["hasChildren"] = true;
|
|
|
|
|
break;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$node["DEP_LAST"] = false;
|
|
|
|
|
$currentDepartments[] = $node;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (isset($currentDepartments[count($currentDepartments) - 1])) {
|
|
|
|
|
$currentDepartments[count($currentDepartments) - 1]["DEP_LAST"] = true;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $currentDepartments;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function lookForChildrenDeps($parent)
|
|
|
|
|
{
|
|
|
|
|
global $ldapAdvanced;
|
|
|
|
|
global $departments;
|
|
|
|
|
|
|
|
|
|
$allDepartments = getDepartments($parent);
|
|
|
|
|
$departmentsObjects = array();
|
|
|
|
|
|
|
|
|
|
$arrayDepartmentNumberOfUsersFromDb = $ldapAdvanced->departmentsGetNumberOfUsersFromDb();
|
|
|
|
|
|
|
|
|
|
foreach ($allDepartments as $department) {
|
|
|
|
|
$departmentObject = new treeNode();
|
|
|
|
|
$departmentObject->text = htmlentities($department["DEP_TITLE"], ENT_QUOTES, "UTF-8");
|
|
|
|
|
$departmentUid = $ldapAdvanced->getDepUidIfExistsDN($department["DEP_DN"]);
|
|
|
|
|
|
|
|
|
|
if ($departmentUid != "") {
|
2017-12-04 13:25:35 +00:00
|
|
|
$departmentObject->text .= " (" . ((isset($arrayDepartmentNumberOfUsersFromDb[$departmentUid])) ? $arrayDepartmentNumberOfUsersFromDb[$departmentUid] : 0) . ")";
|
2015-06-15 17:12:59 -04:00
|
|
|
$departmentObject->checked = true;
|
|
|
|
|
} else {
|
|
|
|
|
$departmentObject->checked = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if ($department["HAS_CHILDREN"] == 1) {
|
|
|
|
|
$departmentObject->children = lookForChildrenDeps($department["DEP_DN"]);
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$departmentObject->id = urlencode($department["DEP_DN"]);
|
|
|
|
|
$departmentsObjects[] = $departmentObject;
|
|
|
|
|
}
|
|
|
|
|
return $departmentsObjects;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getDepartmentsWithDN()
|
|
|
|
|
{
|
|
|
|
|
$arrayDepartmentLdapDn = array();
|
|
|
|
|
|
|
|
|
|
$criteria = new Criteria("workflow");
|
|
|
|
|
|
|
|
|
|
$criteria->addSelectColumn(DepartmentPeer::DEP_LDAP_DN);
|
|
|
|
|
$criteria->add(DepartmentPeer::DEP_LDAP_DN, "", Criteria::NOT_EQUAL);
|
|
|
|
|
$criteria->add(DepartmentPeer::DEP_LDAP_DN, null, Criteria::ISNOTNULL);
|
|
|
|
|
|
|
|
|
|
$rsCriteria = DepartmentPeer::doSelectRS($criteria);
|
|
|
|
|
$rsCriteria->setFetchmode(ResultSet::FETCHMODE_ASSOC);
|
|
|
|
|
|
|
|
|
|
while ($rsCriteria->next()) {
|
|
|
|
|
$row = $rsCriteria->getRow();
|
|
|
|
|
|
|
|
|
|
$arrayDepartmentLdapDn[] = $row;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $arrayDepartmentLdapDn;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getDepartmentsToUncheck($depsToCheck)
|
|
|
|
|
{
|
|
|
|
|
$departmentsWithDN = getDepartmentsWithDN();
|
|
|
|
|
$depsToUncheck = array();
|
|
|
|
|
|
|
|
|
|
foreach ($departmentsWithDN as $departmentWithDN) {
|
|
|
|
|
$found = false;
|
|
|
|
|
|
|
|
|
|
foreach ($depsToCheck as $depToCheck) {
|
|
|
|
|
if ($departmentWithDN["DEP_LDAP_DN"] == $depToCheck) {
|
|
|
|
|
$found = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!$found) {
|
|
|
|
|
$depsToUncheck[] = $departmentWithDN["DEP_LDAP_DN"];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $depsToUncheck;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getGroups()
|
|
|
|
|
{
|
|
|
|
|
global $groups;
|
|
|
|
|
|
|
|
|
|
$currentGroups = array();
|
|
|
|
|
|
|
|
|
|
foreach ($groups as $key => $val) {
|
|
|
|
|
$node = array();
|
|
|
|
|
$node["GRP_UID"] = $val["cn"];
|
|
|
|
|
$node["GRP_TITLE"] = $val["cn"];
|
|
|
|
|
$node["GRP_USERS"] = $val["users"];
|
|
|
|
|
$node["GRP_DN"] = $val["dn"];
|
|
|
|
|
$currentGroups[] = $node;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $currentGroups;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function lookForChildrenGroups()
|
|
|
|
|
{
|
|
|
|
|
global $ldapAdvanced;
|
|
|
|
|
global $groups;
|
|
|
|
|
|
|
|
|
|
$allGroups = getGroups();
|
|
|
|
|
$groupsObjects = array();
|
|
|
|
|
|
|
|
|
|
$arrayGroupNumberOfUsersFromDb = $ldapAdvanced->groupsGetNumberOfUsersFromDb();
|
|
|
|
|
|
|
|
|
|
foreach ($allGroups as $group) {
|
|
|
|
|
$groupObject = new treeNode();
|
|
|
|
|
$groupObject->text = htmlentities($group["GRP_TITLE"], ENT_QUOTES, "UTF-8");
|
|
|
|
|
$groupUid = $ldapAdvanced->getGrpUidIfExistsDN($group["GRP_DN"]);
|
|
|
|
|
|
|
|
|
|
if ($groupUid != "") {
|
2017-12-04 13:25:35 +00:00
|
|
|
$groupObject->text .= " (" . ((isset($arrayGroupNumberOfUsersFromDb[$groupUid])) ? $arrayGroupNumberOfUsersFromDb[$groupUid] : 0) . ")";
|
2015-06-15 17:12:59 -04:00
|
|
|
$groupObject->checked = true;
|
|
|
|
|
} else {
|
|
|
|
|
$groupObject->checked = false;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
$groupObject->id = urlencode($group["GRP_DN"]);
|
|
|
|
|
$groupsObjects[] = $groupObject;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $groupsObjects;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getGroupsWithDN()
|
|
|
|
|
{
|
|
|
|
|
$groupInstance = new Groupwf();
|
|
|
|
|
$allGroups = $groupInstance->getAll()->data;
|
|
|
|
|
$groupsWithDN = array();
|
|
|
|
|
|
|
|
|
|
foreach ($allGroups as $group) {
|
|
|
|
|
if ($group["GRP_LDAP_DN"] != "") {
|
|
|
|
|
$groupsWithDN[] = $group;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $groupsWithDN;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function getGroupsToUncheck($groupsToCheck)
|
|
|
|
|
{
|
|
|
|
|
$groupsWithDN = getGroupsWithDN();
|
|
|
|
|
$groupsToUncheck = array();
|
|
|
|
|
|
|
|
|
|
foreach ($groupsWithDN as $groupWithDN) {
|
|
|
|
|
$found = false;
|
|
|
|
|
|
|
|
|
|
foreach ($groupsToCheck as $groupToCheck) {
|
|
|
|
|
if ($groupWithDN["GRP_LDAP_DN"] == $groupToCheck) {
|
|
|
|
|
$found = true;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (!$found) {
|
|
|
|
|
$groupsToUncheck[] = $groupWithDN["GRP_LDAP_DN"];
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
return $groupsToUncheck;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
function custom_ldap_explode_dn($dn)
|
|
|
|
|
{
|
|
|
|
|
$result = ldap_explode_dn($dn, 0);
|
|
|
|
|
unset($result["count"]);
|
|
|
|
|
|
|
|
|
|
foreach ($result as $key => $value) {
|
2018-05-10 16:20:38 -04:00
|
|
|
$result[$key] = addcslashes(preg_replace_callback("/\\\([0-9A-Fa-f]{2})/", function ($m) {
|
2017-12-04 13:25:35 +00:00
|
|
|
return chr(hexdec($m[1]));
|
|
|
|
|
}, $value), '<>,"');
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|
|
|
|
|
|
2017-12-04 13:25:35 +00:00
|
|
|
return $result;
|
2015-06-15 17:12:59 -04:00
|
|
|
}
|