@cloudbase/app 2.26.1 → 2.26.3

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 (59) hide show
  1. package/dist/cjs/index.d.ts +2 -0
  2. package/dist/cjs/index.js +43 -7
  3. package/dist/cjs/index.node.d.ts +6 -0
  4. package/dist/cjs/index.node.js +20 -0
  5. package/dist/cjs/libs/adapter-node/constants.d.ts +33 -0
  6. package/dist/cjs/libs/adapter-node/constants.js +38 -0
  7. package/dist/cjs/libs/adapter-node/context.d.ts +13 -0
  8. package/dist/cjs/libs/adapter-node/context.js +162 -0
  9. package/dist/cjs/libs/adapter-node/index.d.ts +23 -0
  10. package/dist/cjs/libs/adapter-node/index.js +124 -0
  11. package/dist/cjs/libs/adapter-node/metadata.d.ts +14 -0
  12. package/dist/cjs/libs/adapter-node/metadata.js +130 -0
  13. package/dist/cjs/libs/adapter-node/request.d.ts +38 -0
  14. package/dist/cjs/libs/adapter-node/request.js +441 -0
  15. package/dist/cjs/libs/adapter-node/tool.d.ts +2 -0
  16. package/dist/cjs/libs/adapter-node/tool.js +228 -0
  17. package/dist/cjs/libs/adapter-node/types.d.ts +78 -0
  18. package/dist/cjs/libs/adapter-node/types.js +3 -0
  19. package/dist/cjs/libs/adapter-node/utils.d.ts +17 -0
  20. package/dist/cjs/libs/adapter-node/utils.js +221 -0
  21. package/dist/cjs/libs/request.d.ts +1 -0
  22. package/dist/cjs/libs/request.js +34 -19
  23. package/dist/esm/index.d.ts +2 -0
  24. package/dist/esm/index.js +43 -7
  25. package/dist/esm/index.node.d.ts +6 -0
  26. package/dist/esm/index.node.js +12 -0
  27. package/dist/esm/libs/adapter-node/constants.d.ts +33 -0
  28. package/dist/esm/libs/adapter-node/constants.js +35 -0
  29. package/dist/esm/libs/adapter-node/context.d.ts +13 -0
  30. package/dist/esm/libs/adapter-node/context.js +156 -0
  31. package/dist/esm/libs/adapter-node/index.d.ts +23 -0
  32. package/dist/esm/libs/adapter-node/index.js +118 -0
  33. package/dist/esm/libs/adapter-node/metadata.d.ts +14 -0
  34. package/dist/esm/libs/adapter-node/metadata.js +123 -0
  35. package/dist/esm/libs/adapter-node/request.d.ts +38 -0
  36. package/dist/esm/libs/adapter-node/request.js +438 -0
  37. package/dist/esm/libs/adapter-node/tool.d.ts +2 -0
  38. package/dist/esm/libs/adapter-node/tool.js +224 -0
  39. package/dist/esm/libs/adapter-node/types.d.ts +78 -0
  40. package/dist/esm/libs/adapter-node/types.js +2 -0
  41. package/dist/esm/libs/adapter-node/utils.d.ts +17 -0
  42. package/dist/esm/libs/adapter-node/utils.js +205 -0
  43. package/dist/esm/libs/request.d.ts +1 -0
  44. package/dist/esm/libs/request.js +34 -19
  45. package/dist/miniprogram/index.js +1 -1
  46. package/package.json +32 -4
  47. package/src/index.node.ts +22 -0
  48. package/src/index.ts +91 -7
  49. package/src/libs/adapter-node/constants.ts +42 -0
  50. package/src/libs/adapter-node/context.ts +238 -0
  51. package/src/libs/adapter-node/index.ts +166 -0
  52. package/src/libs/adapter-node/metadata.ts +69 -0
  53. package/src/libs/adapter-node/request.ts +486 -0
  54. package/src/libs/adapter-node/tool.ts +223 -0
  55. package/src/libs/adapter-node/types.ts +116 -0
  56. package/src/libs/adapter-node/utils.ts +182 -0
  57. package/src/libs/request.ts +125 -113
  58. package/webpack/web.prod.js +14 -13
  59. package/webpack/webpack.miniprogram.js +10 -3
