2017 © Pedro Peláez
 

library database-swiftmalier-bundle

Database Spool Bundle for SwiftMailer and Symfony 2

image

dextervip/database-swiftmalier-bundle

Database Spool Bundle for SwiftMailer and Symfony 2

  • Monday, March 20, 2017
  • by dextervip
  • Repository
  • 2 Watchers
  • 8 Stars
  • 11,806 Installations
  • PHP
  • 0 Dependents
  • 0 Suggesters
  • 2 Forks
  • 3 Open issues
  • 1 Versions
  • 4 % Grown

The README.md

DatabaseSwiftMailerBundle

Scrutinizer Code Quality, (*1)

Introduction

This bundle add a database driven swiftmailer spool to your symfony 2 project. It requires Symfony 2.4+ and usage of entities with Doctrine ORM., (*2)

Features

  • 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

Installing

Add composer

Add the dependency to your composer.json, (*3)

    "require": {
        ...
        "dextervip/database-swiftmalier-bundle" : "dev-master"
    }

Add bundle class in kernel

Register the bundle class and its dependencies in your AppKernel.php, (*4)

    public function registerBundles()
    {
        $bundles = array(
        ...
        new Knp\Bundle\PaginatorBundle\KnpPaginatorBundle(),
        new Stof\DoctrineExtensionsBundle\StofDoctrineExtensionsBundle(),
        new Citrax\Bundle\DatabaseSwiftMailerBundle\CitraxDatabaseSwiftMailerBundle(),
        ...
        );
    }

Add routes

If you want to have a spool dashboard, add the following routes., (*5)

citrax_database_swift_mailer:
    resource: "@CitraxDatabaseSwiftMailerBundle/Controller/"
    type:     annotation
    prefix:   /

Configuring

Update database

Update your database schema to create the necessary entities., (*6)

$ php app/console doctrine:schema:update --force

Update swiftmailer config

Change your spool type from memory to db in your config.yml, (*7)

    spool:     { type: db }

Overriding default templates

You may want to override the default template to have the look and feel of your application. You can do it by creating a new bundle and defining its parent as CitraxDatabaseSwiftMailerBundle., (*8)

  1. Create a new empty bundle E.g. EmailBundle, (*9)

  2. Edit its bundle class and add a getParent() method returning 'CitraxDatabaseSwiftMailerBundle', (*10)

class EmailBundle extends Bundle
{
    public function getParent()
    {
        return 'CitraxDatabaseSwiftMailerBundle';
    }
}
  1. Create a twig template inside your new bundle in Resources/views/layout.html.twig and edit it to fit into your application layout. See the example below:
{% extends 'AppBundle::base.html.twig' %}

{% block title %}Email Spool{% endblock %}

{% block body %}
    {% block database_swiftmailer_content %}{% endblock %}
{% endblock %}
  1. All done!

Extra config

??, (*11)

Running

To send emails that are in the database spool, just run the following command:, (*12)

$ php app/console swiftmailer:spool:send

You may add a cron job entry to run it periodically., (*13)

You can check the spool status with all emails at http://your_project_url/email-spool, (*14)

To Do's

  • Filter emails
  • Insert error message once it reaches the maximum of retries
  • Last run date
  • Count total sent

License

MIT, (*15)

The Versions

20/03 2017

dev-master

9999999-dev https://github.com/dextervip/DatabaseSwiftMailerBundle

Database Spool Bundle for SwiftMailer and Symfony 2

  Sources   Download

MIT

The Requires

 

database swiftmailer bundle symfony