@cloudbase/ai 2.8.13-beta.0 → 2.8.15-beta.0

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.
@@ -1,5 +1,5 @@
1
- import type { ICloudbase } from '@cloudbase/types';
2
1
  import type { SDKRequestInterface } from '@cloudbase/adapter-interface';
2
+ import type { ICloudbase } from '@cloudbase/types';
3
3
  import { Bot } from './bot';
4
4
  import * as models from './models';
5
5
  import * as types from './type';
@@ -41,5 +41,19 @@ declare class AI {
41
41
  modelRequest: types.ModelReq;
42
42
  botRequest: types.BotReq;
43
43
  }
44
+ interface IHandleRequestInstance {
45
+ req: SDKRequestInterface;
46
+ }
47
+ type HandleRequestInstanceFunc = (options: IHandleRequestInstance) => SDKRequestInterface;
48
+ interface ICreateAi {
49
+ req: SDKRequestInterface;
50
+ baseUrl?: string;
51
+ env?: string;
52
+ getAccessToken?: () => Promise<{
53
+ accessToken: string;
54
+ }>;
55
+ handleReqInstance?: HandleRequestInstanceFunc;
56
+ }
57
+ declare function createAi({ env, baseUrl, req, getAccessToken, handleReqInstance }: ICreateAi): AI;
44
58
  declare function registerAi(app: ICloudbase): void;
45
- export { types, utils, restModels as models, registerAi, AI, Bot };
59
+ export { AI, Bot, createAi, restModels as models, registerAi, types, utils };
package/dist/cjs/index.js CHANGED
@@ -81,7 +81,7 @@ var __rest = (this && this.__rest) || function (s, e) {
81
81
  return t;
82
82
  };
83
83
  Object.defineProperty(exports, "__esModule", { value: true });
84
- exports.Bot = exports.AI = exports.registerAi = exports.models = exports.utils = exports.types = void 0;
84
+ exports.utils = exports.types = exports.registerAi = exports.models = exports.createAi = exports.Bot = exports.AI = void 0;
85
85
  var bot_1 = require("./bot");
86
86
  Object.defineProperty(exports, "Bot", { enumerable: true, get: function () { return bot_1.Bot; } });
87
87
  var models = __importStar(require("./models"));
@@ -89,6 +89,7 @@ var types = __importStar(require("./type"));
89
89
  exports.types = types;
90
90
  var utils = __importStar(require("./utils"));
91
91
  exports.utils = utils;
92
+ var COMPONENT_NAME = 'ai';
92
93
  var MODELS = models.MODELS, restModels = __rest(models, ["MODELS"]);
93
94
  exports.models = restModels;
