dmn/laravel-exception

Exceptions for Larave 10+

v1.0.5 2023-05-12 07:36 UTC

This package is auto-updated.

Last update: 2024-11-12 10:49:49 UTC


README

composer require dmn/laravel-exception

Usage

Extend Dmn\Exceptions\Handler to your app/Exceptions/Handler.php and add parent::register() to your register().

<?php

namespace App\Exceptions;

use Dmn\Exceptions\Handler as ExceptionHandler;
use Throwable;

class Handler extends ExceptionHandler
{
...
    /**
     * Register the exception handling callbacks for the application.
     */
    public function register(): void
    {
        parent::register();
        $this->reportable(function (Throwable $e) {
            //
        });
    }
...
}

To add more custom exceptions, add new exception by running php artisan make:exception and extend Dmn\Exceptions\Exception instead of \Exception. New exceptions need to have $code, $message and $httpStatusCode. You may add $description.

<?php

namespace App\Exceptions;

use Dmn\Exceptions\Exception;
use Illuminate\Http\Response;

class NewCustomException extends Exception
{
    protected $code = 'sample_error_code';

    protected $message = 'Sample error message';

    protected $httpStatusCode = Response::HTTP_BAD_REQUEST;

    protected $description = 'Sample more detailed error description.';
}

The above exception will render:

{
    status_code: 400,
    code: "sample_error_code",
    message: "Sample error message.",
    description: "Sample more details error description.",
}

To override other exceptions from other packages or from laravel itself, you can add it inside customException().

protected function customException(): void
{
    parent::customException();

    // your overrides here
    // example
    $this->renderable(function (\Vendor\Package\Exception $e) {
        throw new App\Exceptions\NewCustomException();
    });
}

Other usage option (not recommended)

You may use Dmn\Exceptions\Handler directly from your bootstrap/app.php

$app->singleton(
    Illuminate\Contracts\Debug\ExceptionHandler::class,
    // App\Exceptions\Handler::class <-- change this
    Dmn\Exceptions\Handler
);