2020-08-20 22:33:13 +10:00
|
|
|
<?php
|
|
|
|
|
|
|
|
return [
|
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| Default LDAP Connection Name
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Here you may specify which of the LDAP connections below you wish
|
|
|
|
| to use as your default connection for all LDAP operations. Of
|
|
|
|
| course you may add as many connections you'd like below.
|
|
|
|
|
|
|
|
|
*/
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
'default' => env('LDAP_CONNECTION', 'default'),
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| LDAP Connections
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Below you may configure each LDAP connection your application requires
|
|
|
|
| access to. Be sure to include a valid base DN - otherwise you may
|
|
|
|
| not receive any results when performing LDAP search operations.
|
|
|
|
|
|
|
|
|
*/
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
'connections' => [
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
'default' => [
|
|
|
|
'hosts' => [env('LDAP_HOST', '127.0.0.1')],
|
|
|
|
'username' => env('LDAP_USERNAME', 'cn=user,dc=local,dc=com'),
|
|
|
|
'password' => env('LDAP_PASSWORD', 'secret'),
|
|
|
|
'port' => env('LDAP_PORT', 389),
|
|
|
|
'base_dn' => env('LDAP_BASE_DN', 'dc=local,dc=com'),
|
|
|
|
'timeout' => env('LDAP_TIMEOUT', 5),
|
|
|
|
'use_ssl' => env('LDAP_SSL', false),
|
|
|
|
'use_tls' => env('LDAP_TLS', false),
|
|
|
|
'name' => env('LDAP_NAME','LDAP Server'),
|
|
|
|
],
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
],
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| LDAP Logging
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| When LDAP logging is enabled, all LDAP search and authentication
|
|
|
|
| operations are logged using the default application logging
|
|
|
|
| driver. This can assist in debugging issues and more.
|
|
|
|
|
|
|
|
|
*/
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
'logging' => env('LDAP_LOGGING', true),
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| LDAP Cache
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| LDAP caching enables the ability of caching search results using the
|
|
|
|
| query builder. This is great for running expensive operations that
|
|
|
|
| may take many seconds to complete, such as a pagination request.
|
|
|
|
|
|
|
|
|
*/
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2023-03-02 10:17:15 +11:00
|
|
|
'cache' => [
|
|
|
|
'enabled' => env('LDAP_CACHE', false),
|
|
|
|
'driver' => env('CACHE_DRIVER', 'file'),
|
|
|
|
'time' => env('LDAP_CACHE_TIME',5*60), // Seconds
|
|
|
|
],
|
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| Support for attrs display order
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Use this array if you want to have your attributes displayed in a specific
|
|
|
|
| order. Case is not important.
|
|
|
|
|
|
|
|
|
| For example, "sn" will be displayed right after "givenName". All the other
|
|
|
|
| attributes that are not specified in this array will be displayed after in
|
|
|
|
| alphabetical order.
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
|
|
|
'attr_display_order' => [],
|
|
|
|
/*
|
|
|
|
'attr_display_order' => [
|
|
|
|
'givenName',
|
|
|
|
'sn',
|
|
|
|
'cn',
|
|
|
|
'displayName',
|
|
|
|
'uid',
|
|
|
|
'uidNumber',
|
|
|
|
'gidNumber',
|
|
|
|
'homeDirectory',
|
|
|
|
'mail',
|
|
|
|
'userPassword'
|
|
|
|
],
|
|
|
|
*/
|
2020-08-20 22:33:13 +10:00
|
|
|
|
2024-01-08 12:54:58 +11:00
|
|
|
/*
|
|
|
|
* If 'login,attr' is used above such that phpLDAPadmin will search for your DN
|
|
|
|
* at login, you may restrict the search to a specific objectClasses. EG, set this
|
|
|
|
* to array('posixAccount') or array('inetOrgPerson',..), depending upon your
|
|
|
|
* setup.
|
|
|
|
*/
|
|
|
|
'login' => [
|
2024-01-08 14:54:00 +11:00
|
|
|
'attr' => [env('LDAP_LOGIN_ATTR','uid') => env('LDAP_LOGIN_ATTR_DESC','User ID')], // Attribute used to find user for login
|
2024-01-08 12:54:58 +11:00
|
|
|
'objectclass' => explode(',',env('LDAP_LOGIN_OBJECTCLASS', 'posixAccount')), // Objectclass that users must contain to login
|
|
|
|
],
|
|
|
|
|
2023-03-02 18:21:53 +11:00
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| Custom Date Format
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Configuration to determine how date fields will be displayed.
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
'datetime_format' => 'Y-m-d H:i:s',
|
2023-04-12 23:18:26 +10:00
|
|
|
|
|
|
|
/*
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
| Validation
|
|
|
|
|--------------------------------------------------------------------------
|
|
|
|
|
|
|
|
|
| Default validation used for data input.
|
|
|
|
|
|
|
|
|
*/
|
|
|
|
'validation' => [
|
|
|
|
'objectclass' => ['objectclass'=>['array','min:1']],
|
|
|
|
'gidnumber' => ['gidnumber'=>['sometimes','array','max:1'],'gidnumber.*'=>['integer','max:65535']],
|
2023-09-02 20:50:54 +10:00
|
|
|
'mail' => ['mail'=>['sometimes','array','min:1'],'mail.*'=>['nullable','email']],
|
2023-04-12 23:18:26 +10:00
|
|
|
'uidnumber' => ['uidnumber'=>['sometimes','array','max:1'],'uidnumber.*'=>['integer','max:65535']],
|
|
|
|
],
|
2020-08-20 22:33:13 +10:00
|
|
|
];
|