94
95
  var AI = (function () {
@@ -159,7 +160,58 @@ var AI = (function () {
159
160
  return AI;
160
161
  }());
161
162
  exports.AI = AI;
162
- var COMPONENT_NAME = 'ai';
163
+ var createRequestInstanceWithAccessTokenHeader = function (_a) {
164
+ var getAccessToken = _a.getAccessToken, req = _a.req;
165
+ var fetch = function (options) { return __awaiter(void 0, void 0, void 0, function () {
166
+ var token, _a, headers, restOptions, accessToken;
167
+ return __generator(this, function (_b) {
168
+ switch (_b.label) {
169
+ case 0:
170
+ if (typeof req.fetch !== 'function') {
171
+ throw new Error('req.fetch is not a function');
172
+ }
173
+ token = options.token, _a = options.headers, headers = _a === void 0 ? {} : _a, restOptions = __rest(options, ["token", "headers"]);
174
+ if (!(token != null)) return [3, 1];
175
+ accessToken = token;
176
+ return [3, 3];
177
+ case 1: return [4, getAccessToken()];
178
+ case 2:
179
+ accessToken = (_b.sent()).accessToken;
180
+ _b.label = 3;
181
+ case 3: return [2, req.fetch(__assign({ headers: __assign({ Authorization: "Bearer ".concat(accessToken) }, headers) }, restOptions))];
182
+ }
183
+ });
184
+ }); };
185
+ return {
186
+ download: req.download,
187
+ post: req.post,
188
+ upload: req.upload,
189
+ fetch: fetch,
190
+ };
191
+ };
192
+ function createAi(_a) {
193
+ var env = _a.env, baseUrl = _a.baseUrl, req = _a.req, getAccessToken = _a.getAccessToken, handleReqInstance = _a.handleReqInstance;
194
+ var getBaseUrl = function () {
195
+ if (baseUrl != null) {
196
+ return baseUrl;
197
+ }
198
+ if (env == null) {
199
+ throw new Error('`env` is required when `baseUrl` is not provided!');
200
+ }
201
+ return "https://".concat(env, ".api.tcloudbasegateway.com/v1");
202
+ };
203
+ var getReq = function () {
204
+ if (handleReqInstance == null) {
205
+ if (getAccessToken == null) {
206
+ throw new Error('`getAccessToken` is required when `handleReqInstance` is not provided!');
207
+ }
208
+ return createRequestInstanceWithAccessTokenHeader({ req: req, getAccessToken: getAccessToken });
209
+ }
210
+ return handleReqInstance({ req: req });
211
+ };
212
+ return new AI(getReq(), getBaseUrl());
213
+ }
214
+ exports.createAi = createAi;
163
215
  function ai(options) {
164
216
  var _this = this;
165
217
  var _a;
@@ -169,10 +221,13 @@ function ai(options) {
169
221
  }
170
222
  var getUrlFromCloud = function () {
171
223
  var _a = _this.getEndPointWithKey('GATEWAY'), BASE_URL = _a.BASE_URL, PROTOCOL = _a.PROTOCOL;
172
- return "".concat(PROTOCOL).concat(BASE_URL, "/v1");
224
+ return "".concat(PROTOCOL).concat(BASE_URL);
173
225
  };
174
226
  var baseUrl = (_a = options === null || options === void 0 ? void 0 : options.baseUrl) !== null && _a !== void 0 ? _a : getUrlFromCloud();
175
- return new AI(req, baseUrl);
227
+ return createAi({ req: req, baseUrl: baseUrl, handleReqInstance: function (_a) {
228
+ var req = _a.req;
229
+ return req;
230
+ } });
176
231
  }
177
232
  var component = {
178
233
  name: COMPONENT_NAME,
@@ -187,4 +242,4 @@ function registerAi(app) {
187
242
  }
188
243
  }
189
244
  exports.registerAi = registerAi;
190
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBR0EsNkJBQTJCO0FBeUdrQyxvRkF6R3BELFNBQUcsT0F5R29EO0FBeEdoRSwrQ0FBa0M7QUFDbEMsNENBQStCO0FBdUd0QixzQkFBSztBQXRHZCw2Q0FBZ0M7QUFzR2hCLHNCQUFLO0FBcEdiLElBQUEsTUFBTSxHQUFvQixNQUFNLE9BQTFCLEVBQUssVUFBVSxVQUFLLE1BQU0sRUFBbEMsVUFBeUIsQ0FBRixDQUFXO0FBb0dILDRCQUFNO0FBbEczQztJQUtFLFlBQW9CLEdBQXdCLEVBQVMsT0FBZTtRQUFwRSxpQkFJQztRQUptQixRQUFHLEdBQUgsR0FBRyxDQUFxQjtRQUFTLFlBQU8sR0FBUCxPQUFPLENBQVE7UUFrQnBFLGlCQUFZLEdBQW1CLFVBQU8sRUFBOEI7Z0JBQTVCLEdBQUcsU0FBQSxFQUFFLElBQUksVUFBQSxFQUFFLE9BQU8sYUFBQSxFQUFFLE1BQU0sWUFBQTs7OztnQ0FDaEUsV0FBTSxJQUFJLENBQUMsR0FBRyxDQUFDLEtBQUssQ0FBQztnQ0FDbkIsTUFBTSxFQUFFLE1BQU07Z0NBQ2QsT0FBTyxlQUNGLE9BQU8sQ0FDWDtnQ0FDRCxJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxJQUFJLENBQUM7Z0NBQzFCLEdBQUcsS0FBQTtnQ0FDSCxNQUFNLFFBQUE7NkJBQ1AsQ0FBQyxFQUFBO2dDQVRxRSxXQUFBLENBQ3ZFLFNBUUUsQ0FDSCxDQUFDLElBQUksRUFBQTs7OztTQUFBLENBQUE7UUFFTixlQUFVLEdBQWlCLFVBQU8sRUFBMkM7Z0JBQXpDLE1BQU0sWUFBQSxFQUFFLEdBQUcsU0FBQSxFQUFFLFlBQVMsRUFBVCxJQUFJLG1CQUFHLEVB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QUFDLEdBQUcsRUFBRSxPQUFPLENBQUMsQ0FBQTtBQUM3QixDQUFDO0FBRUQsSUFBTSxTQUFTLEdBQXdCO0lBQ3JDLElBQUksRUFBRSxjQUFjO0lBQ3BCLE1BQU0sRUFBRSxFQUFFLEVBQUUsSUFBQSxFQUFFO0NBQ2YsQ0FBQTtBQUVELFNBQVMsVUFBVSxDQUFDLEdBQWU7SUFDakMsSUFBSTtRQUNGLEdBQUcsQ0FBQyxpQkFBaUIsQ0FBQyxTQUFTLENBQUMsQ0FBQTtLQUNqQztJQUFDLE9BQU8sQ0FBQyxFQUFFO1FBQ1YsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDLENBQUMsQ0FBQTtLQUNoQjtBQUNILENBQUM7QUFFNEMsZ0NBQVUiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgdHlwZSB7IElDbG91ZGJhc2UgfSBmcm9tICdAY2xvdWRiYXNlL3R5cGVzJ1xuaW1wb3J0IHR5cGUgeyBJQ2xvdWRiYXNlQ29tcG9uZW50IH0gZnJvbSAnQGNsb3VkYmFzZS90eXBlcy9jb21wb25lbnQnXG5pbXBvcnQgdHlwZSB7IFNES1JlcXVlc3RJbnRlcmZhY2UgfSBmcm9tICdAY2xvdWRiYXNlL2FkYXB0ZXItaW50ZXJmYWNlJ1xuaW1wb3J0IHsgQm90IH0gZnJvbSAnLi9ib3QnXG5pbXBvcnQgKiBhcyBtb2RlbHMgZnJvbSAnLi9tb2RlbHMnXG5pbXBvcnQgKiBhcyB0eXBlcyBmcm9tICcuL3R5cGUnXG5pbXBvcnQgKiBhcyB1dGlscyBmcm9tICcuL3V0aWxzJ1xuXG5jb25zdCB7IE1PREVMUywgLi4ucmVzdE1vZGVscyB9ID0gbW9kZWxzXG5cbmNsYXNzIEFJIHtcbiAgcHVibGljIGFpQmFzZVVybDogc3RyaW5nXG4gIHB1YmxpYyBhaUJvdEJhc2VVcmw6IHN0cmluZ1xuICBwdWJsaWMgYm90OiBCb3RcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIHJlcTogU0RLUmVxdWVzdEludGVyZmFjZSwgcHVibGljIGJhc2VVcmw6IHN0cmluZykge1xuICAgIHRoaXMuYWlCYXNlVXJsID0gYCR7YmFzZVVybH0vYWlgXG4gICAgdGhpcy5haUJvdEJhc2VVcmwgPSBgJHtiYXNlVXJsfS9haWJvdGBcbiAgICB0aGlzLmJvdCA9IG5ldyBCb3QodGhpcy5ib3RSZXF1ZXN0LCB0aGlzLmFpQm90QmFzZVVybClcbiAgfVxuXG4gIGNyZWF0ZU1vZGVsPFQgZXh0ZW5kcyBrZXlvZiB0eXBlb2YgTU9ERUxTPihtb2RlbDogVCkge1xuICAgIHJldHVybiBuZXcgTU9ERUxTW21vZGVsXSh0aGlzLm1vZGVsUmVxdWVzdCwgdGhpcy5haUJhc2VVcmwpIGFzIEluc3RhbmNlVHlwZTwodHlwZW9mIE1PREVMUylbVF0+XG4gIH1cblxuICByZWdpc3Rlck1vZGVsKG5hbWU6IHN0cmluZywgbW9kZWw6IHR5cGVzLkNoYXRNb2RlbENvbnN0cnVjdG9yKSB7XG4gICAgaWYgKE1PREVMU1tuYW1lXSAhPSBudWxsKSB7XG4gICAgICBjb25zb2xlLndhcm4oYEFJIG1vZGVsICR7bmFtZX0gYWxyZWFkeSBleGlzdHMhYClcbiAgICAgIHJldHVyblxuICAgIH1cbiAgICBNT0RFTFNbbmFtZV0gPSBtb2RlbFxuICB9XG5cbiAgbW9kZWxSZXF1ZXN0OiB0eXBlcy5Nb2RlbFJlcSA9IGFzeW5jICh7IHVybCwgZGF0YSwgaGVhZGVycywgc3RyZWFtIH0pID0+IChcbiAgICBhd2FpdCB0aGlzLnJlcS5mZXRjaCh7XG4gICAgICBtZXRob2Q6ICdwb3N0JyxcbiAgICAgIGhlYWRlcnM6IHtcbiAgICAgICAgLi4uaGVhZGVycyxcbiAgICAgIH0sXG4gICAgICBib2R5OiBKU09OLnN0cmluZ2lmeShkYXRhKSxcbiAgICAgIHVybCxcbiAgICAgIHN0cmVhbSxcbiAgICB9KVxuICApLmRhdGFcblxuICBib3RSZXF1ZXN0OiB0eXBlcy5Cb3RSZXEgPSBhc3luYyAoeyBtZXRob2QsIHVybCwgZGF0YSA9IHt9LCBoZWFkZXJzLCBzdHJlYW0gfSkgPT4ge1xuICAgIGlmIChtZXRob2QgPT09ICdnZXQnKSB7XG4gICAgICByZXR1cm4gKGF3YWl0IHRoaXMucmVxLmZldGNoKHsgdXJsOiBgJHt1cmx9PyR7b2JqZWN0VG9QYXJhbShkYXRhKX1gLCBtZXRob2QsIGhlYWRlcnMsIHN0cmVhbSB9KSkuZGF0YVxuICAgIH1cblxuICAgIHJldHVybiAoXG4gICAgICBhd2FpdCB0aGlzLnJlcS5mZXRjaCh7XG4gICAgICAgIHVybCxcbiAgICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoZGF0YSksXG4gICAgICAgIGhlYWRlcnM6IHsgJ0NvbnRlbnQtVHlwZSc6ICdhcHBsaWNhdGlvbi9qc29uJywgLi4uaGVhZGVycyB9LFxuICAgICAgICBzdHJlYW0sXG4gICAgICAgIG1ldGhvZCxcbiAgICAgIH0pXG4gICAgKS5kYXRhXG5cbiAgICBmdW5jdGlvbiBvYmplY3RUb1BhcmFtKG9iajogT2JqZWN0KSB7XG4gICAgICByZXR1cm4gT2JqZWN0LmVudHJpZXMob2JqKVxuICAgICAgICAubWFwKChba2V5LCB2YWx1ZV0pID0+IGAke2tleX09JHt2YWx1ZX1gKVxuICAgICAgICAuam9pbignJicpXG4gICAgfVxuICB9XG59XG5cbmNvbnN0IENPTVBPTkVOVF9OQU1FID0gJ2FpJ1xuXG5pbnRlcmZhY2UgQUlJbml0T3B0aW9uIHtcbiAgZW52Pzogc3RyaW5nXG4gIGJhc2VVcmw/OiBzdHJpbmdcbn1cblxuZnVuY3Rpb24gYWkoXG4gIHRoaXM6IElDbG91ZGJhc2UgJiB7IGdldEVuZFBvaW50V2l0aEtleTogKGtleTogJ0dBVEVXQVknKSA9PiB7IEJBU0VfVVJMOiBzdHJpbmc7IFBST1RPQ09MOiBzdHJpbmcgfSB9LFxuICBvcHRpb25zPzogQUlJbml0T3B0aW9uLFxuKSB7XG4gIGNvbnN0IHJlcSA9IHRoaXMucmVxdWVzdFxuXG4gIGlmIChyZXEuZmV0Y2ggPT0gbnVsbCkge1xuICAgIHRocm93IG5ldyBFcnJvcignY2xvdWRiYXNlLnJlcXVlc3QuZmV0Y2goKSB1bmltcGxlbWVudGVkIScpXG4gIH1cblxuICBjb25zdCBnZXRVcmxGcm9tQ2xvdWQgPSAoKSA9PiB7XG4gICAgY29uc3QgeyBCQVNFX1VSTCwgUFJPVE9DT0wgfSA9IHRoaXMuZ2V0RW5kUG9pbnRXaXRoS2V5KCdHQVRFV0FZJylcbiAgICByZXR1cm4gYCR7UFJPVE9DT0x9JHtCQVNFX1VSTH0vdjFgXG4gIH1cblxuICBjb25zdCBiYXNlVXJsID0gb3B0aW9ucz8uYmFzZVVybCA/PyBnZXRVcmxGcm9tQ2xvdWQoKVxuXG4gIHJldHVybiBuZXcgQUkocmVxLCBiYXNlVXJsKVxufVxuXG5jb25zdCBjb21wb25lbnQ6IElDbG91ZGJhc2VDb21wb25lbnQgPSB7XG4gIG5hbWU6IENPTVBPTkVOVF9OQU1FLFxuICBlbnRpdHk6IHsgYWkgfSxcbn1cblxuZnVuY3Rpb24gcmVnaXN0ZXJBaShhcHA6IElDbG91ZGJhc2UpIHtcbiAgdHJ5IHtcbiAgICBhcHAucmVnaXN0ZXJDb21wb25lbnQoY29tcG9uZW50KVxuICB9IGNhdGNoIChlKSB7XG4gICAgY29uc29sZS53YXJuKGUpXG4gIH1cbn1cblxuZXhwb3J0IHsgdHlwZXMsIHV0aWxzLCByZXN0TW9kZWxzIGFzIG1vZGVscywgcmVnaXN0ZXJBaSwgQUksIEJvdCB9XG4iXX0=
245
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { IFetchOptions, SDKRequestInterface } from '@cloudbase/adapter-interface'\nimport type { ICloudbase } from '@cloudbase/types'\nimport type { ICloudbaseComponent } from '@cloudbase/types/component'\nimport { Bot } from './bot'\nimport * as models from './models'\nimport * as types from './type'\nimport * as utils from './utils'\n\nconst COMPONENT_NAME = 'ai'\n\nconst { MODELS, ...restModels } = 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    return new MODELS[model](this.modelRequest, this.aiBaseUrl) as InstanceType<(typeof MODELS)[T]>\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    await this.req.fetch({\n      method: 'post',\n      headers: {\n        ...headers,\n      },\n      body: JSON.stringify(data),\n      url,\n      stream,\n    })\n  ).data\n\n  botRequest: types.BotReq = async ({ method, url, data = {}, headers, stream }) => {\n    if (method === 'get') {\n      return (await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data\n    }\n\n    return (\n      await this.req.fetch({\n        url,\n        body: JSON.stringify(data),\n        headers: { 'Content-Type': 'application/json', ...headers },\n        stream,\n        method,\n      })\n    ).data\n\n    function objectToParam(obj: Object) {\n      return Object.entries(obj)\n        .map(([key, value]) => `${key}=${value}`)\n        .join('&')\n    }\n  }\n}\n\ninterface IHandleRequestInstance {\n  req: SDKRequestInterface\n}\n\ntype HandleRequestInstanceFunc = (options: IHandleRequestInstance) => SDKRequestInterface\n\nconst createRequestInstanceWithAccessTokenHeader = ({\n  getAccessToken,\n  req,\n}: IHandleRequestInstance & { getAccessToken: () => Promise<{ accessToken: string }> }) => {\n  const fetch: typeof req.fetch = async (options: IFetchOptions & { token?: string }) => {\n    if (typeof req.fetch !== 'function') {\n      throw new Error('req.fetch is not a function')\n    }\n\n    const { token, headers = {}, ...restOptions } = options\n    let accessToken: string\n    if (token != null) {\n      accessToken = token\n    } else {\n      accessToken = (await getAccessToken()).accessToken\n    }\n\n    return req.fetch({\n      headers: {\n        Authorization: `Bearer ${accessToken}`,\n        ...headers,\n      },\n      ...restOptions,\n    })\n  }\n\n  return {\n    download: req.download,\n    post: req.post,\n    upload: req.upload,\n    fetch,\n  }\n}\n\ninterface AIInitOption {\n  baseUrl?: string\n}\n\ninterface ICreateAi {\n  req: SDKRequestInterface\n  baseUrl?: string\n  env?: string\n  getAccessToken?: () => Promise<{ accessToken: string }>\n  handleReqInstance?: HandleRequestInstanceFunc\n}\n\n/**\n * 最简地创建一个接云开发网关服务的 `AI` 实例，请求时会自动带上鉴权请求头。\n * 只需要传入：\n *\n * - `getAccessToken`: 获取 accessToken 的函数\n * - `req`: 请求函数，一般从 adapter 上拿\n * - `env`: 云开发环境 ID\n *\n * 其他参数可按需传入覆盖函数逻辑。\n */\nfunction createAi({ env, baseUrl, req, getAccessToken, handleReqInstance }: ICreateAi) {\n  const getBaseUrl = () => {\n    if (baseUrl != null) {\n      return baseUrl\n    }\n    if (env == null) {\n      throw new Error('`env` is required when `baseUrl` is not provided!')\n    }\n    return `https://${env}.api.tcloudbasegateway.com/v1`\n  }\n\n  const getReq = () => {\n    if (handleReqInstance == null) {\n      if (getAccessToken == null) {\n        throw new Error('`getAccessToken` is required when `handleReqInstance` is not provided!')\n      }\n      return createRequestInstanceWithAccessTokenHeader({ req, getAccessToken })\n    }\n    return handleReqInstance({ req })\n  }\n\n  return new AI(getReq(), getBaseUrl())\n}\n\n/**\n * 创建 `AI` 实例。\n * 该函数挂载在 js sdk 的 Cloudbase 实例上。\n * 该函数调用了本模块暴露的 `createAi` 函数，但调用时通过传入参数做了逻辑覆盖：\n *\n * - 传入从 Cloudbase 实例上的中心的 `req`\n * - 传入从 Cloudbase 实例上拿到的 `baseUrl`\n * - 传入一个不处理 `req` 的 `handleReqInstance`，由于 `req` 是从 Cloudbase 实例上拿到的，这个中心的 `req` 已经可用了\n * - 不用传入 `env` 了，因为已经传了 `baseUrl`\n * - 不用传入 `getAccessToken` 了，因为传了 `handleReqInstance`\n */\nfunction ai(\n  this: ICloudbase & { getEndPointWithKey: (key: 'GATEWAY') => { BASE_URL: string; PROTOCOL: string } },\n  options?: AIInitOption,\n) {\n  const req = this.request\n\n  if (req.fetch == null) {\n    throw new Error('cloudbase.request.fetch() unimplemented!')\n  }\n\n  const getUrlFromCloud = () => {\n    const { BASE_URL, PROTOCOL } = this.getEndPointWithKey('GATEWAY')\n    return `${PROTOCOL}${BASE_URL}`\n  }\n\n  const baseUrl = options?.baseUrl ?? getUrlFromCloud()\n\n  return createAi({ req, baseUrl, handleReqInstance: ({ req }) => req })\n}\n\nconst component: ICloudbaseComponent = {\n  name: COMPONENT_NAME,\n  entity: { ai },\n}\n\nfunction registerAi(app: ICloudbase) {\n  try {\n    app.registerComponent(component)\n  } catch (e) {\n    console.warn(e)\n  }\n}\n\nexport { AI, Bot, createAi, restModels as models, registerAi, types, utils }\n"]}
@@ -1,5 +1,5 @@
1
- import type { ICloudbase } from '@cloudbase/types';
2
1
  import type { SDKRequestInterface } from '@cloudbase/adapter-interface';
2
+ import type { ICloudbase } from '@cloudbase/types';
3
3
  import { Bot } from './bot';
4
4
  import * as models from './models';
5
5
  import * as types from './type';
@@ -41,5 +41,19 @@ declare class AI {
41
41
  modelRequest: types.ModelReq;
42
42
  botRequest: types.BotReq;
43
43
  }
44
+ interface IHandleRequestInstance {
45
+ req: SDKRequestInterface;
46
+ }
47
+ type HandleRequestInstanceFunc = (options: IHandleRequestInstance) => SDKRequestInterface;
48
+ interface ICreateAi {
49
+ req: SDKRequestInterface;
50
+ baseUrl?: string;
51
+ env?: string;
52
+ getAccessToken?: () => Promise<{
53
+ accessToken: string;
54
+ }>;
55
+ handleReqInstance?: HandleRequestInstanceFunc;
56
+ }
57
+ declare function createAi({ env, baseUrl, req, getAccessToken, handleReqInstance }: ICreateAi): AI;
44
58
  declare function registerAi(app: ICloudbase): void;
45
- export { types, utils, restModels as models, registerAi, AI, Bot };
59
+ export { AI, Bot, createAi, restModels as models, registerAi, types, utils };
package/dist/esm/index.js CHANGED
@@ -60,6 +60,7 @@ import { Bot } from './bot';
60
60
  import * as models from './models';
61
61
  import * as types from './type';
62
62
  import * as utils from './utils';
63
+ var COMPONENT_NAME = 'ai';
63
64
  var MODELS = models.MODELS, restModels = __rest(models, ["MODELS"]);
64
65
  var AI = (function () {
65
66
  function AI(req, baseUrl) {
@@ -128,7 +129,57 @@ var AI = (function () {
128
129
  };
129
130
  return AI;
130
131
  }());
131
- var COMPONENT_NAME = 'ai';
132
+ var createRequestInstanceWithAccessTokenHeader = function (_a) {
133
+ var getAccessToken = _a.getAccessToken, req = _a.req;
134
+ var fetch = function (options) { return __awaiter(void 0, void 0, void 0, function () {
135
+ var token, _a, headers, restOptions, accessToken;
136
+ return __generator(this, function (_b) {
137
+ switch (_b.label) {
138
+ case 0:
139
+ if (typeof req.fetch !== 'function') {
140
+ throw new Error('req.fetch is not a function');
141
+ }
142
+ token = options.token, _a = options.headers, headers = _a === void 0 ? {} : _a, restOptions = __rest(options, ["token", "headers"]);
143
+ if (!(token != null)) return [3, 1];
144
+ accessToken = token;
145
+ return [3, 3];
146
+ case 1: return [4, getAccessToken()];
147
+ case 2:
148
+ accessToken = (_b.sent()).accessToken;
149
+ _b.label = 3;
150
+ case 3: return [2, req.fetch(__assign({ headers: __assign({ Authorization: "Bearer ".concat(accessToken) }, headers) }, restOptions))];
151
+ }
152
+ });
153
+ }); };
154
+ return {
155
+ download: req.download,
156
+ post: req.post,
157
+ upload: req.upload,
158
+ fetch: fetch,
159
+ };
160
+ };
161
+ function createAi(_a) {
162
+ var env = _a.env, baseUrl = _a.baseUrl, req = _a.req, getAccessToken = _a.getAccessToken, handleReqInstance = _a.handleReqInstance;
163
+ var getBaseUrl = function () {
164
+ if (baseUrl != null) {
165
+ return baseUrl;
166
+ }
167
+ if (env == null) {
168
+ throw new Error('`env` is required when `baseUrl` is not provided!');
169
+ }
170
+ return "https://".concat(env, ".api.tcloudbasegateway.com/v1");
171
+ };
172
+ var getReq = function () {
173
+ if (handleReqInstance == null) {
174
+ if (getAccessToken == null) {
175
+ throw new Error('`getAccessToken` is required when `handleReqInstance` is not provided!');
176
+ }
177
+ return createRequestInstanceWithAccessTokenHeader({ req: req, getAccessToken: getAccessToken });
178
+ }
179
+ return handleReqInstance({ req: req });
180
+ };
181
+ return new AI(getReq(), getBaseUrl());
182
+ }
132
183
  function ai(options) {
133
184
  var _this = this;
134
185
  var _a;
@@ -138,10 +189,13 @@ function ai(options) {
138
189
  }
139
190
  var getUrlFromCloud = function () {
140
191
  var _a = _this.getEndPointWithKey('GATEWAY'), BASE_URL = _a.BASE_URL, PROTOCOL = _a.PROTOCOL;
141
- return "".concat(PROTOCOL).concat(BASE_URL, "/v1");
192
+ return "".concat(PROTOCOL).concat(BASE_URL);
142
193
  };
143
194
  var baseUrl = (_a = options === null || options === void 0 ? void 0 : options.baseUrl) !== null && _a !== void 0 ? _a : getUrlFromCloud();
144
- return new AI(req, baseUrl);
195
+ return createAi({ req: req, baseUrl: baseUrl, handleReqInstance: function (_a) {
196
+ var req = _a.req;
197
+ return req;
198
+ } });
145
199
  }
146
200
  var component = {
147
201
  name: COMPONENT_NAME,
@@ -155,5 +209,5 @@ function registerAi(app) {
155
209
  console.warn(e);
156
210
  }
157
211
  }
158
- export { types, utils, restModels as models, registerAi, AI, Bot };
159
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztBQUdBLE9BQU8sRUFBRSxHQUFHLEVBQUUsTUFBTSxPQUFPLENBQUE7QUFDM0IsT0FBTyxLQUFLLE1BQU0sTUFBTSxVQUFVLENBQUE7QUFDbEMsT0FBTyxLQUFLLEtBQUssTUFBTSxRQUFRLENBQUE7QUFDL0IsT0FBTyxLQUFLLEtBQUssTUFBTSxTQUFTLENBQUE7QUFFeEIsSUFBQSxNQUFNLEdBQW9CLE1BQU0sT0FBMUIsRUFBSyxVQUFVLFVBQUssTUFBTSxFQUFsQyxVQUF5QixDQUFGLENBQVc7QUFFeEM7SUFLRSxZQUFvQixHQUF3QixFQUFTLE9BQWU7UUFBcEUsaUJBSUM7UUFKbUIsUUFBRyxHQUFILEdBQUcsQ0FBcUI7UUFBUyxZQUFPLEdBQVAsT0FBTyxDQUFRO1FBa0JwRSxpQkFBWSxHQUFtQixVQUFPLEVBQThCO2dCQUE1QixHQUFHLFNBQUEsRUFBRSxJQUFJLFVBQUEsRUFBRSxPQUFPLGFBQUEsRUFBRSxNQUFNLFlBQUE7Ozs7Z0NBQ2hFLFdBQU0sSUFBSSxDQUFDLEdBQUcsQ0FBQyxLQUFLLENBQUM7Z0NBQ25CLE1BQU0sRUFBRSxNQUFNO2dDQUNkLE9BQU8sZUFDRixPQUFPLENBQ1g7Z0NBQ0QsSUFBSSxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsSUFBSSxDQUFDO2dDQUMxQixHQUFHLEtBQUE7Z0NBQ0gsTUFBTSxRQUFBOzZCQUNQLENBQUMsRUFBQTtnQ0FUcUUsV0FBQSxDQUN2RSxTQVFFLENBQ0gsQ0FBQyxJQUFJLEVBQUE7Ozs7U0FBQSxDQUFBO1FBRU4sZUFBVSxHQUFpQixVQUFPLEVBQTJDO2dCQUF6QyxNQUFNLFlBQUEsRUFBRSxHQUFHLFNBQUEsRUFBRSxZQUFTLEVBQVQsSUFBSSxtQkFB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QUUsT0FBTyxDQUFDLENBQUE7QUFDN0IsQ0FBQztBQUVELElBQU0sU0FBUyxHQUF3QjtJQUNyQyxJQUFJLEVBQUUsY0FBYztJQUNwQixNQUFNLEVBQUUsRUFBRSxFQUFFLElBQUEsRUFBRTtDQUNmLENBQUE7QUFFRCxTQUFTLFVBQVUsQ0FBQyxHQUFlO0lBQ2pDLElBQUk7UUFDRixHQUFHLENBQUMsaUJBQWlCLENBQUMsU0FBUyxDQUFDLENBQUE7S0FDakM7SUFBQyxPQUFPLENBQUMsRUFBRTtRQUNWLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQyxDQUFDLENBQUE7S0FDaEI7QUFDSCxDQUFDO0FBRUQsT0FBTyxFQUFFLEtBQUssRUFBRSxLQUFLLEVBQUUsVUFBVSxJQUFJLE1BQU0sRUFBRSxVQUFVLEVBQUUsRUFBRSxFQUFFLEdBQUcsRUFBRSxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHR5cGUgeyBJQ2xvdWRiYXNlIH0gZnJvbSAnQGNsb3VkYmFzZS90eXBlcydcbmltcG9ydCB0eXBlIHsgSUNsb3VkYmFzZUNvbXBvbmVudCB9IGZyb20gJ0BjbG91ZGJhc2UvdHlwZXMvY29tcG9uZW50J1xuaW1wb3J0IHR5cGUgeyBTREtSZXF1ZXN0SW50ZXJmYWNlIH0gZnJvbSAnQGNsb3VkYmFzZS9hZGFwdGVyLWludGVyZmFjZSdcbmltcG9ydCB7IEJvdCB9IGZyb20gJy4vYm90J1xuaW1wb3J0ICogYXMgbW9kZWxzIGZyb20gJy4vbW9kZWxzJ1xuaW1wb3J0ICogYXMgdHlwZXMgZnJvbSAnLi90eXBlJ1xuaW1wb3J0ICogYXMgdXRpbHMgZnJvbSAnLi91dGlscydcblxuY29uc3QgeyBNT0RFTFMsIC4uLnJlc3RNb2RlbHMgfSA9IG1vZGVsc1xuXG5jbGFzcyBBSSB7XG4gIHB1YmxpYyBhaUJhc2VVcmw6IHN0cmluZ1xuICBwdWJsaWMgYWlCb3RCYXNlVXJsOiBzdHJpbmdcbiAgcHVibGljIGJvdDogQm90XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSByZXE6IFNES1JlcXVlc3RJbnRlcmZhY2UsIHB1YmxpYyBiYXNlVXJsOiBzdHJpbmcpIHtcbiAgICB0aGlzLmFpQmFzZVVybCA9IGAke2Jhc2VVcmx9L2FpYFxuICAgIHRoaXMuYWlCb3RCYXNlVXJsID0gYCR7YmFzZVVybH0vYWlib3RgXG4gICAgdGhpcy5ib3QgPSBuZXcgQm90KHRoaXMuYm90UmVxdWVzdCwgdGhpcy5haUJvdEJhc2VVcmwpXG4gIH1cblxuICBjcmVhdGVNb2RlbDxUIGV4dGVuZHMga2V5b2YgdHlwZW9mIE1PREVMUz4obW9kZWw6IFQpIHtcbiAgICByZXR1cm4gbmV3IE1PREVMU1ttb2RlbF0odGhpcy5tb2RlbFJlcXVlc3QsIHRoaXMuYWlCYXNlVXJsKSBhcyBJbnN0YW5jZVR5cGU8KHR5cGVvZiBNT0RFTFMpW1RdPlxuICB9XG5cbiAgcmVnaXN0ZXJNb2RlbChuYW1lOiBzdHJpbmcsIG1vZGVsOiB0eXBlcy5DaGF0TW9kZWxDb25zdHJ1Y3Rvcikge1xuICAgIGlmIChNT0RFTFNbbmFtZV0gIT0gbnVsbCkge1xuICAgICAgY29uc29sZS53YXJuKGBBSSBtb2RlbCAke25hbWV9IGFscmVhZHkgZXhpc3RzIWApXG4gICAgICByZXR1cm5cbiAgICB9XG4gICAgTU9ERUxTW25hbWVdID0gbW9kZWxcbiAgfVxuXG4gIG1vZGVsUmVxdWVzdDogdHlwZXMuTW9kZWxSZXEgPSBhc3luYyAoeyB1cmwsIGRhdGEsIGhlYWRlcnMsIHN0cmVhbSB9KSA9PiAoXG4gICAgYXdhaXQgdGhpcy5yZXEuZmV0Y2goe1xuICAgICAgbWV0aG9kOiAncG9zdCcsXG4gICAgICBoZWFkZXJzOiB7XG4gICAgICAgIC4uLmhlYWRlcnMsXG4gICAgICB9LFxuICAgICAgYm9keTogSlNPTi5zdHJpbmdpZnkoZGF0YSksXG4gICAgICB1cmwsXG4gICAgICBzdHJlYW0sXG4gICAgfSlcbiAgKS5kYXRhXG5cbiAgYm90UmVxdWVzdDogdHlwZXMuQm90UmVxID0gYXN5bmMgKHsgbWV0aG9kLCB1cmwsIGRhdGEgPSB7fSwgaGVhZGVycywgc3RyZWFtIH0pID0+IHtcbiAgICBpZiAobWV0aG9kID09PSAnZ2V0Jykge1xuICAgICAgcmV0dXJuIChhd2FpdCB0aGlzLnJlcS5mZXRjaCh7IHVybDogYCR7dXJsfT8ke29iamVjdFRvUGFyYW0oZGF0YSl9YCwgbWV0aG9kLCBoZWFkZXJzLCBzdHJlYW0gfSkpLmRhdGFcbiAgICB9XG5cbiAgICByZXR1cm4gKFxuICAgICAgYXdhaXQgdGhpcy5yZXEuZmV0Y2goe1xuICAgICAgICB1cmwsXG4gICAgICAgIGJvZHk6IEpTT04uc3RyaW5naWZ5KGRhdGEpLFxuICAgICAgICBoZWFkZXJzOiB7ICdDb250ZW50LVR5cGUnOiAnYXBwbGljYXRpb24vanNvbicsIC4uLmhlYWRlcnMgfSxcbiAgICAgICAgc3RyZWFtLFxuICAgICAgICBtZXRob2QsXG4gICAgICB9KVxuICAgICkuZGF0YVxuXG4gICAgZnVuY3Rpb24gb2JqZWN0VG9QYXJhbShvYmo6IE9iamVjdCkge1xuICAgICAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKG9iailcbiAgICAgICAgLm1hcCgoW2tleSwgdmFsdWVdKSA9PiBgJHtrZXl9PSR7dmFsdWV9YClcbiAgICAgICAgLmpvaW4oJyYnKVxuICAgIH1cbiAgfVxufVxuXG5jb25zdCBDT01QT05FTlRfTkFNRSA9ICdhaSdcblxuaW50ZXJmYWNlIEFJSW5pdE9wdGlvbiB7XG4gIGVudj86IHN0cmluZ1xuICBiYXNlVXJsPzogc3RyaW5nXG59XG5cbmZ1bmN0aW9uIGFpKFxuICB0aGlzOiBJQ2xvdWRiYXNlICYgeyBnZXRFbmRQb2ludFdpdGhLZXk6IChrZXk6ICdHQVRFV0FZJykgPT4geyBCQVNFX1VSTDogc3RyaW5nOyBQUk9UT0NPTDogc3RyaW5nIH0gfSxcbiAgb3B0aW9ucz86IEFJSW5pdE9wdGlvbixcbikge1xuICBjb25zdCByZXEgPSB0aGlzLnJlcXVlc3RcblxuICBpZiAocmVxLmZldGNoID09IG51bGwpIHtcbiAgICB0aHJvdyBuZXcgRXJyb3IoJ2Nsb3VkYmFzZS5yZXF1ZXN0LmZldGNoKCkgdW5pbXBsZW1lbnRlZCEnKVxuICB9XG5cbiAgY29uc3QgZ2V0VXJsRnJvbUNsb3VkID0gKCkgPT4ge1xuICAgIGNvbnN0IHsgQkFTRV9VUkwsIFBST1RPQ09MIH0gPSB0aGlzLmdldEVuZFBvaW50V2l0aEtleSgnR0FURVdBWScpXG4gICAgcmV0dXJuIGAke1BST1RPQ09MfSR7QkFTRV9VUkx9L3YxYFxuICB9XG5cbiAgY29uc3QgYmFzZVVybCA9IG9wdGlvbnM/LmJhc2VVcmwgPz8gZ2V0VXJsRnJvbUNsb3VkKClcblxuICByZXR1cm4gbmV3IEFJKHJlcSwgYmFzZVVybClcbn1cblxuY29uc3QgY29tcG9uZW50OiBJQ2xvdWRiYXNlQ29tcG9uZW50ID0ge1xuICBuYW1lOiBDT01QT05FTlRfTkFNRSxcbiAgZW50aXR5OiB7IGFpIH0sXG59XG5cbmZ1bmN0aW9uIHJlZ2lzdGVyQWkoYXBwOiBJQ2xvdWRiYXNlKSB7XG4gIHRyeSB7XG4gICAgYXBwLnJlZ2lzdGVyQ29tcG9uZW50KGNvbXBvbmVudClcbiAgfSBjYXRjaCAoZSkge1xuICAgIGNvbnNvbGUud2FybihlKVxuICB9XG59XG5cbmV4cG9ydCB7IHR5cGVzLCB1dGlscywgcmVzdE1vZGVscyBhcyBtb2RlbHMsIHJlZ2lzdGVyQWksIEFJLCBCb3QgfVxuIl19
212
+ export { AI, Bot, createAi, restModels as models, registerAi, types, utils };
213
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { IFetchOptions, SDKRequestInterface } from '@cloudbase/adapter-interface'\nimport type { ICloudbase } from '@cloudbase/types'\nimport type { ICloudbaseComponent } from '@cloudbase/types/component'\nimport { Bot } from './bot'\nimport * as models from './models'\nimport * as types from './type'\nimport * as utils from './utils'\n\nconst COMPONENT_NAME = 'ai'\n\nconst { MODELS, ...restModels } = 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    return new MODELS[model](this.modelRequest, this.aiBaseUrl) as InstanceType<(typeof MODELS)[T]>\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    await this.req.fetch({\n      method: 'post',\n      headers: {\n        ...headers,\n      },\n      body: JSON.stringify(data),\n      url,\n      stream,\n    })\n  ).data\n\n  botRequest: types.BotReq = async ({ method, url, data = {}, headers, stream }) => {\n    if (method === 'get') {\n      return (await this.req.fetch({ url: `${url}?${objectToParam(data)}`, method, headers, stream })).data\n    }\n\n    return (\n      await this.req.fetch({\n        url,\n        body: JSON.stringify(data),\n        headers: { 'Content-Type': 'application/json', ...headers },\n        stream,\n        method,\n      })\n    ).data\n\n    function objectToParam(obj: Object) {\n      return Object.entries(obj)\n        .map(([key, value]) => `${key}=${value}`)\n        .join('&')\n    }\n  }\n}\n\ninterface IHandleRequestInstance {\n  req: SDKRequestInterface\n}\n\ntype HandleRequestInstanceFunc = (options: IHandleRequestInstance) => SDKRequestInterface\n\nconst createRequestInstanceWithAccessTokenHeader = ({\n  getAccessToken,\n  req,\n}: IHandleRequestInstance & { getAccessToken: () => Promise<{ accessToken: string }> }) => {\n  const fetch: typeof req.fetch = async (options: IFetchOptions & { token?: string }) => {\n    if (typeof req.fetch !== 'function') {\n      throw new Error('req.fetch is not a function')\n    }\n\n    const { token, headers = {}, ...restOptions } = options\n    let accessToken: string\n    if (token != null) {\n      accessToken = token\n    } else {\n      accessToken = (await getAccessToken()).accessToken\n    }\n\n    return req.fetch({\n      headers: {\n        Authorization: `Bearer ${accessToken}`,\n        ...headers,\n      },\n      ...restOptions,\n    })\n  }\n\n  return {\n    download: req.download,\n    post: req.post,\n    upload: req.upload,\n    fetch,\n  }\n}\n\ninterface AIInitOption {\n  baseUrl?: string\n}\n\ninterface ICreateAi {\n  req: SDKRequestInterface\n  baseUrl?: string\n  env?: string\n  getAccessToken?: () => Promise<{ accessToken: string }>\n  handleReqInstance?: HandleRequestInstanceFunc\n}\n\n/**\n * 最简地创建一个接云开发网关服务的 `AI` 实例，请求时会自动带上鉴权请求头。\n * 只需要传入：\n *\n * - `getAccessToken`: 获取 accessToken 的函数\n * - `req`: 请求函数，一般从 adapter 上拿\n * - `env`: 云开发环境 ID\n *\n * 其他参数可按需传入覆盖函数逻辑。\n */\nfunction createAi({ env, baseUrl, req, getAccessToken, handleReqInstance }: ICreateAi) {\n  const getBaseUrl = () => {\n    if (baseUrl != null) {\n      return baseUrl\n    }\n    if (env == null) {\n      throw new Error('`env` is required when `baseUrl` is not provided!')\n    }\n    return `https://${env}.api.tcloudbasegateway.com/v1`\n  }\n\n  const getReq = () => {\n    if (handleReqInstance == null) {\n      if (getAccessToken == null) {\n        throw new Error('`getAccessToken` is required when `handleReqInstance` is not provided!')\n      }\n      return createRequestInstanceWithAccessTokenHeader({ req, getAccessToken })\n    }\n    return handleReqInstance({ req })\n  }\n\n  return new AI(getReq(), getBaseUrl())\n}\n\n/**\n * 创建 `AI` 实例。\n * 该函数挂载在 js sdk 的 Cloudbase 实例上。\n * 该函数调用了本模块暴露的 `createAi` 函数，但调用时通过传入参数做了逻辑覆盖：\n *\n * - 传入从 Cloudbase 实例上的中心的 `req`\n * - 传入从 Cloudbase 实例上拿到的 `baseUrl`\n * - 传入一个不处理 `req` 的 `handleReqInstance`，由于 `req` 是从 Cloudbase 实例上拿到的，这个中心的 `req` 已经可用了\n * - 不用传入 `env` 了，因为已经传了 `baseUrl`\n * - 不用传入 `getAccessToken` 了，因为传了 `handleReqInstance`\n */\nfunction ai(\n  this: ICloudbase & { getEndPointWithKey: (key: 'GATEWAY') => { BASE_URL: string; PROTOCOL: string } },\n  options?: AIInitOption,\n) {\n  const req = this.request\n\n  if (req.fetch == null) {\n    throw new Error('cloudbase.request.fetch() unimplemented!')\n  }\n\n  const getUrlFromCloud = () => {\n    const { BASE_URL, PROTOCOL } = this.getEndPointWithKey('GATEWAY')\n    return `${PROTOCOL}${BASE_URL}`\n  }\n\n  const baseUrl = options?.baseUrl ?? getUrlFromCloud()\n\n  return createAi({ req, baseUrl, handleReqInstance: ({ req }) => req })\n}\n\nconst component: ICloudbaseComponent = {\n  name: COMPONENT_NAME,\n  entity: { ai },\n}\n\nfunction registerAi(app: ICloudbase) {\n  try {\n    app.registerComponent(component)\n  } catch (e) {\n    console.warn(e)\n  }\n}\n\nexport { AI, Bot, createAi, restModels as models, registerAi, types, utils }\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@cloudbase/ai",
3
- "version": "2.8.13-beta.0",
3
+ "version": "2.8.15-beta.0",
4
4
  "description": "cloudbase js sdk ai module",
5
5
  "main": "dist/cjs/index.js",
6
6
  "module": "dist/esm/index.js",
@@ -27,10 +27,13 @@
27
27
  "author": "",
28
28
  "license": "Apache-2.0",
29
29
  "dependencies": {
30
- "@cloudbase/types": "^2.8.13-beta.0",
30
+ "@cloudbase/types": "^2.8.15-beta.0",
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"
34
34
  },
35
- "gitHead": "6353ef0b3c14bea7dda379265c3c12cbea74b457"
35
+ "devDependencies": {
36
+ "@cloudbase/adapter-interface": "^0.5.0"
37
+ },
38
+ "gitHead": "3720130f448a2dea95aa89bce37f3251ff8253b0"
36
39
  }
