@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 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 (_b) {
87
- switch (_b.label) {
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: return [2, (_b.sent()).data];
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 (_c) {
118
- switch (_c.label) {
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, (_c.sent()).data];
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: return [2, (_c.sent()).data];
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQUkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQUkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUNBLDZCQUEyQjtBQUMzQiwrQ0FBa0M7QUFHMUIsSUFBQSxNQUFNLEdBQUssTUFBTSxPQUFYLENBQVc7QUFFekI7SUFLRSxZQUFvQixHQUF3QixFQUFTLE9BQWU7UUFBcEUsaUJBSUM7UUFKbUIsUUFBRyxHQUFILEdBQUcsQ0FBcUI7UUFBUyxZQUFPLEdBQVAsT0FBTyxDQUFRO1FBcUJwRSxpQkFBWSxHQUFtQixVQUFPLEVBQThCO2dCQUE1QixHQUFHLFNBQUEsRUFBRSxJQUFJLFVBQUEsRUFBRSxPQUFPLGFBQUEsRUFBRSxNQUFNLFlBQUE7Ozs7Ozs0QkFDMUQsWUFBWSxHQUFHO2dDQUNuQixjQUFjLEVBQUUsa0JBQWtCOzZCQUNuQyxDQUFBOzRCQUVELE1BQU0sSUFBSSxNQUFNLENBQUMsTUFBTSxDQUFDLFlBQVksRUFBRSxFQUFFLE1BQU0sRUFBRSxtQkFBbUIsRUFBRSxDQUFDLENBQUE7NEJBR3BFLFdBQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUM7b0NBQ25CLE1BQU0sRUFBRSxNQUFNO29DQUNkLE9BQU8sd0JBQU8sWUFBWSxHQUFLLE9BQU8sQ0FBRTtvQ0FDeEMsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO29DQUMxQixHQUFHLEtBQUE7b0NBQ0gsTUFBTSxRQUFBO2lDQUNQLENBQUMsRUFBQTtnQ0FQSixXQUFPLENBQ0wsU0FNRSxDQUNILENBQUMsSUFBSSxFQUFBOzs7O1NBQ1AsQ0FBQTtRQUVELGVBQVUsR0FBaUIsVUFBTyxFQUEyQztnQkFBekMsTUFBTSxZQUFBLEVBQUUsR0FBRyxTQUFBLEVBQUUsWUFBUyxFQUFULElBQUksbUJBQUcsRUFB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LFNBQUM7QUFBRCxDQUFDLEFBakZELElBaUZDO0FBRVEsZ0JBQUUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IFNES1JlcXVlc3RJbnRlcmZhY2UgfSBmcm9tICdAY2xvdWRiYXNlL2FkYXB0ZXItaW50ZXJmYWNlJ1xuaW1wb3J0IHsgQm90IH0gZnJvbSAnLi9ib3QnXG5pbXBvcnQgKiBhcyBtb2RlbHMgZnJvbSAnLi9tb2RlbHMnXG5pbXBvcnQgKiBhcyB0eXBlcyBmcm9tICcuL3R5cGUnXG5cbmNvbnN0IHsgTU9ERUxTIH0gPSBtb2RlbHNcblxuY2xhc3MgQUkge1xuICBwdWJsaWMgYWlCYXNlVXJsOiBzdHJpbmdcbiAgcHVibGljIGFpQm90QmFzZVVybDogc3RyaW5nXG4gIHB1YmxpYyBib3Q6IEJvdFxuXG4gIGNvbnN0cnVjdG9yKHByaXZhdGUgcmVxOiBTREtSZXF1ZXN0SW50ZXJmYWNlLCBwdWJsaWMgYmFzZVVybDogc3RyaW5nKSB7XG4gICAgdGhpcy5haUJhc2VVcmwgPSBgJHtiYXNlVXJsfS9haWBcbiAgICB0aGlzLmFpQm90QmFzZVVybCA9IGAke2Jhc2VVcmx9L2FpYm90YFxuICAgIHRoaXMuYm90ID0gbmV3IEJvdCh0aGlzLmJvdFJlcXVlc3QsIHRoaXMuYWlCb3RCYXNlVXJsKVxuICB9XG5cbiAgY3JlYXRlTW9kZWw8VCBleHRlbmRzIGtleW9mIHR5cGVvZiBNT0RFTFM+KG1vZGVsOiBUKSB7XG4gICAgY29uc3QgU2ltcGxlTW9kZWxDb25zdHJ1Y3RvciA9IE1PREVMU1ttb2RlbF1cbiAgICBjb25zdCBzaW1wbGVNb2RlbDogdHlwZXMuU2ltcGxlQ2hhdE1vZGVsID0gbmV3IFNpbXBsZU1vZGVsQ29uc3RydWN0b3IodGhpcy5tb2RlbFJlcXVlc3QsIHRoaXMuYWlCYXNlVXJsKVxuICAgIGNvbnN0IHJlYWN0TW9kZWwgPSBuZXcgbW9kZWxzLlJlYWN0TW9kZWwoc2ltcGxlTW9kZWwpXG4gICAgcmV0dXJuIHJlYWN0TW9kZWxcbiAgfVxuXG4gIHJlZ2lzdGVyTW9kZWwobmFtZTogc3RyaW5nLCBtb2RlbDogdHlwZXMuQ2hhdE1vZGVsQ29uc3RydWN0b3IpIHtcbiAgICBpZiAoTU9ERUxTW25hbWVdICE9IG51bGwpIHtcbiAgICAgIGNvbnNvbGUud2FybihgQUkgbW9kZWwgJHtuYW1lfSBhbHJlYWR5IGV4aXN0cyFgKVxuICAgICAgcmV0dXJuXG4gICAgfVxuICAgIE1PREVMU1tuYW1lXSA9IG1vZGVsXG4gIH1cblxuICBtb2RlbFJlcXVlc3Q6IHR5cGVzLk1vZGVsUmVxID0gYXN5bmMgKHsgdXJsLCBkYXRhLCBoZWFkZXJzLCBzdHJlYW0gfSkgPT4ge1xuICAgIGNvbnN0IGZldGNoSGVhZGVycyA9IHtcbiAgICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgfVxuICAgIC8vIOW4piBBY2NlcHQ6IHRleHQvZXZlbnQtc3RyZWFtICDor7fmsYLlpLTmmL7lvI/mjIflrprmmK8gU1NFIOe7lei/hyA2MHMg55qE6ZmQ5Yi2XG4gICAgc3RyZWFtICYmIE9iamVjdC5hc3NpZ24oZmV0Y2hIZWFkZXJzLCB7IEFjY2VwdDogJ3RleHQvZXZlbnQtc3RyZWFtJyB9KVxuXG4gICAgcmV0dXJuIChcbiAgICAgIGF3YWl0IHRoaXMucmVxLmZldGNoKHtcbiAgICAgICAgbWV0aG9kOiAncG9zdCcsXG4gICAgICAgIGhlYWRlcnM6IHsgLi4uZmV0Y2hIZWFkZXJzLCAuLi5oZWFkZXJzIH0sXG4gICAgICAgIGJvZHk6IEpTT04uc3RyaW5naWZ5KGRhdGEpLFxuICAgICAgICB1cmwsXG4gICAgICAgIHN0cmVhbSxcbiAgICAgIH0pXG4gICAgKS5kYXRhXG4gIH1cblxuICBib3RSZXF1ZXN0OiB0eXBlcy5Cb3RSZXEgPSBhc3luYyAoeyBtZXRob2QsIHVybCwgZGF0YSA9IHt9LCBoZWFkZXJzLCBzdHJlYW0gfSkgPT4ge1xuICAgIGlmIChtZXRob2QgPT09ICdnZXQnKSB7XG4gICAgICByZXR1cm4gKGF3YWl0IHRoaXMucmVxLmZldGNoKHsgdXJsOiBgJHt1cmx9PyR7b2JqZWN0VG9QYXJhbShkYXRhKX1gLCBtZXRob2QsIGhlYWRlcnMsIHN0cmVhbSB9KSkuZGF0YVxuICAgIH1cblxuICAgIGNvbnN0IGZldGNoSGVhZGVycyA9IHtcbiAgICAgICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsXG4gICAgfVxuICAgIC8vIOW4piBBY2NlcHQ6IHRleHQvZXZlbnQtc3RyZWFtICDor7fmsYLlpLTmmL7lvI/mjIflrprmmK8gU1NFIOe7lei/hyA2MHMg55qE6ZmQ5Yi2XG4gICAgc3RyZWFtICYmIE9iamVjdC5hc3NpZ24oZmV0Y2hIZWFkZXJzLCB7IEFjY2VwdDogJ3RleHQvZXZlbnQtc3RyZWFtJyB9KVxuXG4gICAgcmV0dXJuIChcbiAgICAgIGF3YWl0IHRoaXMucmVxLmZldGNoKHtcbiAgICAgICAgdXJsLFxuICAgICAgICBib2R5OiBKU09OLnN0cmluZ2lmeShkYXRhKSxcbiAgICAgICAgaGVhZGVyczoge1xuICAgICAgICAgIC4uLmZldGNoSGVhZGVycyxcbiAgICAgICAgICAuLi5oZWFkZXJzLFxuICAgICAgICB9LFxuICAgICAgICBzdHJlYW0sXG4gICAgICAgIG1ldGhvZCxcbiAgICAgIH0pXG4gICAgKS5kYXRhXG5cbiAgICBmdW5jdGlvbiBvYmplY3RUb1BhcmFtKG9iajogT2JqZWN0KSB7XG4gICAgICByZXR1cm4gT2JqZWN0LmVudHJpZXMob2JqKVxuICAgICAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IGAke2tleX09JHt2YWx1ZX1gKVxuICAgICAgICAuam9pbignJicpXG4gICAgfVxuICB9XG5cbiAgcmVnaXN0ZXJGdW5jdGlvblRvb2woZnVuY3Rpb25Ub29sOiB0eXBlcy5GdW5jdGlvblRvb2wpIHtcbiAgICBpZiAobW9kZWxzLnRvb2xNYXAuaGFzKGZ1bmN0aW9uVG9vbC5uYW1lKSkge1xuICAgICAgY29uc29sZS53YXJuKGBBSSBmdW5jdGlvbiB0b29sICR7ZnVuY3Rpb25Ub29sLm5hbWV9IGFscmVhZHkgZXhpc3RzIGFuZCB3aWxsIGJlIG92ZXJ3cml0dGVuIWApXG4gICAgfVxuICAgIG1vZGVscy50b29sTWFwLnNldChmdW5jdGlvblRvb2wubmFtZSwgZnVuY3Rpb25Ub29sLmZuKVxuICB9XG59XG5cbmV4cG9ydCB7IEFJIH1cbiJdfQ==
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"]}
@@ -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 (_b) {
61
- switch (_b.label) {
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: return [2, (_b.sent()).data];
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 (_c) {
92
- switch (_c.label) {
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, (_c.sent()).data];
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: return [2, (_c.sent()).data];
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
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiQUkuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvQUkudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFDQSxPQUFPLEVBQUUsR0FBRyxFQUFFLE1BQU0sT0FBTyxDQUFBO0FBQzNCLE9BQU8sS0FBSyxNQUFNLE1BQU0sVUFBVSxDQUFBO0FBRzFCLElBQUEsTUFBTSxHQUFLLE1BQU0sT0FBWCxDQUFXO0FBRXpCO0lBS0UsWUFBb0IsR0FBd0IsRUFBUyxPQUFlO1FBQXBFLGlCQUlDO1FBSm1CLFFBQUcsR0FBSCxHQUFHLENBQXFCO1FBQVMsWUFBTyxHQUFQLE9BQU8sQ0FBUTtRQXFCcEUsaUJBQVksR0FBbUIsVUFBTyxFQUE4QjtnQkFBNUIsR0FBRyxTQUFBLEVBQUUsSUFBSSxVQUFBLEVBQUUsT0FBTyxhQUFBLEVBQUUsTUFBTSxZQUFBOzs7Ozs7NEJBQzFELFlBQVksR0FBRztnQ0FDbkIsY0FBYyxFQUFFLGtCQUFrQjs2QkFDbkMsQ0FBQTs0QkFFRCxNQUFNLElBQUksTUFBTSxDQUFDLE1BQU0sQ0FBQyxZQUFZLEVBQUUsRUFBRSxNQUFNLEVBQUUsbUJBQW1CLEVBQUUsQ0FBQyxDQUFBOzRCQUdwRSxXQUFNLElBQUksQ0FBQyxHQUFHLENBQUMsS0FBSyxDQUFDO29DQUNuQixNQUFNLEVBQUUsTUFBTTtvQ0FDZCxPQUFPLHdCQUFPLFlBQVksR0FBSyxPQUFPLENBQUU7b0NBQ3hDLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLElBQUksQ0FBQztvQ0FDMUIsR0FBRyxLQUFBO29DQUNILE1BQU0sUUFBQTtpQ0FDUCxDQUFDLEVBQUE7Z0NBUEosV0FBTyxDQUNMLFNBTUUsQ0FDSCxDQUFDLElBQUksRUFBQTs7OztTQUNQLENBQUE7UUFFRCxlQUFVLEdBQWlCLFVBQU8sRUFBMkM7Z0JBQXpDLE1BQU0sWUFBQSxFQUFFLEdBQUcsU0FBQSxFQUFF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Q0FBQyxDQUFBO0lBQ3hELENBQUM7SUFDSCxTQUFDO0FBQUQsQ0FBQyxBQWpGRCxJQWlGQztBQUVELE9BQU8sRUFBRSxFQUFFLEVBQUUsQ0FBQSIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB0eXBlIHsgU0RLUmVxdWVzdEludGVyZmFjZSB9IGZyb20gJ0BjbG91ZGJhc2UvYWRhcHRlci1pbnRlcmZhY2UnXG5pbXBvcnQgeyBCb3QgfSBmcm9tICcuL2JvdCdcbmltcG9ydCAqIGFzIG1vZGVscyBmcm9tICcuL21vZGVscydcbmltcG9ydCAqIGFzIHR5cGVzIGZyb20gJy4vdHlwZSdcblxuY29uc3QgeyBNT0RFTFMgfSA9IG1vZGVsc1xuXG5jbGFzcyBBSSB7XG4gIHB1YmxpYyBhaUJhc2VVcmw6IHN0cmluZ1xuICBwdWJsaWMgYWlCb3RCYXNlVXJsOiBzdHJpbmdcbiAgcHVibGljIGJvdDogQm90XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZXE6IFNES1JlcXVlc3RJbnRlcmZhY2UsIHB1YmxpYyBiYXNlVXJsOiBzdHJpbmcpIHtcbiAgICB0aGlzLmFpQmFzZVVybCA9IGAke2Jhc2VVcmx9L2FpYFxuICAgIHRoaXMuYWlCb3RCYXNlVXJsID0gYCR7YmFzZVVybH0vYWlib3RgXG4gICAgdGhpcy5ib3QgPSBuZXcgQm90KHRoaXMuYm90UmVxdWVzdCwgdGhpcy5haUJvdEJhc2VVcmwpXG4gIH1cblxuICBjcmVhdGVNb2RlbDxUIGV4dGVuZHMga2V5b2YgdHlwZW9mIE1PREVMUz4obW9kZWw6IFQpIHtcbiAgICBjb25zdCBTaW1wbGVNb2RlbENvbnN0cnVjdG9yID0gTU9ERUxTW21vZGVsXVxuICAgIGNvbnN0IHNpbXBsZU1vZGVsOiB0eXBlcy5TaW1wbGVDaGF0TW9kZWwgPSBuZXcgU2ltcGxlTW9kZWxDb25zdHJ1Y3Rvcih0aGlzLm1vZGVsUmVxdWVzdCwgdGhpcy5haUJhc2VVcmwpXG4gICAgY29uc3QgcmVhY3RNb2RlbCA9IG5ldyBtb2RlbHMuUmVhY3RNb2RlbChzaW1wbGVNb2RlbClcbiAgICByZXR1cm4gcmVhY3RNb2RlbFxuICB9XG5cbiAgcmVnaXN0ZXJNb2RlbChuYW1lOiBzdHJpbmcsIG1vZGVsOiB0eXBlcy5DaGF0TW9kZWxDb25zdHJ1Y3Rvcikge1xuICAgIGlmIChNT0RFTFNbbmFtZV0gIT0gbnVsbCkge1xuICAgICAgY29uc29sZS53YXJuKGBBSSBtb2RlbCAke25hbWV9IGFscmVhZHkgZXhpc3RzIWApXG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgTU9ERUxTW25hbWVdID0gbW9kZWxcbiAgfVxuXG4gIG1vZGVsUmVxdWVzdDogdHlwZXMuTW9kZWxSZXEgPSBhc3luYyAoeyB1cmwsIGRhdGEsIGhlYWRlcnMsIHN0cmVhbSB9KSA9PiB7XG4gICAgY29uc3QgZmV0Y2hIZWFkZXJzID0ge1xuICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICB9XG4gICAgLy8g5bimIEFjY2VwdDogdGV4dC9ldmVudC1zdHJlYW0gIOivt+axguWktOaYvuW8j+aMh+WumuaYryBTU0Ug57uV6L+HIDYwcyDnmoTpmZDliLZcbiAgICBzdHJlYW0gJiYgT2JqZWN0LmFzc2lnbihmZXRjaEhlYWRlcnMsIHsgQWNjZXB0OiAndGV4dC9ldmVudC1zdHJlYW0nIH0pXG5cbiAgICByZXR1cm4gKFxuICAgICAgYXdhaXQgdGhpcy5yZXEuZmV0Y2goe1xuICAgICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgICAgaGVhZGVyczogeyAuLi5mZXRjaEhlYWRlcnMsIC4uLmhlYWRlcnMgfSxcbiAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoZGF0YSksXG4gICAgICAgIHVybCxcbiAgICAgICAgc3RyZWFtLFxuICAgICAgfSlcbiAgICApLmRhdGFcbiAgfVxuXG4gIGJvdFJlcXVlc3Q6IHR5cGVzLkJvdFJlcSA9IGFzeW5jICh7IG1ldGhvZCwgdXJsLCBkYXRhID0ge30sIGhlYWRlcnMsIHN0cmVhbSB9KSA9PiB7XG4gICAgaWYgKG1ldGhvZCA9PT0gJ2dldCcpIHtcbiAgICAgIHJldHVybiAoYXdhaXQgdGhpcy5yZXEuZmV0Y2goeyB1cmw6IGAke3VybH0/JHtvYmplY3RUb1BhcmFtKGRhdGEpfWAsIG1ldGhvZCwgaGVhZGVycywgc3RyZWFtIH0pKS5kYXRhXG4gICAgfVxuXG4gICAgY29uc3QgZmV0Y2hIZWFkZXJzID0ge1xuICAgICAgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJyxcbiAgICB9XG4gICAgLy8g5bimIEFjY2VwdDogdGV4dC9ldmVudC1zdHJlYW0gIOivt+axguWktOaYvuW8j+aMh+WumuaYryBTU0Ug57uV6L+HIDYwcyDnmoTpmZDliLZcbiAgICBzdHJlYW0gJiYgT2JqZWN0LmFzc2lnbihmZXRjaEhlYWRlcnMsIHsgQWNjZXB0OiAndGV4dC9ldmVudC1zdHJlYW0nIH0pXG5cbiAgICByZXR1cm4gKFxuICAgICAgYXdhaXQgdGhpcy5yZXEuZmV0Y2goe1xuICAgICAgICB1cmwsXG4gICAgICAgIGJvZHk6IEpTT04uc3RyaW5naWZ5KGRhdGEpLFxuICAgICAgICBoZWFkZXJzOiB7XG4gICAgICAgICAgLi4uZmV0Y2hIZWFkZXJzLFxuICAgICAgICAgIC4uLmhlYWRlcnMsXG4gICAgICAgIH0sXG4gICAgICAgIHN0cmVhbSxcbiAgICAgICAgbWV0aG9kLFxuICAgICAgfSlcbiAgICApLmRhdGFcblxuICAgIGZ1bmN0aW9uIG9iamVjdFRvUGFyYW0ob2JqOiBPYmplY3QpIHtcbiAgICAgIHJldHVybiBPYmplY3QuZW50cmllcyhvYmopXG4gICAgICAgIC5tYXAoKFtrZXksIHZhbHVlXSkgPT4gYCR7a2V5fT0ke3ZhbHVlfWApXG4gICAgICAgIC5qb2luKCcmJylcbiAgICB9XG4gIH1cblxuICByZWdpc3RlckZ1bmN0aW9uVG9vbChmdW5jdGlvblRvb2w6IHR5cGVzLkZ1bmN0aW9uVG9vbCkge1xuICAgIGlmIChtb2RlbHMudG9vbE1hcC5oYXMoZnVuY3Rpb25Ub29sLm5hbWUpKSB7XG4gICAgICBjb25zb2xlLndhcm4oYEFJIGZ1bmN0aW9uIHRvb2wgJHtmdW5jdGlvblRvb2wubmFtZX0gYWxyZWFkeSBleGlzdHMgYW5kIHdpbGwgYmUgb3ZlcndyaXR0ZW4hYClcbiAgICB9XG4gICAgbW9kZWxzLnRvb2xNYXAuc2V0KGZ1bmN0aW9uVG9vbC5uYW1lLCBmdW5jdGlvblRvb2wuZm4pXG4gIH1cbn1cblxuZXhwb3J0IHsgQUkgfVxuIl19
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"]}
@@ -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.0",
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.0",
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": "aff66120b898725227d9b451bff736ca1dac9cfc"
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
- return (
42
- await this.req.fetch({
43
- method: 'post',
44
- headers: { ...fetchHeaders, ...headers },
45
- body: JSON.stringify(data),
46
- url,
47
- stream,
48
- })
49
- ).data
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
- return (
64
- await this.req.fetch({
65
- url,
66
- body: JSON.stringify(data),
67
- headers: {
68
- ...fetchHeaders,
69
- ...headers,
70
- },
71
- stream,
72
- method,
73
- })
74
- ).data
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