jenky / api-error
Standardize error responses in API applications
Requires
- php: ^8.1
- symfony/error-handler: ^6.1|^7.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.10
- phpstan/phpstan: ^2.0
- phpunit/phpunit: ^10.0
- symfony/http-foundation: ^6.1|^7.2
This package is auto-updated.
Last update: 2025-03-05 03:26:32 UTC
README
This package provides an implementation for API error formatting. It can be integrated throughout your code and should result in a standardized error response format for HTTP APIs.
Quick start
Since handling the exceptions is up to the framework, here are a list of supported integrations:
Symfony HTTP Foundation Based Framework
Bring Your Own
You can install the package via composer:
composer require jenky/api-error
The usage may vary depending on your project. Typically, you should handle it in your global exception handler. Here is a minimal example:
use Jenky\ApiError\Formatter\GenericErrorFormatter; use Jenky\ApiError\Transformer\ChainTransformer; $transformer = new ChainTransformer([ // ... list of transformers ]) $formatter = new GenericErrorFormatter(true, $transformer); // or simply without transformer and debug is off $formatter = new GenericErrorFormatter(); /** @var \Throwable $exception */ return \json_encode($formatter->format($exception));
Building Blocks
Error Formatter
The error formatter is the main entry point of the package. It formats the Throwable
exception into a serializable version, allowing the data structure to be used as the response body, typically in JSON
. An error formatter must implement ErrorFormatter
.
Internally, the error formatter transforms the exception into a Problem
, which should return an array as context data for the given exception. This array can contain anything, and when combined with the predefined response error format, will be used to replace placeholders with contextual data.
You can always create your own Problem
using the Exception Transformer.
GenericErrorFormatter
{ 'message' => '{message}', // The exception message 'status' => '{status_code}', // The corresponding HTTP status code, defaults to 500 'code' => '{code}' // The exception int code 'debug' => '{debug}', // The debug information }
Rfc7807ErrorFormatter
{ 'type' => '{type}', 'title' => '{status_text}', // The corresponding HTTP status text 'detail' => '{message}', 'status' => '{status_code}', // The corresponding HTTP status code, defaults to 500 'invalid-params' => '{invalid_params}', 'debug' => '{debug}', // The debug information }
- Placeholder names MUST correspond to keys in the context array.
- Placeholder names MUST be delimited with a single opening brace
{
and a single closing brace}
. There MUST NOT be any whitespace between the delimiters and the placeholder name. - Placeholder names SHOULD be composed only of the characters
A-Z
,a-z
,0-9
, underscore_
, and period.
.
Custom Error Format
Create your own custom formatter that implements ErrorFormatter
. Alternatively, you can extend the AbstractErrorFormatter
, provided for the sake of convenience, and define your own error format in the getFormat
method.
Exception Transformations
An exception transformer is used to customize the transformation of a Throwable
exception into a Problem
, allowing you to add or modify the context data. If you want to add custom transformations, you should create a new class that implements the ExceptionTransformer
and pass it as a second argument of the error formatter.
new GenericFormatter(transformer: new MyExceptionTransformer); // or new Rfc7807ErrorFormatter(transformer: new MyExceptionTransformer);
If you have multiple transformers, use the ChainTransformer
to run all of them.
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING and CODE_OF_CONDUCT for details.
Security
If you discover any security related issues, please email contact@lynh.me instead of using the issue tracker.
Credits
License
The MIT License (MIT). Please see License File for more information.