大规模代码审查存在缺陷。Augment Code 正在解决这个问题。

Laravel OpenAPI CLI:从 API 规范生成 Artisan 命令

发布日期 经过

Laravel OpenAPI CLI:从 API 规范镜像生成 Artisan 命令

空间 Laravel 发布了 OpenAPI CLI,这是一个可以将 OpenAPI 规范转换为专用 Laravel Artisan 命令的软件包。规范中的每个 API 端点都会获得一个单独的命令,其中包含路径和查询参数以及请求体的可配置选项。

工作原理

安装完成后,您可以使用以下方式注册 OpenAPI 规范 URL: OpenApiCli 外观——通常在你的 AppServiceProvider :

命名空间 应用程序\提供商 ;
使用 Illuminate\支持\服务提供商 ;
使用 空间\OpenApiCli\Facades\OpenApiCli ;
班级 应用服务提供商 延伸 服务提供者
{
民众 功能 引导 ()
{
OpenAPI CLI :: 登记 'https://api.acme.com/openapi.yaml' , 'acme'
-> 基础网址 'https://api.acme.com'
-> 持票人 环境 'ACME_API_TOKEN' ));
}
}

给定一个定义规范 GET /orders , POST /orders , 和 DELETE /orders/{order_id} 该软件包会生成以下 Artisan 命令:

  • acme:get-orders
  • acme:post-orders
  • acme:delete-orders
  • acme:list

acme:list 该命令显示所有可用的端点及其描述。

命令遵循以下模式 {prefix}:{http-method}-{path} 其中前缀是注册时给出的名称(第二个参数)。 register 方法),并将路径转换为 ​​kebab-case 格式,并去除路径参数。 GET /orders/{order_id}/items 变成 acme:get-orders-items 如果你的规范定义了操作 ID,你可以使用这些 ID 来代替。 ->useOperationIds()

运行命令

您可以直接从终端调用任何生成的命令:

php 工匠 acme:获取订单 --limit=10

默认情况下,响应以易于阅读的表格形式呈现。传递 --yaml 改为输出 YAML 格式的标志:

php 工匠 acme:获取订单 --limit=10 --yaml

路径和查询参数

路径参数是必需的,查询参数是可选的。两者都会转换为 kebab-case 格式。 order_idorderId 两者都变成了 --order-id :

# 路径参数
php 工匠 acme:获取订单项 --order-id=42
# 多路径参数
php 工匠 acme:删除客户订单 --customer-id=1 --order-id=7
# 查询参数
php 工匠 acme:获取订单 --status=pending --limit=10

查询字符串中的括号表示法也会被扁平化为 kebab-case 格式,因此 filter[status] 变成 --filter-status

发送数据

对于接受请求正文的端点,您可以使用以下方式单独发送字段: --field :

php 工匠 acme:邮购 - 场地 customer_id=1 - 场地 状态="待处理"

默认情况下,字段以 JSON 格式发送,除非规范另有规定。 application/x-www-form-urlencoded 如果需要发送原始 JSON,请使用 --input 反而:

php 工匠 acme:邮购 - 输入 '{"customer_id":1,"shipping":{"address":"123 Main St","city":"纽约"}}'

注意 --field--input 不能合并。对于文件上传,请在字段值前加上前缀。 @ :

php 工匠 acme:post-orders-attachments --order-id=67 - 场地 文件=@/path/to/invoice.pdf

当任何字段包含文件时,请求将以如下方式发送: multipart/form-data

配置选项

注册 API 还通过流畅的接口支持多种选项:

OpenAPI CLI :: 登记 'https://api.acme.com/openapi.yaml' , 'acme'
-> 基础网址 'https://api.acme.com'
-> 持票人 环境 'ACME_API_TOKEN' ))
-> 横幅 “Acme Orders API v2”
-> 缓存 生存时间 : 600
-> 跟随重定向 ()
-> yaml输出 ()
-> 显示HTML正文 ()
-> 使用操作 ID ()
-> 错误 功能 回复 $response, 命令 $command) {
返回 匹配 ($响应) -> 地位 ()){
429 => 命令 -> 警告 “限速……” ),
默认 => 错误的 ,
};
});

