atm / mailbundle
Mailing management bundle
Installs: 306
Dependents: 0
Suggesters: 0
Security: 0
Type:symfony-bundle
pkg:composer/atm/mailbundle
Requires
- php: >=5.3.9
Requires (Dev)
- dyninc/dyn-php: ^0.9.0
- friendsofsymfony/jsrouting-bundle: ^1.6
- symfony/asset: ~2.7|~3.0.0
- symfony/console: ~2.8|~3.0.0
- symfony/expression-language: ~2.4|~3.0.0
- symfony/finder: ~2.3|~3.0.0
- symfony/form: ^2.8.23
- symfony/http-kernel: ~2.8|~3.0.0
- symfony/polyfill-intl-icu: ~1.0
- symfony/routing: ~2.2|~3.0.0
- symfony/security: ~2.6|~3.0.0
- symfony/security-acl: ~2.6|~3.0.0
- symfony/stopwatch: ~2.2|~3.0.0
- symfony/templating: ~2.1|~3.0.0
- symfony/translation: ~2.7|~3.0.0
- symfony/var-dumper: ~2.7.16|~2.8.9|~3.0.9
- symfony/yaml: ^2.0.5|~3.0.0
- xlabs/rabbitmqbundle: ^1.0
Suggests
- symfony/asset: For using the AssetExtension
- symfony/expression-language: For using the ExpressionExtension
- symfony/finder: For using the finder
- symfony/form: For using the FormExtension
- symfony/http-kernel: For using the HttpKernelExtension
- symfony/routing: For using the RoutingExtension
- symfony/security: For using the SecurityExtension
- symfony/stopwatch: For using the StopwatchExtension
- symfony/templating: For using the TwigEngine
- symfony/translation: For using the TranslationExtension
- symfony/var-dumper: For using the DumpExtension
- symfony/yaml: For using the YamlExtension
README
A Mail Manager System
Installation
Install through composer:
php -d memory_limit=-1 composer.phar require atm/mailbundle
In your AppKernel
public function registerbundles()
{
    return [
    	...
    	...
    	new ATM\MailBundle\ATMMailBundle(),
    ];
}
Routing
Append to main routing file:
# app/config/routing.yml
  
atm_mail:
    resource: "@ATMMailBundle/Resources/config/routing.yml"
    prefix:   /
You also have to put outside of your firewalls the following route for unsubscribing users
atm_mail_unsubscribe_user:
    path: /unsubscribe/{userId}
    defaults: { _controller: "ATMMailBundle:Mail:unsubscribeUser" }
Configuration sample
Default values are shown below:
# app/config/config.yml
  
atm_mail:
    class:
        model:
            user: YourBundle\Entity\User
    # Domain of your site
    site_domain: 'atmbundles.com'
    # Folder name where the mail templates are gonna be stored
    templates_folder: 'mail_templates'
    # From address to use for sending mails
    from_address: 'example@example.com'
    # From name to use for sending mails
    from_name: 'EXAMPLE'
    # To Address to use for checking that the commands had been executed successfully 
    checking_to_address: 'alberto.tuzon@manicamedia.com'
    # Your DYN Key
    dyn_api_key: 'yourkeygoeshere'
    # User types to use for mailings
    user_types: ['girls','exmembers','active_users','all']
User Types Conditions
You must define the following function in your User Repository for filtering the different types of users you have for sending mails.
namespace YourBundle\Repository;
use Doctrine\ORM\EntityRepository;
class UserRepository extends EntityRepository
{
    public function getAtmMailingUserTypeWhereClause($qb,$andX,$userType){
        switch($userType){
            case 'usertype1':
                $andX->add($qb->expr()->like('u.roles',$qb->expr()->literal('%ROLE1%')));
                $andX->add($qb->expr()->eq('u.locked',0));
                $andX->add($qb->expr()->eq('u.enabled',1));
                break;
            case 'usertype2':
                $andX->add($qb->expr()->notLike('u.roles',$qb->expr()->literal('%ROLE2%')));
                $andX->add($qb->expr()->eq('u.locked',0));
                $andX->add($qb->expr()->eq('u.enabled',1));
                break;
            case 'usertype3':
                $andX->add($qb->expr()->notLike('u.roles',$qb->expr()->literal('%ROLE3%')));
                $andX->add($qb->expr()->lte('u.expiresAt','CURRENT_TIMESTAMP()'));
                break;
            case 'all':
                return null;
                break;
        }
        return $andX;
    }
}