hatchyu / laravel-api-exceptions
API-first reusable JSON exception classes for Laravel with proper HTTP status codes
Installs: 2
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/hatchyu/laravel-api-exceptions
Requires
- php: ^8.2
- illuminate/auth: ^11.0|^12.0
- illuminate/database: ^11.0|^12.0
- illuminate/support: ^11.0|^12.0
Requires (Dev)
- driftingly/rector-laravel: ^2.1
- laravel/pint: ^1.26
- rector/rector: ^2.3
This package is auto-updated.
Last update: 2026-02-05 08:58:20 UTC
README
A small library of reusable API exception classes for Laravel apps. Each exception
implements Responsable, so throwing one returns a JSON error response with an
appropriate HTTP status code.
Requirements
- PHP
^8.2 - Laravel
11.xor12.x
Install
composer require hatchyu/laravel-api-exceptions
The service provider is auto-discovered by Laravel.
Usage
use Hatchyu\ApiExceptions\Http\BadRequestException; // Returns a 400 JSON response: // { "error": { "message": "Invalid payload." } } throw new BadRequestException('Invalid payload.');
If you omit a message, a default is generated from the class name, for example
BadRequestException becomes "Bad request.".
Factory Helpers Some domain exceptions expose convenient factory methods for consistent messages:
use Hatchyu\ApiExceptions\General\FileTooLargeException; use Hatchyu\ApiExceptions\General\FileUploadException; use Hatchyu\ApiExceptions\General\ModelNotFoundException; throw FileTooLargeException::for('invoice.pdf'); throw FileUploadException::for('invoice.pdf'); throw UnsupportedFileTypeException::forFile('invoice.pdf', 'application/pdf'); throw ModelNotFoundException::forModel(Customer::class, 3);
Note: DocumentUploadException is deprecated in favor of FileUploadException.
Common Exceptions
BadRequestException(400)UnauthorizedException(401)ForbiddenException(403)NotFoundException(404)ConflictException(409)UnprocessableEntityException(422)TooManyRequestsException(429)InternalServerErrorException(500)ServiceUnavailableException(503)
Namespaces
Hatchyu\ApiExceptions\Http(top-level HTTP status exceptions)Hatchyu\ApiExceptions\Auth(authentication/authorization helpers)Hatchyu\ApiExceptions\General(domain-friendly helpers)Hatchyu\ApiExceptions\Validation(validation helpers)
Custom Exceptions
Create your own by extending Hatchyu\ApiExceptions\Base\ApiBaseException and
overriding customHttpCode().
Localization
This package ships English translations in resources/lang/en. You can override
them in your app by placing files under
resources/lang/{locale}/vendor/api-exceptions.
Publishing Translations To publish the translation files into your application for editing:
php artisan vendor:publish --tag=api-exceptions-translations