定制 auto1-oss/service-api-handler-bundle 二次开发

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

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

auto1-oss/service-api-handler-bundle

最新稳定版本:v1.2.0

Composer 安装命令:

composer require auto1-oss/service-api-handler-bundle

包简介

Auto1 Service API Handler Bundle for creating micro-services with PHP

README 文档

README

Register required Bundles:

 Auto1\ServiceAPIComponentsBundle\Auto1ServiceAPIComponentsBundle::class => ['all' => true], Auto1\ServiceAPIHandlerBundle\Auto1ServiceAPIHandlerBundle::class => ['all' => true],

config/routing.yml

endpoints: resource: "@Auto1ServiceAPIHandlerBundle/Resources/config/routing.yml"

Description

Use Endpoints specifications to handle symfony request flow.

Prepares RequestDTO from $_GLOBALS and serializes response from ServiceResponse(ResponseDTO, HTTP_CODE)

Controller

  • Controllers must be tagged with controller.service_arguments and suffixed with Controller
  • Action methods must be suffixed with Action

ServiceResponse

  • Fully imitates, but not implements behaviour of HttpFoundation\Response (JsonResponse)
  • Agnostic to the response format, and performs serialization after being returned from the controller

Example of EP definition (yaml):

# CarLead getCarLeadByVin: method: 'GET' baseUrl: '%auto1.api.url%' path: '/v1/carlead/vin/{vin}' requestClass: 'Auto1\ServiceDTOCollection\CarLead\CarLeadRead\Request\GetCarLeadByVinRequest' responseClass: 'Auto1\ServiceDTOCollection\CarLead\CarLeadRead\Response\CarLead'

Example of ServiceRequest implementation:

class GetCarLeadByVinRequest implements ServiceRequestInterface { private $vin; public function setVin(string $vin): self { $this->vin = $vin; return $this; } public function getVin() { return $this->vin; } }

Example of EP implementation:

use Auto1\ServiceAPIHandlerBundle\Response\ServiceResponse; use Auto1\ServiceDTOCollection\CarLead\CarLeadRead\Request\GetCarLeadByVinRequest; use Auto1\ServiceDTOCollection\CarLead\CarLeadRead\Response\CarLead; class MyController { public function carLeadByVinAction(GetCarLeadByVinRequest $carLeadRequestDTO): ServiceResponse { /** @var CarLead $carLead */ $carLead = $this->...->find($carLeadRequestDTO->getVin()); return new ServiceResponse( $carLead, 200 ); } }

Swagger generation

For symfony:>=6.0 and nelmio/api-doc-bundle:>=4.0 swagger json file is generated in OpenApi v3 format "openapi": "3.0.0". For previous versions of symfony and nelmio/api-doc-bundle swagger json file is generated in Swagger V2 format "swagger": "2.0".

Debug

bin/console c:c && bin/console debug:router --show-controllers

For more info - have a look at service-api-components-bundle usage:

统计信息

  • 总下载量: 63.33k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 3
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 3
  • Watchers: 5
  • Forks: 13
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2026-01-04

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固