@cloudbase/app 3.0.3 → 3.0.5

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.
Files changed (54) hide show
  1. package/dist/cjs/index.d.ts +1 -0
  2. package/dist/cjs/index.js +36 -7
  3. package/dist/cjs/libs/adapter-node/constants.d.ts +33 -0
  4. package/dist/cjs/libs/adapter-node/constants.js +38 -0
  5. package/dist/cjs/libs/adapter-node/context.d.ts +13 -0
  6. package/dist/cjs/libs/adapter-node/context.js +162 -0
  7. package/dist/cjs/libs/adapter-node/index.d.ts +23 -0
  8. package/dist/cjs/libs/adapter-node/index.js +124 -0
  9. package/dist/cjs/libs/adapter-node/metadata.d.ts +14 -0
  10. package/dist/cjs/libs/adapter-node/metadata.js +130 -0
  11. package/dist/cjs/libs/adapter-node/request.d.ts +38 -0
  12. package/dist/cjs/libs/adapter-node/request.js +432 -0
  13. package/dist/cjs/libs/adapter-node/tool.d.ts +2 -0
  14. package/dist/cjs/libs/adapter-node/tool.js +227 -0
  15. package/dist/cjs/libs/adapter-node/types.d.ts +78 -0
  16. package/dist/cjs/libs/adapter-node/types.js +3 -0
  17. package/dist/cjs/libs/adapter-node/utils.d.ts +17 -0
  18. package/dist/cjs/libs/adapter-node/utils.js +221 -0
  19. package/dist/cjs/libs/request.d.ts +1 -0
  20. package/dist/cjs/libs/request.js +3 -2
  21. package/dist/esm/index.d.ts +1 -0
  22. package/dist/esm/index.js +36 -7
  23. package/dist/esm/libs/adapter-node/constants.d.ts +33 -0
  24. package/dist/esm/libs/adapter-node/constants.js +35 -0
  25. package/dist/esm/libs/adapter-node/context.d.ts +13 -0
  26. package/dist/esm/libs/adapter-node/context.js +156 -0
  27. package/dist/esm/libs/adapter-node/index.d.ts +23 -0
  28. package/dist/esm/libs/adapter-node/index.js +118 -0
  29. package/dist/esm/libs/adapter-node/metadata.d.ts +14 -0
  30. package/dist/esm/libs/adapter-node/metadata.js +123 -0
  31. package/dist/esm/libs/adapter-node/request.d.ts +38 -0
  32. package/dist/esm/libs/adapter-node/request.js +429 -0
  33. package/dist/esm/libs/adapter-node/tool.d.ts +2 -0
  34. package/dist/esm/libs/adapter-node/tool.js +223 -0
  35. package/dist/esm/libs/adapter-node/types.d.ts +78 -0
  36. package/dist/esm/libs/adapter-node/types.js +2 -0
  37. package/dist/esm/libs/adapter-node/utils.d.ts +17 -0
  38. package/dist/esm/libs/adapter-node/utils.js +205 -0
  39. package/dist/esm/libs/request.d.ts +1 -0
  40. package/dist/esm/libs/request.js +3 -2
  41. package/dist/miniprogram/index.js +1 -1
  42. package/package.json +20 -4
  43. package/src/index.ts +63 -7
  44. package/src/libs/adapter-node/constants.ts +42 -0
  45. package/src/libs/adapter-node/context.ts +238 -0
  46. package/src/libs/adapter-node/index.ts +166 -0
  47. package/src/libs/adapter-node/metadata.ts +69 -0
  48. package/src/libs/adapter-node/request.ts +480 -0
  49. package/src/libs/adapter-node/tool.ts +223 -0
  50. package/src/libs/adapter-node/types.ts +116 -0
  51. package/src/libs/adapter-node/utils.ts +182 -0
  52. package/src/libs/request.ts +4 -2
  53. package/webpack/web.prod.js +13 -13
  54. package/webpack/webpack.miniprogram.js +9 -3
