mailmotor / mailmotor-bundle
此Symfony扩展包作为服务加载到MailMotor中。因此,您可以订阅/取消订阅任何邮件列表管理API的成员。例如:MailChimp、CampaignMonitor、...
4.0.2
2023-11-27 18:05 UTC
Requires
- php: ^7.4||^8.0
- symfony/http-kernel: ^2.3|^3.0|^4.0|^5.0
Requires (Dev)
- phpunit/phpunit: ^9.6
- symfony/framework-bundle: ^2.3|^3.0|^4.0|^5.0
This package is not auto-updated.
Last update: 2024-09-13 17:55:51 UTC
README
订阅/取消订阅自己的邮件列表从未如此简单!多亏了这个Symfony扩展包。
安装
如何配置MailChimp
composer require mailmotor/mailchimp-bundle
// In `app/AppKernel.php` public function registerBundles() { $bundles = array( // ... new MailMotor\Bundle\MailMotorBundle\MailMotorMailMotorBundle(), new MailMotor\Bundle\MailChimpBundle\MailMotorMailChimpBundle(), );
# In `app/config/parameters.yml` parameters: # ... mailmotor.mail_engine: 'mailchimp' # or another mailmotor engine mailmotor.api_key: xxx # enter your mailchimp api_key here mailmotor.list_id: xxx # enter the mailchimp default list_id here
示例
订阅
$this->get('mailmotor.subscriber')->subscribe( $email, // f.e.: 'info@jeroendesloovere.be' $language, // f.e.: 'nl' $mergeFields, // f.e.: ['FNAME' => 'Jeroen', 'LNAME' => 'Desloovere'] $interests, // f.e.: ['9A28948d9' => true, '8998ASAA' => false] $doubleOptin, // OPTIONAL, default = true $listId // OPTIONAL, default listId is in your config parameters );
取消订阅
$this->get('mailmotor.subscriber')->unsubscribe( $email, $listId // OPTIONAL, default listId is in your config parameters );
存在
$this->get('mailmotor.subscriber')->exists( $email, $listId // OPTIONAL, default listId is in your config parameters );
已订阅
$this->get('mailmotor.subscriber')->isSubscribed( $email, $listId // OPTIONAL, default listId is in your config parameters );
订阅的完整示例
use MailMotor\Bundle\MailMotorBundle\Exception\NotImplementedException; // Don't forget to add validation to your $email $email = 'info@jeroendesloovere.be'; try { if ($this->get('mailmotor.subscriber')->isSubscribed($email)) { // Add error to your form } // Fallback for when no mailmotor parameters are defined } catch (NotImplementedException $e) { // Do nothing } if ($noErrors) try { // Subscribe the user to our default group $this->get('mailmotor.subscriber')->subscribe( $email, $language, $mergeFields ); // Fallback for when no mailmotor parameters are defined } catch (NotImplementedException $e) { // Add you own code here to f.e.: send a mail to the admin } }
取消订阅的完整示例
use MailMotor\Bundle\MailMotorBundle\Exception\NotImplementedException; // Don't forget to add validation to your $email $email = 'info@jeroendesloovere.be'; try { // Email exists if ($this->get('mailmotor.subscriber')->exists($email)) { // User is already unsubscribed if ($this->get('mailmotor.subscriber')->isUnsubscribed($email)) { // Add error to your form: "User is already unsubscribed" } // Email not exists } else { // Add error to your form: "email is not in mailinglist" } // Fallback for when no mailmotor parameters are defined } catch (NotImplementedException $e) { // Do nothing } if ($noErrors) { try { // Unsubscribe the user $this->get('mailmotor.subscriber')->unsubscribe($email); // Fallback for when no mailmotor parameters are defined } catch (NotImplementedException $e) { // We can send a mail to the admin instead } }
扩展
为另一个邮件引擎创建扩展包。
例如:您想使用名为"Crazy"的邮件引擎。
public function registerBundles() { $bundles = array( // ... new Crazy\Bundle\MailMotorBundle\CrazyMailMotorBundle(), );
在 app/config/parameters.yml
mailmotor.mail_engine: 'crazy' mailmotor.api_key: xxx # enter your crazy api_key here mailmotor.list_id: xxx # enter the crazy default list_id here
然后您只需要复制另一个邮件引擎的所有文件,例如:"mailmotor/mailchimp-bundle",并替换所有您自己的邮件引擎的逻辑。