@cloudbase/app 3.0.4 → 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 (47) hide show
  1. package/dist/cjs/index.js +12 -8
  2. package/dist/cjs/libs/adapter-node/constants.d.ts +33 -0
  3. package/dist/cjs/libs/adapter-node/constants.js +38 -0
  4. package/dist/cjs/libs/adapter-node/context.d.ts +13 -0
  5. package/dist/cjs/libs/adapter-node/context.js +162 -0
  6. package/dist/cjs/libs/adapter-node/index.d.ts +23 -0
  7. package/dist/cjs/libs/adapter-node/index.js +124 -0
  8. package/dist/cjs/libs/adapter-node/metadata.d.ts +14 -0
  9. package/dist/cjs/libs/adapter-node/metadata.js +130 -0
  10. package/dist/cjs/libs/adapter-node/request.d.ts +38 -0
  11. package/dist/cjs/libs/adapter-node/request.js +432 -0
  12. package/dist/cjs/libs/adapter-node/tool.d.ts +2 -0
  13. package/dist/cjs/libs/adapter-node/tool.js +227 -0
  14. package/dist/cjs/libs/adapter-node/types.d.ts +78 -0
  15. package/dist/cjs/libs/adapter-node/types.js +3 -0
  16. package/dist/cjs/libs/adapter-node/utils.d.ts +17 -0
  17. package/dist/cjs/libs/adapter-node/utils.js +221 -0
  18. package/dist/esm/index.js +12 -8
  19. package/dist/esm/libs/adapter-node/constants.d.ts +33 -0
  20. package/dist/esm/libs/adapter-node/constants.js +35 -0
  21. package/dist/esm/libs/adapter-node/context.d.ts +13 -0
  22. package/dist/esm/libs/adapter-node/context.js +156 -0
  23. package/dist/esm/libs/adapter-node/index.d.ts +23 -0
  24. package/dist/esm/libs/adapter-node/index.js +118 -0
  25. package/dist/esm/libs/adapter-node/metadata.d.ts +14 -0
  26. package/dist/esm/libs/adapter-node/metadata.js +123 -0
  27. package/dist/esm/libs/adapter-node/request.d.ts +38 -0
  28. package/dist/esm/libs/adapter-node/request.js +429 -0
  29. package/dist/esm/libs/adapter-node/tool.d.ts +2 -0
  30. package/dist/esm/libs/adapter-node/tool.js +223 -0
  31. package/dist/esm/libs/adapter-node/types.d.ts +78 -0
  32. package/dist/esm/libs/adapter-node/types.js +2 -0
  33. package/dist/esm/libs/adapter-node/utils.d.ts +17 -0
  34. package/dist/esm/libs/adapter-node/utils.js +205 -0
  35. package/dist/miniprogram/index.js +1 -1
  36. package/package.json +20 -4
  37. package/src/index.ts +13 -1
  38. package/src/libs/adapter-node/constants.ts +42 -0
  39. package/src/libs/adapter-node/context.ts +238 -0
  40. package/src/libs/adapter-node/index.ts +166 -0
  41. package/src/libs/adapter-node/metadata.ts +69 -0
  42. package/src/libs/adapter-node/request.ts +480 -0
  43. package/src/libs/adapter-node/tool.ts +223 -0
  44. package/src/libs/adapter-node/types.ts +116 -0
  45. package/src/libs/adapter-node/utils.ts +182 -0
  46. package/webpack/web.prod.js +13 -13
  47. package/webpack/webpack.miniprogram.js +9 -3