@@ -0,0 +1,223 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ import { ERROR } from './constants';
49
+ import { getCloudbaseContext, parseContext } from './context';
50
+ import { validateUid } from './utils';
51
+ var jwtSign = null;
52
+ function getJwtSign() {
53
+ var _a;
54
+ return __awaiter(this, void 0, void 0, function () {
55
+ var mod, e_1;
56
+ return __generator(this, function (_b) {
57
+ switch (_b.label) {
58
+ case 0:
59
+ if (!!jwtSign) return [3, 4];
60
+ _b.label = 1;
61
+ case 1:
62
+ _b.trys.push([1, 3, , 4]);
63
+ return [4, import('jsonwebtoken')];
64
+ case 2:
65
+ mod = _b.sent();
66
+ jwtSign = ((_a = mod.default) === null || _a === void 0 ? void 0 : _a.sign) || mod.sign;
67
+ return [3, 4];
68
+ case 3:
69
+ e_1 = _b.sent();
70
+ throw new Error('缺少依赖 jsonwebtoken,请执行以下命令安装:\n\n'
71
+ + ' npm install jsonwebtoken\n\n'
72
+ + '该依赖用于 Node 环境下的自定义登录票据生成。');
73
+ case 4: return [2, jwtSign];
74
+ }
75
+ });
76
+ });
77
+ }
78
+ function getDefaultUserInfo() {
79
+ var _a = getCloudbaseContext(), WX_OPENID = _a.WX_OPENID, WX_APPID = _a.WX_APPID, TCB_UUID = _a.TCB_UUID, TCB_CUSTOM_USER_ID = _a.TCB_CUSTOM_USER_ID, TCB_ISANONYMOUS_USER = _a.TCB_ISANONYMOUS_USER;
80
+ return {
81
+ openId: WX_OPENID || '',
82
+ appId: WX_APPID || '',
83
+ uid: TCB_UUID || '',
84
+ customUserId: TCB_CUSTOM_USER_ID || '',
85
+ isAnonymous: TCB_ISANONYMOUS_USER === 'true',
86
+ };
87
+ }
88
+ function sendUserInfoRequest(app, params) {
89
+ var _a, _b;
90
+ return (_b = (_a = app === null || app === void 0 ? void 0 : app.request) === null || _a === void 0 ? void 0 : _a.send) === null || _b === void 0 ? void 0 : _b.call(_a, 'auth.getUserInfoForAdmin', params, {
91
+ pathname: 'web',
92
+ endPointMode: 'CLOUD_API',
93
+ });
94
+ }
95
+ export var nodeTool = function (app, config) {
96
+ if (app.auth) {
97
+ var auth_1 = {
98
+ getUserInfo: function () {
99
+ return getDefaultUserInfo();
100
+ },
101
+ getEndUserInfo: function (uid) {
102
+ return __awaiter(this, void 0, void 0, function () {
103
+ var defaultUserInfo;
104
+ return __generator(this, function (_a) {
105
+ defaultUserInfo = getDefaultUserInfo();
106
+ if (uid === undefined) {
107
+ return [2, { userInfo: defaultUserInfo }];
108
+ }
109
+ validateUid(uid);
110
+ return [2, sendUserInfoRequest(app, {
111
+ uuid: uid,
112
+ envName: config.env,
113
+ }).then(function (result) {
114
+ if (result.code) {
115
+ return result;
116
+ }
117
+ return {
118
+ userInfo: __assign(__assign({}, defaultUserInfo), result.data),
119
+ requestId: result.requestId,
120
+ };
121
+ })];
122
+ });
123
+ });
124
+ },
125
+ createTicket: function (uid, options) {
126
+ if (options === void 0) { options = {}; }
127
+ return __awaiter(this, void 0, void 0, function () {
128
+ var timestamp, credentials, env, _a, refresh, _b, expire, sign, token;
129
+ return __generator(this, function (_c) {
130
+ switch (_c.label) {
131
+ case 0:
132
+ validateUid(uid);
133
+ timestamp = new Date().getTime();
134
+ credentials = (config.auth || {}).credentials;
135
+ env = config.env;
136
+ if (!env) {
137
+ throw __assign(__assign({}, ERROR.INVALID_PARAM), { message: 'no env in config' });
138
+ }
139
+ if (!(credentials === null || credentials === void 0 ? void 0 : credentials.env_id)) {
140
+ throw __assign(__assign({}, ERROR.INVALID_PARAM), { message: '当前私钥未包含env_id 信息, 请前往腾讯云云开发控制台,获取自定义登录最新私钥' });
141
+ }
142
+ if (credentials.env_id !== env) {
143
+ throw __assign(__assign({}, ERROR.INVALID_PARAM), { message: '当前私钥所属环境与 init 指定环境不一致!' });
144
+ }
145
+ _a = options.refresh, refresh = _a === void 0 ? 3600 * 1000 : _a, _b = options.expire, expire = _b === void 0 ? timestamp + 7 * 24 * 60 * 60 * 1000 : _b;
146
+ return [4, getJwtSign()];
147
+ case 1:
148
+ sign = _c.sent();
149
+ token = sign({
150
+ alg: 'RS256',
151
+ env: env,
152
+ iat: timestamp,
153
+ exp: timestamp + 10 * 60 * 1000,
154
+ uid: uid,
155
+ refresh: refresh,
156
+ expire: expire,
157
+ }, credentials.private_key, {
158
+ allowInsecureKeySizes: true,
159
+ algorithm: 'RS256',
160
+ });
161
+ return [2, "".concat(credentials.private_key_id, "/@@/").concat(token)];
162
+ }
163
+ });
164
+ });
165
+ },
166
+ queryUserInfo: function (query) {
167
+ return __awaiter(this, void 0, void 0, function () {
168
+ var uid, platform, platformId;
169
+ return __generator(this, function (_a) {
170
+ uid = query.uid, platform = query.platform, platformId = query.platformId;
171
+ return [2, sendUserInfoRequest(app, {
172
+ uuid: uid,
173
+ platform: platform,
174
+ platformId: platformId,
175
+ envName: config.env,
176
+ }).then(function (result) {
177
+ if (result.code) {
178
+ return result;
179
+ }
180
+ return {
181
+ userInfo: __assign({}, result.data),
182
+ requestId: result.requestId,
183
+ };
184
+ })];
185
+ });
186
+ });
187
+ },
188
+ getClientIP: function () {
189
+ var TCB_SOURCE_IP = getCloudbaseContext().TCB_SOURCE_IP;
190
+ return TCB_SOURCE_IP || '';
191
+ },
192
+ };
193
+ Object.keys(auth_1).forEach(function (key) {
194
+ app.auth[key] = auth_1[key];
195
+ });
196
+ }
197
+ app.sendTemplateNotification = function (params, opts) { return __awaiter(void 0, void 0, void 0, function () {
198
+ var _a;
199
+ return __generator(this, function (_b) {
200
+ switch (_b.label) {
201
+ case 0: return [4, ((_a = app === null || app === void 0 ? void 0 : app.callFunction) === null || _a === void 0 ? void 0 : _a.call(app, {
202
+ name: 'lowcode-datasource',
203
+ data: {
204
+ methodName: 'callWedaApi',
205
+ params: {
206
+ action: 'PushNotifyMsg',
207
+ data: {
208
+ NotifyId: params.notifyId,
209
+ Data: JSON.stringify(params.data),
210
+ NotifyUsers: undefined,
211
+ Url: params.url,
212
+ },
213
+ },
214
+ mode: 'c',
215
+ },
216
+ }, undefined, opts))];
217
+ case 1: return [2, _b.sent()];
218
+ }
219
+ });
220
+ }); };
221
+ app.parseContext = parseContext;
222
+ };
223
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWJzL2FkYXB0ZXItbm9kZS90b29sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUNuQyxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsWUFBWSxFQUFFLE1BQU0sV0FBVyxDQUFBO0FBQzdELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxTQUFTLENBQUE7QUFZckMsSUFBSSxPQUFPLEdBQXFDLElBQUksQ0FBQTtBQUNwRCxTQUFlLFVBQVU7Ozs7Ozs7eUJBQ25CLENBQUMsT0FBTyxFQUFSLGNBQVE7Ozs7b0JBR0ksV0FBTSxNQUFNLENBQUMsY0FBYyxDQUFDLEVBQUE7O29CQUFsQyxHQUFHLEdBQUcsU0FBNEI7b0JBQ3hDLE9BQU8sR0FBRyxDQUFBLE1BQUEsR0FBRyxDQUFDLE9BQU8sMENBQUUsSUFBSSxLQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUE7Ozs7b0JBRXZDLE1BQU0sSUFBSSxLQUFLLENBQUMsa0NBQWtDOzBCQUM5QyxnQ0FBZ0M7MEJBQ2hDLDJCQUEyQixDQUFDLENBQUE7d0JBR3BDLFdBQU8sT0FBUSxFQUFBOzs7O0NBQ2hCO0FBTUQsU0FBUyxrQkFBa0I7SUFDbkIsSUFBQSxLQUE4RSxtQkFBbUIsRUFBRSxFQUFqRyxTQUFTLGVBQUEsRUFBRSxRQUFRLGNBQUEsRUFBRSxRQUFRLGNBQUEsRUFBRSxrQkFBa0Isd0JBQUEsRUFBRSxvQkFBb0IsMEJBQTBCLENBQUE7SUFFekcsT0FBTztRQUNMLE1BQU0sRUFBRSxTQUFTLElBQUksRUFBRTtRQUN2QixLQUFLLEVBQUUsUUFBUSxJQUFJLEVBQUU7UUFDckIsR0FBRyxFQUFFLFFBQVEsSUFBSSxFQUFFO1FBQ25CLFlBQVksRUFBRSxrQkFBa0IsSUFBSSxF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QUMsQ0FBQTtLQUNIO0lBU0QsR0FBRyxDQUFDLHdCQUF3QixHQUFHLFVBQU8sTUFBMEIsRUFBRSxJQUEyQjs7Ozt3QkFBSyxXQUFNLENBQUEsTUFBQSxHQUFHLGFBQUgsR0FBRyx1QkFBSCxHQUFHLENBQUUsWUFBWSxvREFDdkg7d0JBQ0UsSUFBSSxFQUFFLG9CQUFvQjt3QkFDMUIsSUFBSSxFQUFFOzRCQUNKLFVBQVUsRUFBRSxhQUFhOzRCQUN6QixNQUFNLEVBQUU7Z0NBQ04sTUFBTSxFQUFFLGVBQWU7Z0NBQ3ZCLElBQUksRUFBRTtvQ0FDSixRQUFRLEVBQUUsTUFBTSxDQUFDLFFBQVE7b0NBQ3pCLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7b0NBQ2pDLFdBQVcsRUFBRSxTQUFTO29DQUN0QixHQUFHLEVBQUUsTUFBTSxDQUFDLEdBQUc7aUNBQ2hCOzZCQUNGOzRCQUNELElBQUksRUFBRSxHQUFHO3lCQUNWO3FCQUNGLEVBQ0QsU0FBUyxFQUNULElBQUksQ0FDTCxDQUFBLEVBQUE7d0JBbkJpRyxXQUFBLFNBbUJqRyxFQUFBOzs7U0FBQSxDQUFBO0lBR0QsR0FBRyxDQUFDLFlBQVksR0FBRyxZQUFZLENBQUE7QUFDakMsQ0FBQyxDQUFBIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRVJST1IgfSBmcm9tICcuL2NvbnN0YW50cydcbmltcG9ydCB7IGdldENsb3VkYmFzZUNvbnRleHQsIHBhcnNlQ29udGV4dCB9IGZyb20gJy4vY29udGV4dCdcbmltcG9ydCB7IHZhbGlkYXRlVWlkIH0gZnJvbSAnLi91dGlscydcbmltcG9ydCB0eXBlIHtcbiAgSUNyZWF0ZVRpY2tldE9wdHMsXG4gIElHZXRVc2VySW5mb1Jlc3VsdCxcbiAgSUdldEVuZFVzZXJJbmZvUmVzdWx0LFxuICBJVXNlckluZm9RdWVyeSxcbiAgSVRlbXBsYXRlTm90aWZ5UmVxLFxufSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHsgSUNsb3VkYmFzZUNvbmZpZyB9IGZyb20gJ0BjbG91ZGJhc2UvdHlwZXMnXG5cbi8vIOW7tui/n+WKoOi9ve+8jOmBv+WFjemdniBOb2RlIOeOr+Wig+aJk+WMheaXtuW8leWFpeatpOWMhVxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIEB0eXBlc2NyaXB0LWVzbGludC9uby1leHBsaWNpdC1hbnlcbmxldCBqd3RTaWduOiAoKC4uLmFyZ3M6IGFueVtdKSA9PiBhbnkpIHwgbnVsbCA9IG51bGxcbmFzeW5jIGZ1bmN0aW9uIGdldEp3dFNpZ24oKSB7XG4gIGlmICghand0U2lnbikge1xuICAgIHRyeSB7XG4gICAgICAvLyBAdHMtaWdub3JlIOKAlCDor6XljIXku4XlnKggTm9kZSDov5DooYzml7blrZjlnKjvvIzlvIDlj5Hnjq/looPlj6/og73mnKrlronoo4VcbiAgICAgIGNvbnN0IG1vZCA9IGF3YWl0IGltcG9ydCgnanNvbndlYnRva2VuJylcbiAgICAgIGp3dFNpZ24gPSBtb2QuZGVmYXVsdD8uc2lnbiB8fCBtb2Quc2lnblxuICAgIH0gY2F0Y2ggKGUpIHtcbiAgICAgIHRocm93IG5ldyBFcnJvcign57y65bCR5L6d6LWWIGpzb253ZWJ0b2tlbu+8jOivt+aJp+ihjOS7peS4i+WRveS7pOWuieijhe+8mlxcblxcbidcbiAgICAgICAgKyAnICBucG0gaW5zdGFsbCBqc29ud2VidG9rZW5cXG5cXG4nXG4gICAgICAgICsgJ+ivpeS+nei1lueUqOS6jiBOb2RlIOeOr+Wig+S4i+eahOiHquWumuS5ieeZu+W9leelqOaNrueUn+aIkOOAgicpXG4gICAgfVxuICB9XG4gIHJldHVybiBqd3RTaWduIVxufVxuXG4vKipcbiAqIOS7juS6keWHveaVsOi/kOihjOaXtuS4iuS4i+aWh+S4reiOt+WPluW9k+WJjeivt+axgueahOeUqOaIt+S/oeaBr1xuICog5pWw5o2u5p2l5rqQ5Li6546v5aKD5Y+Y6YeP77yI5b6u5L+hIG9wZW5JZOOAgVRDQiB1dWlkIOetie+8iVxuICovXG5mdW5jdGlvbiBnZXREZWZhdWx0VXNlckluZm8oKTogSUdldFVzZXJJbmZvUmVzdWx0IHtcbiAgY29uc3QgeyBXWF9PUEVOSUQsIFdYX0FQUElELCBUQ0JfVVVJRCwgVENCX0NVU1RPTV9VU0VSX0lELCBUQ0JfSVNBTk9OWU1PVVNfVVNFUiB9ID0gZ2V0Q2xvdWRiYXNlQ29udGV4dCgpXG5cbiAgcmV0dXJuIHtcbiAgICBvcGVuSWQ6IFdYX09QRU5JRCB8fCAnJyxcbiAgICBhcHBJZDogV1hfQVBQSUQgfHwgJycsXG4gICAgdWlkOiBUQ0JfVVVJRCB8fCAnJyxcbiAgICBjdXN0b21Vc2VySWQ6IFRDQl9DVVNUT01fVVNFUl9JRCB8fCAnJyxcbiAgICBpc0Fub255bW91czogVENCX0lTQU5PTllNT1VTX1VTRVIgPT09ICd0cnVlJyxcbiAgfVxufVxuXG4vKipcbiAqIOiwg+eUqOWQjuerr+euoeeQhuaOpeWPo+afpeivoueUqOaIt+S/oeaBr1xuICog57uf5LiA5bCB6KOFIGF1dGguZ2V0VXNlckluZm9Gb3JBZG1pbiDnmoTor7fmsYLpgLvovpFcbiAqL1xuZnVuY3Rpb24gc2VuZFVzZXJJbmZvUmVxdWVzdChhcHA6IGFueSwgcGFyYW1zOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KTogUHJvbWlzZTxhbnk+IHtcbiAgcmV0dXJuIGFwcD8ucmVxdWVzdD8uc2VuZD8uKCdhdXRoLmdldFVzZXJJbmZvRm9yQWRtaW4nLCBwYXJhbXMsIHtcbiAgICBwYXRobmFtZTogJ3dlYicsXG4gICAgZW5kUG9pbnRNb2RlOiAnQ0xPVURfQVBJJyxcbiAgfSlcbn1cblxuLyoqXG4gKiDliJ3lp4vljJYgTm9kZSDnq6/lt6Xlhbfmlrnms5XvvIzmjILovb3liLAganMtc2RrIGFwcCDlrp7kvovkuIpcbiAqIOWMheWQq++8mmF1dGgg55u45YWz5pa55rOV44CB5qih5p2/5raI5oGv5o6o6YCB44CBY29udGV4dCDop6PmnpBcbiAqXG4gKiBAcGFyYW0gYXBwIC0ganMtc2RrIGNsb3VkYmFzZSDlrp7kvotcbiAqIEBwYXJhbSBjb25maWcgLSDphY3nva7kv6Hmga/vvIzljIXlkKvorqTor4Hlh63or4Hlkoznjq/looMgSURcbiAqL1xuZXhwb3J0IGNvbnN0IG5vZGVUb29sID0gKGFwcDogYW55LCBjb25maWc6IElDbG91ZGJhc2VDb25maWcpID0+IHtcbiAgLy8g5LuF5b2TIGFwcCDlt7LliJ3lp4vljJYgYXV0aCDmqKHlnZfml7bvvIzmiY3ms6jlhaUgYXV0aCDnm7jlhbPmlrnms5VcbiAgaWYgKGFwcC5hdXRoKSB7XG4gICAgY29uc3QgYXV0aCA9IHtcbiAgICAgIC8qKiDojrflj5blvZPliY3or7fmsYLnmoTnlKjmiLfkv6Hmga/vvIjku47njq/looPlj5jph4/or7vlj5bvvIzlkIzmraXvvIkgKi9cbiAgICAgIGdldFVzZXJJbmZvKCk6IElHZXRVc2VySW5mb1Jlc3VsdCB7XG4gICAgICAgIHJldHVybiBnZXREZWZhdWx0VXNlckluZm8oKVxuICAgICAgfSxcblxuICAgICAgLyoqXG4gICAgICAgKiDojrflj5bnu4jnq6/nlKjmiLfkv6Hmga9cbiAgICAgICAqIOS4jeS8oCB1aWQg5pe26L+U5Zue5b2T5YmN6K+35rGC55So5oi35L+h5oGv77yM5LygIHVpZCDml7bmn6Xor6LmjIflrprnlKjmiLdcbiAgICAgICAqL1xuICAgICAgYXN5bmMgZ2V0RW5kVXNlckluZm8odWlkPzogc3RyaW5nKTogUHJvbWlzZTxJR2V0RW5kVXNlckluZm9SZXN1bHQ+IHtcbiAgICAgICAgY29uc3QgZGVmYXVsdFVzZXJJbmZvID0gZ2V0RGVmYXVsdFVzZXJJbmZvKClcblxuICAgICAgICBpZiAodWlkID09PSB1bmRlZmluZWQpIHtcbiAgICAgICAgICByZXR1cm4geyB1c2VySW5mbzogZGVmYXVsdFVzZXJJbmZvIH1cbiAgICAgICAgfVxuICAgICAgICB2YWxpZGF0ZVVpZCh1aWQpXG5cbiAgICAgICAgcmV0dXJuIHNlbmRVc2VySW5mb1JlcXVlc3QoYXBwLCB7XG4gICAgICAgICAgdXVpZDogdWlkLFxuICAgICAgICAgIGVudk5hbWU6IGNvbmZpZy5lbnYsXG4gICAgICAgIH0pLnRoZW4oKHJlc3VsdDogYW55KSA9PiB7XG4gICAgICAgICAgaWYgKHJlc3VsdC5jb2RlKSB7XG4gICAgICAgICAgICByZXR1cm4gcmVzdWx0XG4gICAgICAgICAgfVxuICAgICAgICAgIHJldHVybiB7XG4gICAgICAgICAgICB1c2VySW5mbzogeyAuLi5kZWZhdWx0VXNlckluZm8sIC4uLnJlc3VsdC5kYXRhIH0sXG4gICAgICAgICAgICByZXF1ZXN0SWQ6IHJlc3VsdC5yZXF1ZXN0SWQsXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfSxcblxuICAgICAgLyoqXG4gICAgICAgKiDliJvlu7roh6rlrprkuYnnmbvlvZUgVGlja2V0XG4gICAgICAgKiDkvb/nlKggUlNBIOengemSpeetvuWPkSBKV1TvvIzlrqLmiLfnq6/lh63mraQgVGlja2V0IOaNouWPlueZu+W9leaAgVxuICAgICAgICpcbiAgICAgICAqIEBwYXJhbSB1aWQgLSDoh6rlrprkuYnnlKjmiLcgSUTvvIg0fjMyIOS9je+8iVxuICAgICAgICogQHBhcmFtIG9wdGlvbnMgLSDliLfmlrDpl7TpmpTlkozov4fmnJ/ml7bpl7TphY3nva5cbiAgICAgICAqIEByZXR1cm5zIOagvOW8j+S4uiBcIntwcml2YXRlX2tleV9pZH0vQEAve2p3dF90b2tlbn1cIiDnmoQgVGlja2V0IOWtl+espuS4slxuICAgICAgICovXG4gICAgICBhc3luYyBjcmVhdGVUaWNrZXQodWlkOiBzdHJpbmcsIG9wdGlvbnM6IElDcmVhdGVUaWNrZXRPcHRzID0ge30pOiBQcm9taXNlPHN0cmluZz4ge1xuICAgICAgICB2YWxpZGF0ZVVpZCh1aWQpXG5cbiAgICAgICAgY29uc3QgdGltZXN0YW1wID0gbmV3IERhdGUoKS5nZXRUaW1lKClcbiAgICAgICAgY29uc3QgeyBjcmVkZW50aWFscyB9ID0gY29uZmlnLmF1dGggfHwge31cbiAgICAgICAgY29uc3QgeyBlbnYgfSA9IGNvbmZpZ1xuXG4gICAgICAgIGlmICghZW52KSB7XG4gICAgICAgICAgdGhyb3cgeyAuLi5FUlJPUi5JTlZBTElEX1BBUkFNLCBtZXNzYWdlOiAnbm8gZW52IGluIGNvbmZpZycgfVxuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFjcmVkZW50aWFscz8uZW52X2lkKSB7XG4gICAgICAgICAgdGhyb3cge1xuICAgICAgICAgICAgLi4uRVJST1IuSU5WQUxJRF9QQVJBTSxcbiAgICAgICAgICAgIG1lc3NhZ2U6ICflvZPliY3np4HpkqXmnKrljIXlkKtlbnZfaWQg5L+h5oGv77yMIOivt+WJjeW+gOiFvuiur+S6keS6keW8gOWPkeaOp+WItuWPsO+8jOiOt+WPluiHquWumuS5ieeZu+W9leacgOaWsOengemSpScsXG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGNyZWRlbnRpYWxzLmVudl9pZCAhPT0gZW52KSB7XG4gICAgICAgICAgdGhyb3cge1xuICAgICAgICAgICAgLi4uRVJST1IuSU5WQUxJRF9QQVJBTSxcbiAgICAgICAgICAgIG1lc3NhZ2U6ICflvZPliY3np4HpkqXmiYDlsZ7njq/looPkuI4gaW5pdCDmjIflrprnjq/looPkuI3kuIDoh7TvvIEnLFxuICAgICAgICAgIH1cbiAgICAgICAgfVxuXG4gICAgICAgIGNvbnN0IHtcbiAgICAgICAgICByZWZyZXNoID0gMzYwMCAqIDEwMDAsIC8vIOm7mOiupCAxIOWwj+aXtuWIt+aWsFxuICAgICAgICAgIGV4cGlyZSA9IHRpbWVzdGFtcCArIDcgKiAyNCAqIDYwICogNjAgKiAxMDAwLCAvLyDpu5jorqQgNyDlpKnov4fmnJ9cbiAgICAgICAgfSA9IG9wdGlvbnNcbiAgICAgICAgY29uc3Qgc2lnbiA9IGF3YWl0IGdldEp3dFNpZ24oKVxuICAgICAgICBjb25zdCB0b2tlbiA9IHNpZ24oXG4gICAgICAgICAge1xuICAgICAgICAgICAgYWxnOiAnUlMyNTYnLFxuICAgICAgICAgICAgZW52LFxuICAgICAgICAgICAgaWF0OiB0aW1lc3RhbXAsXG4gICAgICAgICAgICBleHA6IHRpbWVzdGFtcCArIDEwICogNjAgKiAxMDAwLCAvLyBUaWNrZXQg5pys6LqrIDEwIOWIhumSn+acieaViFxuICAgICAgICAgICAgdWlkLFxuICAgICAgICAgICAgcmVmcmVzaCxcbiAgICAgICAgICAgIGV4cGlyZSxcbiAgICAgICAgICB9LFxuICAgICAgICAgIGNyZWRlbnRpYWxzLnByaXZhdGVfa2V5LFxuICAgICAgICAgIHtcbiAgICAgICAgICAgIGFsbG93SW5zZWN1cmVLZXlTaXplczogdHJ1ZSxcbiAgICAgICAgICAgIGFsZ29yaXRobTogJ1JTMjU2JyxcbiAgICAgICAgICB9LFxuICAgICAgICApXG5cbiAgICAgICAgcmV0dXJuIGAke2NyZWRlbnRpYWxzLnByaXZhdGVfa2V5X2lkfS9AQC8ke3Rva2VufWBcbiAgICAgIH0sXG5cbiAgICAgIC8qKlxuICAgICAgICog5oyJ5p2h5Lu25p+l6K+i55So5oi35L+h5oGv77yI566h55CG56uv5o6l5Y+j77yJXG4gICAgICAgKiDmlK/mjIHmjIkgdWlk44CBcGxhdGZvcm3jgIFwbGF0Zm9ybUlkIOafpeivolxuICAgICAgICovXG4gICAgICBhc3luYyBxdWVyeVVzZXJJbmZvKHF1ZXJ5OiBJVXNlckluZm9RdWVyeSk6IFByb21pc2U8YW55PiB7XG4gICAgICAgIGNvbnN0IHsgdWlkLCBwbGF0Zm9ybSwgcGxhdGZvcm1JZCB9ID0gcXVlcnlcbiAgICAgICAgcmV0dXJuIHNlbmRVc2VySW5mb1JlcXVlc3QoYXBwLCB7XG4gICAgICAgICAgdXVpZDogdWlkLFxuICAgICAgICAgIHBsYXRmb3JtLFxuICAgICAgICAgIHBsYXRmb3JtSWQsXG4gICAgICAgICAgZW52TmFtZTogY29uZmlnLmVudixcbiAgICAgICAgfSkudGhlbigocmVzdWx0OiBhbnkpID0+IHtcbiAgICAgICAgICBpZiAocmVzdWx0LmNvZGUpIHtcbiAgICAgICAgICAgIHJldHVybiByZXN1bHRcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHVzZXJJbmZvOiB7IC4uLnJlc3VsdC5kYXRhIH0sXG4gICAgICAgICAgICByZXF1ZXN0SWQ6IHJlc3VsdC5yZXF1ZXN0SWQsXG4gICAgICAgICAgfVxuICAgICAgICB9KVxuICAgICAgfSxcblxuICAgICAgLyoqIOiOt+WPluWuouaIt+erryBJUCDlnLDlnYAgKi9cbiAgICAgIGdldENsaWVudElQKCk6IHN0cmluZyB7XG4gICAgICAgIGNvbnN0IHsgVENCX1NPVVJDRV9JUCB9ID0gZ2V0Q2xvdWRiYXNlQ29udGV4dCgpXG4gICAgICAgIHJldHVybiBUQ0JfU09VUkNFX0lQIHx8ICcnXG4gICAgICB9LFxuICAgIH1cblxuICAgIC8vIOWwhiBhdXRoIOaWueazlemAkOS4gOaMgui9veWIsCBhcHAuYXV0aCDkuIpcbiAgICBPYmplY3Qua2V5cyhhdXRoKS5mb3JFYWNoKChrZXkpID0+IHtcbiAgICAgIGFwcC5hdXRoW2tleV0gPSAoYXV0aCBhcyBSZWNvcmQ8c3RyaW5nLCBhbnk+KVtrZXldXG4gICAgfSlcbiAgfVxuXG4gIC8qKlxuICAgKiDlj5HpgIHmqKHmnb/mtojmga/pgJrnn6VcbiAgICog6YCa6L+H6LCD55SoIGxvd2NvZGUtZGF0YXNvdXJjZSDkupHlh73mlbDpl7TmjqXosIPnlKjlvq7mkK0gQVBJXG4gICAqXG4gICAqIEBwYXJhbSBwYXJhbXMgLSDpgJrnn6Xlj4LmlbDvvIjnrZbnlaUgSUTjgIHmqKHmnb/lj5jph4/jgIHot7Povazpk77mjqXvvIlcbiAgICogQHBhcmFtIG9wdHMgLSDlj6/pgInphY3nva7vvIzlpoLotoXml7bml7bpl7RcbiAgICovXG4gIGFwcC5zZW5kVGVtcGxhdGVOb3RpZmljYXRpb24gPSBhc3luYyAocGFyYW1zOiBJVGVtcGxhdGVOb3RpZnlSZXEsIG9wdHM/OiB7IHRpbWVvdXQ/OiBudW1iZXIgfSkgPT4gYXdhaXQgYXBwPy5jYWxsRnVuY3Rpb24/LihcbiAgICB7XG4gICAgICBuYW1lOiAnbG93Y29kZS1kYXRhc291cmNlJyxcbiAgICAgIGRhdGE6IHtcbiAgICAgICAgbWV0aG9kTmFtZTogJ2NhbGxXZWRhQXBpJyxcbiAgICAgICAgcGFyYW1zOiB7XG4gICAgICAgICAgYWN0aW9uOiAnUHVzaE5vdGlmeU1zZycsXG4gICAgICAgICAgZGF0YToge1xuICAgICAgICAgICAgTm90aWZ5SWQ6IHBhcmFtcy5ub3RpZnlJZCxcbiAgICAgICAgICAgIERhdGE6IEpTT04uc3RyaW5naWZ5KHBhcmFtcy5kYXRhKSxcbiAgICAgICAgICAgIE5vdGlmeVVzZXJzOiB1bmRlZmluZWQsXG4gICAgICAgICAgICBVcmw6IHBhcmFtcy51cmwsXG4gICAgICAgICAgfSxcbiAgICAgICAgfSxcbiAgICAgICAgbW9kZTogJ2MnLFxuICAgICAgfSxcbiAgICB9LFxuICAgIHVuZGVmaW5lZCxcbiAgICBvcHRzLFxuICApXG5cbiAgLyoqIOaMgui9vSBjb250ZXh0IOino+aekOW3peWFt++8jOaWueS+v+eUqOaIt+WcqOS6keWHveaVsOS4reS9v+eUqCAqL1xuICBhcHAucGFyc2VDb250ZXh0ID0gcGFyc2VDb250ZXh0XG59XG4iXX0=
@@ -0,0 +1,78 @@
1
+ export interface ICreateTicketOpts {
2
+ refresh?: number;
3
+ expire?: number;
4
+ }
5
+ export interface IGetUserInfoResult {
6
+ openId: string;
7
+ appId: string;
8
+ uid: string;
9
+ customUserId: string;
10
+ isAnonymous: boolean;
11
+ }
12
+ export interface IContextParam {
13
+ memory_limit_in_mb: number;
14
+ time_limit_in_ms: number;
15
+ request_id: string;
16
+ environ?: string;
17
+ environment?: string;
18
+ function_version: string;
19
+ function_name: string;
20
+ namespace: string;
21
+ }
22
+ export interface IUserInfoQuery {
23
+ platform?: string;
24
+ platformId?: string;
25
+ uid?: string;
26
+ }
27
+ export interface ICompleteCloudbaseContext {
28
+ _SCF_TCB_LOG?: string;
29
+ LOGINTYPE?: string;
30
+ QQ_APPID?: string;
31
+ QQ_OPENID?: string;
32
+ SCF_NAMESPACE: string;
33
+ TCB_CONTEXT_CNFG?: string;
34
+ TCB_CONTEXT_KEYS: string[];
35
+ TCB_CUSTOM_USER_ID?: string;
36
+ TCB_ENV: string;
37
+ TCB_HTTP_CONTEXT?: string;
38
+ TCB_ISANONYMOUS_USER?: string;
39
+ TCB_ROUTE_KEY?: string;
40
+ TCB_SEQID: string;
41
+ TCB_SESSIONTOKEN?: string;
42
+ TCB_SOURCE_IP?: string;
43
+ TCB_SOURCE?: string;
44
+ TCB_TRACELOG?: string;
45
+ TCB_UUID?: string;
46
+ TENCENTCLOUD_RUNENV: string;
47
+ TENCENTCLOUD_SECRETID: string;
48
+ TENCENTCLOUD_SECRETKEY: string;
49
+ TENCENTCLOUD_SESSIONTOKEN: string;
50
+ TRIGGER_SRC: string;
51
+ WX_API_TOKEN?: string;
52
+ WX_APPID?: string;
53
+ WX_CLIENTIP?: string;
54
+ WX_CLIENTIPV6?: string;
55
+ WX_CLOUDBASE_ACCESSTOKEN?: string;
56
+ WX_CONTEXT_KEYS: string[];
57
+ WX_OPENID?: string;
58
+ WX_TRIGGER_API_TOKEN_V0?: string;
59
+ WX_UNIONID?: string;
60
+ }
61
+ export interface IGetEndUserInfoResult {
62
+ userInfo?: {
63
+ openId: string;
64
+ appId: string;
65
+ uid: string;
66
+ customUserId: string;
67
+ isAnonymous: boolean;
68
+ };
69
+ requestId?: string;
70
+ }
71
+ export interface ICustomReqOpts {
72
+ timeout?: number;
73
+ }
74
+ export interface ITemplateNotifyReq {
75
+ notifyId: string;
76
+ data?: Record<string, unknown>;
77
+ url?: string;
78
+ }
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHlwZXMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGlicy9hZGFwdGVyLW5vZGUvdHlwZXMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IiIsInNvdXJjZXNDb250ZW50IjpbIi8qKiDoh6rlrprkuYnnmbvlvZUgVGlja2V0IOWIm+W7uumAiemhuSAqL1xuZXhwb3J0IGludGVyZmFjZSBJQ3JlYXRlVGlja2V0T3B0cyB7XG4gIC8qKiDliLfmlrDpl7TpmpTvvIjmr6vnp5LvvInvvIzpu5jorqQgMzYwMDAwMO+8iDHlsI/ml7bvvIkgKi9cbiAgcmVmcmVzaD86IG51bWJlclxuICAvKiog6L+H5pyf5pe26Ze05oiz77yI5q+r56eS77yJ77yM6buY6K6kIDcg5aSp5ZCOICovXG4gIGV4cGlyZT86IG51bWJlclxufVxuXG4vKiog55So5oi35L+h5oGv5p+l6K+i57uT5p6cICovXG5leHBvcnQgaW50ZXJmYWNlIElHZXRVc2VySW5mb1Jlc3VsdCB7XG4gIG9wZW5JZDogc3RyaW5nXG4gIGFwcElkOiBzdHJpbmdcbiAgdWlkOiBzdHJpbmdcbiAgY3VzdG9tVXNlcklkOiBzdHJpbmdcbiAgaXNBbm9ueW1vdXM6IGJvb2xlYW5cbn1cblxuLyoqIOS6keWHveaVsOWFpeWPoyBjb250ZXh0IOWPguaVsOe7k+aehCAqL1xuZXhwb3J0IGludGVyZmFjZSBJQ29udGV4dFBhcmFtIHtcbiAgbWVtb3J5X2xpbWl0X2luX21iOiBudW1iZXJcbiAgdGltZV9saW1pdF9pbl9tczogbnVtYmVyXG4gIHJlcXVlc3RfaWQ6IHN0cmluZ1xuICAvKiog6ICB5p625p6E546v5aKD5Y+Y6YeP5a2X56ym5Liy77yM5YiG5Y+35YiG6ZqU55qEIGtleT12YWx1ZSAqL1xuICBlbnZpcm9uPzogc3RyaW5nXG4gIC8qKiDmlrDmnrbmnoTnjq/looPlj5jph48gSlNPTiDlrZfnrKbkuLIgKi9cbiAgZW52aXJvbm1lbnQ/OiBzdHJpbmdcbiAgZnVuY3Rpb25fdmVyc2lvbjogc3RyaW5nXG4gIGZ1bmN0aW9uX25hbWU6IHN0cmluZ1xuICBuYW1lc3BhY2U6IHN0cmluZ1xufVxuXG4vKiog55So5oi35L+h5oGv5p+l6K+i6K+35rGC5Y+C5pWwICovXG5leHBvcnQgaW50ZXJmYWNlIElVc2VySW5mb1F1ZXJ5IHtcbiAgcGxhdGZvcm0/OiBzdHJpbmdcbiAgcGxhdGZvcm1JZD86IHN0cmluZ1xuICB1aWQ/OiBzdHJpbmdcbn1cblxuLyoqXG4gKiDkupHlh73mlbDov5DooYzml7blrozmlbTnjq/looPlj5jph4/nsbvlnovmsYfmgLtcbiAqIOWMheWQqyBTQ0bjgIFUQ0LjgIHlvq7kv6Hnm7jlhbPnmoTmiYDmnInnjq/looPlj5jph49cbiAqL1xuZXhwb3J0IGludGVyZmFjZSBJQ29tcGxldGVDbG91ZGJhc2VDb250ZXh0IHtcbiAgLyoqIFNDRiDml6Xlv5fphY3nva4gKi9cbiAgX1NDRl9UQ0JfTE9HPzogc3RyaW5nXG4gIC8qKiDnmbvlvZXnsbvlnosgKi9cbiAgTE9HSU5UWVBFPzogc3RyaW5nXG4gIFFRX0FQUElEPzogc3RyaW5nXG4gIFFRX09QRU5JRD86IHN0cmluZ1xuICAvKiogU0NGIOWRveWQjeepuumXtCAqL1xuICBTQ0ZfTkFNRVNQQUNFOiBzdHJpbmdcbiAgLyoqIFRDQiDkuIrkuIvmlofphY3nva4gKi9cbiAgVENCX0NPTlRFWFRfQ05GRz86IHN0cmluZ1xuICAvKiogVENCIOS4iuS4i+aWhyBrZXkg5YiX6KGo77yM6YCX5Y+35YiG6ZqUICovXG4gIFRDQl9DT05URVhUX0tFWVM6IHN0cmluZ1tdXG4gIFRDQl9DVVNUT01fVVNFUl9JRD86IHN0cmluZ1xuICAvKiog5LqR5byA5Y+R546v5aKDIElEICovXG4gIFRDQl9FTlY6IHN0cmluZ1xuICBUQ0JfSFRUUF9DT05URVhUPzogc3RyaW5nXG4gIFRDQl9JU0FOT05ZTU9VU19VU0VSPzogc3RyaW5nXG4gIFRDQl9ST1VURV9LRVk/OiBzdHJpbmdcbiAgLyoqIOivt+axguW6j+WIlyBJRCAqL1xuICBUQ0JfU0VRSUQ6IHN0cmluZ1xuICBUQ0JfU0VTU0lPTlRPS0VOPzogc3RyaW5nXG4gIC8qKiDlrqLmiLfnq6/mnaXmupAgSVAgKi9cbiAgVENCX1NPVVJDRV9JUD86IHN0cmluZ1xuICBUQ0JfU09VUkNFPzogc3RyaW5nXG4gIFRDQl9UUkFDRUxPRz86IHN0cmluZ1xuICAvKiog55So5oi35ZSv5LiA5qCH6K+GICovXG4gIFRDQl9VVUlEPzogc3RyaW5nXG4gIC8qKiDohb7orq/kupHov5DooYznjq/looPmoIfor4YgKi9cbiAgVEVOQ0VOVENMT1VEX1JVTkVOVjogc3RyaW5nXG4gIFRFTkNFTlRDTE9VRF9TRUNSRVRJRDogc3RyaW5nXG4gIFRFTkNFTlRDTE9VRF9TRUNSRVRLRVk6IHN0cmluZ1xuICBURU5DRU5UQ0xPVURfU0VTU0lPTlRPS0VOOiBzdHJpbmdcbiAgLyoqIOinpuWPkeadpea6kCAqL1xuICBUUklHR0VSX1NSQzogc3RyaW5nXG4gIFdYX0FQSV9UT0tFTj86IHN0cmluZ1xuICBXWF9BUFBJRD86IHN0cmluZ1xuICBXWF9DTElFTlRJUD86IHN0cmluZ1xuICBXWF9DTElFTlRJUFY2Pzogc3RyaW5nXG4gIFdYX0NMT1VEQkFTRV9BQ0NFU1NUT0tFTj86IHN0cmluZ1xuICAvKiog5b6u5L+h5LiK5LiL5paHIGtleSDliJfooajvvIzpgJflj7fliIbpmpQgKi9cbiAgV1hfQ09OVEVYVF9LRVlTOiBzdHJpbmdbXVxuICBXWF9PUEVOSUQ/OiBzdHJpbmdcbiAgV1hfVFJJR0dFUl9BUElfVE9LRU5fVjA/OiBzdHJpbmdcbiAgV1hfVU5JT05JRD86IHN0cmluZ1xufVxuXG4vKiogZ2V0RW5kVXNlckluZm8g6L+U5Zue57uT5p6cICovXG5leHBvcnQgaW50ZXJmYWNlIElHZXRFbmRVc2VySW5mb1Jlc3VsdCB7XG4gIHVzZXJJbmZvPzoge1xuICAgIG9wZW5JZDogc3RyaW5nXG4gICAgYXBwSWQ6IHN0cmluZ1xuICAgIHVpZDogc3RyaW5nXG4gICAgY3VzdG9tVXNlcklkOiBzdHJpbmdcbiAgICBpc0Fub255bW91czogYm9vbGVhblxuICB9XG4gIHJlcXVlc3RJZD86IHN0cmluZ1xufVxuXG4vKiog6Ieq5a6a5LmJ6K+35rGC6YCJ6aG5ICovXG5leHBvcnQgaW50ZXJmYWNlIElDdXN0b21SZXFPcHRzIHtcbiAgLyoqIOivt+axgui2heaXtuaXtumXtO+8iOavq+enku+8iSAqL1xuICB0aW1lb3V0PzogbnVtYmVyXG59XG5cbi8qKiDmqKHmnb/mtojmga/mjqjpgIHor7fmsYLlj4LmlbAgKi9cbmV4cG9ydCBpbnRlcmZhY2UgSVRlbXBsYXRlTm90aWZ5UmVxIHtcbiAgLyoqIOmAmuefpeetlueVpSBJRCAqL1xuICBub3RpZnlJZDogc3RyaW5nXG4gIC8qKiDpgJrnn6XmqKHmnb/lj5jph4/plK7lgLzlr7kgKi9cbiAgZGF0YT86IFJlY29yZDxzdHJpbmcsIHVua25vd24+XG4gIC8qKiDngrnlh7vmtojmga/miZPlvIDnmoTpobXpnaLlnLDlnYAgKi9cbiAgdXJsPzogc3RyaW5nXG59XG4iXX0=
@@ -0,0 +1,17 @@
1
+ /// <reference types="node" />
2
+ import { ReadableStream } from 'web-streams-polyfill';
3
+ export declare const isFormData: (obj: unknown) => boolean, toQueryString: (data: Record<string, any>) => string;
4
+ export declare function getEnv(): Record<string, string | undefined>;
5
+ export declare function getEnv(key: string): string | undefined;
6
+ export declare const checkIsInScf: () => boolean;
7
+ export declare function checkIsInCBR(): boolean;
8
+ export declare function checkIsInSumeru(): boolean;
9
+ export declare function isNonEmptyString(str: string): boolean;
10
+ export declare function checkIsInTencentCloud(): Promise<boolean>;
11
+ export declare const getCurrRunEnvTag: () => Promise<string>;
12
+ export declare const validateUid: (uid: string) => void;
13
+ export declare function safeParseJson(text: string): any;
14
+ export declare function obj2StrRecord(obj: object): Record<string, string>;
15
+ export declare function headersInit2Indexable(h: HeadersInit): Record<string, string> | [string, string][];
16
+ export declare function parseQueryString(search: string): Record<string, string | string[]>;
17
+ export declare function createWebStreamFromNodeReadableStream(stream: NodeJS.ReadableStream): ReadableStream;
@@ -0,0 +1,205 @@
1
+ var __assign = (this && this.__assign) || function () {
2
+ __assign = Object.assign || function(t) {
3
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
4
+ s = arguments[i];
5
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
+ t[p] = s[p];
7
+ }
8
+ return t;
9
+ };
10
+ return __assign.apply(this, arguments);
11
+ };
12
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
13
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
14
+ return new (P || (P = Promise))(function (resolve, reject) {
15
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
16
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
17
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
18
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
19
+ });
20
+ };
21
+ var __generator = (this && this.__generator) || function (thisArg, body) {
22
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
23
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
24
+ function verb(n) { return function (v) { return step([n, v]); }; }
25
+ function step(op) {
26
+ if (f) throw new TypeError("Generator is already executing.");
27
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
28
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
29
+ if (y = 0, t) op = [op[0] & 2, t.value];
30
+ switch (op[0]) {
31
+ case 0: case 1: t = op; break;
32
+ case 4: _.label++; return { value: op[1], done: false };
33
+ case 5: _.label++; y = op[1]; op = [0]; continue;
34
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
35
+ default:
36
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
37
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
38
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
39
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
40
+ if (t[2]) _.ops.pop();
41
+ _.trys.pop(); continue;
42
+ }
43
+ op = body.call(thisArg, _);
44
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
45
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
46
+ }
47
+ };
48
+ var _a;
49
+ import { utils } from '@cloudbase/utilities';
50
+ import { ReadableStream } from 'web-streams-polyfill';
51
+ import { ERROR, checkCustomUserIdRegex } from './constants';
52
+ import { lookupAppId } from './metadata';
53
+ export var isFormData = (_a = utils, _a.isFormData), toQueryString = _a.toQueryString;
54
+ export function getEnv(key) {
55
+ if (typeof process === 'undefined' || !process.env) {
56
+ return key !== undefined ? undefined : {};
57
+ }
58
+ return key !== undefined ? process.env[key] : process.env;
59
+ }
60
+ export var checkIsInScf = function () { return getEnv('TENCENTCLOUD_RUNENV') === 'SCF'; };
61
+ export function checkIsInCBR() {
62
+ return !!getEnv('CBR_ENV_ID');
63
+ }
64
+ var kSumeruEnvSet = new Set(['formal', 'pre', 'test']);
65
+ export function checkIsInSumeru() {
66
+ return kSumeruEnvSet.has(getEnv('SUMERU_ENV') || '');
67
+ }
68
+ export function isNonEmptyString(str) {
69
+ return typeof str === 'string' && str !== '';
70
+ }
71
+ export function checkIsInTencentCloud() {
72
+ return __awaiter(this, void 0, void 0, function () {
73
+ var _a;
74
+ return __generator(this, function (_b) {
75
+ switch (_b.label) {
76
+ case 0:
77
+ if (getEnv('TENCENTCLOUD') === 'true') {
78
+ return [2, true];
79
+ }
80
+ _a = isNonEmptyString;
81
+ return [4, lookupAppId()];
82
+ case 1: return [2, _a.apply(void 0, [_b.sent()])];
83
+ }
84
+ });
85
+ });
86
+ }
87
+ export var getCurrRunEnvTag = function () { return __awaiter(void 0, void 0, void 0, function () {
88
+ return __generator(this, function (_a) {
89
+ switch (_a.label) {
90
+ case 0:
91
+ if (checkIsInScf()) {
92
+ return [2, 'scf'];
93
+ }
94
+ if (checkIsInCBR()) {
95
+ return [2, 'cbr'];
96
+ }
97
+ if (checkIsInSumeru()) {
98
+ return [2, 'sumeru'];
99
+ }
100
+ return [4, checkIsInTencentCloud()];
101
+ case 1:
102
+ if (_a.sent()) {
103
+ return [2, 'tencentcloud'];
104
+ }
105
+ return [2, 'unknown'];
106
+ }
107
+ });
108
+ }); };
109
+ export var validateUid = function (uid) {
110
+ if (typeof uid !== 'string') {
111
+ throw __assign(__assign({}, ERROR.INVALID_PARAM), { message: 'uid must be a string' });
112
+ }
113
+ if (!checkCustomUserIdRegex.test(uid)) {
114
+ throw __assign(__assign({}, ERROR.INVALID_PARAM), { message: "Invalid uid: \"".concat(uid, "\"") });
115
+ }
116
+ };
117
+ export function safeParseJson(text) {
118
+ if (!text || !text.trim()) {
119
+ return null;
120
+ }
121
+ try {
122
+ return JSON.parse(text);
123
+ }
124
+ catch (e) {
125
+ console.warn('catch an error', { e: e, text: text });
126
+ return text;
127
+ }
128
+ }
129
+ export function obj2StrRecord(obj) {
130
+ return Object.entries(obj).reduce(function (acc, cur) {
131
+ var key = cur[0], value = cur[1];
132
+ acc[key] = String(value);
133
+ return acc;
134
+ }, {});
135
+ }
136
+ export function headersInit2Indexable(h) {
137
+ if (isHeaders(h)) {
138
+ var ret_1 = {};
139
+ h.forEach(function (val, key) {
140
+ ret_1[key] = val;
141
+ });
142
+ return ret_1;
143
+ }
144
+ return h;
145
+ function isHeaders(h) {
146
+ try {
147
+ return h instanceof Headers;
148
+ }
149
+ catch (_) {
150
+ return false;
151
+ }
152
+ }
153
+ }
154
+ export function parseQueryString(search) {
155
+ var params = {};
156
+ var cleanSearch = search.replace(/^[?#]/, '');
157
+ if (!cleanSearch) {
158
+ return params;
159
+ }
160
+ var pairs = cleanSearch.split('&');
161
+ pairs.forEach(function (item) {
162
+ var _a = item.split('='), key = _a[0], value = _a[1];
163
+ key = decodeURIComponent(key);
164
+ value = decodeURIComponent(value || '');
165
+ if (key) {
166
+ if (params[key]) {
167
+ if (Array.isArray(params[key])) {
168
+ params[key].push(value);
169
+ }
170
+ else {
171
+ params[key] = [params[key], value];
172
+ }
173
+ }
174
+ else {
175
+ params[key] = value;
176
+ }
177
+ }
178
+ });
179
+ return params;
180
+ }
181
+ export function createWebStreamFromNodeReadableStream(stream) {
182
+ var asyncIterator = stream[Symbol.asyncIterator]();
183
+ return new ReadableStream({
184
+ pull: function (controller) {
185
+ return __awaiter(this, void 0, void 0, function () {
186
+ var next;
187
+ return __generator(this, function (_a) {
188
+ switch (_a.label) {
189
+ case 0: return [4, asyncIterator.next()];
190
+ case 1:
191
+ next = _a.sent();
192
+ if (next.done) {
193
+ controller.close();
194
+ }
195
+ else {
196
+ controller.enqueue(next.value);
197
+ }
198
+ return [2];
199
+ }
200
+ });
201
+ });
202
+ },
203
+ });
204
+ }
205
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGlicy9hZGFwdGVyLW5vZGUvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLEtBQUssRUFBRSxNQUFNLHNCQUFzQixDQUFBO0FBQzVDLE9BQU8sRUFBRSxjQUFjLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQTtBQUNyRCxPQUFPLEVBQUUsS0FBSyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQzNELE9BQU8sRUFBRSxXQUFXLEVBQUUsTUFBTSxZQUFZLENBQUE7QUFHeEMsTUFBTSxDQUFTLElBQUEsVUFBVSxJQUFaLEtBQWdDLEtBRzVDLGdCQUh3QixFQUFFLGFBQWEsbUJBQUEsQ0FHdkM7QUFRRCxNQUFNLFVBQVUsTUFBTSxDQUFDLEdBQVk7SUFDakMsSUFBSSxPQUFPLE9BQU8sS0FBSyxXQUFXLElBQUksQ0FBQyxPQUFPLENBQUMsR0FBRyxFQUFFO1FBQ2xELE9BQU8sR0FBRyxLQUFLLFNBQVMsQ0FBQyxDQUFDLENBQUMsU0FBUyxDQUFDLENBQUMsQ0FBQyxFQUFFLENBQUE7S0FDMUM7SUFDRCxPQUFPLEdBQUcsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUE7QUFDM0QsQ0FBQztBQUdELE1BQU0sQ0FBQyxJQUFNLFlBQVksR0FBRyxjQUFNLE9BQUEsTUFBTSxDQUFDLHFCQUFxQixDQUFDLEtBQUssS0FBSyxFQUF2QyxDQUF1QyxDQUFBO0FBRXpFLE1BQU0sVUFBVSxZQUFZO0lBRTFCLE9BQU8sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQTtBQUMvQixDQUFDO0FBRUQsSUFBTSxhQUFhLEdBQUcsSUFB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QyxNQUFNLENBQUMsR0FBRyxDQUFDLEVBQUUsS0FBSyxDQUFDLENBQUE7aUJBQ25DO2FBQ0Y7aUJBQU07Z0JBQ0wsTUFBTSxDQUFDLEdBQUcsQ0FBQyxHQUFHLEtBQUssQ0FBQTthQUNwQjtTQUNGO0lBQ0gsQ0FBQyxDQUFDLENBQUE7SUFDRixPQUFPLE1BQU0sQ0FBQTtBQUNmLENBQUM7QUFNRCxNQUFNLFVBQVUscUNBQXFDLENBQUMsTUFBNkI7SUFDakYsSUFBTSxhQUFhLEdBQUcsTUFBTSxDQUFDLE1BQU0sQ0FBQyxhQUFhLENBQUMsRUFBRSxDQUFBO0lBRXBELE9BQU8sSUFBSSxjQUFjLENBQUM7UUFDbEIsSUFBSSxZQUFDLFVBQVU7Ozs7O2dDQUNOLFdBQU0sYUFBYSxDQUFDLElBQUksRUFBRSxFQUFBOzs0QkFBakMsSUFBSSxHQUFHLFNBQTBCOzRCQUV2QyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7Z0NBQ2IsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFBOzZCQUNuQjtpQ0FBTTtnQ0FDTCxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTs2QkFDL0I7Ozs7O1NBQ0Y7S0FDRixDQUFDLENBQUE7QUFDSixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgdXRpbHMgfSBmcm9tICdAY2xvdWRiYXNlL3V0aWxpdGllcydcbmltcG9ydCB7IFJlYWRhYmxlU3RyZWFtIH0gZnJvbSAnd2ViLXN0cmVhbXMtcG9seWZpbGwnXG5pbXBvcnQgeyBFUlJPUiwgY2hlY2tDdXN0b21Vc2VySWRSZWdleCB9IGZyb20gJy4vY29uc3RhbnRzJ1xuaW1wb3J0IHsgbG9va3VwQXBwSWQgfSBmcm9tICcuL21ldGFkYXRhJ1xuXG4vKiog5LuOIEBjbG91ZGJhc2UvdXRpbGl0aWVzIOS4reaPkOWPlueahOihqOWNleWSjOafpeivouWtl+espuS4suW3peWFtyAqL1xuZXhwb3J0IGNvbnN0IHsgaXNGb3JtRGF0YSwgdG9RdWVyeVN0cmluZyB9ID0gdXRpbHMgYXMge1xuICBpc0Zvcm1EYXRhOiAob2JqOiB1bmtub3duKSA9PiBib29sZWFuXG4gIHRvUXVlcnlTdHJpbmc6IChkYXRhOiBSZWNvcmQ8c3RyaW5nLCBhbnk+KSA9PiBzdHJpbmdcbn1cblxuLyoqXG4gKiDot6jnq6/lronlhajojrflj5bnjq/looPlj5jph49cbiAqIFdlYiDnq6/jgIHlsI/muLjmiI/nq6/nrYnmsqHmnIkgcHJvY2VzcyDlhajlsYDlr7nosaHvvIznm7TmjqXorr/pl64gcHJvY2Vzcy5lbnYg5Lya5oql6ZSZXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBnZXRFbnYoKTogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgdW5kZWZpbmVkPlxuZXhwb3J0IGZ1bmN0aW9uIGdldEVudihrZXk6IHN0cmluZyk6IHN0cmluZyB8IHVuZGVmaW5lZFxuZXhwb3J0IGZ1bmN0aW9uIGdldEVudihrZXk/OiBzdHJpbmcpOiBzdHJpbmcgfCB1bmRlZmluZWQgfCBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+IHtcbiAgaWYgKHR5cGVvZiBwcm9jZXNzID09PSAndW5kZWZpbmVkJyB8fCAhcHJvY2Vzcy5lbnYpIHtcbiAgICByZXR1cm4ga2V5ICE9PSB1bmRlZmluZWQgPyB1bmRlZmluZWQgOiB7fVxuICB9XG4gIHJldHVybiBrZXkgIT09IHVuZGVmaW5lZCA/IHByb2Nlc3MuZW52W2tleV0gOiBwcm9jZXNzLmVudlxufVxuXG4vKiog5Yik5pat5b2T5YmN5piv5ZCm5ZyoIFNDRu+8iOS6keWHveaVsO+8iei/kOihjOeOr+Wig+S4rSAqL1xuZXhwb3J0IGNvbnN0IGNoZWNrSXNJblNjZiA9ICgpID0+IGdldEVudignVEVOQ0VOVENMT1VEX1JVTkVOVicpID09PSAnU0NGJ1xuXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tJc0luQ0JSKCkge1xuICAvLyBDQlIgPSBDTE9VREJBU0VfUlVOXG4gIHJldHVybiAhIWdldEVudignQ0JSX0VOVl9JRCcpXG59XG5cbmNvbnN0IGtTdW1lcnVFbnZTZXQgPSBuZXcgU2V0KFsnZm9ybWFsJywgJ3ByZScsICd0ZXN0J10pXG5leHBvcnQgZnVuY3Rpb24gY2hlY2tJc0luU3VtZXJ1KCkge1xuICAvLyBTVU1FUlVfRU5WPWZvcm1hbCB8IHRlc3QgfCBwcmVcbiAgcmV0dXJuIGtTdW1lcnVFbnZTZXQuaGFzKGdldEVudignU1VNRVJVX0VOVicpIHx8ICcnKVxufVxuXG5leHBvcnQgZnVuY3Rpb24gaXNOb25FbXB0eVN0cmluZyhzdHI6IHN0cmluZykge1xuICByZXR1cm4gdHlwZW9mIHN0ciA9PT0gJ3N0cmluZycgJiYgc3RyICE9PSAnJ1xufVxuXG5leHBvcnQgYXN5bmMgZnVuY3Rpb24gY2hlY2tJc0luVGVuY2VudENsb3VkKCk6IFByb21pc2U8Ym9vbGVhbj4ge1xuICBpZiAoZ2V0RW52KCdURU5DRU5UQ0xPVUQnKSA9PT0gJ3RydWUnKSB7XG4gICAgcmV0dXJuIHRydWVcbiAgfVxuICByZXR1cm4gaXNOb25FbXB0eVN0cmluZyhhd2FpdCBsb29rdXBBcHBJZCgpKVxufVxuXG5leHBvcnQgY29uc3QgZ2V0Q3VyclJ1bkVudlRhZyA9IGFzeW5jICgpOiBQcm9taXNlPHN0cmluZz4gPT4ge1xuICBpZiAoY2hlY2tJc0luU2NmKCkpIHtcbiAgICByZXR1cm4gJ3NjZidcbiAgfSBpZiAoY2hlY2tJc0luQ0JSKCkpIHtcbiAgICByZXR1cm4gJ2NicidcbiAgfSBpZiAoY2hlY2tJc0luU3VtZXJ1KCkpIHtcbiAgICByZXR1cm4gJ3N1bWVydSdcbiAgfSBpZiAoYXdhaXQgY2hlY2tJc0luVGVuY2VudENsb3VkKCkpIHtcbiAgICByZXR1cm4gJ3RlbmNlbnRjbG91ZCdcbiAgfVxuICByZXR1cm4gJ3Vua25vd24nXG59XG5cbi8qKlxuICog5qCh6aqM6Ieq5a6a5LmJ55So5oi3IElEIOagvOW8j1xuICogQHRocm93cyDmoLzlvI/kuI3lkIjms5Xml7bmipvlh7ogSU5WQUxJRF9QQVJBTSDplJnor69cbiAqL1xuZXhwb3J0IGNvbnN0IHZhbGlkYXRlVWlkID0gKHVpZDogc3RyaW5nKTogdm9pZCA9PiB7XG4gIGlmICh0eXBlb2YgdWlkICE9PSAnc3RyaW5nJykge1xuICAgIHRocm93IHsgLi4uRVJST1IuSU5WQUxJRF9QQVJBTSwgbWVzc2FnZTogJ3VpZCBtdXN0IGJlIGEgc3RyaW5nJyB9XG4gIH1cbiAgaWYgKCFjaGVja0N1c3RvbVVzZXJJZFJlZ2V4LnRlc3QodWlkKSkge1xuICAgIHRocm93IHsgLi4uRVJST1IuSU5WQUxJRF9QQVJBTSwgbWVzc2FnZTogYEludmFsaWQgdWlkOiBcIiR7dWlkfVwiYCB9XG4gIH1cbn1cblxuLyoqXG4gKiDlronlhajnmoQgSlNPTiDop6PmnpDvvIzop6PmnpDlpLHotKXml7bov5Tlm57ljp/lp4vmlofmnKzogIzpnZ7mipvlvILluLhcbiAqIEBwYXJhbSB0ZXh0IC0g5b6F6Kej5p6Q55qE5a2X56ym5LiyXG4gKiBAcmV0dXJucyDop6PmnpDlkI7nmoTlr7nosaHvvIznqbrlrZfnrKbkuLLov5Tlm54gbnVsbO+8jOino+aekOWksei0pei/lOWbnuWOn+Wni+aWh+acrFxuICovXG5leHBvcnQgZnVuY3Rpb24gc2FmZVBhcnNlSnNvbih0ZXh0OiBzdHJpbmcpOiBhbnkge1xuICBpZiAoIXRleHQgfHwgIXRleHQudHJpbSgpKSB7XG4gICAgcmV0dXJuIG51bGxcbiAgfVxuICB0cnkge1xuICAgIHJldHVybiBKU09OLnBhcnNlKHRleHQpXG4gIH0gY2F0Y2ggKGUpIHtcbiAgICBjb25zb2xlLndhcm4oJ2NhdGNoIGFuIGVycm9yJywgeyBlLCB0ZXh0IH0pXG4gICAgcmV0dXJuIHRleHRcbiAgfVxufVxuXG4vKipcbiAqIOWwhuWvueixoeeahOaJgOacieWAvOi9rOS4uuWtl+espuS4suexu+Wei1xuICog55So5LqO5bCGIGhlYWRlcnMg562J5a+56LGh57uf5LiA5Li6IFJlY29yZDxzdHJpbmcsIHN0cmluZz5cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIG9iajJTdHJSZWNvcmQob2JqOiBvYmplY3QpOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmc+IHtcbiAgcmV0dXJuIE9iamVjdC5lbnRyaWVzKG9iaikucmVkdWNlPFJlY29yZDxzdHJpbmcsIHN0cmluZz4+KChhY2MsIGN1cjogW3N0cmluZywgdW5rbm93bl0pID0+IHtcbiAgICBjb25zdCBba2V5LCB2YWx1ZV0gPSBjdXJcbiAgICBhY2Nba2V5XSA9IFN0cmluZyh2YWx1ZSlcbiAgICByZXR1cm4gYWNjXG4gIH0sIHt9KVxufVxuXG4vKipcbiAqIOWwhiBIZWFkZXJzSW5pdCDovazkuLrlj6/ntKLlvJXnmoTmma7pgJrlr7nosaFcbiAqIOWFvOWuuSBIZWFkZXJzIOWunuS+i+WSjOaZrumAmuWvueixoeS4pOenjeW9ouW8j1xuICovXG5leHBvcnQgZnVuY3Rpb24gaGVhZGVyc0luaXQySW5kZXhhYmxlKGg6IEhlYWRlcnNJbml0KSB7XG4gIGlmIChpc0hlYWRlcnMoaCkpIHtcbiAgICBjb25zdCByZXQ6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4gPSB7fVxuICAgIGguZm9yRWFjaCgodmFsLCBrZXkpID0+IHtcbiAgICAgIHJldFtrZXldID0gdmFsXG4gICAgfSlcbiAgICByZXR1cm4gcmV0XG4gIH1cbiAgcmV0dXJuIGhcblxuICBmdW5jdGlvbiBpc0hlYWRlcnMoaDogSGVhZGVyc0luaXQpOiBoIGlzIEhlYWRlcnMge1xuICAgIHRyeSB7XG4gICAgICAvLyBOb2RlIOS9jueJiOacrOWPr+iDveayoeacieWFqOWxgCBIZWFkZXJzXG4gICAgICByZXR1cm4gaCBpbnN0YW5jZW9mIEhlYWRlcnNcbiAgICB9IGNhdGNoIChfKSB7XG4gICAgICByZXR1cm4gZmFsc2VcbiAgICB9XG4gIH1cbn1cblxuLyoqXG4gKiDmiYvliqjop6PmnpDmn6Xor6LlrZfnrKbkuLLvvIzpgb/lhY0gVVJMU2VhcmNoUGFyYW1zIOeahOWFvOWuueaAp+mXrumimFxuICog5pSv5oyB6YeN5aSNIGtleSDoh6rliqjovazkuLrmlbDnu4RcbiAqIEBwYXJhbSBzZWFyY2ggLSDmn6Xor6LlrZfnrKbkuLLvvIzlj6/luKbliY3lr7wgPyDmiJYgI1xuICovXG5leHBvcnQgZnVuY3Rpb24gcGFyc2VRdWVyeVN0cmluZyhzZWFyY2g6IHN0cmluZyk6IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IHN0cmluZ1tdPiB7XG4gIGNvbnN0IHBhcmFtczogYW55ID0ge31cbiAgY29uc3QgY2xlYW5TZWFyY2ggPSBzZWFyY2gucmVwbGFjZSgvXls/I10vLCAnJylcblxuICBpZiAoIWNsZWFuU2VhcmNoKSB7XG4gICAgcmV0dXJuIHBhcmFtc1xuICB9XG5cbiAgY29uc3QgcGFpcnMgPSBjbGVhblNlYXJjaC5zcGxpdCgnJicpXG5cbiAgcGFpcnMuZm9yRWFjaCgoaXRlbSkgPT4ge1xuICAgIGxldCBba2V5LCB2YWx1ZV0gPSBpdGVtLnNwbGl0KCc9JylcbiAgICBrZXkgPSBkZWNvZGVVUklDb21wb25lbnQoa2V5KVxuICAgIHZhbHVlID0gZGVjb2RlVVJJQ29tcG9uZW50KHZhbHVlIHx8ICcnKVxuICAgIGlmIChrZXkpIHtcbiAgICAgIGlmIChwYXJhbXNba2V5XSkge1xuICAgICAgICAvLyDlt7LlrZjlnKjlkIzlkI0ga2V577yM6L2s5Li65pWw57uEXG4gICAgICAgIGlmIChBcnJheS5pc0FycmF5KHBhcmFtc1trZXldKSkge1xuICAgICAgICAgIHBhcmFtc1trZXldLnB1c2godmFsdWUpXG4gICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgcGFyYW1zW2tleV0gPSBbcGFyYW1zW2tleV0sIHZhbHVlXVxuICAgICAgICB9XG4gICAgICB9IGVsc2Uge1xuICAgICAgICBwYXJhbXNba2V5XSA9IHZhbHVlXG4gICAgICB9XG4gICAgfVxuICB9KVxuICByZXR1cm4gcGFyYW1zXG59XG5cbi8qKlxuICog5bCGIE5vZGUgUmVhZGFibGVTdHJlYW0g6L2s5o2i5Li6IFdlYiBSZWFkYWJsZVN0cmVhbSAocG9seWZpbGwpXG4gKiDnlKjkuo4gZmV0Y2gg5rWB5byP5ZON5bqU5ZyoIE5vZGUg546v5aKD5LiL55qE6YCC6YWNXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBjcmVhdGVXZWJTdHJlYW1Gcm9tTm9kZVJlYWRhYmxlU3RyZWFtKHN0cmVhbTogTm9kZUpTLlJlYWRhYmxlU3RyZWFtKTogUmVhZGFibGVTdHJlYW0ge1xuICBjb25zdCBhc3luY0l0ZXJhdG9yID0gc3RyZWFtW1N5bWJvbC5hc3luY0l0ZXJhdG9yXSgpXG5cbiAgcmV0dXJuIG5ldyBSZWFkYWJsZVN0cmVhbSh7XG4gICAgYXN5bmMgcHVsbChjb250cm9sbGVyKSB7XG4gICAgICBjb25zdCBuZXh0ID0gYXdhaXQgYXN5bmNJdGVyYXRvci5uZXh0KClcblxuICAgICAgaWYgKG5leHQuZG9uZSkge1xuICAgICAgICBjb250cm9sbGVyLmNsb3NlKClcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGNvbnRyb2xsZXIuZW5xdWV1ZShuZXh0LnZhbHVlKVxuICAgICAgfVxuICAgIH0sXG4gIH0pXG59XG4iXX0=
@@ -44,6 +44,7 @@ export declare class CloudbaseRequest implements ICloudbaseRequest {
44
44
  search?: string;
45
45
  defaultQuery?: KV<any>;
46
46
  headers?: KV<string>;
47
+ endPointMode?: 'CLOUD_API' | 'GATEWAY';
47
48
  }, customReqOpts?: ICustomReqOpts): Promise<ResponseObject>;
48
49
  fetch(options: IFetchOptions & {
49
50
  token?: string;