admin9 / laravel-scramble-extensions
Scramble extensions for Laravel business-response APIs — auto-wraps OpenAPI docs with success/error envelope, scene-based form request extraction, and filter query parameter extraction.
Installs: 4
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/admin9/laravel-scramble-extensions
Requires
- php: ^8.2
- dedoc/scramble: ^0.12 || ^0.13
- nikic/php-parser: ^4.0 || ^5.0
- spatie/laravel-package-tools: ^1.16
Requires (Dev)
- laravel/pint: ^1.24
- orchestra/testbench: ^10.0
Suggests
- mitoop/laravel-api-response: Required for business response envelope wrapping (^7.0)
- mitoop/laravel-efficient-form-request: Required for scene-based form request parameter extraction
- mitoop/laravel-query-builder: Required for filter query parameter extraction
README
为 Laravel 业务接口量身定制的 Scramble (OpenAPI 文档生成器) 扩展包。
主要功能:
- 自动将 200 响应包装为统一的业务信封结构
{success, code, message, data, [meta], request_id} - 支持场景化表单请求 (Scene FormRequest) 的参数提取
- 支持 Filter 查询参数自动提取(筛选字段、排序、分页)
三个功能模块均可通过配置文件独立开启或关闭。
安装
composer require admin9/laravel-scramble-extensions
发布配置文件:
php artisan vendor:publish --tag=scramble-extensions-config
可选依赖
根据你使用的功能,按需安装对应的包:
# 业务响应信封包装 composer require mitoop/laravel-api-response # 场景化表单请求 composer require mitoop/laravel-efficient-form-request # Filter 查询参数提取 composer require mitoop/laravel-query-builder
配置
配置文件 config/scramble-extensions.php:
return [ 'response' => [ 'enabled' => true, // 控制器需要 use 的 trait,提供 $this->success() 等方法 'trait' => 'Mitoop\\Http\\RespondsWithJson', // 模型命名空间,用于分页响应自动推断模型 'model_namespace' => 'App\\Models', ], 'scene_form_request' => [ 'enabled' => true, ], 'filter' => [ 'enabled' => true, 'pagination' => [ 'page_size_default' => 15, 'page_size_max' => 100, ], ], ];
功能说明
1. 业务响应信封包装 (Response)
自动将所有 200 响应包装为统一的业务信封结构。
控制器需要 use 配置中指定的 trait(默认 Mitoop\Http\RespondsWithJson),通过 $this->success()、$this->error()、$this->deny() 返回响应。
class UserController extends Controller { use \Mitoop\Http\RespondsWithJson; public function show(User $user) { return $this->success($user); } public function index() { return $this->success(User::paginate()); } }
生成的 OpenAPI 文档中,标准响应结构为:
{
"success": true,
"code": 0,
"message": "",
"data": { ... },
"request_id": "uuid7"
}
分页响应会额外包含 meta 字段:
{
"success": true,
"code": 0,
"message": "",
"data": [ ... ],
"meta": {
"pagination": "length_aware",
"page": 1,
"page_size": 15,
"has_more": true,
"total": 100
},
"request_id": "uuid7"
}
2. 场景化表单请求提取 (Scene FormRequest)
支持 mitoop/laravel-efficient-form-request,允许同一个 FormRequest 根据控制器方法名定义不同的验证规则。
扩展会自动查找 FormRequest 上的 {actionName}Rules() 方法并提取参数到 OpenAPI 文档。
use Mitoop\LaravelEfficientFormRequest\EfficientSceneFormRequest; class UserRequest extends EfficientSceneFormRequest { // store 方法使用的规则 public function storeRules(): array { return [ 'name' => 'required|string|max:255', 'email' => 'required|email', ]; } // update 方法使用的规则 public function updateRules(): array { return [ 'name' => 'string|max:255', ]; } }
class UserController extends Controller { public function store(UserRequest $request) { ... } public function update(UserRequest $request, User $user) { ... } }
store 接口文档会包含 name(必填)和 email(必填)参数,update 接口文档只包含 name 参数。
3. Filter 查询参数提取 (Filter)
支持 mitoop/laravel-query-builder,自动从 Filter 类中提取筛选字段、排序选项和分页参数到 OpenAPI 文档。
use Mitoop\LaravelQueryBuilder\AbstractFilter; class UserFilter extends AbstractFilter { protected array $allowedSorts = ['created_at', 'name']; public function rules(): array { return [ 'name', 'email', 'status', ]; } }
class UserController extends Controller { public function index() { $users = User::filter(UserFilter::class)->paginate(); return $this->success($users); } }
生成的文档会自动包含以下 query 参数:
name、email、status— 筛选字段sort— 排序字段,可选值created_at、name,前缀-表示降序page_size— 每页条数(默认 15,最大 100,可通过配置修改)page— 页码
License
MIT