跳到主要内容

AI SDK

初始化 SDK

初始化方法请参考初始化 SDK

app.ai

初始化后,可以使用挂载至 cloudbase 实例上的 ai 方法创建 AI 实例,用于后续模型创建。

使用示例

app = cloudbase.init({ env: "your-env" });
const ai = await app.ai();

类型声明

function ai(options?: AIInitOption): Promise<AI>;

参数

参数名必填类型示例说明
optionsAIInitOption{ env: "my-env" }AI 初始化参数,大多数场景下不用传递。该参数传递的数据 SDK 都会自动获取,在特殊场景可按需传递覆盖。

返回值

Promise<AI>

返回新创建的 AI 实例。

AI

用于创建 AI 模型的类。

createModel()

创建指定的 AI 模型。

使用示例

const model = ai.createModel("hunyuan");

类型声明

function createModel(model: string): ChatModel;

返回一个实现了 ChatModel 抽象类的模型实例,该实例提供 AI 生成文本相关能力。

bot

挂载了 Bot 类的实例,上面集合了一系列与 Agent 交互的方法。具体可参考 Bot 类 的详细文档。

使用示例

const agentList = await ai.bot.list({ pageNumber: 1, pageSize: 10 });

registerFunctionTool()

注册函数工具。在进行大模型调用时,可以告知大模型可用的函数工具,当大模型的响应被解析为工具调用时,会自动调用对应的函数工具。

使用示例

// 省略初始化 AI sdk 的操作...

// 1. 定义获取天气的工具,详见 FunctionTool 类型
const getWeatherTool = {
name: "get_weather",
description:
"返回某个城市的天气信息。调用示例:get_weather({city: '北京'})",
fn: ({ city }) => `${city}的天气是:秋高气爽!!!`, // 在这定义工具执行的内容
parameters: {
type: "object",
properties: {
city: {
type: "string",
description: "要查询的城市",
},
},
required: ["city"],
},
};

// 2. 注册我们刚定义好的工具
ai.registerFunctionTool(getWeatherTool);

// 3. 在给大模型发送消息的同时,告知大模型可用一个获取天气的工具
const model = ai.createModel("hunyuan");
const result = await model.generateText({
model: "hunyuan-turbo",
tools: [getWeatherTool], // 这里我们传入了获取天气工具
messages: [
{
role: "user",
content: "请告诉我北京的天气状况"
}
]
})

console.log(result.text);

类型声明

function registerFunctionTool(functionTool: FunctionTool);

参数

参数名必填类型说明
functionToolFunctionTool详见 FunctionTool

ChatModel

这个抽象类描述了 AI 生文模型类提供的接口。

generateText()

调用大模型生成文本。

使用示例

const hy = ai.createModel("hunyuan"); // 创建模型
const res = await hy.generateText({
model: "hunyuan-lite",
messages: [{ role: "user", content: "你好,请你介绍一下李白" }],
});
console.log(res.text); // 打印生成的文本

类型声明

function generateText(data: BaseChatModelInput): Promise<{
rawResponses: Array<unknown>;
text: string;
messages: Array<ChatModelMessage>;
usage: Usage;
error?: unknown;
}>;

参数

参数名必填类型示例说明
dataBaseChatModelInput{model: "hunyuan-lite", messages: [{ role: "user", content: "你好,请你介绍一下李白" }]}参数类型定义为 BaseChatModelInput ,作为基础的入参定义。实际上各家大模型还会有各自独特的输入参数,开发者可按需根据实际使用的大模型官方文档传入其他不在此类型中被定义的参数,充分利用大模型提供的能力。其他参数会被透传至大模型接口, SDK 侧不对它们不做额外处理。

返回值

属性名类型示例说明
res.textstring"李白是一位唐朝诗人。"大模型生成的文本。
res.rawResponsesunknown[][{"choices": [{"finish_reason": "stop","message": {"role": "assistant", "content": "你好呀,有什么我可以帮忙的吗?"}}], "usage": {"prompt_tokens": 14, "completion_tokens": 9, "total_tokens": 23}}]大模型的完整返回值,包含更多详细数据,如消息创建时间等等。由于各家大模型返回值互有出入,请根据实际情况使用。
res.messagesChatModelMessage[][{role: 'user', content: '你好'},{role: 'assistant', content: '你好!很高兴与你交流。请问有什么我可以帮助你的吗?无论是关于生活、工作、学习还是其他方面的问题,我都会尽力为你提供帮助。'}]本次调用的完整消息列表。
usageUsage{"completion_tokens":33,"prompt_tokens":3,"total_tokens":36}本次调用消耗的 token。
errorunknown调用过程中产生的错误。

streamText()

以流式调用大模型生成文本。流式调用时,生成的文本及其他响应数据会通过 SSE 返回,该接口的返回值对 SEE 做了不同程度的封装,开发者能根据实际需求获取到文本流和完整数据流。

使用示例

const hy = ai.createModel("hunyuan"); // 创建模型
const res = await hy.streamText({
model: "hunyuan-lite",
messages: [{ role: "user", content: "你好,请你介绍一下李白" }],
});

