@cloudbase/ai 2.9.0 → 2.9.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/AI.js +43 -10
- package/dist/cjs/utils.d.ts +2 -0
- package/dist/cjs/utils.js +64 -2
- package/dist/esm/AI.js +43 -10
- package/dist/esm/utils.d.ts +2 -0
- package/dist/esm/utils.js +61 -1
- package/package.json +3 -3
- package/src/AI.ts +53 -22
- package/src/utils.ts +16 -0
package/dist/cjs/AI.js
CHANGED
|
@@ -73,6 +73,7 @@ Object.defineProperty(exports, "__esModule", { value: true });
|
|
|
73
73
|
exports.AI = void 0;
|
|
74
74
|
var bot_1 = require("./bot");
|
|
75
75
|
var models = __importStar(require("./models"));
|
|
76
|
+
var utils_1 = require("./utils");
|
|
76
77
|
var MODELS = models.MODELS;
|
|
77
78
|
var AI = (function () {
|
|
78
79
|
function AI(req, baseUrl) {
|
|
@@ -82,9 +83,9 @@ var AI = (function () {
|
|
|
82
83
|
this.modelRequest = function (_a) {
|
|
83
84
|
var url = _a.url, data = _a.data, headers = _a.headers, stream = _a.stream;
|
|
84
85
|
return __awaiter(_this, void 0, void 0, function () {
|
|
85
|
-
var fetchHeaders;
|
|
86
|
-
return __generator(this, function (
|
|
87
|
-
switch (
|
|
86
|
+
var fetchHeaders, _b, responseData, header;
|
|
87
|
+
return __generator(this, function (_c) {
|
|
88
|
+
switch (_c.label) {
|
|
88
89
|
case 0:
|
|
89
90
|
fetchHeaders = {
|
|
90
91
|
'Content-Type': 'application/json',
|
|
@@ -97,7 +98,9 @@ var AI = (function () {
|
|
|
97
98
|
url: url,
|
|
98
99
|
stream: stream,
|
|
99
100
|
})];
|
|
100
|
-
case 1:
|
|
101
|
+
case 1:
|
|
102
|
+
_b = (_c.sent()), responseData = _b.data, header = _b.header;
|
|
103
|
+
return [2, handleResponseData(responseData, header)];
|
|
101
104
|
}
|
|
102
105
|
});
|
|
103
106
|
});
|
|
@@ -113,13 +116,14 @@ var AI = (function () {
|
|
|
113
116
|
})
|
|
114
117
|
.join('&');
|
|
115
118
|
}
|
|
116
|
-
var fetchHeaders;
|
|
117
|
-
return __generator(this, function (
|
|
118
|
-
switch (
|
|
119
|
+
var _c, fetchHeaders, _d, responseData, header;
|
|
120
|
+
return __generator(this, function (_e) {
|
|
121
|
+
switch (_e.label) {
|
|
119
122
|
case 0:
|
|
120
123
|
if (!(method === 'get')) return [3, 2];
|
|
124
|
+
_c = handleResponseData;
|
|
121
125
|
return [4, this.req.fetch({ url: "".concat(url, "?").concat(objectToParam(data)), method: method, headers: headers, stream: stream })];
|
|
122
|
-
case 1: return [2,
|
|
126
|
+
case 1: return [2, _c.apply(void 0, [(_e.sent()).data])];
|
|
123
127
|
case 2:
|
|
124
128
|
fetchHeaders = {
|
|
125
129
|
'Content-Type': 'application/json',
|
|
@@ -132,7 +136,9 @@ var AI = (function () {
|
|
|
132
136
|
stream: stream,
|
|
133
137
|
method: method,
|
|
134
138
|
})];
|
|
135
|
-
case 3:
|
|
139
|
+
case 3:
|
|
140
|
+
_d = (_e.sent()), responseData = _d.data, header = _d.header;
|
|
141
|
+
return [2, handleResponseData(responseData, header)];
|
|
136
142
|
}
|
|
137
143
|
});
|
|
138
144
|
});
|
|
@@ -163,4 +169,31 @@ var AI = (function () {
|
|
|
163
169
|
return AI;
|
|
164
170
|
}());
|
|
165
171
|
exports.AI = AI;
|
|
166
|
-
|
|
172
|
+
var GO_TO_AI_TEXT = '请检查调用方式,或前往云开发 AI+ 首页查看文档:https://tcb.cloud.tencent.com/dev#/ai';
|
|
173
|
+
function handleResponseData(responseData, header) {
|
|
174
|
+
var _a;
|
|
175
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
176
|
+
var json, json;
|
|
177
|
+
return __generator(this, function (_b) {
|
|
178
|
+
switch (_b.label) {
|
|
179
|
+
case 0:
|
|
180
|
+
if (!('then' in responseData)) return [3, 2];
|
|
181
|
+
return [4, responseData];
|
|
182
|
+
case 1:
|
|
183
|
+
json = (_b.sent());
|
|
184
|
+
if ('code' in json && json.code !== 'NORMAL') {
|
|
185
|
+
throw new Error("AI+ \u8BF7\u6C42\u51FA\u9519\uFF0C\u9519\u8BEF\u7801\uFF1A".concat(json.code, "\uFF0C\u9519\u8BEF\u4FE1\u606F\uFF1A").concat(json.message, "\n").concat(GO_TO_AI_TEXT, "\n").concat(JSON.stringify(json, null, 2)));
|
|
186
|
+
}
|
|
187
|
+
return [2, responseData];
|
|
188
|
+
case 2:
|
|
189
|
+
if (!((_a = header === null || header === void 0 ? void 0 : header.get('content-type')) === null || _a === void 0 ? void 0 : _a.includes('application/json'))) return [3, 4];
|
|
190
|
+
return [4, (0, utils_1.readableStream2JsonObject)(responseData)];
|
|
191
|
+
case 3:
|
|
192
|
+
json = _b.sent();
|
|
193
|
+
throw new Error("AI+ \u8BF7\u6C42\u51FA\u9519\uFF0C\u9519\u8BEF\u7801\uFF1A".concat(json.code, "\uFF0C\u9519\u8BEF\u4FE1\u606F\uFF1A").concat(json.message, "\n").concat(GO_TO_AI_TEXT, "\n").concat(JSON.stringify(json, null, 2)));
|
|
194
|
+
case 4: return [2, responseData];
|
|
195
|
+
}
|
|
196
|
+
});
|
|
197
|
+
});
|
|
198
|
+
}
|
|
199
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AI.js","sourceRoot":"","sources":["../../src/AI.ts"],"names":[],"mappings":"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","sourcesContent":["import type { SDKRequestInterface } from '@cloudbase/adapter-interface'\nimport { Bot } from './bot'\nimport * as models from './models'\nimport * as types from './type'\nimport { readableStream2JsonObject } from './utils'\n\nconst { MODELS } = models\n\nclass AI {\n  public aiBaseUrl: string\n  public aiBotBaseUrl: string\n  public bot: Bot\n\n  constructor(private req: SDKRequestInterface, public baseUrl: string) {\n    this.aiBaseUrl = `${baseUrl}/ai`\n    this.aiBotBaseUrl = `${baseUrl}/aibot`\n    this.bot = new Bot(this.botRequest, this.aiBotBaseUrl)\n  }\n\n  createModel<T extends keyof typeof MODELS>(model: T) {\n    const SimpleModelConstructor = MODELS[model]\n    const simpleModel: types.SimpleChatModel = new SimpleModelConstructor(this.modelRequest, this.aiBaseUrl)\n    const reactModel = new models.ReactModel(simpleModel)\n    return reactModel\n  }\n\n  registerModel(name: string, model: types.ChatModelConstructor) {\n    if (MODELS[name] != null) {\n      console.warn(`AI model ${name} already exists!`)\n      return\n    }\n    MODELS[name] = model\n  }\n\n  modelRequest: types.ModelReq = async ({ url, data, headers, stream }) => {\n    const fetchHeaders = {\n      'Content-Type': 'application/json',\n    }\n    // 带 Accept: text/event-stream  请求头显式指定是 SSE 绕过 60s 的限制\n    stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })\n\n    const { data: responseData, header } = (await this.req.fetch({\n      method: 'post',\n      headers: { ...fetchHeaders, ...headers },\n      body: JSON.stringify(data),\n      url,\n      stream,\n    })) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }\n\n    return handleResponseData(responseData, header) as any\n  }\n\n  botRequest: types.BotReq = async ({ method, url, data = {}, headers, stream }) => {\n    if (method === 'get') {\n      return handleResponseData((await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data,)\n    }\n\n    const fetchHeaders = {\n      'Content-Type': 'application/json',\n    }\n    // 带 Accept: text/event-stream  请求头显式指定是 SSE 绕过 60s 的限制\n    stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })\n\n    const { data: responseData, header } = (await this.req.fetch({\n      url,\n      body: JSON.stringify(data),\n      headers: {\n        ...fetchHeaders,\n        ...headers,\n      },\n      stream,\n      method,\n    })) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }\n\n    return handleResponseData(responseData, header) as any\n\n    function objectToParam(obj: Object) {\n      return Object.entries(obj)\n        .map(([key, value]) => `${key}=${value}`)\n        .join('&')\n    }\n  }\n\n  registerFunctionTool(functionTool: types.FunctionTool) {\n    if (models.toolMap.has(functionTool.name)) {\n      console.warn(`AI function tool ${functionTool.name} already exists and will be overwritten!`)\n    }\n    models.toolMap.set(functionTool.name, functionTool.fn)\n  }\n}\n\nexport { AI }\n\nconst GO_TO_AI_TEXT = '请检查调用方式，或前往云开发 AI+ 首页查看文档：https://tcb.cloud.tencent.com/dev#/ai'\n\nasync function handleResponseData(responseData: Promise<unknown> | ReadableStream<Uint8Array>, header?: Headers) {\n  if ('then' in responseData) {\n    // 非流式请求，直接返回 json 数据\n    const json = (await responseData) as Record<string, unknown>\n    if ('code' in json && json.code !== 'NORMAL') {\n      throw new Error(`AI+ 请求出错，错误码：${json.code}，错误信息：${json.message}\\n${GO_TO_AI_TEXT}\\n${JSON.stringify(\n        json,\n        null,\n        2,\n      )}`,)\n    }\n\n    return responseData\n  }\n  // 流式请求，如果接口出错，会变成传 json 格式的响应，通过 header 判断格式\n  if (header?.get('content-type')?.includes('application/json')) {\n    const json = await readableStream2JsonObject(responseData)\n    // 都降为 json 了，就不判断 code 了，直接抛吧\n    throw new Error(`AI+ 请求出错，错误码：${json.code}，错误信息：${json.message}\\n${GO_TO_AI_TEXT}\\n${JSON.stringify(\n      json,\n      null,\n      2,\n    )}`,)\n  } else {\n    return responseData\n  }\n}\n"]}
|
package/dist/cjs/utils.d.ts
CHANGED
|
@@ -27,6 +27,8 @@ export declare class TextDecoderStream {
|
|
|
27
27
|
}
|
|
28
28
|
export declare function createAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableReadableStream<T>;
|
|
29
29
|
export declare function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T>;
|
|
30
|
+
export declare function intoTextStream(stream: ReadableStream<Uint8Array>): AsyncIterableReadableStream<string>;
|
|
31
|
+
export declare function readableStream2JsonObject(stream: ReadableStream): Promise<any>;
|
|
30
32
|
export declare function createPromise<T = unknown>(): {
|
|
31
33
|
promise: Promise<T>;
|
|
32
34
|
res: (value: T | PromiseLike<T>) => void;
|
package/dist/cjs/utils.js
CHANGED
|
@@ -35,8 +35,15 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
35
35
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
36
36
|
}
|
|
37
37
|
};
|
|
38
|
+
var __asyncValues = (this && this.__asyncValues) || function (o) {
|
|
39
|
+
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
40
|
+
var m = o[Symbol.asyncIterator], i;
|
|
41
|
+
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
|
|
42
|
+
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
|
|
43
|
+
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
|
|
44
|
+
};
|
|
38
45
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
39
|
-
exports.functionToolToModelTool = exports.isToolCallAssistantMessage = exports.createPromise = exports.intoStandardStream = exports.createAsyncIterable = exports.TextDecoderStream = exports.toPolyfillReadable = exports.createEventSourceParserTransformStream = exports.TransformStream = exports.ReadableStream = void 0;
|
|
46
|
+
exports.functionToolToModelTool = exports.isToolCallAssistantMessage = exports.createPromise = exports.readableStream2JsonObject = exports.intoTextStream = exports.intoStandardStream = exports.createAsyncIterable = exports.TextDecoderStream = exports.toPolyfillReadable = exports.createEventSourceParserTransformStream = exports.TransformStream = exports.ReadableStream = void 0;
|
|
40
47
|
var web_streams_polyfill_1 = require("web-streams-polyfill");
|
|
41
48
|
var web_streams_adapter_1 = require("@mattiasbuelens/web-streams-adapter");
|
|
42
49
|
var eventsource_parser_1 = require("./eventsource_parser");
|
|
@@ -169,6 +176,61 @@ function intoStandardStream(stream) {
|
|
|
169
176
|
})));
|
|
170
177
|
}
|
|
171
178
|
exports.intoStandardStream = intoStandardStream;
|
|
179
|
+
function intoTextStream(stream) {
|
|
180
|
+
return createAsyncIterable((0, exports.toPolyfillReadable)(stream).pipeThrough(new TextDecoderStream()));
|
|
181
|
+
}
|
|
182
|
+
exports.intoTextStream = intoTextStream;
|
|
183
|
+
function readableStream2JsonObject(stream) {
|
|
184
|
+
var _a, e_1, _b, _c;
|
|
185
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
186
|
+
var s, total, _d, s_1, s_1_1, chunk, e_1_1;
|
|
187
|
+
return __generator(this, function (_e) {
|
|
188
|
+
switch (_e.label) {
|
|
189
|
+
case 0:
|
|
190
|
+
s = intoTextStream(stream);
|
|
191
|
+
total = '';
|
|
192
|
+
_e.label = 1;
|
|
193
|
+
case 1:
|
|
194
|
+
_e.trys.push([1, 6, 7, 12]);
|
|
195
|
+
_d = true, s_1 = __asyncValues(s);
|
|
196
|
+
_e.label = 2;
|
|
197
|
+
case 2: return [4, s_1.next()];
|
|
198
|
+
case 3:
|
|
199
|
+
if (!(s_1_1 = _e.sent(), _a = s_1_1.done, !_a)) return [3, 5];
|
|
200
|
+
_c = s_1_1.value;
|
|
201
|
+
_d = false;
|
|
202
|
+
try {
|
|
203
|
+
chunk = _c;
|
|
204
|
+
total += chunk;
|
|
205
|
+
}
|
|
206
|
+
finally {
|
|
207
|
+
_d = true;
|
|
208
|
+
}
|
|
209
|
+
_e.label = 4;
|
|
210
|
+
case 4: return [3, 2];
|
|
211
|
+
case 5: return [3, 12];
|
|
212
|
+
case 6:
|
|
213
|
+
e_1_1 = _e.sent();
|
|
214
|
+
e_1 = { error: e_1_1 };
|
|
215
|
+
return [3, 12];
|
|
216
|
+
case 7:
|
|
217
|
+
_e.trys.push([7, , 10, 11]);
|
|
218
|
+
if (!(!_d && !_a && (_b = s_1.return))) return [3, 9];
|
|
219
|
+
return [4, _b.call(s_1)];
|
|
220
|
+
case 8:
|
|
221
|
+
_e.sent();
|
|
222
|
+
_e.label = 9;
|
|
223
|
+
case 9: return [3, 11];
|
|
224
|
+
case 10:
|
|
225
|
+
if (e_1) throw e_1.error;
|
|
226
|
+
return [7];
|
|
227
|
+
case 11: return [7];
|
|
228
|
+
case 12: return [2, JSON.parse(total)];
|
|
229
|
+
}
|
|
230
|
+
});
|
|
231
|
+
});
|
|
232
|
+
}
|
|
233
|
+
exports.readableStream2JsonObject = readableStream2JsonObject;
|
|
172
234
|
function createPromise() {
|
|
173
235
|
var res;
|
|
174
236
|
var rej;
|
|
@@ -194,4 +256,4 @@ function functionToolToModelTool(tool) {
|
|
|
194
256
|
};
|
|
195
257
|
}
|
|
196
258
|
exports.functionToolToModelTool = functionToolToModelTool;
|
|
197
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransformStream as _TransformStream, ReadableStream as _ReadableStream } from 'web-streams-polyfill'\nimport { createReadableStreamWrapper } from '@mattiasbuelens/web-streams-adapter'\nimport { createParser, type EventSourceParser, type ParsedEvent } from './eventsource_parser'\nimport type {\n  AsyncIterableReadableStream,\n  ChatModelMessage,\n  ToolCallAssistantMessage,\n  ModelTool,\n  FunctionTool,\n} from './type'\nimport { TextDecoder } from 'text-encoding-shim'\n\nexport const ReadableStream = _ReadableStream as {\n  prototype: ReadableStream\n\n  new (\n    underlyingSource: UnderlyingByteSource,\n    strategy?: {\n      highWaterMark?: number\n    },\n  ): ReadableStream<Uint8Array>\n  new <R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n  new <R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n}\n\nexport const TransformStream = _TransformStream as {\n  prototype: TransformStream\n\n  new <I = any, O = any>(\n    transformer?: Transformer<I, O>,\n    writableStrategy?: QueuingStrategy<I>,\n    readableStrategy?: QueuingStrategy<O>,\n  ): TransformStream<I, O>\n}\n\nexport const createEventSourceParserTransformStream = () => {\n  let parser!: EventSourceParser\n\n  return new TransformStream<string, ParsedEvent>({\n    start(controller) {\n      parser = createParser((event) => {\n        if (event.type === 'event') {\n          controller.enqueue(event)\n        }\n      })\n    },\n    transform(chunk) {\n      parser.feed(chunk)\n    },\n  })\n}\n\nexport const toPolyfillReadable = createReadableStreamWrapper(ReadableStream)\n\nexport class TextDecoderStream {\n  private handle: TextDecoder\n\n  private transform = new TransformStream({\n    transform: (chunk, controller) => {\n      const value = this.handle.decode(new Uint8Array(chunk), { stream: true })\n\n      if (value) {\n        controller.enqueue(value)\n      }\n    },\n    flush: (controller) => {\n      const value = this.handle.decode()\n      if (value) {\n        controller.enqueue(value)\n      }\n\n      controller.terminate()\n    },\n  })\n\n  constructor(encoding = 'utf-8', options: TextDecoderOptions = {}) {\n    this.handle = new TextDecoder(encoding, options)\n  }\n\n  get encoding() {\n    return this.handle.encoding\n  }\n\n  get fatal() {\n    return this.handle.fatal\n  }\n\n  get ignoreBOM() {\n    return this.handle.ignoreBOM\n  }\n\n  get readable() {\n    return this.transform.readable\n  }\n\n  get writable() {\n    return this.transform.writable\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'TextDecoderStream'\n  }\n}\n\nexport function createAsyncIterable<T>(stream: ReadableStream<T>) {\n  const _stream = stream as AsyncIterableReadableStream<T>\n  _stream[Symbol.asyncIterator] = () => {\n    const reader = stream.getReader()\n    return {\n      async next(): Promise<IteratorResult<T>> {\n        const { done, value } = await reader.read()\n        return done ? { done: true, value: undefined } : { done: false, value }\n      },\n    }\n  }\n  return _stream\n}\n\n/**\n * 将 SSE 二进制流转换为 T 类型的流\n */\nexport function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T> {\n  return createAsyncIterable(stream\n    .pipeThrough(new TextDecoderStream())\n    .pipeThrough(createEventSourceParserTransformStream())\n    .pipeThrough(new TransformStream<ParsedEvent, T>({\n      transform(chunk, controller) {\n        try {\n          const data = JSON.parse(chunk.data) as T\n          controller.enqueue(data)\n        } catch (e) {\n          if (chunk.data !== '[DONE]') {\n            console.warn('Error when transforming event source data to json', e, chunk)\n          }\n        }\n      },\n    }),),)\n}\n\nexport function createPromise<T = unknown>() {\n  let res: (value: T | PromiseLike<T>) => void\n  let rej: (reason?: any) => void\n  const promise = new Promise<T>((resolve, reject) => {\n    res = resolve\n    rej = reject\n  })\n  return { promise, res, rej }\n}\n\nexport function isToolCallAssistantMessage(message: ChatModelMessage): message is ToolCallAssistantMessage {\n  return message.role === 'assistant' && 'tool_calls' in message && message.tool_calls[0] != null\n}\n\nexport function functionToolToModelTool(tool: FunctionTool): ModelTool {\n  return {\n    type: 'function',\n    function: {\n      description: tool.description,\n      name: tool.name,\n      parameters: tool.parameters,\n    },\n  }\n}\n"]}
|
|
259
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransformStream as _TransformStream, ReadableStream as _ReadableStream } from 'web-streams-polyfill'\nimport { createReadableStreamWrapper } from '@mattiasbuelens/web-streams-adapter'\nimport { createParser, type EventSourceParser, type ParsedEvent } from './eventsource_parser'\nimport type {\n  AsyncIterableReadableStream,\n  ChatModelMessage,\n  ToolCallAssistantMessage,\n  ModelTool,\n  FunctionTool,\n} from './type'\nimport { TextDecoder } from 'text-encoding-shim'\n\nexport const ReadableStream = _ReadableStream as {\n  prototype: ReadableStream\n\n  new (\n    underlyingSource: UnderlyingByteSource,\n    strategy?: {\n      highWaterMark?: number\n    },\n  ): ReadableStream<Uint8Array>\n  new <R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n  new <R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n}\n\nexport const TransformStream = _TransformStream as {\n  prototype: TransformStream\n\n  new <I = any, O = any>(\n    transformer?: Transformer<I, O>,\n    writableStrategy?: QueuingStrategy<I>,\n    readableStrategy?: QueuingStrategy<O>,\n  ): TransformStream<I, O>\n}\n\nexport const createEventSourceParserTransformStream = () => {\n  let parser!: EventSourceParser\n\n  return new TransformStream<string, ParsedEvent>({\n    start(controller) {\n      parser = createParser((event) => {\n        if (event.type === 'event') {\n          controller.enqueue(event)\n        }\n      })\n    },\n    transform(chunk) {\n      parser.feed(chunk)\n    },\n  })\n}\n\nexport const toPolyfillReadable = createReadableStreamWrapper(ReadableStream)\n\nexport class TextDecoderStream {\n  private handle: TextDecoder\n\n  private transform = new TransformStream({\n    transform: (chunk, controller) => {\n      const value = this.handle.decode(new Uint8Array(chunk), { stream: true })\n\n      if (value) {\n        controller.enqueue(value)\n      }\n    },\n    flush: (controller) => {\n      const value = this.handle.decode()\n      if (value) {\n        controller.enqueue(value)\n      }\n\n      controller.terminate()\n    },\n  })\n\n  constructor(encoding = 'utf-8', options: TextDecoderOptions = {}) {\n    this.handle = new TextDecoder(encoding, options)\n  }\n\n  get encoding() {\n    return this.handle.encoding\n  }\n\n  get fatal() {\n    return this.handle.fatal\n  }\n\n  get ignoreBOM() {\n    return this.handle.ignoreBOM\n  }\n\n  get readable() {\n    return this.transform.readable\n  }\n\n  get writable() {\n    return this.transform.writable\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'TextDecoderStream'\n  }\n}\n\nexport function createAsyncIterable<T>(stream: ReadableStream<T>) {\n  const _stream = stream as AsyncIterableReadableStream<T>\n  _stream[Symbol.asyncIterator] = () => {\n    const reader = stream.getReader()\n    return {\n      async next(): Promise<IteratorResult<T>> {\n        const { done, value } = await reader.read()\n        return done ? { done: true, value: undefined } : { done: false, value }\n      },\n    }\n  }\n  return _stream\n}\n\n/**\n * 将 SSE 二进制流转换为 T 类型的流\n */\nexport function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T> {\n  return createAsyncIterable(stream\n    .pipeThrough(new TextDecoderStream())\n    .pipeThrough(createEventSourceParserTransformStream())\n    .pipeThrough(new TransformStream<ParsedEvent, T>({\n      transform(chunk, controller) {\n        try {\n          const data = JSON.parse(chunk.data) as T\n          controller.enqueue(data)\n        } catch (e) {\n          if (chunk.data !== '[DONE]') {\n            console.warn('Error when transforming event source data to json', e, chunk)\n          }\n        }\n      },\n    }),),)\n}\n\n/**\n * 将 SSE 二进制流转换为字符串流\n */\nexport function intoTextStream(stream: ReadableStream<Uint8Array>): AsyncIterableReadableStream<string> {\n  return createAsyncIterable((toPolyfillReadable(stream) as typeof stream).pipeThrough(new TextDecoderStream()))\n}\n\nexport async function readableStream2JsonObject(stream: ReadableStream) {\n  const s = intoTextStream(stream)\n  let total = ''\n  for await (const chunk of s) {\n    total += chunk\n  }\n  return JSON.parse(total)\n}\n\nexport function createPromise<T = unknown>() {\n  let res: (value: T | PromiseLike<T>) => void\n  let rej: (reason?: any) => void\n  const promise = new Promise<T>((resolve, reject) => {\n    res = resolve\n    rej = reject\n  })\n  return { promise, res, rej }\n}\n\nexport function isToolCallAssistantMessage(message: ChatModelMessage): message is ToolCallAssistantMessage {\n  return message.role === 'assistant' && 'tool_calls' in message && message.tool_calls[0] != null\n}\n\nexport function functionToolToModelTool(tool: FunctionTool): ModelTool {\n  return {\n    type: 'function',\n    function: {\n      description: tool.description,\n      name: tool.name,\n      parameters: tool.parameters,\n    },\n  }\n}\n"]}
|
package/dist/esm/AI.js
CHANGED
|
@@ -47,6 +47,7 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
47
47
|
};
|
|
48
48
|
import { Bot } from './bot';
|
|
49
49
|
import * as models from './models';
|
|
50
|
+
import { readableStream2JsonObject } from './utils';
|
|
50
51
|
var MODELS = models.MODELS;
|
|
51
52
|
var AI = (function () {
|
|
52
53
|
function AI(req, baseUrl) {
|
|
@@ -56,9 +57,9 @@ var AI = (function () {
|
|
|
56
57
|
this.modelRequest = function (_a) {
|
|
57
58
|
var url = _a.url, data = _a.data, headers = _a.headers, stream = _a.stream;
|
|
58
59
|
return __awaiter(_this, void 0, void 0, function () {
|
|
59
|
-
var fetchHeaders;
|
|
60
|
-
return __generator(this, function (
|
|
61
|
-
switch (
|
|
60
|
+
var fetchHeaders, _b, responseData, header;
|
|
61
|
+
return __generator(this, function (_c) {
|
|
62
|
+
switch (_c.label) {
|
|
62
63
|
case 0:
|
|
63
64
|
fetchHeaders = {
|
|
64
65
|
'Content-Type': 'application/json',
|
|
@@ -71,7 +72,9 @@ var AI = (function () {
|
|
|
71
72
|
url: url,
|
|
72
73
|
stream: stream,
|
|
73
74
|
})];
|
|
74
|
-
case 1:
|
|
75
|
+
case 1:
|
|
76
|
+
_b = (_c.sent()), responseData = _b.data, header = _b.header;
|
|
77
|
+
return [2, handleResponseData(responseData, header)];
|
|
75
78
|
}
|
|
76
79
|
});
|
|
77
80
|
});
|
|
@@ -87,13 +90,14 @@ var AI = (function () {
|
|
|
87
90
|
})
|
|
88
91
|
.join('&');
|
|
89
92
|
}
|
|
90
|
-
var fetchHeaders;
|
|
91
|
-
return __generator(this, function (
|
|
92
|
-
switch (
|
|
93
|
+
var _c, fetchHeaders, _d, responseData, header;
|
|
94
|
+
return __generator(this, function (_e) {
|
|
95
|
+
switch (_e.label) {
|
|
93
96
|
case 0:
|
|
94
97
|
if (!(method === 'get')) return [3, 2];
|
|
98
|
+
_c = handleResponseData;
|
|
95
99
|
return [4, this.req.fetch({ url: "".concat(url, "?").concat(objectToParam(data)), method: method, headers: headers, stream: stream })];
|
|
96
|
-
case 1: return [2,
|
|
100
|
+
case 1: return [2, _c.apply(void 0, [(_e.sent()).data])];
|
|
97
101
|
case 2:
|
|
98
102
|
fetchHeaders = {
|
|
99
103
|
'Content-Type': 'application/json',
|
|
@@ -106,7 +110,9 @@ var AI = (function () {
|
|
|
106
110
|
stream: stream,
|
|
107
111
|
method: method,
|
|
108
112
|
})];
|
|
109
|
-
case 3:
|
|
113
|
+
case 3:
|
|
114
|
+
_d = (_e.sent()), responseData = _d.data, header = _d.header;
|
|
115
|
+
return [2, handleResponseData(responseData, header)];
|
|
110
116
|
}
|
|
111
117
|
});
|
|
112
118
|
});
|
|
@@ -137,4 +143,31 @@ var AI = (function () {
|
|
|
137
143
|
return AI;
|
|
138
144
|
}());
|
|
139
145
|
export { AI };
|
|
140
|
-
|
|
146
|
+
var GO_TO_AI_TEXT = '请检查调用方式,或前往云开发 AI+ 首页查看文档:https://tcb.cloud.tencent.com/dev#/ai';
|
|
147
|
+
function handleResponseData(responseData, header) {
|
|
148
|
+
var _a;
|
|
149
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
150
|
+
var json, json;
|
|
151
|
+
return __generator(this, function (_b) {
|
|
152
|
+
switch (_b.label) {
|
|
153
|
+
case 0:
|
|
154
|
+
if (!('then' in responseData)) return [3, 2];
|
|
155
|
+
return [4, responseData];
|
|
156
|
+
case 1:
|
|
157
|
+
json = (_b.sent());
|
|
158
|
+
if ('code' in json && json.code !== 'NORMAL') {
|
|
159
|
+
throw new Error("AI+ \u8BF7\u6C42\u51FA\u9519\uFF0C\u9519\u8BEF\u7801\uFF1A".concat(json.code, "\uFF0C\u9519\u8BEF\u4FE1\u606F\uFF1A").concat(json.message, "\n").concat(GO_TO_AI_TEXT, "\n").concat(JSON.stringify(json, null, 2)));
|
|
160
|
+
}
|
|
161
|
+
return [2, responseData];
|
|
162
|
+
case 2:
|
|
163
|
+
if (!((_a = header === null || header === void 0 ? void 0 : header.get('content-type')) === null || _a === void 0 ? void 0 : _a.includes('application/json'))) return [3, 4];
|
|
164
|
+
return [4, readableStream2JsonObject(responseData)];
|
|
165
|
+
case 3:
|
|
166
|
+
json = _b.sent();
|
|
167
|
+
throw new Error("AI+ \u8BF7\u6C42\u51FA\u9519\uFF0C\u9519\u8BEF\u7801\uFF1A".concat(json.code, "\uFF0C\u9519\u8BEF\u4FE1\u606F\uFF1A").concat(json.message, "\n").concat(GO_TO_AI_TEXT, "\n").concat(JSON.stringify(json, null, 2)));
|
|
168
|
+
case 4: return [2, responseData];
|
|
169
|
+
}
|
|
170
|
+
});
|
|
171
|
+
});
|
|
172
|
+
}
|
|
173
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"AI.js","sourceRoot":"","sources":["../../src/AI.ts"],"names":[],"mappings":"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","sourcesContent":["import type { SDKRequestInterface } from '@cloudbase/adapter-interface'\nimport { Bot } from './bot'\nimport * as models from './models'\nimport * as types from './type'\nimport { readableStream2JsonObject } from './utils'\n\nconst { MODELS } = models\n\nclass AI {\n  public aiBaseUrl: string\n  public aiBotBaseUrl: string\n  public bot: Bot\n\n  constructor(private req: SDKRequestInterface, public baseUrl: string) {\n    this.aiBaseUrl = `${baseUrl}/ai`\n    this.aiBotBaseUrl = `${baseUrl}/aibot`\n    this.bot = new Bot(this.botRequest, this.aiBotBaseUrl)\n  }\n\n  createModel<T extends keyof typeof MODELS>(model: T) {\n    const SimpleModelConstructor = MODELS[model]\n    const simpleModel: types.SimpleChatModel = new SimpleModelConstructor(this.modelRequest, this.aiBaseUrl)\n    const reactModel = new models.ReactModel(simpleModel)\n    return reactModel\n  }\n\n  registerModel(name: string, model: types.ChatModelConstructor) {\n    if (MODELS[name] != null) {\n      console.warn(`AI model ${name} already exists!`)\n      return\n    }\n    MODELS[name] = model\n  }\n\n  modelRequest: types.ModelReq = async ({ url, data, headers, stream }) => {\n    const fetchHeaders = {\n      'Content-Type': 'application/json',\n    }\n    // 带 Accept: text/event-stream  请求头显式指定是 SSE 绕过 60s 的限制\n    stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })\n\n    const { data: responseData, header } = (await this.req.fetch({\n      method: 'post',\n      headers: { ...fetchHeaders, ...headers },\n      body: JSON.stringify(data),\n      url,\n      stream,\n    })) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }\n\n    return handleResponseData(responseData, header) as any\n  }\n\n  botRequest: types.BotReq = async ({ method, url, data = {}, headers, stream }) => {\n    if (method === 'get') {\n      return handleResponseData((await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data,)\n    }\n\n    const fetchHeaders = {\n      'Content-Type': 'application/json',\n    }\n    // 带 Accept: text/event-stream  请求头显式指定是 SSE 绕过 60s 的限制\n    stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })\n\n    const { data: responseData, header } = (await this.req.fetch({\n      url,\n      body: JSON.stringify(data),\n      headers: {\n        ...fetchHeaders,\n        ...headers,\n      },\n      stream,\n      method,\n    })) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }\n\n    return handleResponseData(responseData, header) as any\n\n    function objectToParam(obj: Object) {\n      return Object.entries(obj)\n        .map(([key, value]) => `${key}=${value}`)\n        .join('&')\n    }\n  }\n\n  registerFunctionTool(functionTool: types.FunctionTool) {\n    if (models.toolMap.has(functionTool.name)) {\n      console.warn(`AI function tool ${functionTool.name} already exists and will be overwritten!`)\n    }\n    models.toolMap.set(functionTool.name, functionTool.fn)\n  }\n}\n\nexport { AI }\n\nconst GO_TO_AI_TEXT = '请检查调用方式，或前往云开发 AI+ 首页查看文档：https://tcb.cloud.tencent.com/dev#/ai'\n\nasync function handleResponseData(responseData: Promise<unknown> | ReadableStream<Uint8Array>, header?: Headers) {\n  if ('then' in responseData) {\n    // 非流式请求，直接返回 json 数据\n    const json = (await responseData) as Record<string, unknown>\n    if ('code' in json && json.code !== 'NORMAL') {\n      throw new Error(`AI+ 请求出错，错误码：${json.code}，错误信息：${json.message}\\n${GO_TO_AI_TEXT}\\n${JSON.stringify(\n        json,\n        null,\n        2,\n      )}`,)\n    }\n\n    return responseData\n  }\n  // 流式请求，如果接口出错，会变成传 json 格式的响应，通过 header 判断格式\n  if (header?.get('content-type')?.includes('application/json')) {\n    const json = await readableStream2JsonObject(responseData)\n    // 都降为 json 了，就不判断 code 了，直接抛吧\n    throw new Error(`AI+ 请求出错，错误码：${json.code}，错误信息：${json.message}\\n${GO_TO_AI_TEXT}\\n${JSON.stringify(\n      json,\n      null,\n      2,\n    )}`,)\n  } else {\n    return responseData\n  }\n}\n"]}
|
package/dist/esm/utils.d.ts
CHANGED
|
@@ -27,6 +27,8 @@ export declare class TextDecoderStream {
|
|
|
27
27
|
}
|
|
28
28
|
export declare function createAsyncIterable<T>(stream: ReadableStream<T>): AsyncIterableReadableStream<T>;
|
|
29
29
|
export declare function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T>;
|
|
30
|
+
export declare function intoTextStream(stream: ReadableStream<Uint8Array>): AsyncIterableReadableStream<string>;
|
|
31
|
+
export declare function readableStream2JsonObject(stream: ReadableStream): Promise<any>;
|
|
30
32
|
export declare function createPromise<T = unknown>(): {
|
|
31
33
|
promise: Promise<T>;
|
|
32
34
|
res: (value: T | PromiseLike<T>) => void;
|
package/dist/esm/utils.js
CHANGED
|
@@ -34,6 +34,13 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
34
34
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
35
35
|
}
|
|
36
36
|
};
|
|
37
|
+
var __asyncValues = (this && this.__asyncValues) || function (o) {
|
|
38
|
+
if (!Symbol.asyncIterator) throw new TypeError("Symbol.asyncIterator is not defined.");
|
|
39
|
+
var m = o[Symbol.asyncIterator], i;
|
|
40
|
+
return m ? m.call(o) : (o = typeof __values === "function" ? __values(o) : o[Symbol.iterator](), i = {}, verb("next"), verb("throw"), verb("return"), i[Symbol.asyncIterator] = function () { return this; }, i);
|
|
41
|
+
function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }
|
|
42
|
+
function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }
|
|
43
|
+
};
|
|
37
44
|
import { TransformStream as _TransformStream, ReadableStream as _ReadableStream } from 'web-streams-polyfill';
|
|
38
45
|
import { createReadableStreamWrapper } from '@mattiasbuelens/web-streams-adapter';
|
|
39
46
|
import { createParser } from './eventsource_parser';
|
|
@@ -163,6 +170,59 @@ export function intoStandardStream(stream) {
|
|
|
163
170
|
},
|
|
164
171
|
})));
|
|
165
172
|
}
|
|
173
|
+
export function intoTextStream(stream) {
|
|
174
|
+
return createAsyncIterable(toPolyfillReadable(stream).pipeThrough(new TextDecoderStream()));
|
|
175
|
+
}
|
|
176
|
+
export function readableStream2JsonObject(stream) {
|
|
177
|
+
var _a, e_1, _b, _c;
|
|
178
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
179
|
+
var s, total, _d, s_1, s_1_1, chunk, e_1_1;
|
|
180
|
+
return __generator(this, function (_e) {
|
|
181
|
+
switch (_e.label) {
|
|
182
|
+
case 0:
|
|
183
|
+
s = intoTextStream(stream);
|
|
184
|
+
total = '';
|
|
185
|
+
_e.label = 1;
|
|
186
|
+
case 1:
|
|
187
|
+
_e.trys.push([1, 6, 7, 12]);
|
|
188
|
+
_d = true, s_1 = __asyncValues(s);
|
|
189
|
+
_e.label = 2;
|
|
190
|
+
case 2: return [4, s_1.next()];
|
|
191
|
+
case 3:
|
|
192
|
+
if (!(s_1_1 = _e.sent(), _a = s_1_1.done, !_a)) return [3, 5];
|
|
193
|
+
_c = s_1_1.value;
|
|
194
|
+
_d = false;
|
|
195
|
+
try {
|
|
196
|
+
chunk = _c;
|
|
197
|
+
total += chunk;
|
|
198
|
+
}
|
|
199
|
+
finally {
|
|
200
|
+
_d = true;
|
|
201
|
+
}
|
|
202
|
+
_e.label = 4;
|
|
203
|
+
case 4: return [3, 2];
|
|
204
|
+
case 5: return [3, 12];
|
|
205
|
+
case 6:
|
|
206
|
+
e_1_1 = _e.sent();
|
|
207
|
+
e_1 = { error: e_1_1 };
|
|
208
|
+
return [3, 12];
|
|
209
|
+
case 7:
|
|
210
|
+
_e.trys.push([7, , 10, 11]);
|
|
211
|
+
if (!(!_d && !_a && (_b = s_1.return))) return [3, 9];
|
|
212
|
+
return [4, _b.call(s_1)];
|
|
213
|
+
case 8:
|
|
214
|
+
_e.sent();
|
|
215
|
+
_e.label = 9;
|
|
216
|
+
case 9: return [3, 11];
|
|
217
|
+
case 10:
|
|
218
|
+
if (e_1) throw e_1.error;
|
|
219
|
+
return [7];
|
|
220
|
+
case 11: return [7];
|
|
221
|
+
case 12: return [2, JSON.parse(total)];
|
|
222
|
+
}
|
|
223
|
+
});
|
|
224
|
+
});
|
|
225
|
+
}
|
|
166
226
|
export function createPromise() {
|
|
167
227
|
var res;
|
|
168
228
|
var rej;
|
|
@@ -185,4 +245,4 @@ export function functionToolToModelTool(tool) {
|
|
|
185
245
|
},
|
|
186
246
|
};
|
|
187
247
|
}
|
|
188
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransformStream as _TransformStream, ReadableStream as _ReadableStream } from 'web-streams-polyfill'\nimport { createReadableStreamWrapper } from '@mattiasbuelens/web-streams-adapter'\nimport { createParser, type EventSourceParser, type ParsedEvent } from './eventsource_parser'\nimport type {\n  AsyncIterableReadableStream,\n  ChatModelMessage,\n  ToolCallAssistantMessage,\n  ModelTool,\n  FunctionTool,\n} from './type'\nimport { TextDecoder } from 'text-encoding-shim'\n\nexport const ReadableStream = _ReadableStream as {\n  prototype: ReadableStream\n\n  new (\n    underlyingSource: UnderlyingByteSource,\n    strategy?: {\n      highWaterMark?: number\n    },\n  ): ReadableStream<Uint8Array>\n  new <R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n  new <R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n}\n\nexport const TransformStream = _TransformStream as {\n  prototype: TransformStream\n\n  new <I = any, O = any>(\n    transformer?: Transformer<I, O>,\n    writableStrategy?: QueuingStrategy<I>,\n    readableStrategy?: QueuingStrategy<O>,\n  ): TransformStream<I, O>\n}\n\nexport const createEventSourceParserTransformStream = () => {\n  let parser!: EventSourceParser\n\n  return new TransformStream<string, ParsedEvent>({\n    start(controller) {\n      parser = createParser((event) => {\n        if (event.type === 'event') {\n          controller.enqueue(event)\n        }\n      })\n    },\n    transform(chunk) {\n      parser.feed(chunk)\n    },\n  })\n}\n\nexport const toPolyfillReadable = createReadableStreamWrapper(ReadableStream)\n\nexport class TextDecoderStream {\n  private handle: TextDecoder\n\n  private transform = new TransformStream({\n    transform: (chunk, controller) => {\n      const value = this.handle.decode(new Uint8Array(chunk), { stream: true })\n\n      if (value) {\n        controller.enqueue(value)\n      }\n    },\n    flush: (controller) => {\n      const value = this.handle.decode()\n      if (value) {\n        controller.enqueue(value)\n      }\n\n      controller.terminate()\n    },\n  })\n\n  constructor(encoding = 'utf-8', options: TextDecoderOptions = {}) {\n    this.handle = new TextDecoder(encoding, options)\n  }\n\n  get encoding() {\n    return this.handle.encoding\n  }\n\n  get fatal() {\n    return this.handle.fatal\n  }\n\n  get ignoreBOM() {\n    return this.handle.ignoreBOM\n  }\n\n  get readable() {\n    return this.transform.readable\n  }\n\n  get writable() {\n    return this.transform.writable\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'TextDecoderStream'\n  }\n}\n\nexport function createAsyncIterable<T>(stream: ReadableStream<T>) {\n  const _stream = stream as AsyncIterableReadableStream<T>\n  _stream[Symbol.asyncIterator] = () => {\n    const reader = stream.getReader()\n    return {\n      async next(): Promise<IteratorResult<T>> {\n        const { done, value } = await reader.read()\n        return done ? { done: true, value: undefined } : { done: false, value }\n      },\n    }\n  }\n  return _stream\n}\n\n/**\n * 将 SSE 二进制流转换为 T 类型的流\n */\nexport function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T> {\n  return createAsyncIterable(stream\n    .pipeThrough(new TextDecoderStream())\n    .pipeThrough(createEventSourceParserTransformStream())\n    .pipeThrough(new TransformStream<ParsedEvent, T>({\n      transform(chunk, controller) {\n        try {\n          const data = JSON.parse(chunk.data) as T\n          controller.enqueue(data)\n        } catch (e) {\n          if (chunk.data !== '[DONE]') {\n            console.warn('Error when transforming event source data to json', e, chunk)\n          }\n        }\n      },\n    }),),)\n}\n\nexport function createPromise<T = unknown>() {\n  let res: (value: T | PromiseLike<T>) => void\n  let rej: (reason?: any) => void\n  const promise = new Promise<T>((resolve, reject) => {\n    res = resolve\n    rej = reject\n  })\n  return { promise, res, rej }\n}\n\nexport function isToolCallAssistantMessage(message: ChatModelMessage): message is ToolCallAssistantMessage {\n  return message.role === 'assistant' && 'tool_calls' in message && message.tool_calls[0] != null\n}\n\nexport function functionToolToModelTool(tool: FunctionTool): ModelTool {\n  return {\n    type: 'function',\n    function: {\n      description: tool.description,\n      name: tool.name,\n      parameters: tool.parameters,\n    },\n  }\n}\n"]}
|
|
248
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"utils.js","sourceRoot":"","sources":["../../src/utils.ts"],"names":[],"mappings":"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","sourcesContent":["import { TransformStream as _TransformStream, ReadableStream as _ReadableStream } from 'web-streams-polyfill'\nimport { createReadableStreamWrapper } from '@mattiasbuelens/web-streams-adapter'\nimport { createParser, type EventSourceParser, type ParsedEvent } from './eventsource_parser'\nimport type {\n  AsyncIterableReadableStream,\n  ChatModelMessage,\n  ToolCallAssistantMessage,\n  ModelTool,\n  FunctionTool,\n} from './type'\nimport { TextDecoder } from 'text-encoding-shim'\n\nexport const ReadableStream = _ReadableStream as {\n  prototype: ReadableStream\n\n  new (\n    underlyingSource: UnderlyingByteSource,\n    strategy?: {\n      highWaterMark?: number\n    },\n  ): ReadableStream<Uint8Array>\n  new <R = any>(underlyingSource: UnderlyingDefaultSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n  new <R = any>(underlyingSource?: UnderlyingSource<R>, strategy?: QueuingStrategy<R>): ReadableStream<R>\n}\n\nexport const TransformStream = _TransformStream as {\n  prototype: TransformStream\n\n  new <I = any, O = any>(\n    transformer?: Transformer<I, O>,\n    writableStrategy?: QueuingStrategy<I>,\n    readableStrategy?: QueuingStrategy<O>,\n  ): TransformStream<I, O>\n}\n\nexport const createEventSourceParserTransformStream = () => {\n  let parser!: EventSourceParser\n\n  return new TransformStream<string, ParsedEvent>({\n    start(controller) {\n      parser = createParser((event) => {\n        if (event.type === 'event') {\n          controller.enqueue(event)\n        }\n      })\n    },\n    transform(chunk) {\n      parser.feed(chunk)\n    },\n  })\n}\n\nexport const toPolyfillReadable = createReadableStreamWrapper(ReadableStream)\n\nexport class TextDecoderStream {\n  private handle: TextDecoder\n\n  private transform = new TransformStream({\n    transform: (chunk, controller) => {\n      const value = this.handle.decode(new Uint8Array(chunk), { stream: true })\n\n      if (value) {\n        controller.enqueue(value)\n      }\n    },\n    flush: (controller) => {\n      const value = this.handle.decode()\n      if (value) {\n        controller.enqueue(value)\n      }\n\n      controller.terminate()\n    },\n  })\n\n  constructor(encoding = 'utf-8', options: TextDecoderOptions = {}) {\n    this.handle = new TextDecoder(encoding, options)\n  }\n\n  get encoding() {\n    return this.handle.encoding\n  }\n\n  get fatal() {\n    return this.handle.fatal\n  }\n\n  get ignoreBOM() {\n    return this.handle.ignoreBOM\n  }\n\n  get readable() {\n    return this.transform.readable\n  }\n\n  get writable() {\n    return this.transform.writable\n  }\n\n  get [Symbol.toStringTag]() {\n    return 'TextDecoderStream'\n  }\n}\n\nexport function createAsyncIterable<T>(stream: ReadableStream<T>) {\n  const _stream = stream as AsyncIterableReadableStream<T>\n  _stream[Symbol.asyncIterator] = () => {\n    const reader = stream.getReader()\n    return {\n      async next(): Promise<IteratorResult<T>> {\n        const { done, value } = await reader.read()\n        return done ? { done: true, value: undefined } : { done: false, value }\n      },\n    }\n  }\n  return _stream\n}\n\n/**\n * 将 SSE 二进制流转换为 T 类型的流\n */\nexport function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): ReadableStream<T> {\n  return createAsyncIterable(stream\n    .pipeThrough(new TextDecoderStream())\n    .pipeThrough(createEventSourceParserTransformStream())\n    .pipeThrough(new TransformStream<ParsedEvent, T>({\n      transform(chunk, controller) {\n        try {\n          const data = JSON.parse(chunk.data) as T\n          controller.enqueue(data)\n        } catch (e) {\n          if (chunk.data !== '[DONE]') {\n            console.warn('Error when transforming event source data to json', e, chunk)\n          }\n        }\n      },\n    }),),)\n}\n\n/**\n * 将 SSE 二进制流转换为字符串流\n */\nexport function intoTextStream(stream: ReadableStream<Uint8Array>): AsyncIterableReadableStream<string> {\n  return createAsyncIterable((toPolyfillReadable(stream) as typeof stream).pipeThrough(new TextDecoderStream()))\n}\n\nexport async function readableStream2JsonObject(stream: ReadableStream) {\n  const s = intoTextStream(stream)\n  let total = ''\n  for await (const chunk of s) {\n    total += chunk\n  }\n  return JSON.parse(total)\n}\n\nexport function createPromise<T = unknown>() {\n  let res: (value: T | PromiseLike<T>) => void\n  let rej: (reason?: any) => void\n  const promise = new Promise<T>((resolve, reject) => {\n    res = resolve\n    rej = reject\n  })\n  return { promise, res, rej }\n}\n\nexport function isToolCallAssistantMessage(message: ChatModelMessage): message is ToolCallAssistantMessage {\n  return message.role === 'assistant' && 'tool_calls' in message && message.tool_calls[0] != null\n}\n\nexport function functionToolToModelTool(tool: FunctionTool): ModelTool {\n  return {\n    type: 'function',\n    function: {\n      description: tool.description,\n      name: tool.name,\n      parameters: tool.parameters,\n    },\n  }\n}\n"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@cloudbase/ai",
|
|
3
|
-
"version": "2.9.
|
|
3
|
+
"version": "2.9.1",
|
|
4
4
|
"description": "cloudbase js sdk ai module",
|
|
5
5
|
"main": "dist/cjs/index.js",
|
|
6
6
|
"module": "dist/esm/index.js",
|
|
@@ -27,7 +27,7 @@
|
|
|
27
27
|
"author": "",
|
|
28
28
|
"license": "Apache-2.0",
|
|
29
29
|
"dependencies": {
|
|
30
|
-
"@cloudbase/types": "^2.9.
|
|
30
|
+
"@cloudbase/types": "^2.9.1",
|
|
31
31
|
"@mattiasbuelens/web-streams-adapter": "^0.1.0",
|
|
32
32
|
"text-encoding-shim": "^1.0.5",
|
|
33
33
|
"web-streams-polyfill": "^4.0.0"
|
|
@@ -35,5 +35,5 @@
|
|
|
35
35
|
"devDependencies": {
|
|
36
36
|
"@cloudbase/adapter-interface": "^0.6.0"
|
|
37
37
|
},
|
|
38
|
-
"gitHead": "
|
|
38
|
+
"gitHead": "911cb6e43f8474b1b6e20bf0ce6ab785cbb39210"
|
|
39
39
|
}
|
package/src/AI.ts
CHANGED
|
@@ -2,6 +2,7 @@ import type { SDKRequestInterface } from '@cloudbase/adapter-interface'
|
|
|
2
2
|
import { Bot } from './bot'
|
|
3
3
|
import * as models from './models'
|
|
4
4
|
import * as types from './type'
|
|
5
|
+
import { readableStream2JsonObject } from './utils'
|
|
5
6
|
|
|
6
7
|
const { MODELS } = models
|
|
7
8
|
|
|
@@ -38,20 +39,20 @@ class AI {
|
|
|
38
39
|
// 带 Accept: text/event-stream 请求头显式指定是 SSE 绕过 60s 的限制
|
|
39
40
|
stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })
|
|
40
41
|
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
)
|
|
42
|
+
const { data: responseData, header } = (await this.req.fetch({
|
|
43
|
+
method: 'post',
|
|
44
|
+
headers: { ...fetchHeaders, ...headers },
|
|
45
|
+
body: JSON.stringify(data),
|
|
46
|
+
url,
|
|
47
|
+
stream,
|
|
48
|
+
})) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }
|
|
49
|
+
|
|
50
|
+
return handleResponseData(responseData, header) as any
|
|
50
51
|
}
|
|
51
52
|
|
|
52
53
|
botRequest: types.BotReq = async ({ method, url, data = {}, headers, stream }) => {
|
|
53
54
|
if (method === 'get') {
|
|
54
|
-
return (await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data
|
|
55
|
+
return handleResponseData((await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data,)
|
|
55
56
|
}
|
|
56
57
|
|
|
57
58
|
const fetchHeaders = {
|
|
@@ -60,18 +61,18 @@ class AI {
|
|
|
60
61
|
// 带 Accept: text/event-stream 请求头显式指定是 SSE 绕过 60s 的限制
|
|
61
62
|
stream && Object.assign(fetchHeaders, { Accept: 'text/event-stream' })
|
|
62
63
|
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
)
|
|
64
|
+
const { data: responseData, header } = (await this.req.fetch({
|
|
65
|
+
url,
|
|
66
|
+
body: JSON.stringify(data),
|
|
67
|
+
headers: {
|
|
68
|
+
...fetchHeaders,
|
|
69
|
+
...headers,
|
|
70
|
+
},
|
|
71
|
+
stream,
|
|
72
|
+
method,
|
|
73
|
+
})) as { data: Promise<unknown> | ReadableStream<Uint8Array>; header?: Headers }
|
|
74
|
+
|
|
75
|
+
return handleResponseData(responseData, header) as any
|
|
75
76
|
|
|
76
77
|
function objectToParam(obj: Object) {
|
|
77
78
|
return Object.entries(obj)
|
|
@@ -89,3 +90,33 @@ class AI {
|
|
|
89
90
|
}
|
|
90
91
|
|
|
91
92
|
export { AI }
|
|
93
|
+
|
|
94
|
+
const GO_TO_AI_TEXT = '请检查调用方式,或前往云开发 AI+ 首页查看文档:https://tcb.cloud.tencent.com/dev#/ai'
|
|
95
|
+
|
|
96
|
+
async function handleResponseData(responseData: Promise<unknown> | ReadableStream<Uint8Array>, header?: Headers) {
|
|
97
|
+
if ('then' in responseData) {
|
|
98
|
+
// 非流式请求,直接返回 json 数据
|
|
99
|
+
const json = (await responseData) as Record<string, unknown>
|
|
100
|
+
if ('code' in json && json.code !== 'NORMAL') {
|
|
101
|
+
throw new Error(`AI+ 请求出错,错误码:${json.code},错误信息:${json.message}\n${GO_TO_AI_TEXT}\n${JSON.stringify(
|
|
102
|
+
json,
|
|
103
|
+
null,
|
|
104
|
+
2,
|
|
105
|
+
)}`,)
|
|
106
|
+
}
|
|
107
|
+
|
|
108
|
+
return responseData
|
|
109
|
+
}
|
|
110
|
+
// 流式请求,如果接口出错,会变成传 json 格式的响应,通过 header 判断格式
|
|
111
|
+
if (header?.get('content-type')?.includes('application/json')) {
|
|
112
|
+
const json = await readableStream2JsonObject(responseData)
|
|
113
|
+
// 都降为 json 了,就不判断 code 了,直接抛吧
|
|
114
|
+
throw new Error(`AI+ 请求出错,错误码:${json.code},错误信息:${json.message}\n${GO_TO_AI_TEXT}\n${JSON.stringify(
|
|
115
|
+
json,
|
|
116
|
+
null,
|
|
117
|
+
2,
|
|
118
|
+
)}`,)
|
|
119
|
+
} else {
|
|
120
|
+
return responseData
|
|
121
|
+
}
|
|
122
|
+
}
|
package/src/utils.ts
CHANGED
|
@@ -137,6 +137,22 @@ export function intoStandardStream<T>(stream: ReadableStream<Uint8Array>): Reada
|
|
|
137
137
|
}),),)
|
|
138
138
|
}
|
|
139
139
|
|
|
140
|
+
/**
|
|
141
|
+
* 将 SSE 二进制流转换为字符串流
|
|
142
|
+
*/
|
|
143
|
+
export function intoTextStream(stream: ReadableStream<Uint8Array>): AsyncIterableReadableStream<string> {
|
|
144
|
+
return createAsyncIterable((toPolyfillReadable(stream) as typeof stream).pipeThrough(new TextDecoderStream()))
|
|
145
|
+
}
|
|
146
|
+
|
|
147
|
+
export async function readableStream2JsonObject(stream: ReadableStream) {
|
|
148
|
+
const s = intoTextStream(stream)
|
|
149
|
+
let total = ''
|
|
150
|
+
for await (const chunk of s) {
|
|
151
|
+
total += chunk
|
|
152
|
+
}
|
|
153
|
+
return JSON.parse(total)
|
|
154
|
+
}
|
|
155
|
+
|
|
140
156
|
export function createPromise<T = unknown>() {
|
|
141
157
|
let res: (value: T | PromiseLike<T>) => void
|
|
142
158
|
let rej: (reason?: any) => void
|