An easy-to-use package for sending email notifications with stack traces whenever an exception occurs in your Laravel application.
To install the package, run the following Composer command:
composer require darshan/exceptionemail
In Laravel 11, exception handling logic should be placed in a custom service provider. Follow these steps to set it up:
- Create a Custom Service Provider:
Create a new service provider that will handle exceptions in your application. Add the following code in app/Providers/ExceptionServiceProvider.php
:
namespace App\Providers;
use Illuminate\Support\ServiceProvider;
use Throwable;
class ExceptionServiceProvider extends ServiceProvider
{
public function register()
{
// Nothing here for now.
}
public function boot()
{
app()->error(function (Throwable $e) {
app('exceptionemail')->captureException($e);
});
}
}
- Register the Service Provider:
In bootstrap/providers.php
, register your custom ExceptionServiceProvider
by adding it to the providers
array:
return [
// Other service providers...
App\Providers\ExceptionServiceProvider::class,
],
In order to capture exceptions and send emails (for Laravel versions prior to 11 or if you prefer using Handler.php
), modify the report
method in your app/Exceptions/Handler.php
file:
use Throwable;
public function report(Throwable $exception)
{
app('exceptionemail')->captureException($exception);
parent::report($exception);
}
Publish the ExceptionEmail configuration file by running the following Artisan command:
php artisan vendor:publish --provider="Webmonks\ExceptionEmail\ExceptionEmailServiceProvider"
This will create a configuration file at config/exceptionemail.php
.
By default, the package is configured with 'silent' => true
to prevent sending exception emails in development environments, especially when 'debug' => true
is enabled in Laravel.
You can control this behavior with the following configuration option:
'silent' => env('IS_EXCEPTION_EMAIL_SILENT', true),
To enable email notifications when exceptions occur, set IS_EXCEPTION_EMAIL_SILENT=false
in your .env
file.
You can specify which types of exceptions should trigger email notifications. By default, the package includes Symfony\Component\Debug\Exception\FatalErrorException::class
.
'capture' => [
Symfony\Component\Debug\Exception\FatalErrorException::class,
],
To capture all exceptions, you can use the wildcard '*'
:
'capture' => [
'*'
],
You may define exceptions that should not trigger email notifications. This is done by adding them to the ignored_exception
array.
'ignored_exception' => [
// Webmonks\ExceptionEmail\Exceptions\DummyException::class,
],
For example, to ignore FatalErrorException
, use the following:
'ignored_exception' => [
Symfony\Component\Debug\Exception\FatalErrorException::class,
],
Update the report
method in app/Exceptions/Handler.php
to incorporate ignored exceptions:
public function report(Exception $exception)
{
if ($this->shouldReport($exception)) {
app('exceptionemail')->captureException($exception);
}
parent::report($exception);
}
Specify the email addresses that should receive the exception notifications by updating the to
array:
'to' => [
'[email protected]',
],
You can configure the package to ignore errors triggered by bots, like search engine crawlers. The default configuration includes common bots such as:
'ignored_bots' => [
'googlebot',
'bingbot',
'slurp',
'ia_archiver',
],
To customize the subject and body of the error notification emails, publish the email templates by running:
php artisan vendor:publish --provider="Webmonks\ExceptionEmail\ExceptionEmailServiceProvider"
Note: Only run this command once to avoid overwriting custom changes.
The email views will be published to resources/views/vendor/exceptionemail
. You can modify the templates as needed, and you have access to the $exception
object in the views.
To verify that ExceptionEmail is correctly set up and working, use the following Artisan command:
php artisan exceptionemail:test
This command will throw a Webmonks\ExceptionEmail\Exceptions\DummyException
, and the package will capture and send it as an email. If everything is set up correctly, you should receive the test email.
If you discover any security issues, please contact us directly via email at [email protected], rather than opening an issue on GitHub.
Webmonks is a product development startup based in Ahmedabad, India. You can explore all our open-source projects on GitHub.
This package is open-sourced software licensed under the MIT License.