phauthentic / problem-details-symfony-bundle
Symfony bundle for the Problem Details for HTTP APIs RFC
Installs: 25
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: ^8.2
- symfony/http-kernel: ~7.0
- symfony/serializer: ~7.0
- symfony/uid: ~7.0
- symfony/validator: ~7.0
Requires (Dev)
- infection/infection: ^0.29.10
- phpmd/phpmd: ^2.5
- phpstan/phpstan: ^2.0
- phpunit/phpunit: ^11.5.0
- squizlabs/php_codesniffer: ^3.7.2
- symfony/yaml: ^7.2
This package is auto-updated.
Last update: 2025-01-08 18:32:55 UTC
README
This bundle provides support for RFC 9457.
- Turns
ValidationFailedException
exceptions into aProblemDetails
responses complying with RFC 9457.- The error building is fully customizable.
- Provides a
ProblemDetailsFactory
service to createProblemDetails
instances.
Installation
composer require phauthentic/problem-details-symfony-bundle
Documentation
Simply inject the ProblemDetailsFactoryInterface
into your handlers and use it to create ProblemDetails
responses.
class ExampleController { public function __construct( private ProblemDetailsFactoryInterface $problemDetailsFactory ) { } /** * @Route("/example", methods={"POST"}) */ public function exampleAction(Request $request): Response { return $this->problemDetailsFactory->createResponse( type: 'https://example.net/validation-error', detail: 'Your request is not valid.', status: 422, title: 'Validation Error', ); } }
Service Configuration
To add more converters to the kernel listener, you can tag additional services with phauthentic.problem_details.exception_converter
. They must implement the ExceptionConverterInterface.
Phauthentic\Symfony\ProblemDetails\ExceptionConversion\ValidationFailedExceptionConverter: arguments: $validationErrorsBuilder: '@Phauthentic\Symfony\ProblemDetails\Validation\ValidationErrorsBuilder' $problemDetailsResponseFactory: '@Phauthentic\Symfony\ProblemDetails\FromExceptionEventFactoryInterface' tags: ['phauthentic.problem_details.exception_converter']
To completely override the list of already configured listeners override
Phauthentic\Symfony\ProblemDetails\ThrowableToProblemDetailsKernelListener: public: true arguments: $exceptionConverters: !tagged_iterator phauthentic.problem_details.exception_converter tags: - { name: 'kernel.event_listener', event: 'kernel.exception', priority: 0 }
in your services.yaml
.
Problem Details Example
HTTP/1.1 422 Unprocessable Content
Content-Type: application/problem+json
Content-Language: en
{
"type": "https://example.net/validation-error",
"title": "Your request is not valid.",
"errors": [
{
"detail": "must be a positive integer",
"pointer": "#/age"
},
{
"detail": "must be 'green', 'red' or 'blue'",
"pointer": "#/profile/color"
}
]
}
Alternatives
If you favor a different style of implementation check out the following bundles:
License
This bundle is under the MIT license.
Copyright Florian Krämer