@cloudbase/oauth 2.6.3-beta.0 → 2.6.5-beta.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (68) hide show
  1. package/dist/cjs/auth/apis.d.ts +17 -8
  2. package/dist/cjs/auth/apis.js +166 -23
  3. package/dist/cjs/auth/consts.d.ts +39 -4
  4. package/dist/cjs/auth/consts.js +38 -3
  5. package/dist/cjs/auth/models.d.ts +83 -6
  6. package/dist/cjs/auth/models.js +1 -1
  7. package/dist/cjs/index.d.ts +5 -8
  8. package/dist/cjs/index.js +3 -17
  9. package/dist/cjs/oauth2client/consts.d.ts +1 -48
  10. package/dist/cjs/oauth2client/consts.js +4 -51
  11. package/dist/cjs/oauth2client/models.d.ts +1 -0
  12. package/dist/cjs/oauth2client/models.js +1 -1
  13. package/dist/cjs/oauth2client/oauth2client.d.ts +5 -0
  14. package/dist/cjs/oauth2client/oauth2client.js +24 -18
  15. package/dist/cjs/utils/base64.d.ts +4 -0
  16. package/dist/cjs/utils/base64.js +99 -0
  17. package/dist/cjs/utils/cloudbase-adapter-wx_mp.d.ts +1 -0
  18. package/dist/cjs/utils/cloudbase-adapter-wx_mp.js +40 -0
  19. package/dist/cjs/utils/encrypt.d.ts +2 -2
  20. package/dist/cjs/utils/encrypt.js +5 -5
  21. package/dist/cjs/utils/encryptlong/index.d.ts +537 -145
  22. package/dist/cjs/utils/encryptlong/index.js +2712 -3765
  23. package/dist/esm/auth/apis.d.ts +17 -8
  24. package/dist/esm/auth/apis.js +468 -722
  25. package/dist/esm/auth/consts.d.ts +39 -4
  26. package/dist/esm/auth/consts.js +37 -3
  27. package/dist/esm/auth/models.d.ts +83 -6
  28. package/dist/esm/auth/models.js +0 -1
  29. package/dist/esm/captcha/captcha.js +155 -258
  30. package/dist/esm/index.d.ts +5 -8
  31. package/dist/esm/index.js +17 -31
  32. package/dist/esm/oauth2client/consts.d.ts +1 -48
  33. package/dist/esm/oauth2client/consts.js +1 -50
  34. package/dist/esm/oauth2client/interface.js +2 -7
  35. package/dist/esm/oauth2client/models.d.ts +1 -0
  36. package/dist/esm/oauth2client/models.js +0 -1
  37. package/dist/esm/oauth2client/oauth2client.d.ts +5 -0
  38. package/dist/esm/oauth2client/oauth2client.js +365 -631
  39. package/dist/esm/utils/base64.d.ts +4 -0
  40. package/dist/esm/utils/base64.js +91 -0
  41. package/dist/esm/utils/cloudbase-adapter-wx_mp.d.ts +1 -0
  42. package/dist/esm/utils/cloudbase-adapter-wx_mp.js +35 -0
  43. package/dist/esm/utils/encrypt.d.ts +2 -2
  44. package/dist/esm/utils/encrypt.js +5 -7
  45. package/dist/esm/utils/encryptlong/index.d.ts +537 -145
  46. package/dist/esm/utils/encryptlong/index.js +2605 -3687
  47. package/dist/esm/utils/function/single-promise.js +26 -89
  48. package/dist/esm/utils/index.js +7 -8
  49. package/dist/esm/utils/mp.js +2 -3
  50. package/dist/esm/utils/uuid.js +3 -4
  51. package/dist/miniprogram/index.js +1 -0
  52. package/package.json +11 -6
  53. package/src/auth/apis.ts +179 -36
  54. package/src/auth/consts.ts +37 -3
  55. package/src/auth/models.ts +318 -234
  56. package/src/index.ts +5 -29
  57. package/src/oauth2client/consts.ts +1 -51
  58. package/src/oauth2client/models.ts +1 -0
  59. package/src/oauth2client/oauth2client.ts +31 -17
  60. package/src/utils/base64.ts +100 -0
  61. package/src/utils/cloudbase-adapter-wx_mp.ts +42 -0
  62. package/src/utils/encrypt.ts +8 -6
  63. package/src/utils/encryptlong/index.js +2843 -4895
  64. package/tsconfig.esm.json +8 -19
  65. package/tsconfig.json +5 -16
  66. package/webpack/web.prod.js +100 -0
  67. package/webpack/webpack.miniprogram.js +23 -0
  68. package/src/index.d.ts +0 -1
@@ -1,44 +1,8 @@
1
- var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
2
- function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
3
- return new (P || (P = Promise))(function (resolve, reject) {
4
- function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
5
- function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
6
- function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
7
- step((generator = generator.apply(thisArg, _arguments || [])).next());
8
- });
9
- };
10
- var __generator = (this && this.__generator) || function (thisArg, body) {
11
- var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
12
- return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
13
- function verb(n) { return function (v) { return step([n, v]); }; }
14
- function step(op) {
15
- if (f) throw new TypeError("Generator is already executing.");
16
- while (g && (g = 0, op[0] && (_ = 0)), _) try {
17
- 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;
18
- if (y = 0, t) op = [op[0] & 2, t.value];
19
- switch (op[0]) {
20
- case 0: case 1: t = op; break;
21
- case 4: _.label++; return { value: op[1], done: false };
22
- case 5: _.label++; y = op[1]; op = [0]; continue;
23
- case 7: op = _.ops.pop(); _.trys.pop(); continue;
24
- default:
25
- if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
26
- if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
27
- if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
28
- if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
29
- if (t[2]) _.ops.pop();
30
- _.trys.pop(); continue;
31
- }
32
- op = body.call(thisArg, _);
33
- } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
34
- if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
35
- }
36
- };
37
1
  import { ApiUrls, ErrorType } from '../auth/consts';
38
2
  import { defaultStorage } from '../oauth2client/oauth2client';
39
3
  import { isInMpWebView, isMp } from '../utils/mp';
