Skip to content

Latest commit

 

History

History
75 lines (52 loc) · 2.25 KB

README.md

File metadata and controls

75 lines (52 loc) · 2.25 KB

Swift Mailer Extensions

Overview

This project is intended to extend capabilities of SwiftMailer.

Note, that master now only supports SwiftMailer v.6 and not compatible with earlier version. If you still need earlier versions, check v.1 of this package.

Transport

File transport

For dev environment it is usually desirable to prevent sending out actual emails and store them into files instead for testing.

FileTransport does exactly that - it stores emails into eml format which can then be opened with most email applications (e.g. Outlook or Thunderbird). It accepts event dispatcher as first argument and path to the folder where email files will be stored (you should have write access in it).

Usage example:

// Initialize file transport
$eventDispatcher = new \Swift_Events_SimpleEventDispatcher()
$transport = new FileTransport($eventDispatcher, 'path/to/folder');

// Create the Mailer using your created Transport
$mailer = Swift_Mailer::newInstance($transport);

// Create a message
$message = Swift_Message::newInstance('Wonderful Subject')
  ->setFrom(array('[email protected]' => 'John Doe'))
  ->setTo(array('[email protected]', '[email protected]' => 'A name'))
  ->setBody('Here is the message itself')
  ;

// Send the message
$result = $mailer->send($message);

Connecting to Symfony:

Define FileTransport as service in services.yml:

swiftmailer.mailer.transport.file:
    class: Geekdevs\SwiftMailer\Transport\FileTransport
    arguments:
      - "@swiftmailer.mailer.default.transport.eventdispatcher"
      - "%kernel.project_dir%/var/emails"      

Configure SwiftMailer to understand new transport in config.yml file:

swiftmailer:
    transport: file

Copy plugin

Copy plugin is useful to BCC all outgoing emails to specific address (e.g. if you want to monitor everything what you send out).

Connecting to Symfony:

Define CopyPlugin as service in services.yml:

swiftmailer.mailer.plugin.copy:
    class: Geekdevs\SwiftMailer\Plugin\CopyPlugin
    arguments:
      - "[email protected]"
    tags:
      - { name: "swiftmailer.default.plugin" }

Note the tag swiftmailer.primary.plugin where "default" should be the name of your mailer.