finesse / swiftmailer-defaults-plugin
A plugin for SwiftMailer and Symfony that sets default properties for email Messages (from, sender, reply to and so on)
Fund package maintenance!
Finesse
Patreon
money.yandex.ru/to/410012160248971
Installs: 97 133
Dependents: 0
Suggesters: 0
Security: 0
Stars: 7
Watchers: 2
Forks: 5
Open Issues: 0
Requires
- php: >=5.6
- swiftmailer/swiftmailer: >=4.0 <7.0
Requires (Dev)
- mockery/mockery: ^1.0
- phpunit/phpunit: >=5.4.3 <8.0
README
This plugin adds a possibility to set default properties for the sent Messages (default from address, reply to, subject and so on).
// Set up a Mailer $transport = new Swift_SmtpTransport(); $mailer = new Swift_Mailer($transport); $mailer->registerPlugin(new Finesse\SwiftMailerDefaultsPlugin\SwiftMailerDefaultsPlugin([ 'from' => ['johndoe@example.com' => 'John Doe'], 'replyTo' => 'jackdoe@example.com' ])); // Use the Mailer many times $mailer->send( (new Swift_Message()) ->setTo('bjohnson@example.com', 'Bill Johnson') ->setSubject('Hi') ->setBody('This is awesome, I don\'t need to specify the from address!') );
How to install
Using composer
Run in a console
composer require finesse/swiftmailer-defaults-plugin
How to use
Create and register a plugin instance when you setup a Swift_Mailer
instance.
use Finesse\SwiftMailerDefaultsPlugin\SwiftMailerDefaultsPlugin; use Swift_Mailer; use Swift_SmtpTransport; // Setup an emails sending transport $transport = new Swift_SmtpTransport(); // Create a plugin instance $defaultsPlugin = new SwiftMailerDefaultsPlugin(/* default properties */); // Assemble them with a mailer $mailer = new Swift_Mailer($transport); $mailer->registerPlugin($defaultsPlugin);
For Symfony 4 you can register the plugin this way:
services: # Swift Mailer plugins Finesse\SwiftMailerDefaultsPlugin\SwiftMailerDefaultsPlugin: tags: - { name: swiftmailer.default.plugin } arguments: $defaults: from: johndoe@example.com: John Doe replyTo: jackdoe@example.com
Symfony 3 example
services: # Swift Mailer plugins app.swiftmailer.defaults_plugin: class: Finesse\SwiftMailerDefaultsPlugin\SwiftMailerDefaultsPlugin tags: - { name: swiftmailer.default.plugin } arguments: $defaults: from: johndoe@example.com: John Doe replyTo: jackdoe@example.com
When you need to send an email, just send it without specifying the parameters you set to the plugin instance.
use Swift_Message; $message = new Swift_Message(); $mailer->send($message);
If you specify, the specified parameters will override the default properties.
__constructor
You can pass to the constructor all the properties that you can set to a Swift_Mime_SimpleMessage
instance using the
set...
methods. For example:
$defaultsPlugin = new SwiftMailerDefaultsPlugin([ 'from' => 'johndoe@example.com', 'subject' => 'Notification' ]);
The array keys are the names of the properties that are the Swift_Mime_SimpleMessage
methods names without the set
word and with the lowercase first letter. For example, the body
property corresponds to the setBody
method,
readReceiptTo
to setReadReceiptTo
and so on.
The array values are the first and the only arguments for the corresponding methods. Properties with the null
value
are ignored.
setDefault
Sets a default value for a property.
$defaultsPlugin->setDefault('sender', 'chasy@example.com', 'Chasy');
The first argument is the property name (see __constructor for reference). The rest arguments are the corresponding method arguments.
unsetDefault
Removes a default value
$defaultsPlugin->unsetDefault('sender');
The only argument is the property name (see __constructor for reference).
Versions compatibility
The project follows the Semantic Versioning.
License
MIT. See the LICENSE file for details.