mirror of
				https://github.com/Icinga/icingaweb2.git
				synced 2025-11-04 13:14:41 +01:00 
			
		
		
		
	
		
			
				
	
	
		
			66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
			
		
		
	
	
			66 lines
		
	
	
		
			1.5 KiB
		
	
	
	
		
			PHP
		
	
	
	
	
	
<?php
 | 
						|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
 | 
						|
 | 
						|
namespace Icinga\Repository;
 | 
						|
 | 
						|
use Icinga\Protocol\Ldap\LdapConnection;
 | 
						|
 | 
						|
/**
 | 
						|
 * Abstract base class for concrete LDAP repository implementations
 | 
						|
 *
 | 
						|
 * Additionally provided features:
 | 
						|
 * <ul>
 | 
						|
 *  <li>Attribute name normalization</li>
 | 
						|
 * </ul>
 | 
						|
 */
 | 
						|
abstract class LdapRepository extends Repository
 | 
						|
{
 | 
						|
    /**
 | 
						|
     * The datasource being used
 | 
						|
     *
 | 
						|
     * @var LdapConnection
 | 
						|
     */
 | 
						|
    protected $ds;
 | 
						|
 | 
						|
    /**
 | 
						|
     * Normed attribute names based on known LDAP environments
 | 
						|
     *
 | 
						|
     * @var array
 | 
						|
     */
 | 
						|
    protected $normedAttributes = array(
 | 
						|
        'uid'               => 'uid',
 | 
						|
        'gid'               => 'gid',
 | 
						|
        'user'              => 'user',
 | 
						|
        'group'             => 'group',
 | 
						|
        'member'            => 'member',
 | 
						|
        'inetorgperson'     => 'inetOrgPerson',
 | 
						|
        'samaccountname'    => 'sAMAccountName'
 | 
						|
    );
 | 
						|
 | 
						|
    /**
 | 
						|
     * Create a new LDAP repository object
 | 
						|
     *
 | 
						|
     * @param   LdapConnection  $ds     The data source to use
 | 
						|
     */
 | 
						|
    public function __construct(LdapConnection $ds)
 | 
						|
    {
 | 
						|
        parent::__construct($ds);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * 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;
 | 
						|
    }
 | 
						|
} |