2015-02-03 19:08:07 +08:00
|
|
|
<?php
|
|
|
|
|
|
|
|
class LdapChangePasswordPlugin extends \RainLoop\Plugins\AbstractPlugin
|
|
|
|
{
|
|
|
|
public function Init()
|
|
|
|
{
|
|
|
|
$this->addHook('main.fabrica', 'MainFabrica');
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function Supported()
|
|
|
|
{
|
|
|
|
if (!\function_exists('ldap_connect'))
|
|
|
|
{
|
|
|
|
return 'The LDAP PHP exention must be installed to use this plugin';
|
|
|
|
}
|
|
|
|
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param string $sName
|
|
|
|
* @param mixed $oProvider
|
|
|
|
*/
|
|
|
|
public function MainFabrica($sName, &$oProvider)
|
|
|
|
{
|
|
|
|
switch ($sName)
|
|
|
|
{
|
|
|
|
case 'change-password':
|
|
|
|
|
|
|
|
$sHostName = \trim($this->Config()->Get('plugin', 'hostname', ''));
|
2015-09-08 05:15:39 +08:00
|
|
|
$iHostPort = (int) $this->Config()->Get('plugin', 'port', 389);
|
2015-02-03 19:08:07 +08:00
|
|
|
$sUserDnFormat = \trim($this->Config()->Get('plugin', 'user_dn_format', ''));
|
|
|
|
$sPasswordField = \trim($this->Config()->Get('plugin', 'password_field', ''));
|
|
|
|
$sPasswordEncType = \trim($this->Config()->Get('plugin', 'password_enc_type', ''));
|
|
|
|
|
2015-09-08 05:15:39 +08:00
|
|
|
if (!empty($sHostName) && 0 < $iHostPort && !empty($sUserDnFormat) && !empty($sPasswordField) && !empty($sPasswordEncType))
|
2015-02-03 19:08:07 +08:00
|
|
|
{
|
|
|
|
include_once __DIR__.'/ChangePasswordLdapDriver.php';
|
|
|
|
|
|
|
|
$oProvider = new \ChangePasswordLdapDriver();
|
|
|
|
|
|
|
|
$oProvider
|
2015-09-08 05:15:39 +08:00
|
|
|
->SetConfig($sHostName, $iHostPort, $sUserDnFormat, $sPasswordField, $sPasswordEncType)
|
2015-02-03 19:08:07 +08:00
|
|
|
->SetAllowedEmails(\strtolower(\trim($this->Config()->Get('plugin', 'allowed_emails', ''))))
|
|
|
|
->SetLogger($this->Manager()->Actions()->Logger())
|
|
|
|
;
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function configMapping()
|
|
|
|
{
|
|
|
|
return array(
|
|
|
|
\RainLoop\Plugins\Property::NewInstance('hostname')->SetLabel('LDAP hostname')
|
|
|
|
->SetDefaultValue('127.0.0.1'),
|
2015-09-08 05:15:39 +08:00
|
|
|
\RainLoop\Plugins\Property::NewInstance('port')->SetLabel('LDAP port')
|
|
|
|
->SetType(\RainLoop\Enumerations\PluginPropertyType::INT)
|
|
|
|
->SetDefaultValue(389),
|
2015-02-03 19:08:07 +08:00
|
|
|
\RainLoop\Plugins\Property::NewInstance('user_dn_format')->SetLabel('User DN format')
|
2016-02-05 19:40:14 +08:00
|
|
|
->SetDescription('LDAP user dn format. Supported tokens: {email}, {email:user}, {email:domain}, {login}, {domain}, {domain:dc}, {imap:login}, {imap:host}, {imap:port}')
|
2015-02-03 19:08:07 +08:00
|
|
|
->SetDefaultValue('uid={imap:login},ou=Users,{domain:dc}'),
|
|
|
|
\RainLoop\Plugins\Property::NewInstance('password_field')->SetLabel('Password field')
|
|
|
|
->SetDefaultValue('userPassword'),
|
|
|
|
\RainLoop\Plugins\Property::NewInstance('password_enc_type')->SetLabel('Encryption type')
|
|
|
|
->SetType(\RainLoop\Enumerations\PluginPropertyType::SELECTION)
|
2015-09-08 05:15:39 +08:00
|
|
|
->SetDefaultValue(array('SHA', 'SSHA', 'MD5', 'Crypt', 'Clear')),
|
2015-02-03 19:08:07 +08:00
|
|
|
\RainLoop\Plugins\Property::NewInstance('allowed_emails')->SetLabel('Allowed emails')
|
|
|
|
->SetDescription('Allowed emails, space as delimiter, wildcard supported. Example: user1@domain1.net user2@domain1.net *@domain2.net')
|
|
|
|
->SetDefaultValue('*')
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|