laraben / laravel-postmark
Laravel package for sending mail via the Postmark API
Requires
- php: >=7.1.3
- ext-json: *
- guzzlehttp/guzzle: ~6.0
- illuminate/mail: ~5.5.0|~5.6.0|~5.7.0|~5.8.0
- illuminate/support: ~5.5.0|~5.6.0|~5.7.0|~5.8.0
Requires (Dev)
- orchestra/testbench: ~3.5.0|~3.6.0|~3.7.0|~3.8.0
- phpunit/phpunit: ~6.0|~7.0
- squizlabs/php_codesniffer: ^3.0
Suggests
- mvdnbrk/postmark-inbound: Allows you to process Postmark Inbound Webhooks.
- 2.5.x-dev
- v2.5.0
- 2.4.x-dev
- v2.4.1
- v2.4.0
- 2.3.x-dev
- v2.3.2
- v2.3.1
- v2.3.0
- 2.2.x-dev
- v2.2.0
- 2.1.x-dev
- v2.1.8
- v2.1.7
- v2.1.6
- v2.1.5
- v2.1.4
- v2.1.3
- v2.1.2
- v2.1.1
- v2.1.0
- 2.0.x-dev
- dev-master / 2.0.x-dev
- v2.0.0
- v1.1.5
- v1.1.4
- v1.1.3
- v1.1.2
- v1.1.1
- v1.1.0
- 1.0.x-dev
- v1.0.0
- v0.2.1
- v0.2.0
- v0.1.0
- v0.0.1
- dev-templates
- dev-postmark-template-support
This package is auto-updated.
Last update: 2025-02-20 20:36:15 UTC
README
Laravel Postmark
[![Latest Version on Packagist][ico-version]][link-packagist] ![Software License][ico-license] [![Build Status][ico-travis]][link-travis] [![Coverage Status][ico-scrutinizer]][link-scrutinizer] [![Quality Score][ico-code-quality]][link-code-quality] [![Total Downloads][ico-downloads]][link-downloads]
Postmark is the easiest and most reliable way to be sure your important transactional emails get to your customer's inbox.
Upgrading
Please see UPGRADE for details.
Installation
You can install the package via composer:
$ composer require laraben/laravel-postmark
The package will automatically register itself.
You can optionally publish the config file with:
php artisan vendor:publish --provider="Coconuts\Mail\PostmarkServiceProvider" --tag="config"
Usage
Update your .env
file by adding your server key and set your mail driver to postmark
.
MAIL_DRIVER=postmark POSTMARK_SECRET=YOUR-SERVER-KEY-HERE
That's it! The mail system continues to work the exact same way as before and you can switch out Postmark for any of the pre-packaged Laravel mail drivers (smtp, mailgun, log, etc...).
Remember, when using Postmark the sending address used in your emails must be a valid Sender Signature that you have already configured.
Postmark Templates
Postmark offers a fantastic templating service for you to utilize instead of maintaining your templates within your Laravel application. If you would like to take advantage of that, this package offers an extension on the base MailMessage
provided out of the box with Laravel. Within a Laravel notification, you can do the following to start taking advantage of Postmark templates.
public function toMail($notifiable) { return (new \Coconuts\Mail\MailMessage) ->identifier(8675309) ->include([ 'name' => 'Customer Name', 'action_url' => 'https://example.com/login', ]); }
You may also utilize an alias instead of the template identifier by using the
->alias()
method.
Postmark Tags
If you rely on categorizing your outgoing emails using Tags in Postmark, you can simply add a header within your Mailable class's build method.
public function build() { $this->withSwiftMessage(function (\Swift_Message $message) { $message->getHeaders()->addTextHeader('tag', 'value'); }); }
Postmark Metadata
Similar to tags, you can also include metadata by adding a header. Metadata headers should be prefixed with metadata-
where the string that follows is the metadata key.
public function build() { $this->withSwiftMessage(function (\Swift_Message $message) { $message->getHeaders()->addTextHeader('metadata-field', 'value'); $message->getHeaders()->addTextHeader('metadata-another-field', 'another value'); }); }
In this case, the following object will be sent to Postmark as metadata.
{
"field": "value",
"another-field", "another value"
}
Change log
Please see CHANGELOG for more information on what has changed recently.
Testing
$ composer test
Contributing
Please see CONTRIBUTING and CONDUCT for details.
Security
If you discover any security related issues, please email craig.paul@coconutcalendar.com instead of using the issue tracker.
Credits
- Laraben
- [Craig Paul][link-author]
- [All Contributors][link-contributors]