package/src/index.ts CHANGED
@@ -1,11 +1,13 @@
1
+ import type { IFetchOptions, SDKRequestInterface } from '@cloudbase/adapter-interface'
1
2
  import type { ICloudbase } from '@cloudbase/types'
2
3
  import type { ICloudbaseComponent } from '@cloudbase/types/component'
3
- import type { SDKRequestInterface } from '@cloudbase/adapter-interface'
4
4
  import { Bot } from './bot'
5
5
  import * as models from './models'
6
6
  import * as types from './type'
7
7
  import * as utils from './utils'
8
8
 
9
+ const COMPONENT_NAME = 'ai'
10
+
9
11
  const { MODELS, ...restModels } = models
10
12
 
11
13
  class AI {
@@ -66,13 +68,103 @@ class AI {
66
68
  }
67
69
  }
68
70
 
69
- const COMPONENT_NAME = 'ai'
71
+ interface IHandleRequestInstance {
72
+ req: SDKRequestInterface
73
+ }
74
+
75
+ type HandleRequestInstanceFunc = (options: IHandleRequestInstance) => SDKRequestInterface
76
+
77
+ const createRequestInstanceWithAccessTokenHeader = ({
78
+ getAccessToken,
79
+ req,
80
+ }: IHandleRequestInstance & { getAccessToken: () => Promise<{ accessToken: string }> }) => {
81
+ const fetch: typeof req.fetch = async (options: IFetchOptions & { token?: string }) => {
82
+ if (typeof req.fetch !== 'function') {
83
+ throw new Error('req.fetch is not a function')
84
+ }
85
+
86
+ const { token, headers = {}, ...restOptions } = options
87
+ let accessToken: string
88
+ if (token != null) {
89
+ accessToken = token
90
+ } else {
91
+ accessToken = (await getAccessToken()).accessToken
92
+ }
93
+
94
+ return req.fetch({
95
+ headers: {
96
+ Authorization: `Bearer ${accessToken}`,
97
+ ...headers,
98
+ },
99
+ ...restOptions,
100
+ })
101
+ }
102
+
103
+ return {
104
+ download: req.download,
105
+ post: req.post,
106
+ upload: req.upload,
107
+ fetch,
108
+ }
109
+ }
70
110
 