一些值得注意的选择:

  • cache(ttl: 600) — 将响应缓存指定秒数。
  • followRedirects() — 自动跟随 HTTP 重定向
  • useOperationIds() — 使用规范中的操作 ID 而不是 HTTP 方法和路径来命名命令。
  • onError() — 接受一个回调函数来处理特定的 HTTP 错误状态代码

安装

通过 Composer 安装:

作曲家 要求 space/laravel-openapi-cli

该软件包也能很好地与以下组件集成: 拉拉维尔零 一个用于构建独立 CLI 应用程序的框架。

完整文档可在以下网址获取: Spatie 的文档网站 您可以在[此处插入链接]查看源代码。 GitHub

Yannick Lyn Fatt 的照片

Laravel News 的特约撰稿人和全栈 Web 开发人员。

归档于:
立方体

Laravel 时事通讯

加入超过 4 万名开发者的行列,不错过任何新的技巧、教程等内容。

图像
Jump24 - 英国 Laravel 代理机构

Laravel 开发人员,精通技术,绝不外包,绝不离岸外包,始终卓越。

访问 Jump24 - 英国 Laravel 代理机构
银行标志

银行

只需每月 3200 美元,即可聘请一位拥有 4-6 年经验的资深 Laravel 开发人员,为您的项目注入强劲动力。您将获得 160 小时的专属专业服务,并享受 15 天无风险试用。立即预约通话!

银行
Tinkerwell 徽标

廷克威尔

Laravel 开发者必备的代码运行器。可在本地和生产环境中体验 AI、自动补全和即时反馈功能。

廷克威尔
几天内即可获得 Laravel 代码审查徽标的专家指导

几天内即可获得 Laravel 代码审查方面的专家指导

专家级代码审查!两位拥有 10 年以上 Laravel 开发经验的开发者将为您提供清晰、实用的反馈,帮助团队构建更优质的应用程序。

几天内即可获得 Laravel 代码审查方面的专家指导
PhpStorm 标志

PhpStorm

首选的 PHP IDE,对 Laravel 及其生态系统提供广泛的开箱即用支持。

PhpStorm
Laravel Cloud 标志

Laravel 云

轻松创建和管理服务器,并在几秒钟内部署 Laravel 应用程序。

Laravel 云
了解 Softtech 的标志

了解软科技

Acquaint Softtech 提供 AI 就绪的 Laravel 开发人员,48 小时内即可上手,每月费用为 3000 美元,没有冗长的销售流程,并提供 100% 退款保证。

了解软科技
Kirschbaum 标志

樱桃树

提供创新和稳定性,确保您的Web应用程序取得成功。

樱桃树
Shift 标志

转移

还在运行旧版本的 Laravel?立即实现 Laravel 自动升级和代码现代化,让您的应用程序保持最新状态。

转移
鱼叉:新一代时间跟踪和发票标志

Harpoon:新一代时间跟踪和发票系统

新一代时间跟踪和计费软件,帮助您的机构规划和预测盈利的未来。

Harpoon:新一代时间跟踪和发票系统
Lucky Media 标志

幸运传媒

Get Lucky Now——拥有十余年经验的 Laravel 开发理想之选!

幸运传媒
SaaSykit:Laravel SaaS 入门套件徽标

SaaSykit:Laravel SaaS 入门套件

SaaSykit 是一个多租户 Laravel SaaS 入门套件,包含运行现代 SaaS 所需的所有功能,例如支付、美观的结账界面、管理面板、用户仪表盘、身份验证、现成组件、统计数据、博客、文档等等。

SaaSykit:Laravel SaaS 入门套件
首席:在大型项目中使用基于任务的工作流运行 Claude Code 图片

首席:在基于任务的工作流中,在大型项目中运行 Claude Code

阅读文章
Laravel OpenAPI CLI:从 API 规范镜像生成 Artisan 命令

Laravel OpenAPI CLI:从 API 规范生成 Artisan 命令

阅读文章
Laravel Boost v2.2.0 镜像中技能和指南检测的改进

Laravel Boost v2.2.0 中技能和指南检测得到改进

阅读文章
“氛围”——NativePHP 举办 Laracon 美国站第三天活动

“氛围”——NativePHP 在 Laracon 美国站结束后举办第三天活动

阅读文章
关于 Laravel 13 图片,我们了解多少?

关于 Laravel 13,我们目前了解多少?

阅读文章
Tailwind CSS v4.2 图片新增颜色

Tailwind CSS v4.2 新增颜色

阅读文章