1
0
Fork 0
mirror of https://github.com/YunoHost-Apps/kanboard_ynh.git synced 2024-09-03 19:36:17 +02:00
kanboard_ynh/sources/doc/plugin-mail-transports.markdown
2015-10-26 14:58:06 +01:00

1.4 KiB

Plugin: Add Mail Transport

By default Kanboard supports 3 standards mail transports:

  • Mail (PHP mail function)
  • Smtp
  • Sendmail command

With the plugin API you can add a driver for any email provider. By example, your plugin can add a mail transport for a provider that uses an HTTP API.

Implementation

Your plugin must implements the interface Kanboard\Core\Mail\ClientInterface and extends from Kanboard\Core\Base.

The only method you need to implement is sendEmail():

interface ClientInterface
{
    /**
     * Send a HTML email
     *
     * @access public
     * @param  string  $email
     * @param  string  $name
     * @param  string  $subject
     * @param  string  $html
     * @param  string  $author
     */
    public function sendEmail($email, $name, $subject, $html, $author);
}

To register your new mail transport, use the method setTransport($transport, $class) from the class Kanboard\Core\Mail\Client:

$this->emailClient->setTransport('myprovider', '\Kanboard\Plugin\MyProvider\MyEmailHandler');

The second argument contains the absolute namespace of your concrete class.

Examples of mail transport plugins