casperboone / laravel-expiring-email
Auto-expiring email notifications
Fund package maintenance!
casperboone
Requires
- php: >=7.4
- illuminate/contracts: ^8.38
- spatie/laravel-package-tools: ^1.6.3
- swiftmailer/swiftmailer: ^v6.1.3
Requires (Dev)
- doctrine/dbal: ^3.0
- orchestra/testbench: ^6.13
- phpunit/phpunit: ^9.3
- psalm/plugin-laravel: ^1.4
- spatie/laravel-ray: ^1.9
- vimeo/psalm: ^4.4
This package is auto-updated.
Last update: 2025-01-16 18:58:32 UTC
README
This package allows you to easily send expiring emails. This is useful for cases where you do not want to send sensitive data over email directly and you want to make that no sensitive information is kept in a recipient's mailbox without having control over that data.
By using the expiring email driver of this package instead of the regular email driver in a notification, all that is sent to the receiver is a signed and expiring link to the original content of the email.
Installation
You can install the package via composer:
composer require casperboone/laravel-expiring-email
You should publish and run the migrations with:
php artisan vendor:publish --provider="CasperBoone\LaravelExpiringEmail\LaravelExpiringEmailServiceProvider" --tag="expiring-email-migrations" php artisan migrate
You can optionally publish the config file with:
php artisan vendor:publish --provider="CasperBoone\LaravelExpiringEmail\LaravelExpiringEmailServiceProvider" --tag="expiring-email-config"
You can optionally publish the views to customize the replacement email with:
php artisan vendor:publish --provider="CasperBoone\LaravelExpiringEmail\LaravelExpiringEmailServiceProvider" --tag="expiring-email-views"
An email immediately becomes inaccessible after the expiration date. However, to also remove the emails from your database after the expiration date, you should schedule "clean" command to be run daily.
// app/Console/Kernel.php protected function schedule(Schedule $schedule) { $schedule->command(CleanExpiredEmails::class)->daily(); }
Usage
The basic usage of this package is very easy, all you need to do is replace 'email'
in your via()
method of a notification to the expiring email notification channel.
public function via($notifiable): array { - return ['mail']; + return [ExpiringEmailChannel::class]; }
This sends an email to the original receiver with a signed expiring link to the content of the original email.
The default expiration date is set in the config file but can be set on a case-by-case basis in the notification using ExpiringMailMessage
:
public function toMail($notifiable): MailMessage { - return (new MailMessage) + return (new ExpiringMailMessage) ->subject('Secret document') + ->expiresInDays(7) ->markdown('secret_document_email'); }
Development
Testing
composer test
Static analysis
composer psalm
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.