最近,OpenAI 宣布了一个重大的更新:ChatGPT 支持 Plugin 能力。用户在与 ChatGPT 自然语言交互时,可以选择使用插件。通过插件扩展,可以实现让 ChatGPT 实现以下能力:
举具体例子,用户想要使用 ChatGPT 来查询某个城市的酒店信息,只需要安装并允许使用一个酒店搜索的插件,然后就可以通过简单的对话来获取酒店的名称、价格、评分、位置等信息;如果用户想要使用 ChatGPT 来学习某个编程语言,他们只需要安装并允许使用一个编程教程的插件,然后就可以通过互动式的问答来掌握编程的基础知识和技巧。更多详细的例子可以查看这篇文章:ChatGPT 插件应用场景有哪些?
Openai is offering a web browsing plugin and a code execution plugin, and open-sourcing the code for a retrieval plugin. Plugins are very experimental still but we think there's something great in this direction; it's been a heavily requested feature.
OpenAI 正在提供一个网页浏览插件和一个代码执行插件,并开源检索插件的代码。 插件仍然非常实验性,但我们认为在这个方向上有很大的潜力;这是一个备受期待的功能。-Sam Altman ,CEO of OpenAI
插件开发人员通过标准的 manifest 文件和 OpenAPI 规范格式 的 API 文档文件,指定一个或多个开放的 API Endpoint (指具体的某个 API )。这些文件定义了插件的功能,允许 ChatGPT 读取这些文件,并调用开发人员定义的 API 。一句话描述就是:AI 模型充当了智能 API 的调用方。给定 API 规范和有关何时使用 API 的自然语言描述,模型会主动调用 API 来执行操作。
截止目前时间( 2023 年 3 月 30 日),ChatGPT 插件仍然处于有限的 alpha 版本阶段,所以需要加入等待列表以排队获取访问权限。在 alpha 版本期间,openAI 也承诺会充分和用户与开发人员合作迭代插件系统,所以最后上线的插件功能可能也会有一些变化,这也是想要提前体验与成为插件开发者需要去注意的很重要的点。
yourdomain.com/.well-known/ai-plugin.json
需要了解关于插件的更多详情,可以在 OpenAI 中文文档 中进行查看。当然你也可以去官方文档中查看。
在上面的文章内容中,我们介绍了插件的核心能力与基本的技术实现原理。其中提到很重要的一点:如果想要做到让 AI 模型通过插件作为你 API 的智能调用方,则你必须将你的 API 以 OpenAPI 规范格式的文档放在清单文件中。因为只有当你的 API 文档符合这个规范,才能被 AI 模型理解并真正执行成功调用你的 API 。
为什么 OpenAPI 规范会被 OpenAI 采纳作为自己插件能力调用 API 的标准格式呢?这就要理解 OpenAPI 规范到底是什么,以及它是怎么形成的。了解了这些内容之后,就可以知道 openAI 公司为何把 OpenAPI 规范作为自己旗下最火产品 ChatGPT 的插件能力标准了。
OpenAPI 规范( OpenAPI Specification )是一种开放的、标准化的、机器可读的 API 描述格式,它可以帮助开发者快速地创建、测试、发布和维护 API 。OpenAPI 也可以用来生成 API 的文档、客户端代码、服务器代码等。
OpenAPI 的规范由 OpenAPI Initiative ( OAI )组织制定和维护,目前最新的版本是 3.1.0 。OpenAPI 规范使用 JSON 或 YAML 语言来定义 API 的元数据、路径、参数、响应、安全等信息。OpenAPI 规范是一种通用的和语言无关的接口,它可以让人类和计算机都能够发现和理解 API 的能力,而不需要访问源代码、额外的文档或网络流量检查。
深入了解:OpenAPI 规范 (中文版)
OpenAPI 规范是由 Tony Tam 在 2009 年创立的,当时他是 Wordnik 公司的一名工程师,他想要描述 Wordnik 的在线词典 JSON API ,于是创建了一个规范,叫做 Swagger 。Swagger 在接下来的几年里经过了多次迭代和改进。在 2015 年,SmartBear Software 公司收购了 Swagger 规范,并在同年将其捐赠给了 Linux Foundation 下的一个新组织,叫做 OpenAPI Initiative ( OAI ),该组织由多家公司共同组成,旨在推动和维护 OpenAPI 规范的发展。
从 2016 年开始,Swagger 规范正式更名为 OpenAPI 规范,并迁移到了一个新的 GitHub 仓库。从那时起,OpenAPI 规范就不断地更新和完善。
我们现在可以理解,一个符合规范的 API 文档是有多么的重要。有了这份文档,人类、机器就能够更好的理解你的 API 。在 API 开发过程中,一般来说,常见的产生符合 OpenAPI 规范文档的方式有两种:
Code First 与 API First ,两者都可以写出符合 OpenAPI 规范的文档,但是它们有着不同的应用场景与优缺点。
对于 API First 来说:
对于 Code First 来说:
总之,API First 是一个可以提升效率的工作流程,它的底层思想跟 OKR 工作方式也挺类似,优先定义工作目标、实现规范,从而让所有人的工作协同更好效率更高。
如果你最近想要开发一个 ChatGPT 的插件,一般情况下来说,必然已经对这个插件在什么场景想要做到什么效果,有一个清晰、明确的结论。所以,如果你采用 API First 工作流程,在开发工作开始之前事先将这个能力抽象定义出来并且制作出一个 OpenAPI 规范文档,就有以下明显的好处了:
以上就是对于 ChatGPT 插件、OpenAPI 、API First 的简单介绍,希望这篇文章能够帮助到你更加高效的开发出你的 ChatGPT 插件。