定制 phauthentic/problem-details-symfony-bundle 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

phauthentic/problem-details-symfony-bundle

最新稳定版本:1.0.0

Composer 安装命令:

composer require phauthentic/problem-details-symfony-bundle

包简介

Symfony bundle for the Problem Details for HTTP APIs RFC

README 文档

README

This bundle provides support for RFC 9457.

  • Turns ValidationFailedException exceptions into a ProblemDetails responses complying with RFC 9457.
    • The error building is fully customizable.
  • Provides a ProblemDetailsFactory service to create ProblemDetails 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

统计信息

  • 总下载量: 595
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 1
  • 点击次数: 2
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 1
  • Watchers: 1
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2024-12-29