Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/symfony/mailer
Helps sending emails
https://github.com/symfony/mailer
component php symfony symfony-component
Last synced: 5 days ago
JSON representation
Helps sending emails
- Host: GitHub
- URL: https://github.com/symfony/mailer
- Owner: symfony
- License: mit
- Created: 2019-03-30T11:54:41.000Z (almost 6 years ago)
- Default Branch: 7.2
- Last Pushed: 2025-01-12T17:23:06.000Z (13 days ago)
- Last Synced: 2025-01-15T08:08:05.139Z (11 days ago)
- Topics: component, php, symfony, symfony-component
- Language: PHP
- Homepage: https://symfony.com/mailer
- Size: 674 KB
- Stars: 1,512
- Watchers: 15
- Forks: 48
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
- awesome-php - Symfony Mailer - A powerful library for creating and sending emails. (Table of Contents / Email)
- awesome-php-cn - Symfony Mailer - 一个强大的库创建和发送电子邮件. (目录 / 电子邮件 Email)
- awesome-projects - Symfony Mailer - A powerful library for creating and sending emails. (PHP / Email)
- awesome-php - Symfony Mailer - A powerful library for creating and sending emails. (Table of Contents / Email)
README
Mailer Component
================The Mailer component helps sending emails.
Getting Started
---------------```bash
composer require symfony/mailer
``````php
use Symfony\Component\Mailer\Transport;
use Symfony\Component\Mailer\Mailer;
use Symfony\Component\Mime\Email;$transport = Transport::fromDsn('smtp://localhost');
$mailer = new Mailer($transport);$email = (new Email())
->from('[email protected]')
->to('[email protected]')
//->cc('[email protected]')
//->bcc('[email protected]')
//->replyTo('[email protected]')
//->priority(Email::PRIORITY_HIGH)
->subject('Time for Symfony Mailer!')
->text('Sending emails is fun again!')
->html('See Twig integration for better HTML integration!
');$mailer->send($email);
```To enable the Twig integration of the Mailer, require `symfony/twig-bridge` and
set up the `BodyRenderer`:```php
use Symfony\Bridge\Twig\Mime\BodyRenderer;
use Symfony\Bridge\Twig\Mime\TemplatedEmail;
use Symfony\Component\EventDispatcher\EventDispatcher;
use Symfony\Component\Mailer\EventListener\MessageListener;
use Symfony\Component\Mailer\Mailer;
use Symfony\Component\Mailer\Transport;
use Twig\Environment as TwigEnvironment;$twig = new TwigEnvironment(...);
$messageListener = new MessageListener(null, new BodyRenderer($twig));$eventDispatcher = new EventDispatcher();
$eventDispatcher->addSubscriber($messageListener);$transport = Transport::fromDsn('smtp://localhost', $eventDispatcher);
$mailer = new Mailer($transport, null, $eventDispatcher);$email = (new TemplatedEmail())
// ...
->htmlTemplate('emails/signup.html.twig')
->context([
'expiration_date' => new \DateTimeImmutable('+7 days'),
'username' => 'foo',
])
;
$mailer->send($email);
```Sponsor
-------The Mailer component for Symfony 7.2 is [backed][1] by:
* [Sweego][2], a European email and SMS sending platform for developers and product builders. Easily create, deliver, and monitor your emails and notifications.
Help Symfony by [sponsoring][3] its development!
Resources
---------* [Documentation](https://symfony.com/doc/current/mailer.html)
* [Contributing](https://symfony.com/doc/current/contributing/index.html)
* [Report issues](https://github.com/symfony/symfony/issues) and
[send Pull Requests](https://github.com/symfony/symfony/pulls)
in the [main Symfony repository](https://github.com/symfony/symfony)[1]: https://symfony.com/backers
[2]: https://www.sweego.io/
[3]: https://symfony.com/sponsor