71
111
  interface AIInitOption {
72
- env?: string
73
112
  baseUrl?: string
74
113
  }
75
114
 
115
+ interface ICreateAi {
116
+ req: SDKRequestInterface
117
+ baseUrl?: string
118
+ env?: string
119
+ getAccessToken?: () => Promise<{ accessToken: string }>
120
+ handleReqInstance?: HandleRequestInstanceFunc
121
+ }
122
+
123
+ /**
124
+ * 最简地创建一个接云开发网关服务的 `AI` 实例,请求时会自动带上鉴权请求头。
125
+ * 只需要传入:
126
+ *
127
+ * - `getAccessToken`: 获取 accessToken 的函数
128
+ * - `req`: 请求函数,一般从 adapter 上拿
129
+ * - `env`: 云开发环境 ID
130
+ *
131
+ * 其他参数可按需传入覆盖函数逻辑。
132
+ */
133
+ function createAi({ env, baseUrl, req, getAccessToken, handleReqInstance }: ICreateAi) {
134
+ const getBaseUrl = () => {
135
+ if (baseUrl != null) {
136
+ return baseUrl
137
+ }
138
+ if (env == null) {
139
+ throw new Error('`env` is required when `baseUrl` is not provided!')
140
+ }
141
+ return `https://${env}.api.tcloudbasegateway.com/v1`
142
+ }
143
+
144
+ const getReq = () => {
145
+ if (handleReqInstance == null) {
146
+ if (getAccessToken == null) {
147
+ throw new Error('`getAccessToken` is required when `handleReqInstance` is not provided!')
148
+ }
149
+ return createRequestInstanceWithAccessTokenHeader({ req, getAccessToken })
150
+ }
151
+ return handleReqInstance({ req })
152
+ }
153
+
154
+ return new AI(getReq(), getBaseUrl())
155
+ }
156
+
157
+ /**
158
+ * 创建 `AI` 实例。
159
+ * 该函数挂载在 js sdk 的 Cloudbase 实例上。
160
+ * 该函数调用了本模块暴露的 `createAi` 函数,但调用时通过传入参数做了逻辑覆盖:
161
+ *
162
+ * - 传入从 Cloudbase 实例上的中心的 `req`
163
+ * - 传入从 Cloudbase 实例上拿到的 `baseUrl`
164
+ * - 传入一个不处理 `req` 的 `handleReqInstance`,由于 `req` 是从 Cloudbase 实例上拿到的,这个中心的 `req` 已经可用了
165
+ * - 不用传入 `env` 了,因为已经传了 `baseUrl`
166
+ * - 不用传入 `getAccessToken` 了,因为传了 `handleReqInstance`
167
+ */
76
168
  function ai(
77
169
  this: ICloudbase & { getEndPointWithKey: (key: 'GATEWAY') => { BASE_URL: string; PROTOCOL: string } },
78
170
  options?: AIInitOption,
@@ -85,12 +177,12 @@ function ai(
85
177
 
86
178
  const getUrlFromCloud = () => {
87
179
  const { BASE_URL, PROTOCOL } = this.getEndPointWithKey('GATEWAY')
88
- return `${PROTOCOL}${BASE_URL}/v1`
180
+ return `${PROTOCOL}${BASE_URL}`
89
181
  }
90
182
 
91
183
  const baseUrl = options?.baseUrl ?? getUrlFromCloud()
92
184
 
93
- return new AI(req, baseUrl)
185
+ return createAi({ req, baseUrl, handleReqInstance: ({ req }) => req })
94
186
  }
95
187
 
96
188
  const component: ICloudbaseComponent = {
@@ -106,4 +198,4 @@ function registerAi(app: ICloudbase) {
106
198
  }
107
199
  }
108
200
 
109
- export { types, utils, restModels as models, registerAi, AI, Bot }
201
+ export { AI, Bot, createAi, restModels as models, registerAi, types, utils }