2022-11-16 01:29:01 +08:00
< ? php
use RainLoop\Enumerations\Capa ;
use RainLoop\Enumerations\PluginPropertyType ;
use RainLoop\Plugins\AbstractPlugin ;
use RainLoop\Plugins\Property ;
use RainLoop\Model\Account ;
use RainLoop\Actions ;
class LdapMailAccountsPlugin extends AbstractPlugin
{
const
NAME = 'LDAP Mail Accounts' ,
VERSION = '1.0' ,
AUTHOR = 'cm-schl' ,
URL = 'https://github.com/cm-sch' ,
2022-11-25 18:41:31 +08:00
RELEASE = '2022-11-25' ,
2022-11-16 01:29:01 +08:00
REQUIRED = '2.20.0' ,
CATEGORY = 'Accounts' ,
2022-11-25 18:41:31 +08:00
DESCRIPTION = 'Add additional mail accounts the SnappyMail user has access to by a LDAP query. Basing on the work of FWest98 (https://github.com/FWest98).' ;
2022-11-16 01:29:01 +08:00
public function __construct ()
{
include_once __DIR__ . '/LdapMailAccounts.php' ;
include_once __DIR__ . '/LdapConfig.php' ;
include_once __DIR__ . '/LdapException.php' ;
parent :: __construct ();
}
public function Init () : void
{
$this -> addHook ( " login.success " , 'AddLdapMailAccounts' );
}
2022-11-25 17:42:14 +08:00
// Function gets called by RainLoop/Actions/User.php
2022-11-16 01:29:01 +08:00
public function AddLdapMailAccounts ( Account $oAccount )
{
// Set up config
$config = LdapConfig :: MakeConfig ( $this -> Config ());
$oldapMailAccounts = new LdapMailAccounts ( $config , $this -> Manager () -> Actions () -> Logger ());
$oldapMailAccounts -> AddLdapMailAccounts ( $oAccount );
}
protected function configMapping () : array
{
return [
Property :: NewInstance ( LdapConfig :: CONFIG_SERVER )
-> SetLabel ( " LDAP Server URL " )
-> SetPlaceholder ( " ldap://server:port " )
-> SetType ( PluginPropertyType :: STRING ),
Property :: NewInstance ( LdapConfig :: CONFIG_PROTOCOL_VERSION )
-> SetLabel ( " LDAP Protocol Version " )
-> SetType ( PluginPropertyType :: SELECTION )
-> SetDefaultValue ([ 2 , 3 ]),
Property :: NewInstance ( LdapConfig :: CONFIG_BIND_USER )
2022-11-25 18:41:31 +08:00
-> SetLabel ( " LDAP Username " )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " The user to use for binding to the LDAP server. Should be a DN or RDN. Leave empty for anonymous bind. " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING ),
Property :: NewInstance ( LdapConfig :: CONFIG_BIND_PASSWORD )
2022-11-25 18:41:31 +08:00
-> SetLabel ( " LDAP Password " )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " Leave empty for anonymous bind. " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: PASSWORD ),
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_OBJECTCLASS )
-> SetLabel ( " Object class " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 18:41:31 +08:00
-> SetDescription ( " The object class to use when searching for additional mail accounts of the logged in SnappyMail user " )
2022-11-16 01:29:01 +08:00
-> SetDefaultValue ( " user " ),
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_BASE )
2022-11-25 18:41:31 +08:00
-> SetLabel ( " Base DN " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 18:41:31 +08:00
-> SetDescription ( " The base DN to search in for additional mail accounts of the logged in SnappyMail user " ),
2022-11-16 01:29:01 +08:00
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_FIELD_SEARCH )
-> SetLabel ( " Search field " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 18:41:31 +08:00
-> SetDescription ( " The name of the ldap attribute that has to contain the here defined 'LDAP search string'. " )
2022-11-25 17:42:14 +08:00
-> SetDefaultValue ( " member " ),
2022-11-16 01:29:01 +08:00
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_SEARCH_STRING )
-> SetLabel ( " LDAP search string " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " The search string used to find ldap objects of mail accounts the user has access to.
\nPossible placeholers : \n #USERNAME# - replaced with the username of the actual SnappyMail user
2022-11-25 18:41:31 +08:00
\n #BASE_DN# - replaced with the value inside the field 'User base DN'.")
-> SetDefaultValue ( " uid=#USERNAME# " ),
2022-11-16 01:29:01 +08:00
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_FIELD_USERNAME )
-> SetLabel ( " Username field of additional account " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " The field containing the username of the found additional mail account.
2022-11-25 18:41:31 +08:00
\nThis username gets used by SnappyMail to login to the additional mail account .
\nIf this field contains an email address , only the local - part before the @ is used . " )
2022-11-25 17:42:14 +08:00
-> SetDefaultValue ( " uid " ),
2022-11-16 01:29:01 +08:00
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_FIELD_MAIL_DOMAIN )
-> SetLabel ( " Domain name field of additional account " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " The field containing the domain name of the found additional mail account.
2022-11-25 18:41:31 +08:00
\nThis domain gets looked up by SnappyMail to choose the right connection parameters at logging in to the additional mail account .
\nIf this field contains an email address , only the domain - part after the @ is used . " )
2022-11-25 17:42:14 +08:00
-> SetDefaultValue ( " mail " ),
2022-11-16 01:29:01 +08:00
2022-11-25 17:42:14 +08:00
Property :: NewInstance ( LdapConfig :: CONFIG_FIELD_NAME )
-> SetLabel ( " Additional account name field " )
2022-11-16 01:29:01 +08:00
-> SetType ( PluginPropertyType :: STRING )
2022-11-25 17:42:14 +08:00
-> SetDescription ( " The field containing the default sender name of the found additional mail account. " )
-> SetDefaultValue ( " displayName " )
2022-11-16 01:29:01 +08:00
];
}
}