承接 cnerta/mailing-bundle 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

cnerta/mailing-bundle

最新稳定版本:1.0.1

Composer 安装命令:

composer require cnerta/mailing-bundle

包简介

CnertaMailinBundle is a Symfony2 Bundle who provide an easy way to send email build with Twig template

README 文档

README

CnertaMailingBundle

CnertaMailinBundle is a Symfony2 Bundle who provide an easy way to send email build with Twig template.

Create your email message with Twig and use the CnertaMailinBundle's service for sending it.

Easy, fast and builded on the shoulders of giants like SwiftMail.

Because quality matters : SensioLabsInsight Build Status

Installation

Composer

Add to composer json:

    "require": {
        //..
        "cnerta/mailing-bundle": "dev-master"
    }

Run:

$ composer install cnerta/mailing-bundle

Register the bundle in your AppKernel class.

<?php
// app/AppKernel.php

    public function registerBundles()
    {
        $bundles = array(
            // ...
            new Cnerta\MailingBundle\CnertaMailingBundle(),
        );

        // ...
    }

    // ...

Configure the bundle

In config.yml

cnerta_mailing:
    default_bundle: "FooBundle" # The name of the bundle where the email template are stored
    active_log: false # Defined if you want to log each sending email
    from_email:
        address: exemple@exemple.com
        sender_name: "My name is"

How To Use

Create mail templates

  • Create a Mails folder in your src/AppBundle/Resources
  • Create a BlocksMail.html.twig in this new folder
  • Create a default.html.twig
  • Create a default.txt.twig

The BlocksMail.html.twig must contain all the objects and bodys part of your mail. Exemple :

{% block bar_object %}A mail object{% endblock %}
{% block bar_body %}
A Body with full of pretty things !
{% endblock %}

The default.html.twig is the base template of your mail Exemple :

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
    </head>
    <body>
        <strong>Hello dear user</strong>
        <div>
            {{ body|raw }} {# This is mandatory, it's the body message of your mail #}
        </div>
    </body>
</html>

The default.txt.twig is the base template of your mail Exemple :

Hello dear user</strong

{{ body|raw }} {# This is mandatory, it's the body message of your mail in text version (without HTML elements) #}

Send mail !

Service name : cnerta.mailing

In a Controller :

use Cnerta\MailingBundle\Mailing\MailingServiceInterface;
use Cnerta\MailingBundle\Mailing\MailParameters;
use Cnerta\MailingBundle\Mailing\MailParametersInterface;

[...]
public function fooAction() {
    $mailParameters = MailParameters();

    $mailParameters
            ->setTemplateBundle('MyBundle')
            ->addBodyParameters("user", "User name");

    $this->get('cnerta.mailing')
        ->sendEmail(
            array("user@exemple.com"), // List of mail address or Symfony\Component\Security\Core\User\UserInterface
            "template_email", // Name of the block define in `BlocksMail.html.twig`
            $mailParameters);
}

Log all sending email in a specific channel

Because sometime you need to know what thé system send as email, this bundle provide an easy way to log all message.

This bundle use the mailingbundle channel to write log.

So, if you want to log this specific messages in a separate log file, use the config below.

monolog:
    handlers:
        myMailingChannel:
            # log all messages (since debug is the lowest level)
            level:    debug
            type:     stream
            path:     "%kernel.logs_dir%/mailing.log"
            channels: [mailingbundle]

统计信息

  • 总下载量: 212
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 3
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2015-09-17