Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/eseperio/yii2-email-accounts-manager
Use and manage different email accounts under the same project.
https://github.com/eseperio/yii2-email-accounts-manager
Last synced: 2 months ago
JSON representation
Use and manage different email accounts under the same project.
- Host: GitHub
- URL: https://github.com/eseperio/yii2-email-accounts-manager
- Owner: Eseperio
- License: mit
- Created: 2023-01-31T10:03:48.000Z (almost 2 years ago)
- Default Branch: main
- Last Pushed: 2024-06-02T07:30:51.000Z (8 months ago)
- Last Synced: 2024-11-16T11:37:12.328Z (2 months ago)
- Language: PHP
- Size: 36.1 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# yii2-email-accounts-manager
Use and manage different email accounts under the same project.
Features methods to live test the configuration and ensure it is correct.### Features
- Manage multiple email accounts
- SMTP + IMAP configuration
- SMTP + IMAP live test
- Autodiscover SMTP and IMAP settings (when available)## Installation
The preferred way to install this extension is through [composer](http://getcomposer.org/download/).
`composer require eseperio/yii2-email-accounts-manager`
`ext-simplexml` is required for autodiscover feature, but has not been required within composer.json so you can use the
library without autodiscoverAdd the migration path to your console config:
```php
return [
'controllerMap' => [
'migrate' => [
'class' => 'yii\console\controllers\MigrateController',
'migrationPath' => [
'@vendor/eseperio/yii2-email-accounts-manager/src/migrations',
],
],
],
];
```Add the module to your app modules configuration
```php
return [
'modules' => [
'email-manager' =>[
'class'=> \eseperio\emailManager\EmailManagerModule::class,
'showImapSettings' => false, // change if you need imap settings to be shown,
// 'mailer'=> 'mailer',
// 'transport => ['class' => 'Swift_SmtpTransport'],
],
]
]
```## Usage
Important: This module will replace the current transport for the mailer defined and it does not restore to previous value.
If you want to prevent this use a different mailer component for this module.This module includes methods for checking whether the email account is valid and for sending emails using the given
configuration.The EmailAccount model includes useful methods, like `getTransport()` and `setAsMainTransport()`.
`getTransport()` returns the transport configuration based on configuration defined within module and the account
itself.`setAsMainTransport()` will set the transport configuration for the mailer component defined in the module configuration
and will return the mailer instance.
`compose($view='',$params=[])` will return a new message instance preconfigured with the transport configuration for the
account and also `setFrom` defined with the account address.### Sending an email from a custom account
```php
use eseperio\emailmanager\models\EmailAccount;$account = EmailAccount::findOne(1)->compose('test', ['message' => 'Hello world!'])->setTo('[email protected]')->send();
```