@@ -0,0 +1,227 @@
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
+ throw new Error('缺少依赖 jsonwebtoken,请执行以下命令安装:\n\n'
74
+ + ' npm install jsonwebtoken\n\n'
75
+ + '该依赖用于 Node 环境下的自定义登录票据生成。');
76
+ case 4: return [2, jwtSign];
77
+ }
78
+ });
79
+ });
80
+ }
81
+ function getDefaultUserInfo() {
82
+ 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;
83
+ return {
84
+ openId: WX_OPENID || '',
85
+ appId: WX_APPID || '',
86
+ uid: TCB_UUID || '',
87
+ customUserId: TCB_CUSTOM_USER_ID || '',
88
+ isAnonymous: TCB_ISANONYMOUS_USER === 'true',
89
+ };
90
+ }
91
+ function sendUserInfoRequest(app, params) {
92
+ var _a, _b;
93
+ 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, {
94
+ pathname: 'web',
95
+ endPointMode: 'CLOUD_API',
96
+ });
97
+ }
98
+ var nodeTool = function (app, config) {
99
+ if (app.auth) {
100
+ var auth_1 = {
101
+ getUserInfo: function () {
102
+ return getDefaultUserInfo();
103
+ },
104
+ getEndUserInfo: function (uid) {
105
+ return __awaiter(this, void 0, void 0, function () {
106
+ var defaultUserInfo;
107
+ return __generator(this, function (_a) {
108
+ defaultUserInfo = getDefaultUserInfo();
109
+ if (uid === undefined) {
110
+ return [2, { userInfo: defaultUserInfo }];
111
+ }
112
+ (0, utils_1.validateUid)(uid);
113
+ return [2, sendUserInfoRequest(app, {
114
+ uuid: uid,
115
+ envName: config.env,
116
+ }).then(function (result) {
117
+ if (result.code) {
118
+ return result;
119
+ }
120
+ return {
121
+ userInfo: __assign(__assign({}, defaultUserInfo), result.data),
122
+ requestId: result.requestId,
123
+ };
124
+ })];
125
+ });
126
+ });
127
+ },
128
+ createTicket: function (uid, options) {
129
+ if (options === void 0) { options = {}; }
130
+ return __awaiter(this, void 0, void 0, function () {
131
+ var timestamp, credentials, env, _a, refresh, _b, expire, sign, token;
132
+ return __generator(this, function (_c) {
133
+ switch (_c.label) {
134
+ case 0:
135
+ (0, utils_1.validateUid)(uid);
136
+ timestamp = new Date().getTime();
137
+ credentials = (config.auth || {}).credentials;
138
+ env = config.env;
139
+ if (!env) {
140
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: 'no env in config' });
141
+ }
142
+ if (!(credentials === null || credentials === void 0 ? void 0 : credentials.env_id)) {
143
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: '当前私钥未包含env_id 信息, 请前往腾讯云云开发控制台,获取自定义登录最新私钥' });
144
+ }
145
+ if (credentials.env_id !== env) {
146
+ throw __assign(__assign({}, constants_1.ERROR.INVALID_PARAM), { message: '当前私钥所属环境与 init 指定环境不一致!' });
147
+ }
148
+ _a = options.refresh, refresh = _a === void 0 ? 3600 * 1000 : _a, _b = options.expire, expire = _b === void 0 ? timestamp + 7 * 24 * 60 * 60 * 1000 : _b;
149
+ return [4, getJwtSign()];
150
+ case 1:
151
+ sign = _c.sent();
152
+ token = sign({
153
+ alg: 'RS256',
154
+ env: env,
155
+ iat: timestamp,
156
+ exp: timestamp + 10 * 60 * 1000,
157
+ uid: uid,
158
+ refresh: refresh,
159
+ expire: expire,
160
+ }, credentials.private_key, {
161
+ allowInsecureKeySizes: true,
162
+ algorithm: 'RS256',
163
+ });
164
+ return [2, "".concat(credentials.private_key_id, "/@@/").concat(token)];
165
+ }
166
+ });
167
+ });
168
+ },
169
+ queryUserInfo: function (query) {
170
+ return __awaiter(this, void 0, void 0, function () {
171
+ var uid, platform, platformId;
172
+ return __generator(this, function (_a) {
173
+ uid = query.uid, platform = query.platform, platformId = query.platformId;
174
+ return [2, sendUserInfoRequest(app, {
175
+ uuid: uid,
176
+ platform: platform,
177
+ platformId: platformId,
178
+ envName: config.env,
179
+ }).then(function (result) {
180
+ if (result.code) {
181
+ return result;
182
+ }
183
+ return {
184
+ userInfo: __assign({}, result.data),
185
+ requestId: result.requestId,
186
+ };
187
+ })];
188
+ });
189
+ });
190
+ },
191
+ getClientIP: function () {
192
+ var TCB_SOURCE_IP = (0, context_1.getCloudbaseContext)().TCB_SOURCE_IP;
193
+ return TCB_SOURCE_IP || '';
194
+ },
195
+ };
196
+ Object.keys(auth_1).forEach(function (key) {
197
+ app.auth[key] = auth_1[key];
198
+ });
199
+ }
200
+ app.sendTemplateNotification = function (params, opts) { return __awaiter(void 0, void 0, void 0, function () {
201
+ var _a;
202
+ return __generator(this, function (_b) {
203
+ switch (_b.label) {
204
+ case 0: return [4, ((_a = app === null || app === void 0 ? void 0 : app.callFunction) === null || _a === void 0 ? void 0 : _a.call(app, {
205
+ name: 'lowcode-datasource',
206
+ data: {
207
+ methodName: 'callWedaApi',
208
+ params: {
209
+ action: 'PushNotifyMsg',
210
+ data: {
211
+ NotifyId: params.notifyId,
212
+ Data: JSON.stringify(params.data),
213
+ NotifyUsers: undefined,
214
+ Url: params.url,
215
+ },
216
+ },
217
+ mode: 'c',
218
+ },
219
+ }, undefined, opts))];
220
+ case 1: return [2, _b.sent()];
221
+ }
222
+ });
223
+ }); };
224
+ app.parseContext = context_1.parseContext;
225
+ };
226
+ exports.nodeTool = nodeTool;
227
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9saWJzL2FkYXB0ZXItbm9kZS90b29sLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEseUNBQW1DO0FBQ25DLHFDQUE2RDtBQUM3RCxpQ0FBcUM7QUFZckMsSUFBSSxPQUFPLEdBQXFDLElBQUksQ0FBQTtBQUNwRCxTQUFlLFVBQVU7Ozs7Ozs7eUJBQ25CLENBQUMsT0FBTyxFQUFSLGNBQVE7Ozs7b0JBR0ksV0FBTSxNQUFNLENBQUMsY0FBYyxDQUFDLEVBQUE7O29CQUFsQyxHQUFHLEdBQUcsU0FBNEI7b0JBQ3hDLE9BQU8sR0FBRyxDQUFBLE1BQUEsR0FBRyxDQUFDLE9BQU8sMENBQUUsSUFBSSxLQUFJLEdBQUcsQ0FBQyxJQUFJLENBQUE7Ozs7b0JBRXZDLE1BQU0sSUFBSSxLQUFLLENBQUMsa0NBQWtDOzBCQUM5QyxnQ0FBZ0M7MEJBQ2hDLDJCQUEyQixDQUFDLENBQUE7d0JBR3BDLFdBQU8sT0FBUSxFQUFBOzs7O0NBQ2hCO0FBTUQsU0FBUyxrQkFBa0I7SUFDbkIsSUFBQSxLQUE4RSxJQUFBLDZCQUFtQixHQUFFLEVBQWpHLFNBQVMsZUFBQSxFQUFFLFFBQVEsY0FBQSxFQUFFLFFBQVEsY0FBQSxFQUFFLGtCQUFrQix3QkFBQSxFQUFFLG9CQUFvQiwwQkFBMEIsQ0FBQTtJQUV6RyxPQUFPO1FBQ0wsTUFBTSxFQUFFLFNBQVMsSUFBSSxFQUFFO1FBQ3ZCLEtBQUssRUFBRSxRQUFRLElBQUksRUFBRTtRQUNyQixHQUFHLEVBQUUsUUFBUSxJQUFJLEVBQUU7UUFDbkIsWUFBWSxFQUFFLGtCQUFrQixJQUFJLEVBQUU7UUFDdEMsV0FBVyxFQUFFLG9CQUFvQixLQUFLLE1BQU07S0FDN0MsQ0FBQTtBQUNILENBQUM7QUFNRCxTQUFTLG1CQUFtQixDQUFDLEdBQVEsRUFB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QUEsTUFBQSxHQUFHLGFBQUgsR0FBRyx1QkFBSCxHQUFHLENBQUUsWUFBWSxvREFDdkg7d0JBQ0UsSUFBSSxFQUFFLG9CQUFvQjt3QkFDMUIsSUFBSSxFQUFFOzRCQUNKLFVBQVUsRUFBRSxhQUFhOzRCQUN6QixNQUFNLEVBQUU7Z0NBQ04sTUFBTSxFQUFFLGVBQWU7Z0NBQ3ZCLElBQUksRUFBRTtvQ0FDSixRQUFRLEVBQUUsTUFBTSxDQUFDLFFBQVE7b0NBQ3pCLElBQUksRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLE1BQU0sQ0FBQyxJQUFJLENBQUM7b0NBQ2pDLFdBQVcsRUFBRSxTQUFTO29DQUN0QixHQUFHLEVBQUUsTUFBTSxDQUFDLEdBQUc7aUNBQ2hCOzZCQUNGOzRCQUNELElBQUksRUFBRSxHQUFHO3lCQUNWO3FCQUNGLEVBQ0QsU0FBUyxFQUNULElBQUksQ0FDTCxDQUFBLEVBQUE7d0JBbkJpRyxXQUFBLFNBbUJqRyxFQUFBOzs7U0FBQSxDQUFBO0lBR0QsR0FBRyxDQUFDLFlBQVksR0FBRyxzQkFBWSxDQUFBO0FBQ2pDLENBQUMsQ0FBQTtBQTlKWSxRQUFBLFFBQVEsWUE4SnBCIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgRVJST1IgfSBmcm9tICcuL2NvbnN0YW50cydcbmltcG9ydCB7IGdldENsb3VkYmFzZUNvbnRleHQsIHBhcnNlQ29udGV4dCB9IGZyb20gJy4vY29udGV4dCdcbmltcG9ydCB7IHZhbGlkYXRlVWlkIH0gZnJvbSAnLi91dGlscydcbmltcG9ydCB0eXBlIHtcbiAgSUNyZWF0ZVRpY2tldE9wdHMsXG4gIElHZXRVc2VySW5mb1Jlc3VsdCxcbiAgSUdldEVuZFVzZXJJbmZvUmVzdWx0LFxuICBJVXNlckluZm9RdWVyeSxcbiAgSVRlbXBsYXRlTm90aWZ5UmVxLFxufSBmcm9tICcuL3R5cGVzJ1xuaW1wb3J0IHsgSUNsb3VkYmFzZUNvbmZpZyB9IGZyb20gJ0BjbG91ZGJhc2UvdHlwZXMnXG5cbi8vIOW7tui/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,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==