atm / mailbundle
1.0.20
2019-03-13 08:53 UTC
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
邮件管理系统
安装
通过composer安装
php -d memory_limit=-1 composer.phar require atm/mailbundle
在你的AppKernel中
public function registerbundles()
{
return [
...
...
new ATM\MailBundle\ATMMailBundle(),
];
}
路由
追加到主路由文件
# app/config/routing.yml
atm_mail:
resource: "@ATMMailBundle/Resources/config/routing.yml"
prefix: /
你还需要在你的防火墙之外放置以下路由,用于取消订阅用户
atm_mail_unsubscribe_user:
path: /unsubscribe/{userId}
defaults: { _controller: "ATMMailBundle:Mail:unsubscribeUser" }
配置示例
以下显示默认值
# 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']
用户类型条件
你必须在你用户的存储库中定义以下函数,以过滤发送邮件的不同类型的用户。
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;
}
}