Use the correct name for malformed LDAP attributes automatically
...or more purposefully: Guard lazy users from themselves. I hope I don't have to explain why _this_ is not part of Icinga\Protocol\Ldap\Query... resolves #8608
This commit is contained in:
parent
edf55728cb
commit
0bc1416b10
|
@ -30,6 +30,18 @@ class LdapUserBackend extends UserBackend
|
||||||
|
|
||||||
protected $groupOptions;
|
protected $groupOptions;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Normed attribute names based on known LDAP environments
|
||||||
|
*
|
||||||
|
* @var array
|
||||||
|
*/
|
||||||
|
protected $normedAttributes = array(
|
||||||
|
'uid' => 'uid',
|
||||||
|
'user' => 'user',
|
||||||
|
'inetorgperson' => 'inetOrgPerson',
|
||||||
|
'samaccountname' => 'sAMAccountName'
|
||||||
|
);
|
||||||
|
|
||||||
public function __construct(
|
public function __construct(
|
||||||
Connection $conn,
|
Connection $conn,
|
||||||
$userClass,
|
$userClass,
|
||||||
|
@ -40,12 +52,29 @@ class LdapUserBackend extends UserBackend
|
||||||
) {
|
) {
|
||||||
$this->conn = $conn;
|
$this->conn = $conn;
|
||||||
$this->baseDn = trim($baseDn) ?: $conn->getDN();
|
$this->baseDn = trim($baseDn) ?: $conn->getDN();
|
||||||
$this->userClass = $userClass;
|
$this->userClass = $this->getNormedAttribute($userClass);
|
||||||
$this->userNameAttribute = $userNameAttribute;
|
$this->userNameAttribute = $this->getNormedAttribute($userNameAttribute);
|
||||||
$this->customFilter = trim($cutomFilter);
|
$this->customFilter = trim($cutomFilter);
|
||||||
$this->groupOptions = $groupOptions;
|
$this->groupOptions = $groupOptions;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Return the given attribute name normed to known LDAP enviroments, if possible
|
||||||
|
*
|
||||||
|
* @param string $name
|
||||||
|
*
|
||||||
|
* @return string
|
||||||
|
*/
|
||||||
|
protected function getNormedAttribute($name)
|
||||||
|
{
|
||||||
|
$loweredName = strtolower($name);
|
||||||
|
if (array_key_exists($loweredName, $this->normedAttributes)) {
|
||||||
|
return $this->normedAttributes[$loweredName];
|
||||||
|
}
|
||||||
|
|
||||||
|
return $name;
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Create a query to select all usernames
|
* Create a query to select all usernames
|
||||||
*
|
*
|
||||||
|
|
Loading…
Reference in New Issue