LDAP plugin for CakePHP 3.x
Installs: 7 322
Dependents: 1
Suggesters: 0
Security: 0
Stars: 13
Watchers: 7
Forks: 4
Open Issues: 0
Type:cakephp-plugin
Requires
- php: >=5.5.9
- cakephp/cakephp: >=3.2.0
Requires (Dev)
- cakephp/cakephp-codesniffer: dev-master
- phpunit/phpunit: *
README
LDAP Authenticate Plugin for CakePHP 3.x and AuthComponent.
Requirements
- CakePHP 3.0
- php5-ldap module or
- php7.0-ldap module
Installation
You can install this plugin into your CakePHP application using composer.
The recommended way to install composer packages is:
composer require queencitycodefactory/ldap
You can also add "queencitycodefactory/ldap" : "dev-master"
to require
section in your application's composer.json
.
Usage
Include the CakeSoap library files:
use Ldap\Auth\LdapAuthenticate;
Configuration:
Setup the authentication class settings
AppController Setup:
public function initialize() { parent::initialize(); $this->loadComponent('Flash'); $this->loadComponent('Auth', [ 'loginAction' => [ 'controller' => 'Users', 'action' => 'login' ], 'authError' => 'Insufficient privileges to view requested resources. Please login to continue!', 'authenticate' => [ 'Ldap.Ldap' => Configure::read('Ldap') + [ 'fields' => [ 'username' => 'username', 'password' => 'password' ], 'flash' => [ 'key' => 'ldap', 'element' => 'Flash/error', ] ] ] ]); }
Setting the Base LDAP settings
config/app.php:
/** * LDAP Configuration. * * Contains an array of settings to use for the LDAP configuration. * * ## Options * * - `domain` - The domain name to match against or auto complete so user isn't * required to enter full email address * - `host` - The domain controller hostname. This can be a closure or a string. * The closure allows you to modify the rules in the configuration without the * need to modify the LDAP plugin. One host (string) should be returned when * using closure. * - `baseDN` - The base DN for directory - Closure must be used here, the plugin * is expecting a closure object to be set. * - `bindDN` - The bind DN for directory - Closure must be used here, the plugin * is expecting a closure object to be set. * - `search` - The attribute to search against. Usually 'UserPrincipalName' * - `port` - The port to use. Default is 389 and is not required. * - `errors` - Array of errors where key is the error and the value is the error * message. Set in session to Flash.ldap for flashing * - `logErrors` - Should the errors be logged * - `options` - Array of options to set using ldap_set_option * * @link http://php.net/manual/en/function.ldap-search.php - for more info on ldap search */ 'Ldap' => [ 'domain' => 'example.com', 'alternateDomains' => [ 'anotherexample.com', 'example2.com', ], 'host' => function() { $hosts = ['192.168.1.13', '127.0.0.1']; shuffle($hosts); return $hosts[0]; }, //'host' => '127.0.0.1', 'port' => 389, 'search' => function($username) { return '(UserPrincipalName=' . $username . ')'; }, 'searchAttributes' => ['*', 'memberof'], 'baseDN' => function($username, $domain) { if (strpos($username, $domain) !== false) { $baseDN = 'OU=example,DC=domain,DC=local'; } else { $baseDN = 'CN=Users,DC=domain,DC=local'; } return $baseDN; }, 'bindDN' => function($username, $domain) { $bindDN = "CN=".$username.", OU=example"; return $bindDN; }, 'errors' => [ 'data 773' => 'Some error for Flash', 'data 532' => 'Some error for Flash', ], 'logErrors' => true, 'options' => [ LDAP_OPT_NETWORK_TIMEOUT => 5, LDAP_OPT_PROTOCOL_VERSION => 3, ] ]