2015-09-08 05:15:39 +08:00
< ? php
class LdapContactsSuggestionsPlugin extends \RainLoop\Plugins\AbstractPlugin
{
2021-02-10 16:50:20 +08:00
const
NAME = 'Contacts suggestions (LDAP)' ,
VERSION = '2.0' ,
CATEGORY = 'Security' ,
DESCRIPTION = 'Plugin that adds functionality to get contacts from LDAP on compose page.' ;
2020-08-31 00:04:54 +08:00
public function Init () : void
2015-09-08 05:15:39 +08:00
{
$this -> addHook ( 'main.fabrica' , 'MainFabrica' );
}
/**
* @ return string
*/
2020-08-31 00:04:54 +08:00
public function Supported () : string
2015-09-08 05:15:39 +08:00
{
if ( ! \function_exists ( 'ldap_connect' ))
{
2017-07-23 05:29:33 +08:00
return 'The LDAP PHP extension must be installed to use this plugin' ;
2015-09-08 05:15:39 +08:00
}
return '' ;
}
/**
* @ param string $sName
* @ param mixed $mResult
*/
public function MainFabrica ( $sName , & $mResult )
{
switch ( $sName )
{
case 'suggestions' :
if ( ! \is_array ( $mResult ))
{
$mResult = array ();
}
$sHostName = \trim ( $this -> Config () -> Get ( 'plugin' , 'hostname' , '' ));
$iHostPort = ( int ) $this -> Config () -> Get ( 'plugin' , 'port' , 389 );
2021-08-22 16:48:33 +08:00
$bUseStartTLS = ( bool ) $this -> Config () -> Get ( 'plugin' , 'use_start_tls' , True );
2015-09-08 05:15:39 +08:00
$sAccessDn = \trim ( $this -> Config () -> Get ( 'plugin' , 'access_dn' , '' ));
$sAccessPassword = \trim ( $this -> Config () -> Get ( 'plugin' , 'access_password' , '' ));
$sUsersDn = \trim ( $this -> Config () -> Get ( 'plugin' , 'users_dn_format' , '' ));
$sObjectClass = \trim ( $this -> Config () -> Get ( 'plugin' , 'object_class' , '' ));
2021-08-22 17:48:21 +08:00
$sUidField = \trim ( $this -> Config () -> Get ( 'plugin' , 'uid_field' , '' ));
2015-09-08 05:15:39 +08:00
$sNameField = \trim ( $this -> Config () -> Get ( 'plugin' , 'name_field' , '' ));
$sEmailField = \trim ( $this -> Config () -> Get ( 'plugin' , 'mail_field' , '' ));
2021-08-22 06:42:38 +08:00
$sAllowedEmails = \trim ( $this -> Config () -> Get ( 'plugin' , 'allowed_emails' , '' ));
2015-09-08 05:15:39 +08:00
2018-11-30 20:54:28 +08:00
if ( 0 < \strlen ( $sUsersDn ) && 0 < \strlen ( $sObjectClass ) && 0 < \strlen ( $sEmailField ))
2015-09-08 05:15:39 +08:00
{
include_once __DIR__ . '/LdapContactsSuggestions.php' ;
$oProvider = new LdapContactsSuggestions ();
2021-08-22 17:48:21 +08:00
$oProvider -> SetConfig ( $sHostName , $iHostPort , $bUseStartTLS , $sAccessDn , $sAccessPassword , $sUsersDn , $sObjectClass , $sUidField , $sNameField , $sEmailField , $sAllowedEmails );
2015-09-08 05:15:39 +08:00
$mResult [] = $oProvider ;
}
break ;
}
}
/**
* @ return array
*/
2020-08-31 00:04:54 +08:00
protected function configMapping () : array
2015-09-08 05:15:39 +08:00
{
return array (
\RainLoop\Plugins\Property :: NewInstance ( 'hostname' ) -> SetLabel ( 'LDAP hostname' )
-> SetDefaultValue ( '127.0.0.1' ),
\RainLoop\Plugins\Property :: NewInstance ( 'port' ) -> SetLabel ( 'LDAP port' )
-> SetType ( \RainLoop\Enumerations\PluginPropertyType :: INT )
-> SetDefaultValue ( 389 ),
2021-08-22 16:48:33 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'use_start_tls' ) -> SetLabel ( 'Use StartTLS' )
-> SetType ( \RainLoop\Enumerations\PluginPropertyType :: BOOL )
-> SetDefaultValue ( True ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'access_dn' ) -> SetLabel ( 'Bind DN' )
-> SetDescription ( 'DN to bind (login) with. If left blank, anonymous bind will be tried and the password will be ignored' )
2015-09-08 05:15:39 +08:00
-> SetDefaultValue ( '' ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'access_password' ) -> SetLabel ( 'Bind password' )
2015-09-08 05:15:39 +08:00
-> SetType ( \RainLoop\Enumerations\PluginPropertyType :: PASSWORD )
-> SetDefaultValue ( '' ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'users_dn_format' ) -> SetLabel ( 'Search base DN' )
-> SetDescription ( 'DN to use as the search base. Supported tokens: {domain}, {domain:dc}, {email}, {email:user}, {email:domain}, {login}, {imap:login}, {imap:host}, {imap:port}' )
2015-09-08 05:15:39 +08:00
-> SetDefaultValue ( 'ou=People,dc=domain,dc=com' ),
\RainLoop\Plugins\Property :: NewInstance ( 'object_class' ) -> SetLabel ( 'objectClass value' )
-> SetDefaultValue ( 'inetOrgPerson' ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'uid_field' ) -> SetLabel ( 'uid attributes' )
-> SetDescription ( 'LDAP attributes for userids, comma separated list in order of preference' )
2018-06-07 06:02:43 +08:00
-> SetDefaultValue ( 'uid' ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'name_field' ) -> SetLabel ( 'Name attributes' )
-> SetDescription ( 'LDAP attributes for user names, comma separated list in order of preference' )
2021-08-22 17:03:56 +08:00
-> SetDefaultValue ( 'givenName' ),
2021-08-22 17:48:21 +08:00
\RainLoop\Plugins\Property :: NewInstance ( 'mail_field' ) -> SetLabel ( 'Mail attributes' )
-> SetDescription ( 'LDAP attributes for user email addresses, comma separated list in order of preference' )
2015-09-08 05:15:39 +08:00
-> SetDefaultValue ( 'mail' ),
\RainLoop\Plugins\Property :: NewInstance ( 'allowed_emails' ) -> SetLabel ( 'Allowed emails' )
2021-08-22 17:48:21 +08:00
-> SetDescription ( 'Email addresses of users which should be allowed to do LDAP lookups, space as delimiter, wildcard supported. Example: user1@domain1.net user2@domain1.net *@domain2.net' )
2015-09-08 05:15:39 +08:00
-> SetDefaultValue ( '*' )
);
}
2018-11-30 20:54:28 +08:00
}