A Laravel based package for changing Mail
transport and it's credentials from application layer in runtime. Simple and easy abstraction Mailable
layer will be provided with this package. Currently this package support only SMTP.
You can start it from composer. Go to your terminal and run this command from your project root directory.
composer require hashemi/laravel-too-mailable
- If you're using Laravel, then Laravel will automatically discover the package. In case it doesn't discover the package then add the following provider in your
config/app.php
's providers array.
Hashemi\TooMailable\TooMailableServiceProvider::class
This package will be provide TooMailable
abstract class and you need to use your mail class. This abstract class has two abstract method.
-
transport(): string|EsmtpTransport
This method will be return package supported transport by string or custom transport class which will beEsmtpTransport
inherited. -
credentials(): array
This method will be return necessary credentials of current transport.
Example:
use Hashemi\TooMailable\TooMailable;
class SendVerificatioMail extends TooMailable
{
//...
public function transport()
{
return 'amazon';
}
public function credentials()
{
return [
'username' => 'my-user',
'password' => 'password-123',
'region' => 'us-east-2'
];
}
}
This package is also contain a config where each built-in transport class is configured. If anyone needs to override that transport they can easily do it by publish config from vendor. Config file will be stored in config/too-mailable.php
on your application.
Example:
use Hashemi\TooMailable\Transports\{
Amazon, Google, Mailchimp, Mailgun, Mailjet,
OhMySmtp, Postmark, Sendgrid, SendInBlue
};
return [
'transports' => [
'amazon' => Amazon::class,
'google' => Google::class,
'mailchimp' => Mailchimp::class,
'mailgun' => Mailgun::class,
'mailjet' => Mailjet::class,
'postmark' => Postmark::class,
'sendgrid' => Sendgrid::class,
'sendinblue' => SendInBlue::class,
'oh-my-smtp' => OhMySmtp::class,
],
];
So if you want to change exists transport then,
return [
'transports' => [
//...
'amazon' => MyNewAmazonTransport::class,
],
];
Or, if you want to add new transport then,
return [
'transports' => [
//...
'converkit' => MyNewConvertKit::class
],
];
But MyNewConvertKit
class should be implements Hashemi\TooMailable\Interfaces\TransportInterface
interface. Credentials will be passed through __construct
function of MyNewConvertKit
class.
Pull requests are welcome. For any changes, please open an issue first to discuss what you would like to change.