This bundle add a database driven swiftmailer spool to your Symfony 3 project. It requires Symfony 3.0+ and usage of entities with Doctrine ORM.
- Auto Retrying: set a maximum number of retries that spool will try to send in case of failure
- Dashboard to list the email spool and perform some actions
- Retry sending an email
- Cancelling an email sending
- Resending an email
Add the dependency to your composer.json
"require": {
...
"paneedesign/database-swiftmailer-bundle" : "dev-master"
}
Register the bundle class and its dependencies in your AppKernel.php
public function registerBundles()
{
$bundles = array(
...
new PaneeDesign\DatabaseSwiftMailerBundle\PedDatabaseSwiftMailerBundle(),
...
);
}
If you want to have a spool dashboard, add the following routes.
ped_database_swift_mailer:
resource: "@PedDatabaseSwiftMailerBundle/Controller/"
type: annotation
prefix: /
Update your database schema to create the necessary entities.
$ php bin/console doctrine:schema:update --force
Change your spool type from memory to db in your config.yml
spool: { type: db }
You may want to override the default template to have the look and feel of your application. You can do it following the official Symfony documentation: https://symfony.com/doc/3.4/templating/overriding.html
To send emails that are in the database spool, just run the following command:
$ php bin/console swiftmailer:spool:send
You may add a cron job entry to run it periodically.
You can check the spool status with all emails at http://your_project_url/email-spool
- Filter emails
- Insert error message once it reaches the maximum of retries
- Last run date
- Count total sent
MIT