Download the PHP package tomazahlin/symfony-mailer-bundle without Composer
On this page you can find all versions of the php package tomazahlin/symfony-mailer-bundle. It is possible to download/install these versions without Composer. Possible dependencies are resolved automatically.
Download tomazahlin/symfony-mailer-bundle
More information about tomazahlin/symfony-mailer-bundle
Files in tomazahlin/symfony-mailer-bundle
Package symfony-mailer-bundle
Short Description Mailer bundle provides a mailer (mail broker) implementation (Swiftmailer wrapper) for Symfony2 framework. It enables you to send mails in a very elegant way while providing extension points for needed modifications.
License MIT
Informations about the package symfony-mailer-bundle
Symfony2 Mailer Bundle
This is the explanation of how the bundle is structured and also an installation / example tutorial for the bundle.
Mailer bundle allows you to write very clean code when sending emails. By default it uses Swiftmailer, but if you want, you can override the complete mailer implementation and use some other mailer library. Emails can be forwarded (send) to Swiftmailer directly in the code where you require it, and also if you implement a queueable mailer, sending of the mails can be postponed until Symfony's kernel.terminate event, which is handled after the output is already sent to the user, so the user does not notice the delay of the mailing.
The code is coupled to the Symfony2 framework, as it is presented in the bundle. It might be decoupled later if needed or requested.
Installation
Use composer to require the bundle inside composer.json by running the command:
Enable the bundle in your AppKernel.php
Run tests
Usage
View a controller with examples here
The bundle provides you with the mailing service which gives you access to other services as well, because it uses composition. It exposes one service, so you only have to inject one dependency, preferably the MailingInterface, to keep things decoupled.
To define your service, you should inject the ahlin_mailer.mailing service:
Templates
To override anything in the bundle, you can of course use bundle inheritance, but for simplicity you can also override some classes by overriding some of the default parameters of the bundle. And to override templates you can define your custom templates in app/Resources.
The bundle is packaged with a default responsive html template:
- Resources/views/Mail/default.html.twig
You can easily replace the template, by defining your own in app/Resources folder or you can use bundle inheritance to do the same.
To define your own templates, the bundle uses Open for extension / closed for modification solid principle. To define your own templates, you need to create a class and tag it with "ahlin_mailer.mapping". Let's say you wanted to create a mapping for your UserBundle.
Create a class which implements TemplateMappingInterface.
As you can see, it is only a mapping between aliases and their paths, so when you need to specify which template you want to use, your code will be much shorter and cleaner. And the service definition for the container would look like this:
You can define (override) the parameters which are always passed to the email templates, by overriding the parameter:
In the twig template, you can access it with {{ myHomepageUrl }}.
For any questions or issues regarding this bundle, please do not hesitate to ask. Feel free to create your own forked version or submit any pull requests.
Version 2.2 allows you to add Filters, which modify the email's body. Some filters (if they maybe convert images from url to inline images) also can modify the Swift_Message model. All you have to do is to implement FilterInterface and tag the filter with "ahlin_mailer.filter".
Version 2.2 allows you to use the Mailer class to send Swfit_Message instances.
All versions of symfony-mailer-bundle with dependencies
symfony/framework-bundle Version ~2.6
symfony/swiftmailer-bundle Version ~2.3
sensio/distribution-bundle Version >=4.0
sensio/framework-extra-bundle Version ~3.0,>=3.0.2