for await (let str of res.textStream) {
console.log(str); // 打印生成的文本
}
for await (let data of res.dataStream) {
console.log(data); // 打印每次返回的完整数据
}

类型声明

function streamText(data: BaseChatModelInput): Promise<StreamTextResult>;

参数

参数名必填类型示例说明
dataBaseChatModelInput{model: "hunyuan-lite", messages: [{ role: "user", content: "你好,请你介绍一下李白" }]}参数类型定义为 BaseChatModelInput ,作为基础的入参定义。实际上各家大模型还会有各自独特的输入参数,开发者可按需根据实际使用的大模型官方文档传入其他不在此类型中被定义的参数,充分利用大模型提供的能力。其他参数会被透传至大模型接口, SDK 侧不对它们不做额外处理。

返回值

StreamTextResult 属性名类型说明
textStreamReadableStream<string>以流式返回的大模型生成文本,可参考使用示例获取到生成的增量文本。
dataStreamReadableStream<DataChunk>以流式返回的大模型响应数据,可参考使用示例获取到生成的增量数据。由于各家大模型响应值互有出入,请根据实际情况合理使用。
messagesPromise<ChatModelMessage[]>本次调用的完整消息列表。
usagePromise<Usage>本次调用消耗的 token。
errorunknown本次调用产生的错误。
DataChunk 属性名类型说明
choicesArray<object>
choices[n].finish_reasonstring模型终止推断的原因。
choices[n].deltaChatModelMessage本次请求的消息。
usageUsage本次请求消耗的 token。
rawResponseunknown大模型返回的原始回复。

示例

const hy = ai.createModel("hunyuan");
const res = await hy.streamText({
model: "hunyuan-lite",
messages: [{ role: "user", content: "1+1结果是" }],
});

// 文本流
for await (let str of res.textStream) {
console.log(str);
}
// 1
// 加
// 1
// 的结果
// 是
// 2
// 。

// 数据流
for await (let str of res.dataStream) {
console.log(str);
}

// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}
// {created: 1723013866, id: "a95a54b5c5d2144eb700e60d0dfa5c98", model: "hunyuan-lite", version: "202404011000", choices: Array(1), …}

Bot

用于与 Agent 交互的类。

get()

获取某个 Agent 的信息。

使用示例

await ai.bot.get({ botId: "botId-xxx" });

类型声明

function get(props: { botId: string });

参数

参数名必填类型说明
props.botIdstring要获取信息的 Agent 的 id

list()

批量获取多个 Agent 的信息。

使用示例

await ai.bot.list({
pageNumber: 1,
pageSize: 10,
name: "",
enable: true,
information: "",
introduction: "",
});

类型声明

function list(props: {
name: string;
introduction: string;
information: string;
enable: boolean;
pageSize: number;
pageNumber: number;
});

参数

参数名必填类型说明
props.pageNumbernumber分页下标
props.pageSizenumber分页大小
props.enablebooleanAgent 是否启用
props.namestringAgent 名字,用于模糊查询
props.informationstringAgent 信息,用于模糊查询
props.introductionstringAgent 简介,用于模糊查询

sendMessage()

与 Agent 进行对话。

使用示例

const res = await ai.bot.sendMessage({
botId: "botId-xxx",
history: [{ content: "你是李白。", role: "user" }],
msg: "你好",
});
for await (let str of res.dataStream) {
console.log(str);
}

类型声明

function sendMessage(props: {
botId: string;
msg: string;
history: Array<{
role: string;
content: string;
}>;
});

参数

参数名必填类型说明
props.botIdnumberAgent id
props.msgnumber此次对话要发送的消息
props.historyboolean在此次对话前发生的聊天记录
props.history[n].rolestring本聊天信息的发送角色
props.history[n].contentstring本聊天信息的内容

getChatRecords()

获取聊天记录。

使用示例

await ai.bot.getChatRecords({
botId: "botId-xxx",
pageNumber: 1,
pageSize: 10,
sort: "asc",
});

类型声明

function getChatRecords(props: {
botId: string;
sort: string;
pageSize: number;
pageNumber: number;
});

参数

参数名必填类型说明
props.botIdstringAgent id
props.sortstring排序方式
props.pageSizenumber分页大小
props.pageNumbernumber分页下标

sendFeedback()

发送对某条聊天记录的反馈信息。

使用示例

const res = await ai.bot.sendFeedback({
userFeedback: {
botId: "botId-xxx",
recordId: "recordId-xxx",
comment: "非常棒",
rating: 5,
tags: ["优美"],
aiAnswer: "落英缤纷",
input: "来个成语",
type: "upvote",
},
});

类型声明

function sendFeedback(props: { userFeedback: IUserFeedback });

参数

参数名必填类型说明
props.userFeedbackIUserFeedback用户反馈,详见 IUserFeedback 类型定义

getFeedback()

获取已存在的反馈信息。

使用示例

