Encapsulate a LDAP DN string using Arrays in PHP
During a project I had to fork privileges assignation logic with information coming from an LDAP server. Since the DN string representing users can be very different for each user: their affiliations and roles. I had to find ways to interpret sub-parts of that string to figure out what privileges to attach to them.
My snippet's purpose is to get the capability to get a subset of that LDAP DN string, assuming that the first index is more precise than the last, but concatenated would give the full context.
While I was trying to find already made function that explodes that string into manageable arrays in PHP, I realized that there was none. I then decided to contribute it as a comment on the PHP.net website.
The basics
As a reminder, an LDAP DN string looks like the following: CN=username,OU=UNITNAME,OU=Region,OU=Country,DC=subdomain,DC=domain,DC=com
In such a string, we get basically everything a user may inherit from:
- Group assignation
- Organization domain (either DNS or Microsoft's idea of a "domain" (aka. "Active Directory"))
- etc.
The main idea is to deal with different logic based on changes or assignment. The DN has all we need.
Reading the data from it can be done using successive explode
on the =
and the ,
. But How about to use the implicit hierarchy the string conveys.
My objective was to read the previously shown DN string, and parse a manageable array that would look like this:`
array(
'CN' => array("username"),
'OU' => array("UNITNAME","Region","Country"),
'DC' => array ("subdomain","domain","com")
);
How to use
Assuming we want to work with changes in the OU field. We could do as:find($userId); // $user instanceof User
// This is coming from the LDAP
$dn= 'CN=username,OU=UNITNAME,OU=Region,OU=Country,DC=subdomain,DC=domain,DC=com';
$wrapper = parseLdapDn($dn);
// We are working with "UNITNAME" but there can be other ones
switch($wrapper['OU'][0]){
case 'UNITNAME':
// Specific logic or authorization setters
$user->addRole('ROLE_UNITNAME');
break;
default:
// Default behavior, in case we did not grasp
break;
}
// And so on...
In this example I added a role using Symfony2's method on a Doctrine2 provided object. But you may see other use cases.
Snippet
I also published it as a comment on the PHP.net website.