入门 OpenAI 聊天补全 API
OpenAI 聊天补全 API 允许你使用 OpenAI 的模型构建 AI Agent。
有代码演示
本指南包含代码演示,帮助你快速入门。查看 GitHub 仓库。
客户端设置
首先,安装 AI Agent 扩展。
npm install @tiptap-pro/extension-ai-agent然后,导入该扩展,并使用 AiAgentProvider 类进行配置。
import { Editor } from '@tiptap/core'
import StarterKit from '@tiptap/starter-kit'
import AiAgent, { AiAgentProvider } from '@tiptap-pro/extension-ai-agent'
const provider = new AiAgentProvider()
const editor = new Editor({
extensions: [
StarterKit,
AiAgent.configure({
provider,
}),
],
})在 AI Agent 提供者中,定义一个调用后端的 resolver 函数。
import AiAgent, { AiAgentProvider } from '@tiptap-pro/extension-ai-agent'
const provider = new AiAgentProvider({
// `chatMessages` 属性包含对话的聊天消息
resolver: async ({ chatMessages, schemaAwarenessData }) => {
// 调用你的后端 API 端点
const response = await fetch('/api-endpoint', {
method: 'POST',
body: JSON.stringify({ chatMessages, schemaAwarenessData }),
})
return await response.json()
},
})下一节中,我们将看到如何实现返回正确格式回复的 API 端点。
服务器端设置
首先,安装 AI Agent 和 OpenAI 服务器端库。
npm install @tiptap-pro/extension-ai-agent-server openai从请求参数中获取聊天消息和模式感知数据。
// Code inside your API endpoint. Code depends on your backend framework
const { chatMessages, schemaAwarenessData } = request然后,在你的 API 端点中,创建一个 AiAgentToolkit 实例。它允许你配置 AI 模型可使用的工具。
import { AiAgentToolkit, openaiChatCompletionsAdapter } from '@tiptap-pro/extension-ai-agent-server'
const toolkit = new AiAgentToolkit({
adapter: openaiChatCompletionsAdapter,
schemaAwarenessData,
})同时定义一个 ChatMessagesFormatter 实例。它让你将聊天消息转换成 OpenAI 聊天补全 API 期望的格式。
import {
AiAgentToolkit,
openaiChatCompletionsAdapter,
ChatMessagesFormatter,
} from '@tiptap-pro/extension-ai-agent-server'
const formatter = new ChatMessagesFormatter({
initialMessages: chatMessages,
adapter: openaiChatCompletionsAdapter,
})创建工具包和格式化器后,向 OpenAI 聊天补全 API 发送请求。
import {
AiAgentToolkit,
openaiChatCompletionsAdapter,
ChatMessagesFormatter,
} from '@tiptap-pro/extension-ai-agent-server'
import OpenAI from 'openai'
const { chatMessages, schemaAwarenessData } = request
const toolkit = new AiAgentToolkit({
adapter: openaiChatCompletionsAdapter,
schemaAwarenessData,
})
const formatter = new ChatMessagesFormatter({
// 从请求体获取聊天消息
initialMessages: chatMessages,
adapter: openaiChatCompletionsAdapter,
})
// 初始化 OpenAI 客户端
const openai = new OpenAI()
// 调用 OpenAI 聊天补全 API
const response = await openai.chat.completions.create({
model: 'gpt-4.1',
messages: [
{
role: 'system',
content: `
<你的系统提示>
${toolkit.getSystemPrompt()}
`,
},
...formatter.format(),
],
// 提供 AI 模型可调用的工具
tools: toolkit.format(),
})在系统提示的末尾,包含 AiAgentToolkit 实例生成的系统提示,如:toolkit.getSystemPrompt()。其中包含了有关如何使用工具的指令。
关于如何编写系统提示,请参阅系统提示指南。其中包含了可用作起点的示例系统提示。
最后,使用 formatter 将回复转换为 AI Agent 扩展期望的格式。
formatter.addAiResponse(response)
const response = formatter.getResolverResponse()formatter.getResolverResponse() 返回的值应作为你的 API 端点响应以及 resolver 函数的返回值。