@@ -0,0 +1,228 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ 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;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ Object.defineProperty(exports, "__esModule", { value: true });
50
+ exports.nodeTool = void 0;
51
+ var constants_1 = require("./constants");
52
+ var context_1 = require("./context");
53
+ var utils_1 = require("./utils");
54
+ var jwtSign = null;
55
+ function getJwtSign() {
56
+ var _a;
57
+ return __awaiter(this, void 0, void 0, function () {
58
+ var mod, e_1;
59
+ return __generator(this, function (_b) {
60
+ switch (_b.label) {
61
+ case 0:
62
+ if (!!jwtSign) return [3, 4];
63
+ _b.label = 1;
64
+ case 1:
65
+ _b.trys.push([1, 3, , 4]);
66
+ return [4, import('jsonwebtoken')];
67
+ case 2:
68
+ mod = _b.sent();
69
+ jwtSign = ((_a = mod.default) === null || _a === void 0 ? void 0 : _a.sign) || mod.sign;
70
+ return [3, 4];
71
+ case 3:
72
+ e_1 = _b.sent();
73
+ console.error('缺少依赖 jsonwebtoken,请执行以下命令安装:\n\n'
74
+ + ' npm install jsonwebtoken\n\n'
75
+ + '该依赖用于 Node 环境下的自定义登录票据生成。');
76
+ return [3, 4];
77
+ case 4: return [2, jwtSign];
78
+ }
79
+ });
80
+ });
81
+ }
82
+ function getDefaultUserInfo() {
83
+ var _a = (0, context_1.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;
84
+ return {
85
+ openId: WX_OPENID || '',
86
+ appId: WX_APPID || '',
87
+ uid: TCB_UUID || '',
88
+ customUserId: TCB_CUSTOM_USER_ID || '',
89
+ isAnonymous: TCB_ISANONYMOUS_USER === 'true',
90
+ };
91
+ }
92
+ function sendUserInfoRequest(app, params) {
93
+ var _a, _b;
94
+ 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, {
95
+ pathname: 'web',
96
+ endPointMode: 'CLOUD_API',
97
+ });
98
+ }
99
+ var nodeTool = function (app, config) {
100
+ if (app.auth) {
101
+ var auth_1 = {
102
+ getUserInfo: function () {
103
+ return getDefaultUserInfo();
104
+ },
105
+ getEndUserInfo: function (uid) {
106
+ return __awaiter(this, void 0, void 0, function () {
107
+ var defaultUserInfo;
108
+ return __generator(this, function (_a) {
109
+ defaultUserInfo = getDefaultUserInfo();
110
+ if (uid === undefined) {
111
+ return [2, { userInfo: defaultUserInfo }];
112
+ }
113
+ (0, utils_1.validateUid)(uid);
114
+ return [2, sendUserInfoRequest(app, {
115
+ uuid: uid,
116
+ envName: config.env,
117
+ }).then(function (result) {
118
+ if (result.code) {
119
+ return result;
120
+ }
121
+ return {
122
+ userInfo: __assign(__assign({}, defaultUserInfo), result.data),
123
+ requestId: result.requestId,
124
+ };
125
+ })];
126
+ });
127
+ });
128
+ },
129
+ createTicket: function (uid, options) {
130
+ if (options === void 0) { options = {}; }
131
+ return __awaiter(this, void 0, void 0, function () {
132
+ var timestamp, credentials, env, _a, refresh, _b, expire, sign, token;
133
+ return __generator(this, function (_c) {
134
+ switch (_c.label) {
135
+ case 0:
136
+ (0, utils_1.validateUid)(uid);
137
+ timestamp = new Date().getTime();
138
+ credentials = (config.auth || {}).credentials;
139
+ env = config.env;
140
+ if (!env) {
141
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: 'no env in config' });
142
+ }
143
+ if (!(credentials === null || credentials === void 0 ? void 0 : credentials.env_id)) {
144
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: '当前私钥未包含env_id 信息, 请前往腾讯云云开发控制台,获取自定义登录最新私钥' });
145
+ }
146
+ if (credentials.env_id !== env) {
147
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: '当前私钥所属环境与 init 指定环境不一致!' });
148
+ }
149
+ _a = options.refresh, refresh = _a === void 0 ? 3600 * 1000 : _a, _b = options.expire, expire = _b === void 0 ? timestamp + 7 * 24 * 60 * 60 * 1000 : _b;
150
+ return [4, getJwtSign()];
151
+ case 1:
152
+ sign = _c.sent();
153
+ token = sign({
154
+ alg: 'RS256',
155
+ env: env,
156
+ iat: timestamp,
157
+ exp: timestamp + 10 * 60 * 1000,
158
+ uid: uid,
159
+ refresh: refresh,
160
+ expire: expire,
161
+ }, credentials.private_key, {
162
+ allowInsecureKeySizes: true,
163
+ algorithm: 'RS256',
164
+ });
165
+ return [2, "".concat(credentials.private_key_id, "/@@/").concat(token)];
166
+ }
167
+ });
168
+ });
169
+ },
170
+ queryUserInfo: function (query) {
171
+ return __awaiter(this, void 0, void 0, function () {
172
+ var uid, platform, platformId;
173
+ return __generator(this, function (_a) {
174
+ uid = query.uid, platform = query.platform, platformId = query.platformId;
175
+ return [2, sendUserInfoRequest(app, {
176
+ uuid: uid,
177
+ platform: platform,
178
+ platformId: platformId,
179
+ envName: config.env,
180
+ }).then(function (result) {
181
+ if (result.code) {
182
+ return result;
183
+ }
184
+ return {
185
+ userInfo: __assign({}, result.data),
186
+ requestId: result.requestId,
187
+ };
188
+ })];
189
+ });
190
+ });
191
+ },
192
+ getClientIP: function () {
193
+ var TCB_SOURCE_IP = (0, context_1.getCloudbaseContext)().TCB_SOURCE_IP;
194
+ return TCB_SOURCE_IP || '';
195
+ },
196
+ };
197
+ Object.keys(auth_1).forEach(function (key) {
198
+ app.auth[key] = auth_1[key];
199
+ });
200
+ }
201
+ app.sendTemplateNotification = function (params, opts) { return __awaiter(void 0, void 0, void 0, function () {
202
+ var _a;
203
+ return __generator(this, function (_b) {
204
+ switch (_b.label) {
205
+ case 0: return [4, ((_a = app === null || app === void 0 ? void 0 : app.callFunction) === null || _a === void 0 ? void 0 : _a.call(app, {
206
+ name: 'lowcode-datasource',
207
+ data: {
208
+ methodName: 'callWedaApi',
209
+ params: {
210
+ action: 'PushNotifyMsg',
211
+ data: {
212
+ NotifyId: params.notifyId,
213
+ Data: JSON.stringify(params.data),
214
+ NotifyUsers: undefined,
215
+ Url: params.url,
216
+ },
217
+ },
218
+ mode: 'c',
219
+ },
220
+ }, undefined, opts))];
221
+ case 1: return [2, _b.sent()];
222
+ }
223
+ });
224
+ }); };
225
+ app.parseContext = context_1.parseContext;
226
+ };
227
+ exports.nodeTool = nodeTool;
228
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWJzL2FkYXB0ZXItbm9kZS90b29sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW1DO0FBQ25DLHFDQUE2RDtBQUM3RCxpQ0FBcUM7QUFZckMsSUFBSSxPQUFPLEdBQXFDLElBQUksQ0FBQTtBQUNwRCxTQUFlLFVBQVU7Ozs7Ozs7eUJBQ25CLENBQUMsT0FBTyxFQUFSLGNBQVE7Ozs7b0JBR0ksV0FBTSxNQUFNLENBQUMsY0FBYyxDQUFDLEVBQUE7O29CQUFsQyxHQUFHLEdBQUcsU0FBNEI7b0JBQ3hDLE9BQU8sR0FBRyxDQUFBLE1BQUEsR0FBRyxDQUFDLE9BQU8sMENBQUUsSUFBSSxLQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUE7Ozs7b0JBRXZDLE9BQU8sQ0FBQyxLQUFLLENBQUMsa0NBQWtDOzBCQUM1QyxnQ0FBZ0M7MEJBQ2hDLDJCQUEyQixDQUFDLENBQUE7O3dCQUdwQyxXQUFPLE9BQVEsRUFBQTs7OztDQUNoQjtBQU1ELFNBQVMsa0JBQWtCO0lBQ25CLElBQUEsS0FBOEUsSUFBQSw2QkFBbUIsR0FBRSxFQUFqRyxTQUFTLGVBQUEsRUFBRSxRQUFRLGNBQUEsRUFBRSxRQUFRLGNBQUEsRUFBRSxrQkFBa0Isd0JBQUEsRUFBRSxvQkFBb0IsMEJBQTBCLENBQUE7SUFFekcsT0FBTztRQUNMLE1BQU0sRUFBRSxTQUFTLElBQUksRUFBRTtRQUN2QixLQUFLLEVBQUUsUUFBUSxJQUFJLEVBQUU7UUFDckIsR0FBRyxFQUFFLFFBQVEsSUFBSSxFQUFFO1FBQ25CLFlBQVksRUFBRSxrQkFBa0IsSUFBSSxFQUFFO1FBQ3RDLFdBQVcsRUFBRSxvQkFBb0IsS0FBSyxNQUFNO0tBQzdDLENBQUE7QUFDSCxDQUFDO0FBTUQsU0FBUyxtQkFBbUIsQ0FBQyxHQUFRLEVB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QUFBLE1BQUEsR0FBRyxhQUFILEdBQUcsdUJBQUgsR0FBRyxDQUFFLFlBQVksb0RBQ3ZIO3dCQUNFLElBQUksRUFBRSxvQkFBb0I7d0JBQzFCLElBQUksRUFBRTs0QkFDSixVQUFVLEVBQUUsYUFBYTs0QkFDekIsTUFBTSxFQUFFO2dDQUNOLE1BQU0sRUFBRSxlQUFlO2dDQUN2QixJQUFJLEVBQUU7b0NBQ0osUUFBUSxFQUFFLE1BQU0sQ0FBQyxRQUFRO29DQUN6QixJQUFJLEVBQUUsSUFBSSxDQUFDLFNBQVMsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDO29DQUNqQyxXQUFXLEVBQUUsU0FBUztvQ0FDdEIsR0FBRyxFQUFFLE1BQU0sQ0FBQyxHQUFHO2lDQUNoQjs2QkFDRjs0QkFDRCxJQUFJLEVBQUUsR0FBRzt5QkFDVjtxQkFDRixFQUNELFNBQVMsRUFDVCxJQUFJLENBQ0wsQ0FBQSxFQUFBO3dCQW5CaUcsV0FBQSxTQW1CakcsRUFBQTs7O1NBQUEsQ0FBQTtJQUdELEdBQUcsQ0FBQyxZQUFZLEdBQUcsc0JBQVksQ0FBQTtBQUNqQyxDQUFDLENBQUE7QUE5SlksUUFBQSxRQUFRLFlBOEpwQiIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IEVSUk9SIH0gZnJvbSAnLi9jb25zdGFudHMnXG5pbXBvcnQgeyBnZXRDbG91ZGJhc2VDb250ZXh0LCBwYXJzZUNvbnRleHQgfSBmcm9tICcuL2NvbnRleHQnXG5pbXBvcnQgeyB2YWxpZGF0ZVVpZCB9IGZyb20gJy4vdXRpbHMnXG5pbXBvcnQgdHlwZSB7XG4gIElDcmVhdGVUaWNrZXRPcHRzLFxuICBJR2V0VXNlckluZm9SZXN1bHQsXG4gIElHZXRFbmRVc2VySW5mb1Jlc3VsdCxcbiAgSVVzZXJJbmZvUXVlcnksXG4gIElUZW1wbGF0ZU5vdGlmeVJlcSxcbn0gZnJvbSAnLi90eXBlcydcbmltcG9ydCB7IElDbG91ZGJhc2VDb25maWcgfSBmcm9tICdAY2xvdWRiYXNlL3R5cGVzJ1xuXG4vLyDlu7bov5/liqDovb3vvIzpgb/lhY3pnZ4gTm9kZSDnjq/looPmiZPljIXml7blvJXlhaXmraTljIVcbi8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSBAdHlwZXNjcmlwdC1lc2xpbnQvbm8tZXhwbGljaXQtYW55XG5sZXQgand0U2lnbjogKCguLi5hcmdzOiBhbnlbXSkgPT4gYW55KSB8IG51bGwgPSBudWxsXG5hc3luYyBmdW5jdGlvbiBnZXRKd3RTaWduKCkge1xuICBpZiAoIWp3dFNpZ24pIHtcbiAgICB0cnkge1xuICAgICAgLy8gQHRzLWlnbm9yZSDigJQg6K+l5YyF5LuF5ZyoIE5vZGUg6L+Q6KGM5pe25a2Y5Zyo77yM5byA5Y+R546v5aKD5Y+v6IO95pyq5a6J6KOFXG4gICAgICBjb25zdCBtb2QgPSBhd2FpdCBpbXBvcnQoJ2pzb253ZWJ0b2tlbicpXG4gICAgICBqd3RTaWduID0gbW9kLmRlZmF1bHQ/LnNpZ24gfHwgbW9kLnNpZ25cbiAgICB9IGNhdGNoIChlKSB7XG4gICAgICBjb25zb2xlLmVycm9yKCfnvLrlsJHkvp3otZYganNvbndlYnRva2Vu77yM6K+35omn6KGM5Lul5LiL5ZG95Luk5a6J6KOF77yaXFxuXFxuJ1xuICAgICAgICArICcgIG5wbSBpbnN0YWxsIGpzb253ZWJ0b2tlblxcblxcbidcbiAgICAgICAgKyAn6K+l5L6d6LWW55So5LqOIE5vZGUg546v5aKD5LiL55qE6Ieq5a6a5LmJ55m75b2V56Wo5o2u55Sf5oiQ44CCJylcbiAgICB9XG4gIH1cbiAgcmV0dXJuIGp3dFNpZ24hXG59XG5cbi8qKlxuICog5LuO5LqR5Ye95pWw6L+Q6KGM5pe25LiK5LiL5paH5Lit6I635Y+W5b2T5YmN6K+35rGC55qE55So5oi35L+h5oGvXG4gKiDmlbDmja7mnaXmupDkuLrnjq/looPlj5jph4/vvIjlvq7kv6Egb3Blbklk44CBVENCIHV1aWQg562J77yJXG4gKi9cbmZ1bmN0aW9uIGdldERlZmF1bHRVc2VySW5mbygpOiBJR2V0VXNlckluZm9SZXN1bHQge1xuICBjb25zdCB7IFdYX09QRU5JRCwgV1hfQVBQSUQsIFRDQl9VVUlELCBUQ0JfQ1VTVE9NX1VTRVJfSUQsIFRDQl9JU0FOT05ZTU9VU19VU0VSIH0gPSBnZXRDbG91ZGJhc2VDb250ZXh0KClcblxuICByZXR1cm4ge1xuICAgIG9wZW5JZDogV1hfT1BFTklEIHx8ICcnLFxuICAgIGFwcElkOiBXWF9BUFBJRCB8fCAnJyxcbiAgICB1aWQ6IFRDQl9VVUlEIHx8ICcnLFxuICAgIGN1c3RvbVVzZXJJZDogVENCX0NVU1RPTV9VU0VSX0lEIHx8ICcnLFxuICAgIGlzQW5vbnltb3VzOiBUQ0JfSVNBTk9OWU1PVVNfVVNFUiA9PT0gJ3RydWUnLFxuICB9XG59XG5cbi8qKlxuICog6LCD55So5ZCO56uv566h55CG5o6l5Y+j5p+l6K+i55So5oi35L+h5oGvXG4gKiDnu5/kuIDlsIHoo4UgYXV0aC5nZXRVc2VySW5mb0ZvckFkbWluIOeahOivt+axgumAu+i+kVxuICovXG5mdW5jdGlvbiBzZW5kVXNlckluZm9SZXF1ZXN0KGFwcDogYW55LCBwYXJhbXM6IFJlY29yZDxzdHJpbmcsIGFueT4pOiBQcm9taXNlPGFueT4ge1xuICByZXR1cm4gYXBwPy5yZXF1ZXN0Py5zZW5kPy4oJ2F1dGguZ2V0VXNlckluZm9Gb3JBZG1pbicsIHBhcmFtcywge1xuICAgIHBhdGhuYW1lOiAnd2ViJyxcbiAgICBlbmRQb2ludE1vZGU6ICdDTE9VRF9BUEknLFxuICB9KVxufVxuXG4vKipcbiAqIOWIneWni+WMliBOb2RlIOerr+W3peWFt+aWueazle+8jOaMgui9veWIsCBqcy1zZGsgYXBwIOWunuS+i+S4ilxuICog5YyF5ZCr77yaYXV0aCDnm7jlhbPmlrnms5XjgIHmqKHmnb/mtojmga/mjqjpgIHjgIFjb250ZXh0IOino+aekFxuICpcbiAqIEBwYXJhbSBhcHAgLSBqcy1zZGsgY2xvdWRiYXNlIOWunuS+i1xuICogQHBhcmFtIGNvbmZpZyAtIOmFjee9ruS/oeaBr++8jOWMheWQq+iupOivgeWHreivgeWSjOeOr+WigyBJRFxuICovXG5leHBvcnQgY29uc3Qgbm9kZVRvb2wgPSAoYXBwOiBhbnksIGNvbmZpZzogSUNsb3VkYmFzZUNvbmZpZykgPT4ge1xuICAvLyDku4XlvZMgYXBwIOW3suWIneWni+WMliBhdXRoIOaooeWdl+aXtu+8jOaJjeazqOWFpSBhdXRoIOebuOWFs+aWueazlVxuICBpZiAoYXBwLmF1dGgpIHtcbiAgICBjb25zdCBhdXRoID0ge1xuICAgICAgLyoqIOiOt+WPluW9k+WJjeivt+axgueahOeUqOaIt+S/oeaBr++8iOS7jueOr+Wig+WPmOmHj+ivu+WPlu+8jOWQjOatpe+8iSAqL1xuICAgICAgZ2V0VXNlckluZm8oKTogSUdldFVzZXJJbmZvUmVzdWx0IHtcbiAgICAgICAgcmV0dXJuIGdldERlZmF1bHRVc2VySW5mbygpXG4gICAgICB9LFxuXG4gICAgICAvKipcbiAgICAgICAqIOiOt+WPlue7iOerr+eUqOaIt+S/oeaBr1xuICAgICAgICog5LiN5LygIHVpZCDml7bov5Tlm57lvZPliY3or7fmsYLnlKjmiLfkv6Hmga/vvIzkvKAgdWlkIOaXtuafpeivouaMh+WumueUqOaIt1xuICAgICAgICovXG4gICAgICBhc3luYyBnZXRFbmRVc2VySW5mbyh1aWQ/OiBzdHJpbmcpOiBQcm9taXNlPElHZXRFbmRVc2VySW5mb1Jlc3VsdD4ge1xuICAgICAgICBjb25zdCBkZWZhdWx0VXNlckluZm8gPSBnZXREZWZhdWx0VXNlckluZm8oKVxuXG4gICAgICAgIGlmICh1aWQgPT09IHVuZGVmaW5lZCkge1xuICAgICAgICAgIHJldHVybiB7IHVzZXJJbmZvOiBkZWZhdWx0VXNlckluZm8gfVxuICAgICAgICB9XG4gICAgICAgIHZhbGlkYXRlVWlkKHVpZClcblxuICAgICAgICByZXR1cm4gc2VuZFVzZXJJbmZvUmVxdWVzdChhcHAsIHtcbiAgICAgICAgICB1dWlkOiB1aWQsXG4gICAgICAgICAgZW52TmFtZTogY29uZmlnLmVudixcbiAgICAgICAgfSkudGhlbigocmVzdWx0OiBhbnkpID0+IHtcbiAgICAgICAgICBpZiAocmVzdWx0LmNvZGUpIHtcbiAgICAgICAgICAgIHJldHVybiByZXN1bHRcbiAgICAgICAgICB9XG4gICAgICAgICAgcmV0dXJuIHtcbiAgICAgICAgICAgIHVzZXJJbmZvOiB7IC4uLmRlZmF1bHRVc2VySW5mbywgLi4ucmVzdWx0LmRhdGEgfSxcbiAgICAgICAgICAgIHJlcXVlc3RJZDogcmVzdWx0LnJlcXVlc3RJZCxcbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICB9LFxuXG4gICAgICAvKipcbiAgICAgICAqIOWIm+W7uuiHquWumuS5ieeZu+W9lSBUaWNrZXRcbiAgICAgICAqIOS9v+eUqCBSU0Eg56eB6ZKl562+5Y+RIEpXVO+8jOWuouaIt+err+WHreatpCBUaWNrZXQg5o2i5Y+W55m75b2V5oCBXG4gICAgICAgKlxuICAgICAgICogQHBhcmFtIHVpZCAtIOiHquWumuS5ieeUqOaItyBJRO+8iDR+MzIg5L2N77yJXG4gICAgICAgKiBAcGFyYW0gb3B0aW9ucyAtIOWIt+aWsOmXtOmalOWSjOi/h+acn+aXtumXtOmFjee9rlxuICAgICAgICogQHJldHVybnMg5qC85byP5Li6IFwie3ByaXZhdGVfa2V5X2lkfS9AQC97and0X3Rva2VufVwiIOeahCBUaWNrZXQg5a2X56ym5LiyXG4gICAgICAgKi9cbiAgICAgIGFzeW5jIGNyZWF0ZVRpY2tldCh1aWQ6IHN0cmluZywgb3B0aW9uczogSUNyZWF0ZVRpY2tldE9wdHMgPSB7fSk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgICAgIHZhbGlkYXRlVWlkKHVpZClcblxuICAgICAgICBjb25zdCB0aW1lc3RhbXAgPSBuZXcgRGF0ZSgpLmdldFRpbWUoKVxuICAgICAgICBjb25zdCB7IGNyZWRlbnRpYWxzIH0gPSBjb25maWcuYXV0aCB8fCB7fVxuICAgICAgICBjb25zdCB7IGVudiB9ID0gY29uZmlnXG5cbiAgICAgICAgaWYgKCFlbnYpIHtcbiAgICAgICAgICB0aHJvdyB7IC4uLkVSUk9SLklOVkFMSURfUEFSQU0sIG1lc3NhZ2U6ICdubyBlbnYgaW4gY29uZmlnJyB9XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoIWNyZWRlbnRpYWxzPy5lbnZfaWQpIHtcbiAgICAgICAgICB0aHJvdyB7XG4gICAgICAgICAgICAuLi5FUlJPUi5JTlZBTElEX1BBUkFNLFxuICAgICAgICAgICAgbWVzc2FnZTogJ+W9k+WJjeengemSpeacquWMheWQq2Vudl9pZCDkv6Hmga/vvIwg6K+35YmN5b6A6IW+6K6v5LqR5LqR5byA5Y+R5o6n5Yi25Y+w77yM6I635Y+W6Ieq5a6a5LmJ55m75b2V5pyA5paw56eB6ZKlJyxcbiAgICAgICAgICB9XG4gICAgICAgIH1cblxuICAgICAgICBpZiAoY3JlZGVudGlhbHMuZW52X2lkICE9PSBlbnYpIHtcbiAgICAgICAgICB0aHJvdyB7XG4gICAgICAgICAgICAuLi5FUlJPUi5JTlZBTElEX1BBUkFNLFxuICAgICAgICAgICAgbWVzc2FnZTogJ+W9k+WJjeengemSpeaJgOWxnueOr+Wig+S4jiBpbml0IOaMh+WumueOr+Wig+S4jeS4gOiHtO+8gScsXG4gICAgICAgICAgfVxuICAgICAgICB9XG5cbiAgICAgICAgY29uc3Qge1xuICAgICAgICAgIHJlZnJlc2ggPSAzNjAwICogMTAwMCwgLy8g6buY6K6kIDEg5bCP5pe25Yi35pawXG4gICAgICAgICAgZXhwaXJlID0gdGltZXN0YW1wICsgNyAqIDI0ICogNjAgKiA2MCAqIDEwMDAsIC8vIOm7mOiupCA3IOWkqei/h+acn1xuICAgICAgICB9ID0gb3B0aW9uc1xuICAgICAgICBjb25zdCBzaWduID0gYXdhaXQgZ2V0Snd0U2lnbigpXG4gICAgICAgIGNvbnN0IHRva2VuID0gc2lnbihcbiAgICAgICAgICB7XG4gICAgICAgICAgICBhbGc6ICdSUzI1NicsXG4gICAgICAgICAgICBlbnYsXG4gICAgICAgICAgICBpYXQ6IHRpbWVzdGFtcCxcbiAgICAgICAgICAgIGV4cDogdGltZXN0YW1wICsgMTAgKiA2MCAqIDEwMDAsIC8vIFRpY2tldCDmnKzouqsgMTAg5YiG6ZKf5pyJ5pWIXG4gICAgICAgICAgICB1aWQsXG4gICAgICAgICAgICByZWZyZXNoLFxuICAgICAgICAgICAgZXhwaXJlLFxuICAgICAgICAgIH0sXG4gICAgICAgICAgY3JlZGVudGlhbHMucHJpdmF0ZV9rZXksXG4gICAgICAgICAge1xuICAgICAgICAgICAgYWxsb3dJbnNlY3VyZUtleVNpemVzOiB0cnVlLFxuICAgICAgICAgICAgYWxnb3JpdGhtOiAnUlMyNTYnLFxuICAgICAgICAgIH0sXG4gICAgICAgIClcblxuICAgICAgICByZXR1cm4gYCR7Y3JlZGVudGlhbHMucHJpdmF0ZV9rZXlfaWR9L0BALyR7dG9rZW59YFxuICAgICAgfSxcblxuICAgICAgLyoqXG4gICAgICAgKiDmjInmnaHku7bmn6Xor6LnlKjmiLfkv6Hmga/vvIjnrqHnkIbnq6/mjqXlj6PvvIlcbiAgICAgICAqIOaUr+aMgeaMiSB1aWTjgIFwbGF0Zm9ybeOAgXBsYXRmb3JtSWQg5p+l6K+iXG4gICAgICAgKi9cbiAgICAgIGFzeW5jIHF1ZXJ5VXNlckluZm8ocXVlcnk6IElVc2VySW5mb1F1ZXJ5KTogUHJvbWlzZTxhbnk+IHtcbiAgICAgICAgY29uc3QgeyB1aWQsIHBsYXRmb3JtLCBwbGF0Zm9ybUlkIH0gPSBxdWVyeVxuICAgICAgICByZXR1cm4gc2VuZFVzZXJJbmZvUmVxdWVzdChhcHAsIHtcbiAgICAgICAgICB1dWlkOiB1aWQsXG4gICAgICAgICAgcGxhdGZvcm0sXG4gICAgICAgICAgcGxhdGZvcm1JZCxcbiAgICAgICAgICBlbnZOYW1lOiBjb25maWcuZW52LFxuICAgICAgICB9KS50aGVuKChyZXN1bHQ6IGFueSkgPT4ge1xuICAgICAgICAgIGlmIChyZXN1bHQuY29kZSkge1xuICAgICAgICAgICAgcmV0dXJuIHJlc3VsdFxuICAgICAgICAgIH1cbiAgICAgICAgICByZXR1cm4ge1xuICAgICAgICAgICAgdXNlckluZm86IHsgLi4ucmVzdWx0LmRhdGEgfSxcbiAgICAgICAgICAgIHJlcXVlc3RJZDogcmVzdWx0LnJlcXVlc3RJZCxcbiAgICAgICAgICB9XG4gICAgICAgIH0pXG4gICAgICB9LFxuXG4gICAgICAvKiog6I635Y+W5a6i5oi356uvIElQIOWcsOWdgCAqL1xuICAgICAgZ2V0Q2xpZW50SVAoKTogc3RyaW5nIHtcbiAgICAgICAgY29uc3QgeyBUQ0JfU09VUkNFX0lQIH0gPSBnZXRDbG91ZGJhc2VDb250ZXh0KClcbiAgICAgICAgcmV0dXJuIFRDQl9TT1VSQ0VfSVAgfHwgJydcbiAgICAgIH0sXG4gICAgfVxuXG4gICAgLy8g5bCGIGF1dGgg5pa55rOV6YCQ5LiA5oyC6L295YiwIGFwcC5hdXRoIOS4ilxuICAgIE9iamVjdC5rZXlzKGF1dGgpLmZvckVhY2goKGtleSkgPT4ge1xuICAgICAgYXBwLmF1dGhba2V5XSA9IChhdXRoIGFzIFJlY29yZDxzdHJpbmcsIGFueT4pW2tleV1cbiAgICB9KVxuICB9XG5cbiAgLyoqXG4gICAqIOWPkemAgeaooeadv+a2iOaBr+mAmuefpVxuICAgKiDpgJrov4fosIPnlKggbG93Y29kZS1kYXRhc291cmNlIOS6keWHveaVsOmXtOaOpeiwg+eUqOW+ruaQrSBBUElcbiAgICpcbiAgICogQHBhcmFtIHBhcmFtcyAtIOmAmuefpeWPguaVsO+8iOetlueVpSBJROOAgeaooeadv+WPmOmHj+OAgei3s+i9rOmTvuaOpe+8iVxuICAgKiBAcGFyYW0gb3B0cyAtIOWPr+mAiemFjee9ru+8jOWmgui2heaXtuaXtumXtFxuICAgKi9cbiAgYXBwLnNlbmRUZW1wbGF0ZU5vdGlmaWNhdGlvbiA9IGFzeW5jIChwYXJhbXM6IElUZW1wbGF0ZU5vdGlmeVJlcSwgb3B0cz86IHsgdGltZW91dD86IG51bWJlciB9KSA9PiBhd2FpdCBhcHA/LmNhbGxGdW5jdGlvbj8uKFxuICAgIHtcbiAgICAgIG5hbWU6ICdsb3djb2RlLWRhdGFzb3VyY2UnLFxuICAgICAgZGF0YToge1xuICAgICAgICBtZXRob2ROYW1lOiAnY2FsbFdlZGFBcGknLFxuICAgICAgICBwYXJhbXM6IHtcbiAgICAgICAgICBhY3Rpb246ICdQdXNoTm90aWZ5TXNnJyxcbiAgICAgICAgICBkYXRhOiB7XG4gICAgICAgICAgICBOb3RpZnlJZDogcGFyYW1zLm5vdGlmeUlkLFxuICAgICAgICAgICAgRGF0YTogSlNPTi5zdHJpbmdpZnkocGFyYW1zLmRhdGEpLFxuICAgICAgICAgICAgTm90aWZ5VXNlcnM6IHVuZGVmaW5lZCxcbiAgICAgICAgICAgIFVybDogcGFyYW1zLnVybCxcbiAgICAgICAgICB9LFxuICAgICAgICB9LFxuICAgICAgICBtb2RlOiAnYycsXG4gICAgICB9LFxuICAgIH0sXG4gICAgdW5kZWZpbmVkLFxuICAgIG9wdHMsXG4gIClcblxuICAvKiog5oyC6L29IGNvbnRleHQg6Kej5p6Q5bel5YW377yM5pa55L6/55So5oi35Zyo5LqR5Ye95pWw5Lit5L2/55SoICovXG4gIGFwcC5wYXJzZUNvbnRleHQgPSBwYXJzZUNvbnRleHRcbn1cbiJdfQ==
@@ -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,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# 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,221 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ 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;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ var _a;
50
+ Object.defineProperty(exports, "__esModule", { value: true });
51
+ exports.createWebStreamFromNodeReadableStream = exports.parseQueryString = exports.headersInit2Indexable = exports.obj2StrRecord = exports.safeParseJson = exports.validateUid = exports.getCurrRunEnvTag = exports.checkIsInTencentCloud = exports.isNonEmptyString = exports.checkIsInSumeru = exports.checkIsInCBR = exports.checkIsInScf = exports.getEnv = exports.toQueryString = exports.isFormData = void 0;
52
+ var utilities_1 = require("@cloudbase/utilities");
53
+ var web_streams_polyfill_1 = require("web-streams-polyfill");
54
+ var constants_1 = require("./constants");
55
+ var metadata_1 = require("./metadata");
56
+ exports.isFormData = (_a = utilities_1.utils, _a.isFormData), exports.toQueryString = _a.toQueryString;
57
+ function getEnv(key) {
58
+ if (typeof process === 'undefined' || !process.env) {
59
+ return key !== undefined ? undefined : {};
60
+ }
61
+ return key !== undefined ? process.env[key] : process.env;
62
+ }
63
+ exports.getEnv = getEnv;
64
+ var checkIsInScf = function () { return getEnv('TENCENTCLOUD_RUNENV') === 'SCF'; };
65
+ exports.checkIsInScf = checkIsInScf;
66
+ function checkIsInCBR() {
67
+ return !!getEnv('CBR_ENV_ID');
68
+ }
69
+ exports.checkIsInCBR = checkIsInCBR;
70
+ var kSumeruEnvSet = new Set(['formal', 'pre', 'test']);
71
+ function checkIsInSumeru() {
72
+ return kSumeruEnvSet.has(getEnv('SUMERU_ENV') || '');
73
+ }
74
+ exports.checkIsInSumeru = checkIsInSumeru;
75
+ function isNonEmptyString(str) {
76
+ return typeof str === 'string' && str !== '';
77
+ }
78
+ exports.isNonEmptyString = isNonEmptyString;
79
+ function checkIsInTencentCloud() {
80
+ return __awaiter(this, void 0, void 0, function () {
81
+ var _a;
82
+ return __generator(this, function (_b) {
83
+ switch (_b.label) {
84
+ case 0:
85
+ if (getEnv('TENCENTCLOUD') === 'true') {
86
+ return [2, true];
87
+ }
88
+ _a = isNonEmptyString;
89
+ return [4, (0, metadata_1.lookupAppId)()];
90
+ case 1: return [2, _a.apply(void 0, [_b.sent()])];
91
+ }
92
+ });
93
+ });
94
+ }
95
+ exports.checkIsInTencentCloud = checkIsInTencentCloud;
96
+ var getCurrRunEnvTag = function () { return __awaiter(void 0, void 0, void 0, function () {
97
+ return __generator(this, function (_a) {
98
+ switch (_a.label) {
99
+ case 0:
100
+ if ((0, exports.checkIsInScf)()) {
101
+ return [2, 'scf'];
102
+ }
103
+ if (checkIsInCBR()) {
104
+ return [2, 'cbr'];
105
+ }
106
+ if (checkIsInSumeru()) {
107
+ return [2, 'sumeru'];
108
+ }
109
+ return [4, checkIsInTencentCloud()];
110
+ case 1:
111
+ if (_a.sent()) {
112
+ return [2, 'tencentcloud'];
113
+ }
114
+ return [2, 'unknown'];
115
+ }
116
+ });
117
+ }); };
118
+ exports.getCurrRunEnvTag = getCurrRunEnvTag;
119
+ var validateUid = function (uid) {
120
+ if (typeof uid !== 'string') {
121
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: 'uid must be a string' });
122
+ }
123
+ if (!constants_1.checkCustomUserIdRegex.test(uid)) {
124
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: "Invalid uid: \"".concat(uid, "\"") });
125
+ }
126
+ };
127
+ exports.validateUid = validateUid;
128
+ function safeParseJson(text) {
129
+ if (!text || !text.trim()) {
130
+ return null;
131
+ }
132
+ try {
133
+ return JSON.parse(text);
134
+ }
135
+ catch (e) {
136
+ console.warn('catch an error', { e: e, text: text });
137
+ return text;
138
+ }
139
+ }
140
+ exports.safeParseJson = safeParseJson;
141
+ function obj2StrRecord(obj) {
142
+ return Object.entries(obj).reduce(function (acc, cur) {
143
+ var key = cur[0], value = cur[1];
144
+ acc[key] = String(value);
145
+ return acc;
146
+ }, {});
147
+ }
148
+ exports.obj2StrRecord = obj2StrRecord;
149
+ function headersInit2Indexable(h) {
150
+ if (isHeaders(h)) {
151
+ var ret_1 = {};
152
+ h.forEach(function (val, key) {
153
+ ret_1[key] = val;
154
+ });
155
+ return ret_1;
156
+ }
157
+ return h;
158
+ function isHeaders(h) {
159
+ try {
160
+ return h instanceof Headers;
161
+ }
162
+ catch (_) {
163
+ return false;
164
+ }
165
+ }
166
+ }
167
+ exports.headersInit2Indexable = headersInit2Indexable;
168
+ function parseQueryString(search) {
169
+ var params = {};
170
+ var cleanSearch = search.replace(/^[?#]/, '');
171
+ if (!cleanSearch) {
172
+ return params;
173
+ }
174
+ var pairs = cleanSearch.split('&');
175
+ pairs.forEach(function (item) {
176
+ var _a = item.split('='), key = _a[0], value = _a[1];
177
+ key = decodeURIComponent(key);
178
+ value = decodeURIComponent(value || '');
179
+ if (key) {
180
+ if (params[key]) {
181
+ if (Array.isArray(params[key])) {
182
+ params[key].push(value);
183
+ }
184
+ else {
185
+ params[key] = [params[key], value];
186
+ }
187
+ }
188
+ else {
189
+ params[key] = value;
190
+ }
191
+ }
192
+ });
193
+ return params;
194
+ }
195
+ exports.parseQueryString = parseQueryString;
196
+ function createWebStreamFromNodeReadableStream(stream) {
197
+ var asyncIterator = stream[Symbol.asyncIterator]();
198
+ return new web_streams_polyfill_1.ReadableStream({
199
+ pull: function (controller) {
200
+ return __awaiter(this, void 0, void 0, function () {
201
+ var next;
202
+ return __generator(this, function (_a) {
203
+ switch (_a.label) {
204
+ case 0: return [4, asyncIterator.next()];
205
+ case 1:
206
+ next = _a.sent();
207
+ if (next.done) {
208
+ controller.close();
209
+ }
210
+ else {
211
+ controller.enqueue(next.value);
212
+ }
213
+ return [2];
214
+ }
215
+ });
216
+ });
217
+ },
218
+ });
219
+ }
220
+ exports.createWebStreamFromNodeReadableStream = createWebStreamFromNodeReadableStream;
221
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbHMuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi9zcmMvbGlicy9hZGFwdGVyLW5vZGUvdXRpbHMudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsa0RBQTRDO0FBQzVDLDZEQUFxRDtBQUNyRCx5Q0FBMkQ7QUFDM0QsdUNBQXdDO0FBR3pCLFFBQUEsVUFBVSxJQUFaLEtBQWdDLGlCQUc1QyxrQkFIMEIsUUFBQSxhQUFhLG9CQUd2QztBQVFELFNBQWdCLE1BQU0sQ0FBQyxHQUFZO0lBQ2pDLElBQUksT0FBTyxPQUFPLEtBQUssV0FBVyxJQUFJLENBQUMsT0FBTyxDQUFDLEdBQUcsRUFBRTtRQUNsRCxPQUFPLEdBQUcsS0FBSyxTQUFTLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxDQUFDLENBQUMsRUFBRSxDQUFBO0tBQzFDO0lBQ0QsT0FBTyxHQUFHLEtBQUssU0FBUyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFBO0FBQzNELENBQUM7QUFMRCx3QkFLQztBQUdNLElBQU0sWUFBWSxHQUFHLGNBQU0sT0FBQSxNQUFNLENBQUMscUJBQXFCLENBQUMsS0FBSyxLQUFLLEVBQXZDLENBQXVDLENBQUE7QUFBNUQsUUFBQSxZQUFZLGdCQUFnRDtBQUV6RSxTQUFnQixZQUFZO0lBRTFCLE9BQU8sQ0FBQyxDQUFDLE1BQU0sQ0FBQyxZQUFZLENBQUMsQ0FBQTtBQUMvQixDQUFDO0FBSEQsb0NBR0M7QUFFRCxJQUFNLGFBQWEsR0FBRyxJQUFJLEdBQUcsQ0FBQyxDQUFDLFFBQVEsRUFBRSxLQUFLLEVBQUUsTUFBTSxDQUFDLENBQUMsQ0FBQTtBQUN4RCxTQUFnQixlQUFlO0lBRTdCLE9BQU8sYUFBYSxDQUFDLEdBQUcsQ0FBQyxNQUFNLENB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QUMsQ0FBQTtpQkFDbkM7YUFDRjtpQkFBTTtnQkFDTCxNQUFNLENBQUMsR0FBRyxDQUFDLEdBQUcsS0FBSyxDQUFBO2FBQ3BCO1NBQ0Y7SUFDSCxDQUFDLENBQUMsQ0FBQTtJQUNGLE9BQU8sTUFBTSxDQUFBO0FBQ2YsQ0FBQztBQTVCRCw0Q0E0QkM7QUFNRCxTQUFnQixxQ0FBcUMsQ0FBQyxNQUE2QjtJQUNqRixJQUFNLGFBQWEsR0FBRyxNQUFNLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxFQUFFLENBQUE7SUFFcEQsT0FBTyxJQUFJLHFDQUFjLENBQUM7UUFDbEIsSUFBSSxZQUFDLFVBQVU7Ozs7O2dDQUNOLFdBQU0sYUFBYSxDQUFDLElBQUksRUFBRSxFQUFBOzs0QkFBakMsSUFBSSxHQUFHLFNBQTBCOzRCQUV2QyxJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7Z0NBQ2IsVUFBVSxDQUFDLEtBQUssRUFBRSxDQUFBOzZCQUNuQjtpQ0FBTTtnQ0FDTCxVQUFVLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQTs2QkFDL0I7Ozs7O1NBQ0Y7S0FDRixDQUFDLENBQUE7QUFDSixDQUFDO0FBZEQsc0ZBY0MiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyB1dGlscyB9IGZyb20gJ0BjbG91ZGJhc2UvdXRpbGl0aWVzJ1xuaW1wb3J0IHsgUmVhZGFibGVTdHJlYW0gfSBmcm9tICd3ZWItc3RyZWFtcy1wb2x5ZmlsbCdcbmltcG9ydCB7IEVSUk9SLCBjaGVja0N1c3RvbVVzZXJJZFJlZ2V4IH0gZnJvbSAnLi9jb25zdGFudHMnXG5pbXBvcnQgeyBsb29rdXBBcHBJZCB9IGZyb20gJy4vbWV0YWRhdGEnXG5cbi8qKiDku44gQGNsb3VkYmFzZS91dGlsaXRpZXMg5Lit5o+Q5Y+W55qE6KGo5Y2V5ZKM5p+l6K+i5a2X56ym5Liy5bel5YW3ICovXG5leHBvcnQgY29uc3QgeyBpc0Zvcm1EYXRhLCB0b1F1ZXJ5U3RyaW5nIH0gPSB1dGlscyBhcyB7XG4gIGlzRm9ybURhdGE6IChvYmo6IHVua25vd24pID0+IGJvb2xlYW5cbiAgdG9RdWVyeVN0cmluZzogKGRhdGE6IFJlY29yZDxzdHJpbmcsIGFueT4pID0+IHN0cmluZ1xufVxuXG4vKipcbiAqIOi3qOerr+WuieWFqOiOt+WPlueOr+Wig+WPmOmHj1xuICogV2ViIOerr+OAgeWwj+a4uOaIj+err+etieayoeaciSBwcm9jZXNzIOWFqOWxgOWvueixoe+8jOebtOaOpeiuv+mXriBwcm9jZXNzLmVudiDkvJrmiqXplJlcbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGdldEVudigpOiBSZWNvcmQ8c3RyaW5nLCBzdHJpbmcgfCB1bmRlZmluZWQ+XG5leHBvcnQgZnVuY3Rpb24gZ2V0RW52KGtleTogc3RyaW5nKTogc3RyaW5nIHwgdW5kZWZpbmVkXG5leHBvcnQgZnVuY3Rpb24gZ2V0RW52KGtleT86IHN0cmluZyk6IHN0cmluZyB8IHVuZGVmaW5lZCB8IFJlY29yZDxzdHJpbmcsIHN0cmluZyB8IHVuZGVmaW5lZD4ge1xuICBpZiAodHlwZW9mIHByb2Nlc3MgPT09ICd1bmRlZmluZWQnIHx8ICFwcm9jZXNzLmVudikge1xuICAgIHJldHVybiBrZXkgIT09IHVuZGVmaW5lZCA/IHVuZGVmaW5lZCA6IHt9XG4gIH1cbiAgcmV0dXJuIGtleSAhPT0gdW5kZWZpbmVkID8gcHJvY2Vzcy5lbnZba2V5XSA6IHByb2Nlc3MuZW52XG59XG5cbi8qKiDliKTmlq3lvZPliY3mmK/lkKblnKggU0NG77yI5LqR5Ye95pWw77yJ6L+Q6KGM546v5aKD5LitICovXG5leHBvcnQgY29uc3QgY2hlY2tJc0luU2NmID0gKCkgPT4gZ2V0RW52KCdURU5DRU5UQ0xPVURfUlVORU5WJykgPT09ICdTQ0YnXG5cbmV4cG9ydCBmdW5jdGlvbiBjaGVja0lzSW5DQlIoKSB7XG4gIC8vIENCUiA9IENMT1VEQkFTRV9SVU5cbiAgcmV0dXJuICEhZ2V0RW52KCdDQlJfRU5WX0lEJylcbn1cblxuY29uc3Qga1N1bWVydUVudlNldCA9IG5ldyBTZXQoWydmb3JtYWwnLCAncHJlJywgJ3Rlc3QnXSlcbmV4cG9ydCBmdW5jdGlvbiBjaGVja0lzSW5TdW1lcnUoKSB7XG4gIC8vIFNVTUVSVV9FTlY9Zm9ybWFsIHwgdGVzdCB8IHByZVxuICByZXR1cm4ga1N1bWVydUVudlNldC5oYXMoZ2V0RW52KCdTVU1FUlVfRU5WJykgfHwgJycpXG59XG5cbmV4cG9ydCBmdW5jdGlvbiBpc05vbkVtcHR5U3RyaW5nKHN0cjogc3RyaW5nKSB7XG4gIHJldHVybiB0eXBlb2Ygc3RyID09PSAnc3RyaW5nJyAmJiBzdHIgIT09ICcnXG59XG5cbmV4cG9ydCBhc3luYyBmdW5jdGlvbiBjaGVja0lzSW5UZW5jZW50Q2xvdWQoKTogUHJvbWlzZTxib29sZWFuPiB7XG4gIGlmIChnZXRFbnYoJ1RFTkNFTlRDTE9VRCcpID09PSAndHJ1ZScpIHtcbiAgICByZXR1cm4gdHJ1ZVxuICB9XG4gIHJldHVybiBpc05vbkVtcHR5U3RyaW5nKGF3YWl0IGxvb2t1cEFwcElkKCkpXG59XG5cbmV4cG9ydCBjb25zdCBnZXRDdXJyUnVuRW52VGFnID0gYXN5bmMgKCk6IFByb21pc2U8c3RyaW5nPiA9PiB7XG4gIGlmIChjaGVja0lzSW5TY2YoKSkge1xuICAgIHJldHVybiAnc2NmJ1xuICB9IGlmIChjaGVja0lzSW5DQlIoKSkge1xuICAgIHJldHVybiAnY2JyJ1xuICB9IGlmIChjaGVja0lzSW5TdW1lcnUoKSkge1xuICAgIHJldHVybiAnc3VtZXJ1J1xuICB9IGlmIChhd2FpdCBjaGVja0lzSW5UZW5jZW50Q2xvdWQoKSkge1xuICAgIHJldHVybiAndGVuY2VudGNsb3VkJ1xuICB9XG4gIHJldHVybiAndW5rbm93bidcbn1cblxuLyoqXG4gKiDmoKHpqozoh6rlrprkuYnnlKjmiLcgSUQg5qC85byPXG4gKiBAdGhyb3dzIOagvOW8j+S4jeWQiOazleaXtuaKm+WHuiBJTlZBTElEX1BBUkFNIOmUmeivr1xuICovXG5leHBvcnQgY29uc3QgdmFsaWRhdGVVaWQgPSAodWlkOiBzdHJpbmcpOiB2b2lkID0+IHtcbiAgaWYgKHR5cGVvZiB1aWQgIT09ICdzdHJpbmcnKSB7XG4gICAgdGhyb3cgeyAuLi5FUlJPUi5JTlZBTElEX1BBUkFNLCBtZXNzYWdlOiAndWlkIG11c3QgYmUgYSBzdHJpbmcnIH1cbiAgfVxuICBpZiAoIWNoZWNrQ3VzdG9tVXNlcklkUmVnZXgudGVzdCh1aWQpKSB7XG4gICAgdGhyb3cgeyAuLi5FUlJPUi5JTlZBTElEX1BBUkFNLCBtZXNzYWdlOiBgSW52YWxpZCB1aWQ6IFwiJHt1aWR9XCJgIH1cbiAgfVxufVxuXG4vKipcbiAqIOWuieWFqOeahCBKU09OIOino+aekO+8jOino+aekOWksei0peaXtui/lOWbnuWOn+Wni+aWh+acrOiAjOmdnuaKm+W8guW4uFxuICogQHBhcmFtIHRleHQgLSDlvoXop6PmnpDnmoTlrZfnrKbkuLJcbiAqIEByZXR1cm5zIOino+aekOWQjueahOWvueixoe+8jOepuuWtl+espuS4sui/lOWbniBudWxs77yM6Kej5p6Q5aSx6LSl6L+U5Zue5Y6f5aeL5paH5pysXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBzYWZlUGFyc2VKc29uKHRleHQ6IHN0cmluZyk6IGFueSB7XG4gIGlmICghdGV4dCB8fCAhdGV4dC50cmltKCkpIHtcbiAgICByZXR1cm4gbnVsbFxuICB9XG4gIHRyeSB7XG4gICAgcmV0dXJuIEpTT04ucGFyc2UodGV4dClcbiAgfSBjYXRjaCAoZSkge1xuICAgIGNvbnNvbGUud2FybignY2F0Y2ggYW4gZXJyb3InLCB7IGUsIHRleHQgfSlcbiAgICByZXR1cm4gdGV4dFxuICB9XG59XG5cbi8qKlxuICog5bCG5a+56LGh55qE5omA5pyJ5YC86L2s5Li65a2X56ym5Liy57G75Z6LXG4gKiDnlKjkuo7lsIYgaGVhZGVycyDnrYnlr7nosaHnu5/kuIDkuLogUmVjb3JkPHN0cmluZywgc3RyaW5nPlxuICovXG5leHBvcnQgZnVuY3Rpb24gb2JqMlN0clJlY29yZChvYmo6IG9iamVjdCk6IFJlY29yZDxzdHJpbmcsIHN0cmluZz4ge1xuICByZXR1cm4gT2JqZWN0LmVudHJpZXMob2JqKS5yZWR1Y2U8UmVjb3JkPHN0cmluZywgc3RyaW5nPj4oKGFjYywgY3VyOiBbc3RyaW5nLCB1bmtub3duXSkgPT4ge1xuICAgIGNvbnN0IFtrZXksIHZhbHVlXSA9IGN1clxuICAgIGFjY1trZXldID0gU3RyaW5nKHZhbHVlKVxuICAgIHJldHVybiBhY2NcbiAgfSwge30pXG59XG5cbi8qKlxuICog5bCGIEhlYWRlcnNJbml0IOi9rOS4uuWPr+e0ouW8leeahOaZrumAmuWvueixoVxuICog5YW85a65IEhlYWRlcnMg5a6e5L6L5ZKM5pmu6YCa5a+56LGh5Lik56eN5b2i5byPXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBoZWFkZXJzSW5pdDJJbmRleGFibGUoaDogSGVhZGVyc0luaXQpIHtcbiAgaWYgKGlzSGVhZGVycyhoKSkge1xuICAgIGNvbnN0IHJldDogUmVjb3JkPHN0cmluZywgc3RyaW5nPiA9IHt9XG4gICAgaC5mb3JFYWNoKCh2YWwsIGtleSkgPT4ge1xuICAgICAgcmV0W2tleV0gPSB2YWxcbiAgICB9KVxuICAgIHJldHVybiByZXRcbiAgfVxuICByZXR1cm4gaFxuXG4gIGZ1bmN0aW9uIGlzSGVhZGVycyhoOiBIZWFkZXJzSW5pdCk6IGggaXMgSGVhZGVycyB7XG4gICAgdHJ5IHtcbiAgICAgIC8vIE5vZGUg5L2O54mI5pys5Y+v6IO95rKh5pyJ5YWo5bGAIEhlYWRlcnNcbiAgICAgIHJldHVybiBoIGluc3RhbmNlb2YgSGVhZGVyc1xuICAgIH0gY2F0Y2ggKF8pIHtcbiAgICAgIHJldHVybiBmYWxzZVxuICAgIH1cbiAgfVxufVxuXG4vKipcbiAqIOaJi+WKqOino+aekOafpeivouWtl+espuS4su+8jOmBv+WFjSBVUkxTZWFyY2hQYXJhbXMg55qE5YW85a655oCn6Zeu6aKYXG4gKiDmlK/mjIHph43lpI0ga2V5IOiHquWKqOi9rOS4uuaVsOe7hFxuICogQHBhcmFtIHNlYXJjaCAtIOafpeivouWtl+espuS4su+8jOWPr+W4puWJjeWvvCA/IOaIliAjXG4gKi9cbmV4cG9ydCBmdW5jdGlvbiBwYXJzZVF1ZXJ5U3RyaW5nKHNlYXJjaDogc3RyaW5nKTogUmVjb3JkPHN0cmluZywgc3RyaW5nIHwgc3RyaW5nW10+IHtcbiAgY29uc3QgcGFyYW1zOiBhbnkgPSB7fVxuICBjb25zdCBjbGVhblNlYXJjaCA9IHNlYXJjaC5yZXBsYWNlKC9eWz8jXS8sICcnKVxuXG4gIGlmICghY2xlYW5TZWFyY2gpIHtcbiAgICByZXR1cm4gcGFyYW1zXG4gIH1cblxuICBjb25zdCBwYWlycyA9IGNsZWFuU2VhcmNoLnNwbGl0KCcmJylcblxuICBwYWlycy5mb3JFYWNoKChpdGVtKSA9PiB7XG4gICAgbGV0IFtrZXksIHZhbHVlXSA9IGl0ZW0uc3BsaXQoJz0nKVxuICAgIGtleSA9IGRlY29kZVVSSUNvbXBvbmVudChrZXkpXG4gICAgdmFsdWUgPSBkZWNvZGVVUklDb21wb25lbnQodmFsdWUgfHwgJycpXG4gICAgaWYgKGtleSkge1xuICAgICAgaWYgKHBhcmFtc1trZXldKSB7XG4gICAgICAgIC8vIOW3suWtmOWcqOWQjOWQjSBrZXnvvIzovazkuLrmlbDnu4RcbiAgICAgICAgaWYgKEFycmF5LmlzQXJyYXkocGFyYW1zW2tleV0pKSB7XG4gICAgICAgICAgcGFyYW1zW2tleV0ucHVzaCh2YWx1ZSlcbiAgICAgICAgfSBlbHNlIHtcbiAgICAgICAgICBwYXJhbXNba2V5XSA9IFtwYXJhbXNba2V5XSwgdmFsdWVdXG4gICAgICAgIH1cbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIHBhcmFtc1trZXldID0gdmFsdWVcbiAgICAgIH1cbiAgICB9XG4gIH0pXG4gIHJldHVybiBwYXJhbXNcbn1cblxuLyoqXG4gKiDlsIYgTm9kZSBSZWFkYWJsZVN0cmVhbSDovazmjaLkuLogV2ViIFJlYWRhYmxlU3RyZWFtIChwb2x5ZmlsbClcbiAqIOeUqOS6jiBmZXRjaCDmtYHlvI/lk43lupTlnKggTm9kZSDnjq/looPkuIvnmoTpgILphY1cbiAqL1xuZXhwb3J0IGZ1bmN0aW9uIGNyZWF0ZVdlYlN0cmVhbUZyb21Ob2RlUmVhZGFibGVTdHJlYW0oc3RyZWFtOiBOb2RlSlMuUmVhZGFibGVTdHJlYW0pOiBSZWFkYWJsZVN0cmVhbSB7XG4gIGNvbnN0IGFzeW5jSXRlcmF0b3IgPSBzdHJlYW1bU3ltYm9sLmFzeW5jSXRlcmF0b3JdKClcblxuICByZXR1cm4gbmV3IFJlYWRhYmxlU3RyZWFtKHtcbiAgICBhc3luYyBwdWxsKGNvbnRyb2xsZXIpIHtcbiAgICAgIGNvbnN0IG5leHQgPSBhd2FpdCBhc3luY0l0ZXJhdG9yLm5leHQoKVxuXG4gICAgICBpZiAobmV4dC5kb25lKSB7XG4gICAgICAgIGNvbnRyb2xsZXIuY2xvc2UoKVxuICAgICAgfSBlbHNlIHtcbiAgICAgICAgY29udHJvbGxlci5lbnF1ZXVlKG5leHQudmFsdWUpXG4gICAgICB9XG4gICAgfSxcbiAgfSlcbn1cbiJdfQ==
@@ -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;