40
- var Captcha = (function () {
41
- function Captcha(opts) {
4
+ export class Captcha {
5
+ constructor(opts) {
42
6
  if (!opts.openURIWithCallback) {
43
7
  opts.openURIWithCallback = this.getDefaultOpenURIWithCallback();
44
8
  }
@@ -46,240 +10,173 @@ var Captcha = (function () {
46
10
  opts.storage = defaultStorage;
47
11
  }
48
12
  this.config = opts;
49
- this.tokenSectionName = "captcha_".concat(opts.clientId);
13
+ this.tokenSectionName = `captcha_${opts.clientId}`;
50
14
  }
51
- Captcha.prototype.request = function (url, options) {
52
- return __awaiter(this, void 0, void 0, function () {
53
- var state, reqURL, resp, err_1;
54
- return __generator(this, function (_a) {
55
- switch (_a.label) {
56
- case 0:
57
- if (!options) {
58
- options = {};
59
- }
60
- if (!options.method) {
61
- options.method = 'GET';
62
- }
63
- state = "".concat(options.method, ":").concat(url);
64
- reqURL = url;
65
- if (!options.withCaptcha) return [3, 2];
66
- return [4, this.appendCaptchaTokenToURL(url, state, false)];
67
- case 1:
68
- reqURL = _a.sent();
69
- _a.label = 2;
70
- case 2:
71
- _a.trys.push([2, 4, , 7]);
72
- return [4, this.config.request(reqURL, options)];
73
- case 3:
74
- resp = _a.sent();
75
- return [3, 7];
76
- case 4:
77
- err_1 = _a.sent();
78
- if (!(err_1.error === ErrorType.CAPTCHA_REQUIRED || err_1.error === ErrorType.CAPTCHA_INVALID)) return [3, 6];
79
- return [4, this.appendCaptchaTokenToURL(url, state, err_1.error === ErrorType.CAPTCHA_INVALID)];
80
- case 5:
81
- url = _a.sent();
82
- return [2, this.config.request(url, options)];
83
- case 6: return [2, Promise.reject(err_1)];
84
- case 7: return [2, resp];
85
- }
86
- });
87
- });
88
- };
89
- Captcha.prototype.getDefaultOpenURIWithCallback = function () {
15
+ async request(url, options) {
16
+ if (!options) {
17
+ options = {};
18
+ }
19
+ if (!options.method) {
20
+ options.method = 'GET';
21
+ }
22
+ const state = `${options.method}:${url}`;
23
+ let reqURL = url;
24
+ if (options.withCaptcha) {
25
+ reqURL = await this.appendCaptchaTokenToURL(url, state, false);
26
+ }
27
+ let resp;
28
+ try {
29
+ resp = await this.config.request(reqURL, options);
30
+ }
31
+ catch (err) {
32
+ if (err.error === ErrorType.CAPTCHA_REQUIRED || err.error === ErrorType.CAPTCHA_INVALID) {
33
+ url = await this.appendCaptchaTokenToURL(url, state, err.error === ErrorType.CAPTCHA_INVALID);
34
+ return this.config.request(url, options);
35
+ }
36
+ return Promise.reject(err);
37
+ }
38
+ return resp;
39
+ }
40
+ getDefaultOpenURIWithCallback() {
90
41
  if (!isMp() && !isInMpWebView()) {
91
42
  if (window.location.search.indexOf('__captcha') > 0) {
92
43
  document.body.style.display = 'none';
93
44
  }
94
45
  if (document.getElementById('captcha_panel_wrap') === null) {
95
- var elementDiv_1 = document.createElement('div');
96
- elementDiv_1.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
97
- elementDiv_1.setAttribute('id', 'captcha_panel_wrap');
98
- setTimeout(function () {
99
- document.body.appendChild(elementDiv_1);
46
+ const elementDiv = document.createElement('div');
47
+ elementDiv.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
48
+ elementDiv.setAttribute('id', 'captcha_panel_wrap');
49
+ setTimeout(() => {
50
+ document.body.appendChild(elementDiv);
100
51
  }, 0);
101
52
  }
102
53
  }
103
54
  return this.defaultOpenURIWithCallback;
104
- };
105
- Captcha.prototype.defaultOpenURIWithCallback = function (url, opts) {
106
- return __awaiter(this, void 0, void 0, function () {
107
- var _a, _b, width, _c, height, matched, target, iframe;
108
- return __generator(this, function (_d) {
109
- _a = opts || {}, _b = _a.width, width = _b === void 0 ? '355px' : _b, _c = _a.height, height = _c === void 0 ? '355px' : _c;
110
- matched = url.match(/^(data:.*)$/);
111
- if (matched) {
112
- return [2, Promise.reject({
113
- error: ErrorType.UNIMPLEMENTED,
114
- error_description: 'need to impl captcha data',
115
- })];
116
- }
117
- target = document.getElementById('captcha_panel_wrap');
118
- iframe = document.createElement('iframe');
119
- target.innerHTML = '';
120
- iframe.setAttribute('src', url);
121
- iframe.setAttribute('id', 'review-panel-iframe');
122
- iframe.style.cssText = "min-width:".concat(width, ";display:block;height:").concat(height, ";margin:0 auto;background-color: rgb(255, 255, 255);border: none;");
123
- target.appendChild(iframe);
124
- target.style.display = 'block';
125
- return [2, new Promise(function (resolve, reject) {
126
- iframe.onload = function () {
127
- try {
128
- var windowLocation = window.location;
129
- var iframeLocation = iframe.contentWindow.location;
130
- if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {
131
- target.style.display = 'none';
132
- var iframeUrlParams = new URLSearchParams(iframeLocation.search);
133
- var captchToken = iframeUrlParams.get('captcha_token');
134
- if (captchToken) {
135
- return resolve({
136
- captcha_token: captchToken,
137
- expires_in: Number(iframeUrlParams.get('expires_in')),
138
- });
139
- }
140
- return reject({
141
- error: iframeUrlParams.get('error'),
142
- error_description: iframeUrlParams.get('error_description'),
143
- });
144
- }
145
- target.style.display = 'block';
146
- }
147
- catch (error) {
148
- target.style.display = 'block';
149
- }
150
- };
151
- })];
55
+ }
56
+ async defaultOpenURIWithCallback(url, opts) {
57
+ const { width = '355px', height = '355px' } = opts || {};
58
+ const matched = url.match(/^(data:.*)$/);
59
+ if (matched) {
60
+ return Promise.reject({
61
+ error: ErrorType.UNIMPLEMENTED,
62
+ error_description: 'need to impl captcha data',
152
63
  });
153
- });
154
- };
155
- Captcha.prototype.getCaptchaToken = function (forceNewToken, state) {
156
- return __awaiter(this, void 0, void 0, function () {
157
- var captchaToken_1, captchaTokenResp, redirect_uri, captchaToken_2, captchaDataResp, captchaToken;
158
- return __generator(this, function (_a) {
159
- switch (_a.label) {
160
- case 0:
161
- if (!!forceNewToken) return [3, 2];
162
- return [4, this.findCaptchaToken()];
163
- case 1:
164
- captchaToken_1 = _a.sent();
165
- if (captchaToken_1) {
166
- return [2, captchaToken_1];
167
- }
168
- _a.label = 2;
169
- case 2:
170
- if (!(!isMp() && !isInMpWebView())) return [3, 4];
171
- redirect_uri = "".concat(window.location.origin + window.location.pathname, "?__captcha=on");
172
- return [4, this.config.request(ApiUrls.GET_CAPTCHA_URL, {
173
- method: 'POST',
174
- body: {
175
- client_id: this.config.clientId,
176
- redirect_uri: redirect_uri,
177
- state: state,
178
- },
179
- withCredentials: false,
180
- })];
181
- case 3:
182
- captchaTokenResp = _a.sent();
183
- if (captchaTokenResp.captcha_token) {
184
- captchaToken_2 = {
185
- captcha_token: captchaTokenResp.captcha_token,
186
- expires_in: captchaTokenResp.expires_in,
187
- };
188
- this.saveCaptchaToken(captchaToken_2);
189
- return [2, captchaTokenResp.captcha_token];
64
+ }
65
+ const target = document.getElementById('captcha_panel_wrap');
66
+ const iframe = document.createElement('iframe');
67
+ target.innerHTML = '';
68
+ iframe.setAttribute('src', url);
69
+ iframe.setAttribute('id', 'review-panel-iframe');
70
+ iframe.style.cssText = `min-width:${width};display:block;height:${height};margin:0 auto;background-color: rgb(255, 255, 255);border: none;`;
71
+ target.appendChild(iframe);
72
+ target.style.display = 'block';
73
+ return new Promise((resolve, reject) => {
74
+ iframe.onload = function () {
75
+ try {
76
+ const windowLocation = window.location;
77
+ const iframeLocation = iframe.contentWindow.location;
78
+ if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {
79
+ target.style.display = 'none';
80
+ const iframeUrlParams = new URLSearchParams(iframeLocation.search);
81
+ const captchToken = iframeUrlParams.get('captcha_token');
82
+ if (captchToken) {
83
+ return resolve({
84
+ captcha_token: captchToken,
85
+ expires_in: Number(iframeUrlParams.get('expires_in')),
86
+ });
190
87
  }
191
- return [3, 6];
192
- case 4: return [4, this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
193
- method: 'POST',
194
- body: {
195
- state: state,
196
- redirect_uri: '',
197
- },
198
- withCredentials: false,
199
- })];
200
- case 5:
201
- captchaDataResp = _a.sent();
202
- captchaTokenResp = {
203
- url: "".concat(captchaDataResp.data, "?state=").concat(encodeURIComponent(state), "&token=").concat(encodeURIComponent(captchaDataResp.token)),
204
- };
205
- _a.label = 6;
206
- case 6: return [4, this.config.openURIWithCallback(captchaTokenResp.url)];
207
- case 7:
208
- captchaToken = _a.sent();
209
- this.saveCaptchaToken(captchaToken);
210
- return [2, captchaToken.captcha_token];
88
+ return reject({
89
+ error: iframeUrlParams.get('error'),
90
+ error_description: iframeUrlParams.get('error_description'),
91
+ });
92
+ }
93
+ target.style.display = 'block';
211
94
  }
212
- });
213
- });
214
- };
215
- Captcha.prototype.appendCaptchaTokenToURL = function (url, state, forceNewToken) {
216
- return __awaiter(this, void 0, void 0, function () {
217
- var captchaToken;
218
- return __generator(this, function (_a) {
219
- switch (_a.label) {
220
- case 0: return [4, this.getCaptchaToken(forceNewToken, state)];
221
- case 1:
222
- captchaToken = _a.sent();
223
- if (url.indexOf('?') > 0) {
224
- url += "&captcha_token=".concat(captchaToken);
225
- }
226
- else {
227
- url += "?captcha_token=".concat(captchaToken);
228
- }
229
- return [2, url];
95
+ catch (error) {
96
+ target.style.display = 'block';
230
97
  }
231
- });
98
+ };
232
99
  });
233
- };
234
- Captcha.prototype.saveCaptchaToken = function (token) {
235
- return __awaiter(this, void 0, void 0, function () {
236
- var tokenStr;
237
- return __generator(this, function (_a) {
238
- switch (_a.label) {
239
- case 0:
240
- token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
241
- tokenStr = JSON.stringify(token);
242
- return [4, this.config.storage.setItem(this.tokenSectionName, tokenStr)];
243
- case 1:
244
- _a.sent();
245
- return [2];
246
- }
100
+ }
101
+ async getCaptchaToken(forceNewToken, state) {
102
+ if (!forceNewToken) {
103
+ const captchaToken = await this.findCaptchaToken();
104
+ if (captchaToken) {
105
+ return captchaToken;
106
+ }
107
+ }
108
+ let captchaTokenResp;
109
+ if (!isMp() && !isInMpWebView()) {
110
+ const redirect_uri = `${window.location.origin + window.location.pathname}?__captcha=on`;
111
+ captchaTokenResp = await this.config.request(ApiUrls.GET_CAPTCHA_URL, {
112
+ method: 'POST',
113
+ body: {
114
+ client_id: this.config.clientId,
115
+ redirect_uri,
116
+ state,
117
+ },
118
+ withCredentials: false,
247
119
  });
248
- });
249
- };
250
- Captcha.prototype.findCaptchaToken = function () {
251
- return __awaiter(this, void 0, void 0, function () {
252
- var tokenStr, captchaToken, isExpired, error_1;
253
- return __generator(this, function (_a) {
254
- switch (_a.label) {
255
- case 0: return [4, this.config.storage.getItem(this.tokenSectionName)];
256
- case 1:
257
- tokenStr = _a.sent();
258
- if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
259
- _a.label = 2;
260
- case 2:
261
- _a.trys.push([2, 3, , 5]);
262
- captchaToken = JSON.parse(tokenStr);
263
- if (captchaToken === null || captchaToken === void 0 ? void 0 : captchaToken.expires_at) {
264
- captchaToken.expires_at = new Date(captchaToken.expires_at);
265
- }
266
- isExpired = captchaToken.expires_at < new Date();
267
- if (isExpired) {
268
- return [2, null];
269
- }
270
- return [2, captchaToken.captcha_token];
271
- case 3:
272
- error_1 = _a.sent();
273
- return [4, this.config.storage.removeItem(this.tokenSectionName)];
274
- case 4:
275
- _a.sent();
276
- return [2, null];
277
- case 5: return [2, null];
278
- }
120
+ if (captchaTokenResp.captcha_token) {
121
+ const captchaToken = {
122
+ captcha_token: captchaTokenResp.captcha_token,
123
+ expires_in: captchaTokenResp.expires_in,
124
+ };
125
+ this.saveCaptchaToken(captchaToken);
126
+ return captchaTokenResp.captcha_token;
127
+ }
128
+ }
129
+ else {
130
+ const captchaDataResp = await this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
131
+ method: 'POST',
132
+ body: {
133
+ state,
134
+ redirect_uri: '',
135
+ },
136
+ withCredentials: false,
279
137
  });
280
- });
281
- };
282
- return Captcha;
283
- }());
284
- export { Captcha };
285
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY2FwdGNoYS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9jYXB0Y2hhL2NhcHRjaGEudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUEsT0FBTyxFQUFFLE9BQU8sRUFBRSxTQUFTLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQTtBQUduRCxPQUFPLEVBQUUsY0FBYyxFQUFFLE1BQU0sOEJBQThCLENBQUE7QUFDN0QsT0FBTyxFQUFFLGFBQWEsRUFBRSxJQUFJLEVBQUUsTUFBTSxhQUFhLENBQUE7QUE0QmpEO0lBUUUsaUJBQVksSUFBb0I7UUFDOUIsSUFBSSxDQUFDLElBQUksQ0FBQyxtQkFBbUIsRUFBRTtZQUM3QixJQUFJLENBQUMsbUJBQW1CLEdBQUcsSUFBSSxDQUFDLDZCQUE2QixFQUFFLENBQUE7U0FDaEU7UUFDRCxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sRUFBRTtZQUNqQixJQUFJLENBQUMsT0FBTyxHQUFHLGNBQWMsQ0FBQTtTQUM5QjtRQUVELElBQUksQ0FBQyxNQUFNLEdBQUcsSUFBSSxDQUFBO1FBQ2xCLElBQUksQ0FBQyxnQkFBZ0IsR0FBRyxrQkFBVyxJQUFJLENBQUMsUUFBUSxDQUFFLENBQUE7SUFDcEQsQ0FBQztJQU9ZLHlCQUFPLEdBQXBCLFVBQXdCLEdBQVcsRUFBRSxPQUErQjs7Ozs7O3dCQUNsRSxJQUFJLENBQUMsT0FBTyxFQUFFOzRCQUNaLE9BQU8sR0FBRyxFQUFFLENBQUE7eUJBQ2I7d0JBQ0QsSUFBSSxDQUFDLE9BQU8sQ0FBQyxNQUFNLEVBQUU7NEJBQ25CLE9BQU8sQ0FBQyxNQUFNLEdBQUcsS0FBSyxDQUFBO3lCQUN2Qjt3QkFDSyxLQUFLLEdBQUcsVUFBRyxPQUFPLENBQUMsTUFBTSxjQUFJLEdBQUcsQ0FBRSxDQUFBO3dCQUNwQyxNQUFNLEdBQUcsR0FBRyxDQUFBOzZCQUNaLE9BQU8sQ0FBQyxXQUFXLEVBQW5CLGNBQW1CO3dCQUNaLFdBQU0sSUFBSSxDQUFDLHVCQUF1QixDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsS0FBSyxDQUFDLEVBQUE7O3dCQUE5RCxNQUFNLEdBQUcsU0FBcUQsQ0FBQTs7Ozt3QkFLdkQsV0FBTSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBSSxNQUFNLEVBQUUsT0FBTyxDQUFDLEVBQUE7O3dCQUFwRCxJQUFJLEdBQUcsU0FBNkMsQ0FBQTs7Ozs2QkFFaEQsQ0FBQSxLQUFHLENBQUMsS0FBSyxLQUFLLFNBQVMsQ0FBQyxnQkFBZ0IsSUFBSSxLQUFHLENBQUMsS0FBSyxLQUFLLFNBQVMsQ0FBQyxlQUFlLENBQUEsRUFBbkYsY0FBbUY7d0JBQy9FLFdBQU0sSUFBSSxDQUFDLHVCQUF1QixDQUFDLEdBQUcsRUFBRSxLQUFLLEVBQUUsS0FBRyxDQUFDLEtBQUssS0FBSyxTQUFTLENBQUMsZUFBZSxDQUFDLEVBQUE7O3dCQUE3RixHQUFHLEdBQUcsU0FBdUYsQ0FBQTt3QkFDN0YsV0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBSSxHQUFHLEVBQUUsT0FBTyxDQUFDLEVBQUE7NEJBRTdDLFdBQU8sT0FBTyxDQUFDLE1BQU0sQ0FBQyxLQUFHLENBQUMsRUFBQTs0QkFFNUIsV0FBTyxJQUFJLEVBQUE7Ozs7S0FDWjtJQUVPLCtDQUE2QixHQUFyQztRQUNFLElBQUksQ0FBQyxJQUFJLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxFQUFFO1lBQy9CLElBQUksTUFBTSxDQUFDLFFBQVEsQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFDLFdBQVcsQ0FBQyxHQUFHLENBQUMsRUFBRTtnQkFDbkQsUUFBUSxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE1BQU0sQ0FBQTthQUNyQztZQUNELElBQUksUUFBUSxDQUFDLGNBQWMsQ0FBQyxvQkFBb0IsQ0FBQyxLQUFLLElBQUksRUFBRTtnQkFDMUQsSUFBTSxZQUFVLEdBQUcsUUFBUSxDQUFDLGFBQWEsQ0FBQyxLQUFLLENBQUMsQ0FBQTtnQkFDaEQsWUFBVSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQVksOElBQThJLENBQUE7Z0JBQ2xMLFlBQVUsQ0FBQyxZQUFZLENBQUMsSUFBSSxFQUFFLG9CQUFvQixDQUFDLENBQUE7Z0JBQ25ELFVBQVUsQ0FBQztvQkFDVCxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxZQUFVLENBQUMsQ0FBQTtnQkFDdkMsQ0FBQyxFQUFFLENBQUMsQ0FBQyxDQUFBO2FBQ047U0FDRjtRQUNELE9BQU8sSUFBSSxDQUFDLDBCQUEwQixDQUFBO0lBQ3hDLENBQUM7SUFLYSw0Q0FBMEIsR0FBeEMsVUFDRSxHQUFXLEVBQ1gsSUFBMEM7Ozs7Z0JBRXBDLEtBQXdDLElBQUksSUFBSSxFQUFFLEVBQWhELGFBQWUsRUFBZixLQUFLLG1CQUFHLE9BQU8sS0FBQSxFQUFFLGNBQWdCLEVBQWhCLE1BQU0sbUJBQUcsT0FBTyxLQUFBLENBQWU7Z0JBRWxELE9BQU8sR0FBRyxHQUFHLENBQUMsS0FBSyxDQUFDLGFBQWEsQ0FBQyxDQUFBO2dCQUN4QyxJQUFJLE9BQU8sRUFBRTtvQkFDWCxXQUFPLE9BQU8sQ0FBQyxNQUFNLENBQUM7NEJBQ3BCLEtBQUssRUFBRSxTQUFTLENBQUMsYUFBYTs0QkFDOUIsaUJBQWlCLEVBQUUsMkJBQTJCO3lCQUMvQyxDQUFDLEVBQUE7aUJBQ0g7Z0JBRUssTUFBTSxHQUFHLFFBQVEsQ0FBQyxjQUFjLENBQUMsb0JBQW9CLENBQUMsQ0FBQTtnQkFDdEQsTUFBTSxHQUFHLFFBQVEsQ0FBQyxhQUFhLENBQUMsUUFBUSxDQUFDLENBQUE7Z0JBQy9DLE1BQU0sQ0FBQyxTQUFTLEdBQUcsRUFBRSxDQUFBO2dCQUVyQixNQUFNLENBQUMsWUFBWSxDQUFDLEtBQUssRUFBRSxHQUFHLENBQUMsQ0FBQTtnQkFDL0IsTUFBTSxDQUFDLFlBQVksQ0FBQyxJQUFJLEVBQUUscUJBQXFCLENBQUMsQ0FBQTtnQkFDaEQsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsb0JBQWEsS0FBSyxtQ0FBeUIsTUFBTSxzRUFBbUUsQ0FBQTtnQkFDM0ksTUFBTSxDQUFDLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQTtnQkFDMUIsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFBO2dCQUM5QixXQUFPLElBQUksT0FBTyxDQUFlLFVBQUMsT0FBTyxFQUFFLE1BQU07d0JBQy9DLE1BQU0sQ0FBQyxNQUFNLEdBQUc7NEJBQ2QsSUFBSTtnQ0FDRixJQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsUUFBUSxDQUFBO2dDQUN0QyxJQUFNLGNBQWMsR0FBRyxNQUFNLENBQUMsYUFBYSxDQUFDLFFBQVEsQ0FBQTtnQ0FDcEQsSUFBSSxjQUFjLENBQUMsSUFBSSxHQUFHLGNBQWMsQ0FBQyxRQUFRLEtBQUssY0FBYyxDQUFDLElBQUksR0FBRyxjQUFjLENBQUMsUUFBUSxFQUFFO29DQUNuRyxNQUFNLENBQUMsS0FBSyxDQUFDLE9BQU8sR0FBRyxNQUFNLENBQUE7b0NBQzdCLElBQU0sZUFBZSxHQUFHLElBQUksZUFBZSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQTtvQ0FDbEUsSUFBTSxXQUFXLEdBQUcsZUFBZSxDQUFDLEdBQUcsQ0FBQyxlQUFlLENBQUMsQ0FBQTtvQ0FDeEQsSUFBSSxXQUFXLEVBQUU7d0NBQ2YsT0FBTyxPQUFPLENBQUM7NENBQ2IsYUFBYSxFQUFFLFdBQVc7NENBQzFCLFVBQVUsRUFBRSxNQUFNLENBQUMsZUFBZSxDQUFDLEdBQUcsQ0FBQyxZQUFZLENBQUMsQ0FBQzt5Q0FDdEQsQ0FBQyxDQUFBO3FDQUNIO29DQUNELE9BQU8sTUFBTSxDQUFDO3dDQUNaLEtBQUssRUFBRSxlQUFlLENBQUMsR0FBRyxDQUFDLE9BQU8sQ0FBQzt3Q0FDbkMsaUJBQWlCLEVBQUUsZUFBZSxDQUFDLEdBQUcsQ0FBQyxtQkFBbUIsQ0FBQztxQ0FDNUQsQ0FBQyxDQUFBO2lDQUNIO2dDQUNELE1BQU0sQ0FBQyxLQUFLLENBQUMsT0FBTyxHQUFHLE9BQU8sQ0FBQTs2QkFDL0I7NEJBQUMsT0FBTyxLQUFLLEVBQUU7Z0NBQ2QsTUFBTSxDQUFDLEtBQUssQ0FBQyxPQUFPLEdBQUcsT0FBTyxDQUFBOzZCQUMvQjt3QkFDSCxDQUFDLENBQUE7b0JBQ0gsQ0FBQyxDQUFDLEVBQUE7OztLQUNIO0lBSWEsaUNBQWUsR0FBN0IsVUFBOEIsYUFBc0IsRUFBRSxLQUFhOzs7Ozs7NkJBQzdELENBQUMsYUFBYSxFQUFkLGNBQWM7d0JBRUssV0FBTSxJQUFJLENBQUMsZ0JBQWdCLEVBQUUsRUFBQTs7d0JBQTVDLGlCQUFlLFNBQTZCO3dCQUNsRCxJQUFJLGNBQVksRUFBRTs0QkFDaEIsV0FBTyxjQUFZLEVBQUE7eUJBQ3BCOzs7NkJBT0MsQ0FBQSxDQUFDLElBQUksRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUEsRUFBM0IsY0FBMkI7d0JBQ3ZCLFlBQVksR0FBRyxVQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsTUFBTSxHQUFHLE1BQU0sQ0FBQyxRQUFRLENBQUMsUUFBUSxrQkFBZSxDQUFBO3dCQUNyRSxXQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsT0FBTyxDQUFxQixPQUFPLENBQUMsZUFBZSxFQUFFO2dDQUN4RixNQUFNLEVBQUUsTUFBTTtnQ0FDZCxJQUFJLEVBQUU7b0NBQ0osU0FBUyxFQUFFLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUTtvQ0FDL0IsWUFBWSxjQUFBO29DQUNaLEtBQUssT0FBQTtpQ0FDTjtnQ0FDRCxlQUFlLEVBQUUsS0FBSzs2QkFDdkIsQ0FBQyxFQUFBOzt3QkFSRixnQkFBZ0IsR0FBRyxTQVFqQixDQUFBO3dCQUNGLElBQUksZ0JBQWdCLENBQUMsYUFBYSxFQUFFOzRCQUM1QixpQkFBZTtnQ0FDbkIsYUFBYSxFQUFFLGdCQUFnQixDQUFDLGFBQWE7Z0NBQzdDLFVBQVUsRUFBRSxnQkFBZ0IsQ0FBQyxVQUFVOzZCQUN4QyxDQUFBOzRCQUNELElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxjQUFZLENBQUMsQ0FBQTs0QkFDbkMsV0FBTyxnQkFBZ0IsQ0FBQyxhQUFhLEVBQUE7eUJBQ3RDOzs0QkFLdUIsV0FBTSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FLOUMsT0FBTyxDQUFDLGdCQUFnQixFQUFFOzRCQUMzQixNQUFNLEVBQUUsTUFBTTs0QkFDZCxJQUFJLEVBQUU7Z0NBQ0osS0FBSyxPQUFBO2dDQUNMLFlBQVksRUFBRSxFQUFFOzZCQUNqQjs0QkFDRCxlQUFlLEVBQUUsS0FBSzt5QkFDdkIsQ0FBQyxFQUFBOzt3QkFaSSxlQUFlLEdBQUcsU0FZdEI7d0JBQ0YsZ0JBQWdCLEdBQUc7NEJBQ2pCLEdBQUcsRUFBRSxVQUFHLGVBQWUsQ0FBQyxJQUFJLG9CQUFVLGtCQUFrQixDQUFDLEtBQUssQ0FBQyxvQkFBVSxrQkFBa0IsQ0FBQyxlQUFlLENBQUMsS0FBSyxDQUFFLENBQUU7eUJBQ3RILENBQUE7OzRCQUVrQixXQUFNLElBQUksQ0FBQyxNQUFNLENBQUMsbUJBQW1CLENBQUMsZ0JBQWdCLENBQUMsR0FBRyxDQUFDLEVBQUE7O3dCQUExRSxZQUFZLEdBQUcsU0FBMkQ7d0JBQ2hGLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxZQUFZLENBQUMsQ0FBQTt3QkFDbkMsV0FBTyxZQUFZLENBQUMsYUFBYSxFQUFBOzs7O0tBQ2xDO0lBRWEseUNBQXVCLEdBQXJDLFVBQXNDLEdBQVcsRUFBRSxLQUFhLEVBQUUsYUFBc0I7Ozs7OzRCQUNqRSxXQUFNLElBQUksQ0FBQyxlQUFlLENBQUMsYUFBYSxFQUFFLEtBQUssQ0FBQyxFQUFBOzt3QkFBL0QsWUFBWSxHQUFHLFNBQWdEO3dCQUNyRSxJQUFJLEdBQUcsQ0FBQyxPQUFPLENBQUMsR0FBRyxDQUFDLEdBQUcsQ0FBQyxFQUFFOzRCQUN4QixHQUFHLElBQUkseUJBQWtCLFlBQVksQ0FBRSxDQUFBO3lCQUN4Qzs2QkFBTTs0QkFDTCxHQUFHLElBQUkseUJBQWtCLFlBQVksQ0FBRSxDQUFBO3lCQUN4Qzt3QkFDRCxXQUFPLEdBQUcsRUFBQTs7OztLQUNYO0lBRWEsa0NBQWdCLEdBQTlCLFVBQStCLEtBQW1COzs7Ozs7d0JBQ2hELEtBQUssQ0FBQyxVQUFVLEdBQUcsSUFBSSxJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsRUFBRSxHQUFHLENBQUMsS0FBSyxDQUFDLFVBQVUsR0FBRyxFQUFFLENBQUMsR0FBRyxJQUFJLENBQUMsQ0FBQTt3QkFDbEUsUUFBUSxHQUFXLElBQUksQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLENBQUE7d0JBQzlDLFdBQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsRUFBRSxRQUFRLENBQUMsRUFBQTs7d0JBQWxFLFNBQWtFLENBQUE7Ozs7O0tBQ25FO0lBRWEsa0NBQWdCLEdBQTlCOzs7Ozs0QkFDMkIsV0FBTSxJQUFJLENBQUMsTUFBTSxDQUFDLE9BQU8sQ0FBQyxPQUFPLENBQUMsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEVBQUE7O3dCQUEzRSxRQUFRLEdBQVcsU0FBd0Q7NkJBQzdFLENBQUEsUUFBUSxLQUFLLFNBQVMsSUFBSSxRQUFRLEtBQUssSUFBSSxDQUFBLEVBQTNDLGNBQTJDOzs7O3dCQUVyQyxZQUFZLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxRQUFRLENBQUMsQ0FBQTt3QkFDekMsSUFBSSxZQUFZLGFBQVosWUFBWSx1QkFBWixZQUFZLENBQUUsVUFBVSxFQUFFOzRCQUM1QixZQUFZLENBQUMsVUFBVSxHQUFHLElBQUksSUFBSSxDQUFDLFlBQVksQ0FBQyxVQUFVLENBQUMsQ0FBQTt5QkFDNUQ7d0JBQ0ssU0FBUyxHQUFHLFlBQVksQ0FBQyxVQUFVLEdBQUcsSUFBSSxJQUFJLEVBQUUsQ0FBQTt3QkFDdEQsSUFBSSxTQUFTLEVBQUU7NEJBQ2IsV0FBTyxJQUFJLEVBQUE7eUJBQ1o7d0JBQ0QsV0FBTyxZQUFZLENBQUMsYUFBYSxFQUFBOzs7d0JBRWpDLFdBQU0sSUFBSSxDQUFDLE1BQU0sQ0FBQyxPQUFPLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxFQUFBOzt3QkFBM0QsU0FBMkQsQ0FBQTt3QkFDM0QsV0FBTyxJQUFJLEVBQUE7NEJBR2YsV0FBTyxJQUFJLEVBQUE7Ozs7S0FDWjtJQUNILGNBQUM7QUFBRCxDQUFDLEFBMU5ELElBME5DIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQXBpVXJscywgRXJyb3JUeXBlIH0gZnJvbSAnLi4vYXV0aC9jb25zdHMnXG5pbXBvcnQgeyBTaW1wbGVTdG9yYWdlLCBSZXF1ZXN0RnVuY3Rpb24gfSBmcm9tICcuLi9vYXV0aDJjbGllbnQvaW50ZXJmYWNlJ1xuaW1wb3J0IHsgQXV0aENsaWVudFJlcXVlc3RPcHRpb25zIH0gZnJvbSAnLi4vb2F1dGgyY2xpZW50L21vZGVscydcbmltcG9ydCB7IGRlZmF1bHRTdG9yYWdlIH0gZnJvbSAnLi4vb2F1dGgyY2xpZW50L29hdXRoMmNsaWVudCdcbmltcG9ydCB7IGlzSW5NcFdlYlZpZXcsIGlzTXAgfSBmcm9tICcuLi91dGlscy9tcCdcblxuZXhwb3J0IGludGVyZmFjZSBDYXB0Y2hhT3B0aW9ucyB7XG4gIGNsaWVudElkOiBzdHJpbmdcbiAgcmVxdWVzdDogUmVxdWVzdEZ1bmN0aW9uXG4gIHN0b3JhZ2U6IFNpbXBsZVN0b3JhZ2VcbiAgLy8g5omT5byA572R6aG15bm26YCa6L+HVVJM5Zue6LCD6I635Y+WIENhcHRjaGFUb2tlbu+8jOmSiOWvueS4jemAmueahOW5s+WPsO+8jOivpeWHveaVsOWPr+S7peiHquWumuS5ieWunueOsCwg6buY6K6k6ZuG5oiQ5rWP6KeI5Zmo56uv6K6k6K+BXG4gIG9wZW5VUklXaXRoQ2FsbGJhY2s/OiBPcGVuVVJJV2l0aENhbGxiYWNrRnVjdGlvblxufVxuXG50eXBlIE9wZW5VUklXaXRoQ2FsbGJhY2tGdWN0aW9uID0gKHVybDogc3RyaW5nKSA9PiBQcm9taXNlPENhcHRjaGFUb2tlbj5cblxuZXhwb3J0IGludGVyZmFjZSBDYXB0Y2hhVG9rZW4ge1xuICBjYXB0Y2hhX3Rva2VuOiBzdHJpbmdcbiAgZXhwaXJlc19pbjogbnVtYmVyXG4gIGV4cGlyZXNfYXQ/OiBEYXRlIHwgbnVsbFxufVxuXG5leHBvcnQgaW50ZXJmYWNlIENhcHRjaGFSZXF1ZXN0T3B0aW9ucyBleHRlbmRzIEF1dGhDbGllbnRSZXF1ZXN0T3B0aW9ucyB7XG4gIHdpdGhDYXB0Y2hhPzogYm9vbGVhblxufVxuXG5leHBvcnQgaW50ZXJmYWNlIEdldENhcHRjaGFSZXNwb25zZSB7XG4gIGNhcHRjaGFfdG9rZW4/OiBzdHJpbmdcbiAgZXhwaXJlc19pbj86IG51bWJlclxuICB1cmw/OiBzdHJpbmdcbn1cblxuZXhwb3J0IGNsYXNzIENhcHRjaGEge1xuICBwcml2YXRlIGNvbmZpZzogQ2FwdGNoYU9wdGlvbnNcbiAgcHJpdmF0ZSB0b2tlblNlY3Rpb25OYW1lOiBzdHJpbmdcblxuICAvKipcbiAgICogY29uc3RydWN0b3JcbiAgICogQHBhcmFtIHtDYXB0Y2hhT3B0aW9uc30gb3B0c1xuICAgKi9cbiAgY29uc3RydWN0b3Iob3B0czogQ2FwdGNoYU9wdGlvbnMpIHtcbiAgICBpZiAoIW9wdHMub3BlblVSSVdpdGhDYWxsYmFjaykge1xuICAgICAgb3B0cy5vcGVuVVJJV2l0aENhbGxiYWNrID0gdGhpcy5nZXREZWZhdWx0T3BlblVSSVdpdGhDYWxsYmFjaygpXG4gICAgfVxuICAgIGlmICghb3B0cy5zdG9yYWdlKSB7XG4gICAgICBvcHRzLnN0b3JhZ2UgPSBkZWZhdWx0U3RvcmFnZVxuICAgIH1cblxuICAgIHRoaXMuY29uZmlnID0gb3B0c1xuICAgIHRoaXMudG9rZW5TZWN0aW9uTmFtZSA9IGBjYXB0Y2hhXyR7b3B0cy5jbGllbnRJZH1gXG4gIH1cblxuICAvKipcbiAgICogcmVxdWVzdCBodHRwIGxpa2Ugc2ltcGxlIGZldGNoIGFwaSwgZXhwOnJlcXVlc3QoJy92MS91c2VyL21lJywge3dpdGhDcmVkZW50aWFsczp0cnVlfSlcbiAgICogQHBhcmFtIHtzdHJpbmd9IHVybFxuICAgKiBAcGFyYW0ge0F1dGhDbGllbnRSZXF1ZXN0T3B0aW9uc30gb3B0aW9uc1xuICAgKi9cbiAgcHVibGljIGFzeW5jIHJlcXVlc3Q8VD4odXJsOiBzdHJpbmcsIG9wdGlvbnM/OiBDYXB0Y2hhUmVxdWVzdE9wdGlvbnMpOiBQcm9taXNlPFQ+IHtcbiAgICBpZiAoIW9wdGlvbnMpIHtcbiAgICAgIG9wdGlvbnMgPSB7fVxuICAgIH1cbiAgICBpZiAoIW9wdGlvbnMubWV0aG9kKSB7XG4gICAgICBvcHRpb25zLm1ldGhvZCA9ICdHRVQnXG4gICAgfVxuICAgIGNvbnN0IHN0YXRlID0gYCR7b3B0aW9ucy5tZXRob2R9OiR7dXJsfWBcbiAgICBsZXQgcmVxVVJMID0gdXJsXG4gICAgaWYgKG9wdGlvbnMud2l0aENhcHRjaGEpIHtcbiAgICAgIHJlcVVSTCA9IGF3YWl0IHRoaXMuYXBwZW5kQ2FwdGNoYVRva2VuVG9VUkwodXJsLCBzdGF0ZSwgZmFsc2UpXG4gICAgfVxuXG4gICAgbGV0IHJlc3A6IFRcbiAgICB0cnkge1xuICAgICAgcmVzcCA9IGF3YWl0IHRoaXMuY29uZmlnLnJlcXVlc3Q8VD4ocmVxVVJMLCBvcHRpb25zKVxuICAgIH0gY2F0Y2ggKGVycikge1xuICAgICAgaWYgKGVyci5lcnJvciA9PT0gRXJyb3JUeXBlLkNBUFRDSEFfUkVRVUlSRUQgfHwgZXJyLmVycm9yID09PSBFcnJvclR5cGUuQ0FQVENIQV9JTlZBTElEKSB7XG4gICAgICAgIHVybCA9IGF3YWl0IHRoaXMuYXBwZW5kQ2FwdGNoYVRva2VuVG9VUkwodXJsLCBzdGF0ZSwgZXJyLmVycm9yID09PSBFcnJvclR5cGUuQ0FQVENIQV9JTlZBTElEKVxuICAgICAgICByZXR1cm4gdGhpcy5jb25maWcucmVxdWVzdDxUPih1cmwsIG9wdGlvbnMpXG4gICAgICB9XG4gICAgICByZXR1cm4gUHJvbWlzZS5yZWplY3QoZXJyKVxuICAgIH1cbiAgICByZXR1cm4gcmVzcFxuICB9XG5cbiAgcHJpdmF0ZSBnZXREZWZhdWx0T3BlblVSSVdpdGhDYWxsYmFjaygpOiBPcGVuVVJJV2l0aENhbGxiYWNrRnVjdGlvbiB7XG4gICAgaWYgKCFpc01wKCkgJiYgIWlzSW5NcFdlYlZpZXcoKSkge1xuICAgICAgaWYgKHdpbmRvdy5sb2NhdGlvbi5zZWFyY2guaW5kZXhPZignX19jYXB0Y2hhJykgPiAwKSB7XG4gICAgICAgIGRvY3VtZW50LmJvZHkuc3R5bGUuZGlzcGxheSA9ICdub25lJ1xuICAgICAgfVxuICAgICAgaWYgKGRvY3VtZW50LmdldEVsZW1lbnRCeUlkKCdjYXB0Y2hhX3BhbmVsX3dyYXAnKSA9PT0gbnVsbCkge1xuICAgICAgICBjb25zdCBlbGVtZW50RGl2ID0gZG9jdW1lbnQuY3JlYXRlRWxlbWVudCgnZGl2JylcbiAgICAgICAgZWxlbWVudERpdi5zdHlsZS5jc3NUZXh0ID0gICAgICAgICAgJ2JhY2tncm91bmQtY29sb3I6IHJnYmEoMCwgMCwgMCwgMC43KTtwb3NpdGlvbjogZml4ZWQ7bGVmdDogMHB4O3JpZ2h0OiAwcHg7dG9wOiAwcHg7Ym90dG9tOiAwcHg7cGFkZGluZzogOXZ3IDAgMCAwO2Rpc3BsYXk6IG5vbmU7ei1pbmRleDoxMDA7J1xuICAgICAgICBlbGVtZW50RGl2LnNldEF0dHJpYnV0ZSgnaWQnLCAnY2FwdGNoYV9wYW5lbF93cmFwJylcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgZG9jdW1lbnQuYm9keS5hcHBlbmRDaGlsZChlbGVtZW50RGl2KVxuICAgICAgICB9LCAwKVxuICAgICAgfVxuICAgIH1cbiAgICByZXR1cm4gdGhpcy5kZWZhdWx0T3BlblVSSVdpdGhDYWxsYmFja1xuICB9XG5cbiAgLyoqXG4gICAqIOm7mOiupOmAmui/h+a1j+iniOWZqOaJk+W8gOe9kemhteW5tuiOt+WPluWbnuiwg1xuICAgKi9cbiAgcHJpdmF0ZSBhc3luYyBkZWZhdWx0T3BlblVSSVdpdGhDYWxsYmFjayhcbiAgICB1cmw6IHN0cmluZyxcbiAgICBvcHRzPzogeyB3aWR0aD86IHN0cmluZzsgaGVpZ2h0Pzogc3RyaW5nIH0sXG4gICk6IFByb21pc2U8Q2FwdGNoYVRva2VuPiB7XG4gICAgY29uc3QgeyB3aWR0aCA9ICczNTVweCcsIGhlaWdodCA9ICczNTVweCcgfSA9IG9wdHMgfHwge31cblxuICAgIGNvbnN0IG1hdGNoZWQgPSB1cmwubWF0Y2goL14oZGF0YTouKikkLylcbiAgICBpZiAobWF0Y2hlZCkge1xuICAgICAgcmV0dXJuIFByb21pc2UucmVqZWN0KHtcbiAgICAgICAgZXJyb3I6IEVycm9yVHlwZS5VTklNUExFTUVOVEVELFxuICAgICAgICBlcnJvcl9kZXNjcmlwdGlvbjogJ25lZWQgdG8gaW1wbCBjYXB0Y2hhIGRhdGEnLFxuICAgICAgfSlcbiAgICB9XG5cbiAgICBjb25zdCB0YXJnZXQgPSBkb2N1bWVudC5nZXRFbGVtZW50QnlJZCgnY2FwdGNoYV9wYW5lbF93cmFwJylcbiAgICBjb25zdCBpZnJhbWUgPSBkb2N1bWVudC5jcmVhdGVFbGVtZW50KCdpZnJhbWUnKVxuICAgIHRhcmdldC5pbm5lckhUTUwgPSAnJ1xuXG4gICAgaWZyYW1lLnNldEF0dHJpYnV0ZSgnc3JjJywgdXJsKVxuICAgIGlmcmFtZS5zZXRBdHRyaWJ1dGUoJ2lkJywgJ3Jldmlldy1wYW5lbC1pZnJhbWUnKVxuICAgIGlmcmFtZS5zdHlsZS5jc3NUZXh0ID0gYG1pbi13aWR0aDoke3dpZHRofTtkaXNwbGF5OmJsb2NrO2hlaWdodDoke2hlaWdodH07bWFyZ2luOjAgYXV0bztiYWNrZ3JvdW5kLWNvbG9yOiByZ2IoMjU1LCAyNTUsIDI1NSk7Ym9yZGVyOiBub25lO2BcbiAgICB0YXJnZXQuYXBwZW5kQ2hpbGQoaWZyYW1lKVxuICAgIHRhcmdldC5zdHlsZS5kaXNwbGF5ID0gJ2Jsb2NrJ1xuICAgIHJldHVybiBuZXcgUHJvbWlzZTxDYXB0Y2hhVG9rZW4+KChyZXNvbHZlLCByZWplY3QpID0+IHtcbiAgICAgIGlmcmFtZS5vbmxvYWQgPSBmdW5jdGlvbiAoKSB7XG4gICAgICAgIHRyeSB7XG4gICAgICAgICAgY29uc3Qgd2luZG93TG9jYXRpb24gPSB3aW5kb3cubG9jYXRpb25cbiAgICAgICAgICBjb25zdCBpZnJhbWVMb2NhdGlvbiA9IGlmcmFtZS5jb250ZW50V2luZG93LmxvY2F0aW9uXG4gICAgICAgICAgaWYgKGlmcmFtZUxvY2F0aW9uLmhvc3QgKyBpZnJhbWVMb2NhdGlvbi5wYXRobmFtZSA9PT0gd2luZG93TG9jYXRpb24uaG9zdCArIHdpbmRvd0xvY2F0aW9uLnBhdGhuYW1lKSB7XG4gICAgICAgICAgICB0YXJnZXQuc3R5bGUuZGlzcGxheSA9ICdub25lJ1xuICAgICAgICAgICAgY29uc3QgaWZyYW1lVXJsUGFyYW1zID0gbmV3IFVSTFNlYXJjaFBhcmFtcyhpZnJhbWVMb2NhdGlvbi5zZWFyY2gpXG4gICAgICAgICAgICBjb25zdCBjYXB0Y2hUb2tlbiA9IGlmcmFtZVVybFBhcmFtcy5nZXQoJ2NhcHRjaGFfdG9rZW4nKVxuICAgICAgICAgICAgaWYgKGNhcHRjaFRva2VuKSB7XG4gICAgICAgICAgICAgIHJldHVybiByZXNvbHZlKHtcbiAgICAgICAgICAgICAgICBjYXB0Y2hhX3Rva2VuOiBjYXB0Y2hUb2tlbixcbiAgICAgICAgICAgICAgICBleHBpcmVzX2luOiBOdW1iZXIoaWZyYW1lVXJsUGFyYW1zLmdldCgnZXhwaXJlc19pbicpKSxcbiAgICAgICAgICAgICAgfSlcbiAgICAgICAgICAgIH1cbiAgICAgICAgICAgIHJldHVybiByZWplY3Qoe1xuICAgICAgICAgICAgICBlcnJvcjogaWZyYW1lVXJsUGFyYW1zLmdldCgnZXJyb3InKSxcbiAgICAgICAgICAgICAgZXJyb3JfZGVzY3JpcHRpb246IGlmcmFtZVVybFBhcmFtcy5nZXQoJ2Vycm9yX2Rlc2NyaXB0aW9uJyksXG4gICAgICAgICAgICB9KVxuICAgICAgICAgIH1cbiAgICAgICAgICB0YXJnZXQuc3R5bGUuZGlzcGxheSA9ICdibG9jaydcbiAgICAgICAgfSBjYXRjaCAoZXJyb3IpIHtcbiAgICAgICAgICB0YXJnZXQuc3R5bGUuZGlzcGxheSA9ICdibG9jaydcbiAgICAgICAgfVxuICAgICAgfVxuICAgIH0pXG4gIH1cbiAgLyoqXG4gICAqIGdldENhcHRjaGFUb2tlbiDojrflj5ZjYXB0Y2hhVG9rZW5cbiAgICovXG4gIHByaXZhdGUgYXN5bmMgZ2V0Q2FwdGNoYVRva2VuKGZvcmNlTmV3VG9rZW46IGJvb2xlYW4sIHN0YXRlOiBzdHJpbmcpOiBQcm9taXNlPHN0cmluZz4ge1xuICAgIGlmICghZm9yY2VOZXdUb2tlbikge1xuICAgICAgLy8g5aaC5p6c5pys5Zyw5a2Y5Zyo77yM5YiZ55u05o6l6L+U5ZueXG4gICAgICBjb25zdCBjYXB0Y2hhVG9rZW4gPSBhd2FpdCB0aGlzLmZpbmRDYXB0Y2hhVG9rZW4oKVxuICAgICAgaWYgKGNhcHRjaGFUb2tlbikge1xuICAgICAgICByZXR1cm4gY2FwdGNoYVRva2VuXG4gICAgICB9XG4gICAgfVxuICAgIGxldCBjYXB0Y2hhVG9rZW5SZXNwOiB7XG4gICAgICB1cmw/OiBzdHJpbmdcbiAgICAgIGNhcHRjaGFfdG9rZW4/OiBzdHJpbmdcbiAgICAgIGV4cGlyZXNfaW4/OiBudW1iZXJcbiAgICB9XG4gICAgaWYgKCFpc01wKCkgJiYgIWlzSW5NcFdlYlZpZXcoKSkge1xuICAgICAgY29uc3QgcmVkaXJlY3RfdXJpID0gYCR7d2luZG93LmxvY2F0aW9uLm9yaWdpbiArIHdpbmRvdy5sb2NhdGlvbi5wYXRobmFtZX0/X19jYXB0Y2hhPW9uYFxuICAgICAgY2FwdGNoYVRva2VuUmVzcCA9IGF3YWl0IHRoaXMuY29uZmlnLnJlcXVlc3Q8R2V0Q2FwdGNoYVJlc3BvbnNlPihBcGlVcmxzLkdFVF9DQVBUQ0hBX1VSTCwge1xuICAgICAgICBtZXRob2Q6ICdQT1NUJyxcbiAgICAgICAgYm9keToge1xuICAgICAgICAgIGNsaWVudF9pZDogdGhpcy5jb25maWcuY2xpZW50SWQsXG4gICAgICAgICAgcmVkaXJlY3RfdXJpLFxuICAgICAgICAgIHN0YXRlLFxuICAgICAgICB9LFxuICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IGZhbHNlLFxuICAgICAgfSlcbiAgICAgIGlmIChjYXB0Y2hhVG9rZW5SZXNwLmNhcHRjaGFfdG9rZW4pIHtcbiAgICAgICAgY29uc3QgY2FwdGNoYVRva2VuID0ge1xuICAgICAgICAgIGNhcHRjaGFfdG9rZW46IGNhcHRjaGFUb2tlblJlc3AuY2FwdGNoYV90b2tlbixcbiAgICAgICAgICBleHBpcmVzX2luOiBjYXB0Y2hhVG9rZW5SZXNwLmV4cGlyZXNfaW4sXG4gICAgICAgIH1cbiAgICAgICAgdGhpcy5zYXZlQ2FwdGNoYVRva2VuKGNhcHRjaGFUb2tlbilcbiAgICAgICAgcmV0dXJuIGNhcHRjaGFUb2tlblJlc3AuY2FwdGNoYV90b2tlblxuICAgICAgfVxuICAgIH0gZWxzZSB7XG4gICAgICAvKipcbiAgICAgICAqIGh0dHBzOi8vaXdpa2kud29hLmNvbS9wLzQwMTA2OTk0MTdcbiAgICAgICAqL1xuICAgICAgY29uc3QgY2FwdGNoYURhdGFSZXNwID0gYXdhaXQgdGhpcy5jb25maWcucmVxdWVzdDx7XG4gICAgICAgIGRhdGE6IHN0cmluZ1xuICAgICAgICB0eXBlOiAnaW1hZ2UnXG4gICAgICAgIHRva2VuOiBzdHJpbmdcbiAgICAgICAgZXhwaXJlc19pbjogbnVtYmVyXG4gICAgICB9PihBcGlVcmxzLkNBUFRDSEFfREFUQV9VUkwsIHtcbiAgICAgICAgbWV0aG9kOiAnUE9TVCcsXG4gICAgICAgIGJvZHk6IHtcbiAgICAgICAgICBzdGF0ZSxcbiAgICAgICAgICByZWRpcmVjdF91cmk6ICcnLFxuICAgICAgICB9LFxuICAgICAgICB3aXRoQ3JlZGVudGlhbHM6IGZhbHNlLFxuICAgICAgfSlcbiAgICAgIGNhcHRjaGFUb2tlblJlc3AgPSB7XG4gICAgICAgIHVybDogYCR7Y2FwdGNoYURhdGFSZXNwLmRhdGF9P3N0YXRlPSR7ZW5jb2RlVVJJQ29tcG9uZW50KHN0YXRlKX0mdG9rZW49JHtlbmNvZGVVUklDb21wb25lbnQoY2FwdGNoYURhdGFSZXNwLnRva2VuLCl9YCxcbiAgICAgIH1cbiAgICB9XG4gICAgY29uc3QgY2FwdGNoYVRva2VuID0gYXdhaXQgdGhpcy5jb25maWcub3BlblVSSVdpdGhDYWxsYmFjayhjYXB0Y2hhVG9rZW5SZXNwLnVybClcbiAgICB0aGlzLnNhdmVDYXB0Y2hhVG9rZW4oY2FwdGNoYVRva2VuKVxuICAgIHJldHVybiBjYXB0Y2hhVG9rZW4uY2FwdGNoYV90b2tlblxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBhcHBlbmRDYXB0Y2hhVG9rZW5Ub1VSTCh1cmw6IHN0cmluZywgc3RhdGU6IHN0cmluZywgZm9yY2VOZXdUb2tlbjogYm9vbGVhbik6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgY29uc3QgY2FwdGNoYVRva2VuID0gYXdhaXQgdGhpcy5nZXRDYXB0Y2hhVG9rZW4oZm9yY2VOZXdUb2tlbiwgc3RhdGUpXG4gICAgaWYgKHVybC5pbmRleE9mKCc/JykgPiAwKSB7XG4gICAgICB1cmwgKz0gYCZjYXB0Y2hhX3Rva2VuPSR7Y2FwdGNoYVRva2VufWBcbiAgICB9IGVsc2Uge1xuICAgICAgdXJsICs9IGA/Y2FwdGNoYV90b2tlbj0ke2NhcHRjaGFUb2tlbn1gXG4gICAgfVxuICAgIHJldHVybiB1cmxcbiAgfVxuXG4gIHByaXZhdGUgYXN5bmMgc2F2ZUNhcHRjaGFUb2tlbih0b2tlbjogQ2FwdGNoYVRva2VuKSB7XG4gICAgdG9rZW4uZXhwaXJlc19hdCA9IG5ldyBEYXRlKERhdGUubm93KCkgKyAodG9rZW4uZXhwaXJlc19pbiAtIDEwKSAqIDEwMDApXG4gICAgY29uc3QgdG9rZW5TdHI6IHN0cmluZyA9IEpTT04uc3RyaW5naWZ5KHRva2VuKVxuICAgIGF3YWl0IHRoaXMuY29uZmlnLnN0b3JhZ2Uuc2V0SXRlbSh0aGlzLnRva2VuU2VjdGlvbk5hbWUsIHRva2VuU3RyKVxuICB9XG5cbiAgcHJpdmF0ZSBhc3luYyBmaW5kQ2FwdGNoYVRva2VuKCk6IFByb21pc2U8c3RyaW5nPiB7XG4gICAgY29uc3QgdG9rZW5TdHI6IHN0cmluZyA9IGF3YWl0IHRoaXMuY29uZmlnLnN0b3JhZ2UuZ2V0SXRlbSh0aGlzLnRva2VuU2VjdGlvbk5hbWUpXG4gICAgaWYgKHRva2VuU3RyICE9PSB1bmRlZmluZWQgJiYgdG9rZW5TdHIgIT09IG51bGwpIHtcbiAgICAgIHRyeSB7XG4gICAgICAgIGNvbnN0IGNhcHRjaGFUb2tlbiA9IEpTT04ucGFyc2UodG9rZW5TdHIpXG4gICAgICAgIGlmIChjYXB0Y2hhVG9rZW4/LmV4cGlyZXNfYXQpIHtcbiAgICAgICAgICBjYXB0Y2hhVG9rZW4uZXhwaXJlc19hdCA9IG5ldyBEYXRlKGNhcHRjaGFUb2tlbi5leHBpcmVzX2F0KVxuICAgICAgICB9XG4gICAgICAgIGNvbnN0IGlzRXhwaXJlZCA9IGNhcHRjaGFUb2tlbi5leHBpcmVzX2F0IDwgbmV3IERhdGUoKVxuICAgICAgICBpZiAoaXNFeHBpcmVkKSB7XG4gICAgICAgICAgcmV0dXJuIG51bGxcbiAgICAgICAgfVxuICAgICAgICByZXR1cm4gY2FwdGNoYVRva2VuLmNhcHRjaGFfdG9rZW5cbiAgICAgIH0gY2F0Y2ggKGVycm9yKSB7XG4gICAgICAgIGF3YWl0IHRoaXMuY29uZmlnLnN0b3JhZ2UucmVtb3ZlSXRlbSh0aGlzLnRva2VuU2VjdGlvbk5hbWUpXG4gICAgICAgIHJldHVybiBudWxsXG4gICAgICB9XG4gICAgfVxuICAgIHJldHVybiBudWxsXG4gIH1cbn1cbiJdfQ==
138
+ captchaTokenResp = {
139
+ url: `${captchaDataResp.data}?state=${encodeURIComponent(state)}&token=${encodeURIComponent(captchaDataResp.token)}`,
140
+ };
141
+ }
142
+ const captchaToken = await this.config.openURIWithCallback(captchaTokenResp.url);
143
+ this.saveCaptchaToken(captchaToken);
144
+ return captchaToken.captcha_token;
145
+ }
146
+ async appendCaptchaTokenToURL(url, state, forceNewToken) {
147
+ const captchaToken = await this.getCaptchaToken(forceNewToken, state);
148
+ if (url.indexOf('?') > 0) {
149
+ url += `&captcha_token=${captchaToken}`;
150
+ }
151
+ else {
152
+ url += `?captcha_token=${captchaToken}`;
153
+ }
154
+ return url;
155
+ }
156
+ async saveCaptchaToken(token) {
157
+ token.expires_at = new Date(Date.now() + (token.expires_in - 10) * 1000);
158
+ const tokenStr = JSON.stringify(token);
159
+ await this.config.storage.setItem(this.tokenSectionName, tokenStr);
160
+ }
161
+ async findCaptchaToken() {
162
+ const tokenStr = await this.config.storage.getItem(this.tokenSectionName);
163
+ if (tokenStr !== undefined && tokenStr !== null) {
164
+ try {
165
+ const captchaToken = JSON.parse(tokenStr);
166
+ if (captchaToken?.expires_at) {
167
+ captchaToken.expires_at = new Date(captchaToken.expires_at);
168
+ }
169
+ const isExpired = captchaToken.expires_at < new Date();
170
+ if (isExpired) {
171
+ return null;
172
+ }
173
+ return captchaToken.captcha_token;
174
+ }
175
+ catch (error) {
176
+ await this.config.storage.removeItem(this.tokenSectionName);
177
+ return null;
178
+ }
179
+ }
180
+ return null;
181
+ }
182
+ }
@@ -1,13 +1,10 @@
1
1
  import { OAuth2Client } from './oauth2client/oauth2client';
2
2
  import { AuthOptions, Auth } from './auth/apis';
3
- import * as authModels from './auth/models';
4
- export { Syntax, ErrorType } from './oauth2client/consts';
5
- export { defaultStorage, defaultRequest, ToResponseErrorOptions, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
6
- export { AuthClient, SimpleStorage } from './oauth2client/interface';
7
- export { Credentials, ResponseError, OAuth2ClientOptions, AuthClientRequestOptions, } from './oauth2client/models';
8
- export { AuthOptions, Auth } from './auth/apis';
9
- export { authModels };
10
- export { ApiUrls } from './auth/consts';
3
+ export { Auth } from './auth/apis';
4
+ export * as authModels from './auth/models';
5
+ export type { ProviderProfile } from './auth/models';
6
+ export type { Credentials, OAuth2ClientOptions, ResponseError, AuthClientRequestOptions } from './oauth2client/models';
7
+ export type { AuthOptions } from './auth/apis';
11
8
  export declare class CloudbaseOAuth {
12
9
  oauth2client: OAuth2Client;
13
10
  authApi: Auth;
package/dist/esm/index.js CHANGED
@@ -1,38 +1,24 @@
1
- var __assign = (this && this.__assign) || function () {
2
- __assign = Object.assign || function(t) {
3
- for (var s, i = 1, n = arguments.length; i < n; i++) {
4
- s = arguments[i];
5
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
6
- t[p] = s[p];
7
- }
8
- return t;
9
- };
10
- return __assign.apply(this, arguments);
11
- };
12
1
  import { OAuth2Client } from './oauth2client/oauth2client';
13
2
  import { Auth } from './auth/apis';
14
- import * as authModels from './auth/models';
15
- export { Syntax, ErrorType } from './oauth2client/consts';
16
- export { defaultStorage, defaultRequest, toResponseError, generateRequestId, OAuth2Client, } from './oauth2client/oauth2client';
17
- export { AuthClient } from './oauth2client/interface';
18
3
  export { Auth } from './auth/apis';
19
- export { authModels };
20
- export { ApiUrls } from './auth/consts';
21
- var CloudbaseOAuth = (function () {
22
- function CloudbaseOAuth(authOptions) {
23
- var apiOrigin = authOptions.apiOrigin, clientId = authOptions.clientId, env = authOptions.env, storage = authOptions.storage, request = authOptions.request, baseRequest = authOptions.baseRequest, anonymousSignInFunc = authOptions.anonymousSignInFunc, wxCloud = authOptions.wxCloud;
4
+ import * as authModels_1 from './auth/models';
5
+ export { authModels_1 as authModels };
6
+ export class CloudbaseOAuth {
7
+ constructor(authOptions) {
8
+ const { apiOrigin, clientId, env, storage, request, baseRequest, anonymousSignInFunc, wxCloud } = authOptions;
24
9
  this.oauth2client = new OAuth2Client({
25
- apiOrigin: apiOrigin,
26
- clientId: clientId,
27
- env: env,
28
- storage: storage,
10
+ apiOrigin,
11
+ clientId,
12
+ env,
13
+ storage,
29
14
  baseRequest: baseRequest || request,
30
- anonymousSignInFunc: anonymousSignInFunc,
31
- wxCloud: wxCloud,
15
+ anonymousSignInFunc,
16
+ wxCloud,
17
+ });
18
+ this.authApi = new Auth({
19
+ credentialsClient: this.oauth2client,
20
+ ...authOptions,
21
+ request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined,
32
22
  });
33
- this.authApi = new Auth(__assign(__assign({ credentialsClient: this.oauth2client }, authOptions), { request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined }));
34
23
  }
35
- return CloudbaseOAuth;
36
- }());
37
- export { CloudbaseOAuth };
38
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7QUFBQSxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sNkJBQTZCLENBQUE7QUFFMUQsT0FBTyxFQUFlLElBQUksRUFBRSxNQUFNLGFBQWEsQ0FBQTtBQUUvQyxPQUFPLEtBQUssVUFBVSxNQUFNLGVBQWUsQ0FBQTtBQUUzQyxPQUFPLEVBQUUsTUFBTSxFQUFFLFNBQVMsRUFBRSxNQUFNLHVCQUF1QixDQUFBO0FBRXpELE9BQU8sRUFDTCxjQUFjLEVBQ2QsY0FBYyxFQUVkLGVBQWUsRUFDZixpQkFBaUIsRUFDakIsWUFBWSxHQUNiLE1BQU0sNkJBQTZCLENBQUE7QUFFcEMsT0FBTyxFQUFFLFVBQVUsRUFBaUIsTUFBTSwwQkFBMEIsQ0FBQTtBQVNwRSxPQUFPLEVBQWUsSUFBSSxFQUFFLE1BQU0sYUFBYSxDQUFBO0FBQy9DLE9BQU8sRUFBRSxVQUFVLEVBQUUsQ0FBQTtBQUNyQixPQUFPLEVBQUcsT0FBTyxFQUFFLE1BQU0sZUFBZSxDQUFBO0FBR3hDO0lBSUUsd0JBQVksV0FBd0I7UUFDMUIsSUFBQSxTQUFTLEdBQWlGLFdBQVcsVUFBNUYsRUFBRSxRQUFRLEdBQXVFLFdBQVcsU0FBbEYsRUFBRSxHQUFHLEdBQWtFLFdBQVcsSUFBN0UsRUFBRSxPQUFPLEdBQXlELFdBQVcsUUFBcEUsRUFBRSxPQUFPLEdBQWdELFdBQVcsUUFBM0QsRUFBRSxXQUFXLEdBQW1DLFdBQVcsWUFBOUMsRUFBRSxtQkFBbUIsR0FBYyxXQUFXLG9CQUF6QixFQUFFLE9BQU8sR0FBSyxXQUFXLFFBQWhCLENBQWdCO1FBQzdHLElBQUksQ0FBQyxZQUFZLEdBQUcsSUFBSSxZQUFZLENBQUM7WUFDbkMsU0FBUyxXQUFBO1lBQ1QsUUFBUSxVQUFBO1lBQ1IsR0FBRyxLQUFBO1lBQ0gsT0FBTyxTQUFBO1lBQ1AsV0FBVyxFQUFFLFdBQVcsSUFBSSxPQUFPO1lBQ25DLG1CQUFtQixxQkFBQTtZQUNuQixPQUFPLFNBQUE7U0FDUixDQUFDLENBQUE7UUFFRixJQUFJLENBQUMsT0FBTyxHQUFHLElBQUksSUFBSSxxQkFDckIsaUJBQWlCLEVBQUUsSUFBSSxDQUFDLFlBQVksSUFDakMsV0FBVyxLQUVkLE9BQU8sRUFBRSxPQUFPLENBQUMsQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLENBQUMsT0FBTyxDQUFDLElBQUksQ0FBQyxJQUFJLENBQUMsWUFBWSxDQUFDLENBQUMsQ0FBQyxDQUFDLFNBQVMsSUFDaEYsQ0FBQTtJQUNKLENBQUM7SUFDSCxxQkFBQztBQUFELENBQUMsQUF2QkQsSUF1QkMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBPQXV0aDJDbGllbnQgfSBmcm9tICcuL29hdXRoMmNsaWVudC9vYXV0aDJjbGllbnQnXG5cbmltcG9ydCB7IEF1dGhPcHRpb25zLCBBdXRoIH0gZnJvbSAnLi9hdXRoL2FwaXMnXG5cbmltcG9ydCAqIGFzIGF1dGhNb2RlbHMgZnJvbSAnLi9hdXRoL21vZGVscydcblxuZXhwb3J0IHsgU3ludGF4LCBFcnJvclR5cGUgfSBmcm9tICcuL29hdXRoMmNsaWVudC9jb25zdHMnXG5cbmV4cG9ydCB7XG4gIGRlZmF1bHRTdG9yYWdlLFxuICBkZWZhdWx0UmVxdWVzdCxcbiAgVG9SZXNwb25zZUVycm9yT3B0aW9ucyxcbiAgdG9SZXNwb25zZUVycm9yLFxuICBnZW5lcmF0ZVJlcXVlc3RJZCxcbiAgT0F1dGgyQ2xpZW50LFxufSBmcm9tICcuL29hdXRoMmNsaWVudC9vYXV0aDJjbGllbnQnXG5cbmV4cG9ydCB7IEF1dGhDbGllbnQsIFNpbXBsZVN0b3JhZ2UgfSBmcm9tICcuL29hdXRoMmNsaWVudC9pbnRlcmZhY2UnXG5cbmV4cG9ydCB7XG4gIENyZWRlbnRpYWxzLFxuICBSZXNwb25zZUVycm9yLFxuICBPQXV0aDJDbGllbnRPcHRpb25zLFxuICBBdXRoQ2xpZW50UmVxdWVzdE9wdGlvbnMsXG59IGZyb20gJy4vb2F1dGgyY2xpZW50L21vZGVscydcblxuZXhwb3J0IHsgQXV0aE9wdGlvbnMsIEF1dGggfSBmcm9tICcuL2F1dGgvYXBpcydcbmV4cG9ydCB7IGF1dGhNb2RlbHMgfVxuZXhwb3J0IHsgIEFwaVVybHMgfSBmcm9tICcuL2F1dGgvY29uc3RzJ1xuXG5cbmV4cG9ydCBjbGFzcyBDbG91ZGJhc2VPQXV0aCB7XG4gIHB1YmxpYyBvYXV0aDJjbGllbnQ6IE9BdXRoMkNsaWVudFxuICBwdWJsaWMgYXV0aEFwaTogQXV0aFxuXG4gIGNvbnN0cnVjdG9yKGF1dGhPcHRpb25zOiBBdXRoT3B0aW9ucykge1xuICAgIGNvbnN0IHsgYXBpT3JpZ2luLCBjbGllbnRJZCwgZW52LCBzdG9yYWdlLCByZXF1ZXN0LCBiYXNlUmVxdWVzdCwgYW5vbnltb3VzU2lnbkluRnVuYywgd3hDbG91ZCB9ID0gYXV0aE9wdGlvbnNcbiAgICB0aGlzLm9hdXRoMmNsaWVudCA9IG5ldyBPQXV0aDJDbGllbnQoe1xuICAgICAgYXBpT3JpZ2luLFxuICAgICAgY2xpZW50SWQsXG4gICAgICBlbnYsXG4gICAgICBzdG9yYWdlLFxuICAgICAgYmFzZVJlcXVlc3Q6IGJhc2VSZXF1ZXN0IHx8IHJlcXVlc3QsXG4gICAgICBhbm9ueW1vdXNTaWduSW5GdW5jLFxuICAgICAgd3hDbG91ZCxcbiAgICB9KVxuXG4gICAgdGhpcy5hdXRoQXBpID0gbmV3IEF1dGgoe1xuICAgICAgY3JlZGVudGlhbHNDbGllbnQ6IHRoaXMub2F1dGgyY2xpZW50LFxuICAgICAgLi4uYXV0aE9wdGlvbnMsXG4gICAgICAvLyDlhbzlrrnogIHpgLvovpHvvIzmnInlgLzkvKDlhaXliJnkuI3otbBBdXRo5YaF55qE6aqM6K+B56CB6K+35rGC6YC76L6RXG4gICAgICByZXF1ZXN0OiByZXF1ZXN0ID8gdGhpcy5vYXV0aDJjbGllbnQucmVxdWVzdC5iaW5kKHRoaXMub2F1dGgyY2xpZW50KSA6IHVuZGVmaW5lZCxcbiAgICB9KVxuICB9XG59XG5cbiJdfQ==
24
+ }
@@ -1,3 +1,4 @@
1
+ export { ErrorType } from '../auth/consts';
1
2
  export declare enum Syntax {
2
3
  CLIENT_ID = "client_id",
3
4
  CLIENT_SECRET = "client_secret",
@@ -17,51 +18,3 @@ export declare enum Syntax {
17
18
  PASSWORD = "password",
18
19
  REFRESH_TOKEN = "refresh_token"
19
20
  }
20
- export declare enum ErrorType {
21
- UNREACHABLE = "unreachable",
22
- LOCAL = "local",
23
- CANCELLED = "cancelled",
24
- UNKNOWN = "unknown",
25
- INVALID_ARGUMENT = "invalid_argument",
26
- DEADLINE_EXCEEDED = "deadline_exceeded",
27
- NOT_FOUND = "not_found",
28
- ALREADY_EXISTS = "already_exists",
29
- PERMISSION_DENIED = "permission_denied",
30
- UNAUTHENTICATED = "unauthenticated",
31
- RESOURCE_EXHAUSTED = "resource_exhausted",
32
- FAILED_PRECONDITION = "failed_precondition",
33
- ABORTED = "aborted",
34
- OUT_OF_RANGE = "out_of_range",
35
- UNIMPLEMENTED = "unimplemented",
36
- INTERNAL = "internal",
37
- UNAVAILABLE = "unavailable",
38
- DATA_LOSS = "data_loss",
39
- CAPTCHA_REQUIRED = "captcha_required",
40
- CAPTCHA_INVALID = "captcha_invalid",
41
- INVALID_PASSWORD = "invalid_password",
42
- INVALID_STATUS = "invalid_status",
43
- USER_PENDING = "user_pending",
44
- USER_BLOCKED = "user_blocked",
45
- INVALID_VERIFICATION_CODE = "invalid_verification_code",
46
- TWO_FACTOR_REQUIRED = "two_factor_required",
47
- INVALID_TWO_FACTOR = "invalid_two_factor",
48
- INVALID_TWO_FACTOR_RECOVERY = "invalid_two_factor_recovery",
49
- UNDER_REVIEW = "under_review",
50
- INVALID_REQUEST = "invalid_request",
51
- UNAUTHORIZED_CLIENT = "unauthorized_client",
52
- ACCESS_DENIED = "access_denied",
53
- UNSUPPORTED_RESPONSE_TYPE = "unsupported_response_type",
54
- INVALID_SCOPE = "invalid_scope",
55
- INVALID_GRANT = "invalid_grant",
56
- SERVER_ERROR = "server_error",
57
- TEMPORARILY_UNAVAILABLE = "temporarily_unavailable",
58
- INTERACTION_REQUIRED = "interaction_required",
59
- LOGIN_REQUIRED = "login_required",
60
- ACCOUNT_SELECTION_REQUIRED = "account_selection_required",
61
- CONSENT_REQUIRED = "consent_required",
62
- INVALID_REQUEST_URI = "invalid_request_uri",
63
- INVALID_REQUEST_OBJECT = "invalid_request_object",
64
- REQUEST_NOT_SUPPORTED = "request_not_supported",
65
- REQUEST_URI_NOT_SUPPORTED = "request_uri_not_supported",
66
- REGISTRATION_NOT_SUPPORTED = "registration_not_supported"
67
- }