const res = await ai.bot.getFeedback({
botId: "botId-xxx",
from: 0,
to: 0,
maxRating: 4,
minRating: 3,
pageNumber: 1,
pageSize: 10,
sender: "user-a",
senderFilter: "include",
type: "upvote",
});

类型声明

function sendFeedback(props: {
botId: string;
type: string;
sender: string;
senderFilter: string;
minRating: number;
maxRating: number;
from: number;
to: number;
pageSize: number;
pageNumber: number;
});

参数

参数名必填类型说明
props.botIdstringAgent id
props.typestring用户反馈类型,点赞 upvote 点踩 downvote
props.senderstring评论创建用户
props.senderFilterstring评论创建用户过滤关系 include:包含 exclude:不包含 equal:等于 unequal:不等于 prefix:前缀
props.minRatingnumber最低评分
props.maxRatingnumber最高评分
props.fromnumber开始时间戳
props.tonumber结束时间戳
props.pageSizenumber分页大小
props.pageNumbernumber分页下标

getRecommendQuestions()

获取推荐的问题。

使用示例

const res = ai.bot.getRecommendQuestions({
botId: "botId-xxx",
history: [{ content: "你是谁啊", role: "user" }],
msg: "你好",
agentSetting: "",
introduction: "",
name: "",
});

for await (let str of res.textStream) {
console.log(str);
}

类型声明

function getRecommendQuestions(props: {
botId: string;
name: string;
introduction: string;
agentSetting: string;
msg: string;
history: Array<{
role: string;
content: string;
}>;
});

参数

参数名必填类型说明
props.botIdstringAgent id
props.namestringAgent 名称
props.introductionstringAgent 简介
props.agentSettingstringAgent 设定
props.msgstring用户发送信息
props.historyArray历史对话信息
props.history[n].rolestring历史信息角色
props.history[n].contentstring历史信息内容

BaseChatModelInput

interface BaseChatModelInput {
model: string
messages: Array<ChatModelMessage>
temperature?: number
topP?: number
tools?: Array<FunctionTool>
toolChoice?: 'none' | 'auto' | 'custom'
maxSteps?: number
onStepFinish?: (prop: IOnStepFinish) => unknown
}
BaseChatModelInput 属性名类型说明
modelstring模型名称。
messagesArray<ChatModelMessage>消息列表。
temperaturenumber采样温度,控制输出的随机性。
topPnumber温度采样,即模型考虑概率质量为 top_p 的标记的结果。
toolsArray<FunctionTool>大模型可用的工具列表。
toolChoicestring指定大模型选择工具的方式。
maxStepsnumber请求大模型的最大次数。
onStepFinish(prop: IOnStepFinish) => unknown当对大模型的一次请求完成时,出发的回调函数。

BotInfo

interface BotInfo {
botId: string;
name: string;
introduction: string;
agentSetting: string;
welcomeMessage: string;
avatar: string;
background: string;
tags: Array<string>;
isNeedRecommend: boolean;
knowledgeBase: Array<string>;
type: string;
initQuestions: Array<string>;
enable: true;
}

IUserFeedback

interface IUserFeedback {
recordId: string;
type: string;
botId: string;
comment: string;
rating: number;
tags: Array<string>;
input: string;
aiAnswer: string;
}

ChatModelMessage

type ChatModelMessage = UserMessage | SystemMessage | AssistantMessage | ToolMessage

UserMessage

type UserMessage = {
role: 'user'
content: string
}

SystemMessage

type SystemMessage = {
role: 'system'
content: string
}

AssistantMessage

type AssistantMessage = {
role: 'assistant'
content?: string
tool_calls?: Array<ToolCall>
}

ToolMessage

type ToolMessage = {
role: 'tool'
tool_call_id: string
content: string
}

ToolCall

export type ToolCall = {
id: string
type: string
function: { name: string; arguments: string }
}

FunctionTool

工具定义类型。

type FunctionTool = {
name: string
description: string
fn: CallableFunction
parameters: object
}
FunctionTool 属性名类型说明
namestring工具名称。
descriptionstring工具的描述。清楚的工具描述有助于大模型认识工具的用途。
fnCallableFunction工具的执行函数。当 AI SDK 解析出大模型的响应需要该工具调用时,会调用此函数,并将结果返回给大模型。
parametersobject工具执行函数的入参。需要使用 JSON Schema 的格式定义入参。

IOnStepFinish

大模型响应后出发的回调函数的入参类型。

interface IOnStepFinish {
messages: Array<ChatModelMessage>
text?: string
toolCall?: ToolCall
toolResult?: unknown
finishReason?: string
stepUsage?: Usage
totalUsage?: Usage
}
IOnStepFinish 属性名类型说明
messagesArray<ChatModelMessage>到当前步骤为止所有的消息列表。
textstring当前响应的文本。
toolCallToolCall当前响应调用的工具。
toolResultunknown对应的工具调用结果。
finishReasonstring大模型推理结束的原因。
stepUsageUsage当前步骤所花费的 token。
totalUsageUsage到当前步骤为止所花费的总 token。

Usage

type Usage = {
completion_tokens: number
prompt_tokens: number
total_tokens: number
}