admin9/laravel-scramble-extensions
最新稳定版本:v0.2.0
Composer 安装命令:
composer require 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.
README 文档
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
统计信息
- 总下载量: 7
- 月度下载量: 0
- 日度下载量: 0
- 收藏数: 0
- 点击次数: 6
- 依赖项目数: 0
- 推荐数: 0
其他信息
- 授权协议: MIT
- 更新时间: 2026-02-23