@cloudbase/oauth 3.0.0 → 3.0.1

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 (70) hide show
  1. package/dist/cjs/auth/apis.d.ts +22 -4
  2. package/dist/cjs/auth/apis.js +255 -66
  3. package/dist/cjs/auth/auth-error.d.ts +6 -0
  4. package/dist/cjs/auth/auth-error.js +32 -0
  5. package/dist/cjs/auth/consts.d.ts +22 -0
  6. package/dist/cjs/auth/consts.js +24 -2
  7. package/dist/cjs/auth/models.d.ts +13 -4
  8. package/dist/cjs/auth/models.js +1 -1
  9. package/dist/cjs/captcha/captcha-dom.d.ts +3 -0
  10. package/dist/cjs/captcha/captcha-dom.js +223 -0
  11. package/dist/cjs/captcha/captcha.d.ts +3 -1
  12. package/dist/cjs/captcha/captcha.js +11 -102
  13. package/dist/cjs/index.d.ts +12 -2
  14. package/dist/cjs/index.js +27 -4
  15. package/dist/cjs/oauth2client/interface.d.ts +1 -1
  16. package/dist/cjs/oauth2client/interface.js +1 -1
  17. package/dist/cjs/oauth2client/models.d.ts +15 -1
  18. package/dist/cjs/oauth2client/models.js +1 -1
  19. package/dist/cjs/oauth2client/oauth2client.d.ts +62 -3
  20. package/dist/cjs/oauth2client/oauth2client.js +426 -131
  21. package/dist/cjs/utils/base64.d.ts +5 -0
  22. package/dist/cjs/utils/base64.js +15 -2
  23. package/dist/cjs/utils/encryptlong/index.js +22 -16
  24. package/dist/cjs/utils/index.js +1 -1
  25. package/dist/cjs/utils/mp.js +4 -4
  26. package/dist/cjs/utils/urlSearchParams.js +1 -1
  27. package/dist/esm/auth/apis.d.ts +22 -4
  28. package/dist/esm/auth/apis.js +130 -10
  29. package/dist/esm/auth/auth-error.d.ts +6 -0
  30. package/dist/esm/auth/auth-error.js +9 -0
  31. package/dist/esm/auth/consts.d.ts +22 -0
  32. package/dist/esm/auth/consts.js +22 -0
  33. package/dist/esm/auth/models.d.ts +13 -4
  34. package/dist/esm/captcha/captcha-dom.d.ts +3 -0
  35. package/dist/esm/captcha/captcha-dom.js +129 -0
  36. package/dist/esm/captcha/captcha.d.ts +3 -1
  37. package/dist/esm/captcha/captcha.js +14 -97
  38. package/dist/esm/index.d.ts +12 -2
  39. package/dist/esm/index.js +20 -3
  40. package/dist/esm/oauth2client/interface.d.ts +1 -1
  41. package/dist/esm/oauth2client/models.d.ts +15 -1
  42. package/dist/esm/oauth2client/oauth2client.d.ts +62 -3
  43. package/dist/esm/oauth2client/oauth2client.js +200 -55
  44. package/dist/esm/utils/base64.d.ts +5 -0
  45. package/dist/esm/utils/base64.js +12 -0
  46. package/dist/esm/utils/encryptlong/index.js +21 -15
  47. package/dist/esm/utils/mp.js +3 -3
  48. package/dist/miniprogram/index.js +1 -1
  49. package/package.json +10 -4
  50. package/src/auth/apis.ts +222 -17
  51. package/src/auth/auth-error.ts +21 -0
  52. package/src/auth/consts.ts +28 -0
  53. package/src/auth/models.ts +13 -4
  54. package/src/captcha/captcha-dom.ts +178 -0
  55. package/src/captcha/captcha.ts +25 -114
  56. package/src/index.ts +54 -4
  57. package/src/oauth2client/interface.ts +1 -1
  58. package/src/oauth2client/models.ts +29 -1
  59. package/src/oauth2client/oauth2client.ts +308 -55
  60. package/src/utils/base64.ts +12 -0
  61. package/src/utils/encryptlong/index.js +20 -14
  62. package/src/utils/index.ts +1 -0
  63. package/src/utils/mp.ts +3 -3
  64. package/src/utils/urlSearchParams.ts +2 -0
  65. package/tsconfig.json +1 -0
  66. package/dist/cjs/utils/cloudbase-adapter-wx_mp.d.ts +0 -1
  67. package/dist/cjs/utils/cloudbase-adapter-wx_mp.js +0 -40
  68. package/dist/esm/utils/cloudbase-adapter-wx_mp.d.ts +0 -1
  69. package/dist/esm/utils/cloudbase-adapter-wx_mp.js +0 -35
  70. package/src/utils/cloudbase-adapter-wx_mp.ts +0 -42
@@ -46,6 +46,15 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
46
46
  if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
47
  }
48
48
  };
49
+ var __spreadArray = (this && this.__spreadArray) || function (to, from, pack) {
50
+ if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {
51
+ if (ar || !(i in from)) {
52
+ if (!ar) ar = Array.prototype.slice.call(from, 0, i);
53
+ ar[i] = from[i];
54
+ }
55
+ }
56
+ return to.concat(ar || Array.prototype.slice.call(from));
57
+ };
49
58
  Object.defineProperty(exports, "__esModule", { value: true });
50
59
  exports.OAuth2Client = exports.defaultStorage = exports.generateRequestId = exports.toResponseError = exports.defaultRequest = void 0;
51
60
  var consts_1 = require("./consts");
@@ -54,7 +63,7 @@ var uuid_1 = require("../utils/uuid");
54
63
  var index_1 = require("../utils/index");
55
64
  var single_promise_1 = require("../utils/function/single-promise");
56
65
  var base64_1 = require("../utils/base64");
57
- var cloudbase_adapter_wx_mp_1 = require("../utils/cloudbase-adapter-wx_mp");
66
+ var mp_1 = require("../utils/mp");
58
67
  var utilities_1 = require("@cloudbase/utilities");
59
68
  var RequestIdHeaderName = 'x-request-id';
60
69
  var DeviceIdHeaderName = 'x-device-id';
@@ -188,15 +197,13 @@ function isCredentialsExpired(credentials) {
188
197
  var LocalCredentials = (function () {
189
198
  function LocalCredentials(options) {
190
199
  this.credentials = null;
200
+ this.accessKeyCredentials = null;
191
201
  this.singlePromise = null;
192
202
  this.tokenSectionName = options.tokenSectionName;
193
203
  this.storage = options.storage;
194
204
  this.clientId = options.clientId;
195
205
  this.singlePromise = new single_promise_1.SinglePromise({ clientId: this.clientId });
196
206
  this.credentials = options.credentials || null;
197
- if (this.credentials) {
198
- this.setCredentials(this.credentials);
199
- }
200
207
  }
201
208
  LocalCredentials.prototype.getStorageCredentialsSync = function () {
202
209
  var credentials = null;
@@ -248,20 +255,26 @@ var LocalCredentials = (function () {
248
255
  });
249
256
  });
250
257
  };
258
+ LocalCredentials.prototype.setAccessKeyCredentials = function (credentials) {
259
+ this.accessKeyCredentials = credentials;
260
+ };
251
261
  LocalCredentials.prototype.getCredentials = function () {
252
262
  return __awaiter(this, void 0, void 0, function () {
253
263
  var _this = this;
254
264
  return __generator(this, function (_a) {
255
265
  return [2, this.singlePromise.run('getCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
256
- var _a;
266
+ var _a, credentials, isAccessKeyCredentials;
257
267
  return __generator(this, function (_b) {
258
268
  switch (_b.label) {
259
269
  case 0:
260
270
  if (!isCredentialsExpired(this.credentials)) return [3, 2];
261
- _a = this;
262
271
  return [4, this.getStorageCredentials()];
263
272
  case 1:
264
- _a.credentials = _b.sent();
273
+ _a = _b.sent(), credentials = _a.credentials, isAccessKeyCredentials = _a.isAccessKeyCredentials;
274
+ if (isAccessKeyCredentials) {
275
+ return [2, credentials];
276
+ }
277
+ this.credentials = credentials;
265
278
  _b.label = 2;
266
279
  case 2: return [2, this.credentials];
267
280
  }
@@ -275,15 +288,16 @@ var LocalCredentials = (function () {
275
288
  var _this = this;
276
289
  return __generator(this, function (_a) {
277
290
  return [2, this.singlePromise.run('_getStorageCredentials', function () { return __awaiter(_this, void 0, void 0, function () {
278
- var credentials, tokenStr, error_2;
291
+ var credentials, isAccessKeyCredentials, tokenStr, error_2;
279
292
  return __generator(this, function (_a) {
280
293
  switch (_a.label) {
281
294
  case 0:
282
295
  credentials = null;
296
+ isAccessKeyCredentials = false;
283
297
  return [4, this.storage.getItem(this.tokenSectionName)];
284
298
  case 1:
285
299
  tokenStr = _a.sent();
286
- if (!(tokenStr !== undefined && tokenStr !== null)) return [3, 5];
300
+ if (!!!tokenStr) return [3, 6];
287
301
  _a.label = 2;
288
302
  case 2:
289
303
  _a.trys.push([2, 3, , 5]);
@@ -299,7 +313,12 @@ var LocalCredentials = (function () {
299
313
  _a.sent();
300
314
  credentials = null;
301
315
  return [3, 5];
302
- case 5: return [2, credentials];
316
+ case 5: return [3, 7];
317
+ case 6:
318
+ credentials = this.accessKeyCredentials || null;
319
+ isAccessKeyCredentials = true;
320
+ _a.label = 7;
321
+ case 7: return [2, { credentials: credentials, isAccessKeyCredentials: isAccessKeyCredentials }];
303
322
  }
304
323
  });
305
324
  }); })];
@@ -311,6 +330,10 @@ var LocalCredentials = (function () {
311
330
  var OAuth2Client = exports.OAuth2Client = (function () {
312
331
  function OAuth2Client(options) {
313
332
  var _this = this;
333
+ var _a;
334
+ this.initializePromise = null;
335
+ this.lockAcquired = false;
336
+ this.pendingInLock = [];
314
337
  this.singlePromise = null;
315
338
  if (!options.clientSecret) {
316
339
  options.clientSecret = '';
@@ -322,7 +345,7 @@ var OAuth2Client = exports.OAuth2Client = (function () {
322
345
  this.apiPath = options.apiPath || consts_2.AUTH_API_PREFIX;
323
346
  this.clientId = options.clientId;
324
347
  this.i18n = options.i18n;
325
- this.publishable_key = options.publishable_key;
348
+ this.eventBus = options.eventBus;
326
349
  this.singlePromise = new single_promise_1.SinglePromise({ clientId: this.clientId });
327
350
  this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry);
328
351
  if (options.baseRequest) {
@@ -338,13 +361,6 @@ var OAuth2Client = exports.OAuth2Client = (function () {
338
361
  tokenSectionName: "credentials_".concat(options.clientId),
339
362
  storage: this.storage,
340
363
  clientId: options.clientId,
341
- credentials: this.publishable_key ? {
342
- access_token: this.publishable_key,
343
- token_type: 'Bearer',
344
- scope: 'publishable_key',
345
- expires_at: new Date(+new Date() + +new Date()),
346
- expires_in: +new Date() + +new Date(),
347
- } : null,
348
364
  });
349
365
  this.clientSecret = options.clientSecret;
350
366
  if (options.clientId) {
@@ -352,9 +368,12 @@ var OAuth2Client = exports.OAuth2Client = (function () {
352
368
  }
353
369
  this.wxCloud = options.wxCloud;
354
370
  try {
355
- if ((0, cloudbase_adapter_wx_mp_1.isMatch)() && this.wxCloud === undefined && options.env) {
356
- wx.cloud.init({ env: options.env });
357
- this.wxCloud = wx.cloud;
371
+ if ((0, mp_1.isMp)()) {
372
+ this.useWxCloud = options.useWxCloud;
373
+ if (this.wxCloud === undefined && options.env) {
374
+ wx.cloud.init({ env: options.env });
375
+ this.wxCloud = wx.cloud;
376
+ }
358
377
  }
359
378
  }
360
379
  catch (error) {
@@ -362,21 +381,83 @@ var OAuth2Client = exports.OAuth2Client = (function () {
362
381
  this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc;
363
382
  this.anonymousSignInFunc = options.anonymousSignInFunc;
364
383
  this.onCredentialsError = options.onCredentialsError;
384
+ this.getInitialSession = options.getInitialSession;
385
+ this.onInitialSessionObtained = options.onInitialSessionObtained;
386
+ this.logDebugMessages = (_a = options.debug) !== null && _a !== void 0 ? _a : false;
365
387
  utilities_1.langEvent.bus.on(utilities_1.langEvent.LANG_CHANGE_EVENT, function (params) {
366
388
  var _a;
367
389
  _this.i18n = ((_a = params.data) === null || _a === void 0 ? void 0 : _a.i18n) || _this.i18n;
368
390
  });
369
391
  }
392
+ OAuth2Client.prototype.setGetInitialSession = function (callback) {
393
+ this.getInitialSession = callback;
394
+ };
395
+ OAuth2Client.prototype.setOnInitialSessionObtained = function (callback) {
396
+ this.onInitialSessionObtained = callback;
397
+ };
398
+ OAuth2Client.prototype.initialize = function (func) {
399
+ return __awaiter(this, void 0, void 0, function () {
400
+ var _this = this;
401
+ return __generator(this, function (_a) {
402
+ switch (_a.label) {
403
+ case 0:
404
+ if (!this.initializePromise) return [3, 2];
405
+ return [4, this.initializePromise];
406
+ case 1: return [2, _a.sent()];
407
+ case 2:
408
+ if (!(func !== undefined)) return [3, 4];
409
+ this.initializePromise = func;
410
+ return [4, this.initializePromise];
411
+ case 3: return [2, _a.sent()];
412
+ case 4:
413
+ this.initializePromise = (function () { return __awaiter(_this, void 0, void 0, function () {
414
+ var _this = this;
415
+ return __generator(this, function (_a) {
416
+ switch (_a.label) {
417
+ case 0: return [4, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
418
+ switch (_a.label) {
419
+ case 0: return [4, this._initialize()];
420
+ case 1: return [2, _a.sent()];
421
+ }
422
+ }); }); })];
423
+ case 1: return [2, _a.sent()];
424
+ }
425
+ });
426
+ }); })();
427
+ return [4, this.initializePromise];
428
+ case 5: return [2, _a.sent()];
429
+ }
430
+ });
431
+ });
432
+ };
370
433
  OAuth2Client.prototype.setCredentials = function (credentials) {
371
- return this.localCredentials.setCredentials(credentials);
434
+ return __awaiter(this, void 0, void 0, function () {
435
+ var _this = this;
436
+ return __generator(this, function (_a) {
437
+ switch (_a.label) {
438
+ case 0: return [4, this.initializePromise];
439
+ case 1:
440
+ _a.sent();
441
+ return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
442
+ return [2, this.localCredentials.setCredentials(credentials)];
443
+ }); }); })];
444
+ }
445
+ });
446
+ });
447
+ };
448
+ OAuth2Client.prototype.setAccessKeyCredentials = function (credentials) {
449
+ return this.localCredentials.setAccessKeyCredentials(credentials);
372
450
  };
373
451
  OAuth2Client.prototype.getAccessToken = function () {
374
452
  return __awaiter(this, void 0, void 0, function () {
375
453
  var credentials, respErr;
376
454
  return __generator(this, function (_a) {
377
455
  switch (_a.label) {
378
- case 0: return [4, this.getCredentials()];
456
+ case 0: return [4, this.initializePromise];
379
457
  case 1:
458
+ _a.sent();
459
+ return [4, this.getCredentials()];
460
+ case 2:
380
461
  credentials = _a.sent();
381
462
  if (credentials === null || credentials === void 0 ? void 0 : credentials.access_token) {
382
463
  return [2, Promise.resolve(credentials.access_token)];
@@ -390,16 +471,16 @@ var OAuth2Client = exports.OAuth2Client = (function () {
390
471
  OAuth2Client.prototype.request = function (url, options) {
391
472
  var _a, _b;
392
473
  return __awaiter(this, void 0, void 0, function () {
393
- var retry, deviceId, credentials, response, maxRequestTimes, requestTime, responseError_1;
394
- var _c;
395
- return __generator(this, function (_d) {
396
- switch (_d.label) {
474
+ var retry, deviceId, credentials, _c, response, maxRequestTimes, requestTime, responseError_1;
475
+ var _d;
476
+ return __generator(this, function (_f) {
477
+ switch (_f.label) {
397
478
  case 0:
398
479
  if (!options) {
399
480
  options = {};
400
481
  }
401
482
  retry = this.formatRetry(options.retry, this.retry);
402
- options.headers = __assign(__assign({}, options.headers), (_c = {}, _c[(_a = this.i18n) === null || _a === void 0 ? void 0 : _a.LANG_HEADER_KEY] = (_b = this.i18n) === null || _b === void 0 ? void 0 : _b.lang, _c));
483
+ options.headers = __assign(__assign({}, options.headers), (_d = {}, _d[(_a = this.i18n) === null || _a === void 0 ? void 0 : _a.LANG_HEADER_KEY] = (_b = this.i18n) === null || _b === void 0 ? void 0 : _b.lang, _d));
403
484
  if (this.headers) {
404
485
  options.headers = __assign(__assign({}, this.headers), options.headers);
405
486
  }
@@ -409,17 +490,25 @@ var OAuth2Client = exports.OAuth2Client = (function () {
409
490
  if (!!options.headers[DeviceIdHeaderName]) return [3, 2];
410
491
  return [4, this.getDeviceId()];
411
492
  case 1:
412
- deviceId = _d.sent();
493
+ deviceId = _f.sent();
413
494
  options.headers[DeviceIdHeaderName] = deviceId;
414
- _d.label = 2;
495
+ _f.label = 2;
415
496
  case 2:
416
497
  if ((options === null || options === void 0 ? void 0 : options.withBasicAuth) && this.basicAuth) {
417
498
  options.headers.Authorization = this.basicAuth;
418
499
  }
419
- if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3, 4];
420
- return [4, this.getCredentials()];
500
+ if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3, 7];
501
+ if (!options.getCredentials) return [3, 4];
502
+ return [4, options.getCredentials()];
421
503
  case 3:
422
- credentials = _d.sent();
504
+ _c = _f.sent();
505
+ return [3, 6];
506
+ case 4: return [4, this.getCredentials()];
507
+ case 5:
508
+ _c = _f.sent();
509
+ _f.label = 6;
510
+ case 6:
511
+ credentials = _c;
423
512
  if (credentials) {
424
513
  if (this.tokenInURL) {
425
514
  if (url.indexOf('?') < 0) {
@@ -431,56 +520,64 @@ var OAuth2Client = exports.OAuth2Client = (function () {
431
520
  options.headers.Authorization = "".concat(credentials.token_type, " ").concat(credentials.access_token);
432
521
  }
433
522
  }
434
- return [3, 5];
435
- case 4:
523
+ return [3, 8];
524
+ case 7:
436
525
  if (this.clientId && url.indexOf('client_id') < 0) {
437
526
  url += url.indexOf('?') < 0 ? '?' : '&';
438
527
  url += "client_id=".concat(this.clientId);
439
528
  }
440
- _d.label = 5;
441
- case 5:
529
+ _f.label = 8;
530
+ case 8:
442
531
  if (url.startsWith('/')) {
443
532
  url = "".concat(this.apiOrigin).concat(this.apiPath).concat(url);
444
533
  }
445
534
  response = null;
446
535
  maxRequestTimes = retry + 1;
447
536
  requestTime = 0;
448
- _d.label = 6;
449
- case 6:
450
- if (!(requestTime < maxRequestTimes)) return [3, 18];
451
- _d.label = 7;
452
- case 7:
453
- _d.trys.push([7, 12, , 15]);
454
- if (!options.useWxCloud) return [3, 9];
455
- return [4, this.wxCloudCallFunction(url, options)];
456
- case 8:
457
- response = _d.sent();
458
- return [3, 11];
459
- case 9: return [4, this.baseRequest(url, options)];
537
+ _f.label = 9;
538
+ case 9:
539
+ if (!(requestTime < maxRequestTimes)) return [3, 21];
540
+ _f.label = 10;
460
541
  case 10:
461
- response = _d.sent();
462
- _d.label = 11;
463
- case 11: return [3, 18];
464
- case 12:
465
- responseError_1 = _d.sent();
466
- if (!(options.withCredentials && responseError_1 && responseError_1.error === consts_1.ErrorType.UNAUTHENTICATED)) return [3, 14];
467
- return [4, this.setCredentials(null)];
542
+ _f.trys.push([10, 15, , 18]);
543
+ if (!(options.useWxCloud || this.useWxCloud)) return [3, 12];
544
+ return [4, this.wxCloudCallFunction(url, options)];
545
+ case 11:
546
+ response = _f.sent();
547
+ return [3, 14];
548
+ case 12: return [4, this.baseRequest(url, options)];
468
549
  case 13:
469
- _d.sent();
470
- return [2, Promise.reject(responseError_1)];
550
+ response = _f.sent();
551
+ _f.label = 14;
471
552
  case 14:
472
- if (requestTime === retry || !responseError_1 || responseError_1.error !== 'unreachable') {
473
- return [2, Promise.reject(responseError_1)];
553
+ if (!!(response === null || response === void 0 ? void 0 : response.code)) {
554
+ throw ({
555
+ error: response.code,
556
+ error_description: response.message,
557
+ error_uri: new URL(url).pathname,
558
+ });
474
559
  }
475
- return [3, 15];
476
- case 15: return [4, this.sleep(OAuth2Client.retryInterval)];
560
+ return [3, 21];
561
+ case 15:
562
+ responseError_1 = _f.sent();
563
+ if (!(options.withCredentials && responseError_1 && responseError_1.error === consts_1.ErrorType.UNAUTHENTICATED)) return [3, 17];
564
+ return [4, this.setCredentials(null)];
477
565
  case 16:
478
- _d.sent();
479
- _d.label = 17;
566
+ _f.sent();
567
+ return [2, Promise.reject(responseError_1)];
480
568
  case 17:
569
+ if (requestTime === retry || !responseError_1 || responseError_1.error !== 'unreachable') {
570
+ return [2, Promise.reject(responseError_1)];
571
+ }
572
+ return [3, 18];
573
+ case 18: return [4, this.sleep(OAuth2Client.retryInterval)];
574
+ case 19:
575
+ _f.sent();
576
+ _f.label = 20;
577
+ case 20:
481
578
  requestTime++;
482
- return [3, 6];
483
- case 18: return [2, response];
579
+ return [3, 9];
580
+ case 21: return [2, response];
484
581
  }
485
582
  });
486
583
  });
@@ -548,51 +645,16 @@ var OAuth2Client = exports.OAuth2Client = (function () {
548
645
  });
549
646
  };
550
647
  OAuth2Client.prototype.getCredentials = function () {
551
- var _a, _b, _c;
552
648
  return __awaiter(this, void 0, void 0, function () {
553
- var credentials, msg, error_5, msg;
554
- return __generator(this, function (_d) {
555
- switch (_d.label) {
556
- case 0: return [4, this.localCredentials.getCredentials()];
649
+ var _this = this;
650
+ return __generator(this, function (_a) {
651
+ switch (_a.label) {
652
+ case 0: return [4, this.initializePromise];
557
653
  case 1:
558
- credentials = _d.sent();
559
- if (!credentials) {
560
- msg = 'credentials not found';
561
- (_a = this.onCredentialsError) === null || _a === void 0 ? void 0 : _a.call(this, { msg: msg });
562
- return [2, this.unAuthenticatedError(msg)];
563
- }
564
- if (!isCredentialsExpired(credentials)) return [3, 12];
565
- if (!credentials.refresh_token) return [3, 9];
566
- _d.label = 2;
567
- case 2:
568
- _d.trys.push([2, 4, , 8]);
569
- return [4, this.refreshToken(credentials)];
570
- case 3:
571
- credentials = _d.sent();
572
- return [3, 8];
573
- case 4:
574
- error_5 = _d.sent();
575
- if (!(credentials.scope === 'anonymous')) return [3, 6];
576
- return [4, this.anonymousLogin(credentials)];
577
- case 5:
578
- credentials = _d.sent();
579
- return [3, 7];
580
- case 6:
581
- (_b = this.onCredentialsError) === null || _b === void 0 ? void 0 : _b.call(this, { msg: error_5.error_description });
582
- return [2, Promise.reject(error_5)];
583
- case 7: return [3, 8];
584
- case 8: return [3, 12];
585
- case 9:
586
- if (!(credentials.scope === 'anonymous')) return [3, 11];
587
- return [4, this.anonymousLogin(credentials)];
588
- case 10:
589
- credentials = _d.sent();
590
- return [3, 12];
591
- case 11:
592
- msg = 'no refresh token found in credentials';
593
- (_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
594
- return [2, this.unAuthenticatedError(msg)];
595
- case 12: return [2, credentials];
654
+ _a.sent();
655
+ return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
656
+ return [2, this._getCredentials()];
657
+ }); }); })];
596
658
  }
597
659
  });
598
660
  });
@@ -642,43 +704,62 @@ var OAuth2Client = exports.OAuth2Client = (function () {
642
704
  });
643
705
  });
644
706
  };
645
- OAuth2Client.prototype.refreshToken = function (credentials) {
707
+ OAuth2Client.prototype.refreshToken = function (credentials, options) {
708
+ return __awaiter(this, void 0, void 0, function () {
709
+ var _this = this;
710
+ return __generator(this, function (_a) {
711
+ switch (_a.label) {
712
+ case 0: return [4, this.initializePromise];
713
+ case 1:
714
+ _a.sent();
715
+ return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
716
+ return [2, this._refreshToken(credentials, options)];
717
+ }); }); })];
718
+ }
719
+ });
720
+ });
721
+ };
722
+ OAuth2Client.prototype._refreshToken = function (credentials, options) {
646
723
  return __awaiter(this, void 0, void 0, function () {
647
724
  var _this = this;
648
725
  return __generator(this, function (_a) {
649
726
  return [2, this.singlePromise.run('_refreshToken', function () { return __awaiter(_this, void 0, void 0, function () {
650
- var msg, newCredentials, error_6, msg;
651
- var _a, _b, _c;
652
- return __generator(this, function (_d) {
653
- switch (_d.label) {
727
+ var msg, newCredentials, error_5, msg;
728
+ var _a, _b, _c, _d;
729
+ return __generator(this, function (_f) {
730
+ switch (_f.label) {
654
731
  case 0:
655
732
  if (!credentials || !credentials.refresh_token) {
656
733
  msg = 'no refresh token found in credentials';
657
734
  (_a = this.onCredentialsError) === null || _a === void 0 ? void 0 : _a.call(this, { msg: msg });
658
735
  return [2, this.unAuthenticatedError(msg)];
659
736
  }
660
- _d.label = 1;
737
+ _f.label = 1;
661
738
  case 1:
662
- _d.trys.push([1, 4, , 7]);
739
+ _f.trys.push([1, 4, , 7]);
663
740
  return [4, this.refreshTokenFunc(credentials.refresh_token, credentials)];
664
741
  case 2:
665
- newCredentials = _d.sent();
742
+ newCredentials = _f.sent();
666
743
  return [4, this.localCredentials.setCredentials(newCredentials)];
667
744
  case 3:
668
- _d.sent();
745
+ _f.sent();
746
+ (_b = this.eventBus) === null || _b === void 0 ? void 0 : _b.fire(consts_2.EVENTS.AUTH_STATE_CHANGED, { event: consts_2.AUTH_STATE_CHANGED_TYPE.TOKEN_REFRESHED });
669
747
  return [2, newCredentials];
670
748
  case 4:
671
- error_6 = _d.sent();
672
- if (!(error_6.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
749
+ error_5 = _f.sent();
750
+ if (options === null || options === void 0 ? void 0 : options.throwError) {
751
+ throw error_5;
752
+ }
753
+ if (!(error_5.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
673
754
  return [4, this.localCredentials.setCredentials(null)];
674
755
  case 5:
675
- _d.sent();
676
- msg = error_6.error_description;
677
- (_b = this.onCredentialsError) === null || _b === void 0 ? void 0 : _b.call(this, { msg: msg });
756
+ _f.sent();
757
+ msg = error_5.error_description;
758
+ (_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
678
759
  return [2, this.unAuthenticatedError(msg)];
679
760
  case 6:
680
- (_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: error_6.error_description });
681
- return [2, Promise.reject(error_6)];
761
+ (_d = this.onCredentialsError) === null || _d === void 0 ? void 0 : _d.call(this, { msg: error_5.error_description });
762
+ return [2, Promise.reject(error_5)];
682
763
  case 7: return [2];
683
764
  }
684
765
  });
@@ -754,7 +835,7 @@ var OAuth2Client = exports.OAuth2Client = (function () {
754
835
  var _this = this;
755
836
  return __generator(this, function (_a) {
756
837
  return [2, this.singlePromise.run('_anonymous', function () { return __awaiter(_this, void 0, void 0, function () {
757
- var newCredentials, error_7;
838
+ var newCredentials, error_6;
758
839
  return __generator(this, function (_a) {
759
840
  switch (_a.label) {
760
841
  case 0:
@@ -776,13 +857,13 @@ var OAuth2Client = exports.OAuth2Client = (function () {
776
857
  _a.sent();
777
858
  return [2, newCredentials];
778
859
  case 4:
779
- error_7 = _a.sent();
780
- if (!(error_7.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
860
+ error_6 = _a.sent();
861
+ if (!(error_6.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
781
862
  return [4, this.localCredentials.setCredentials(null)];
782
863
  case 5:
783
864
  _a.sent();
784
- return [2, this.unAuthenticatedError(error_7.error_description)];
785
- case 6: return [2, Promise.reject(error_7)];
865
+ return [2, this.unAuthenticatedError(error_6.error_description)];
866
+ case 6: return [2, Promise.reject(error_6)];
786
867
  case 7: return [2];
787
868
  }
788
869
  });
@@ -854,10 +935,224 @@ var OAuth2Client = exports.OAuth2Client = (function () {
854
935
  };
855
936
  return Promise.reject(respErr);
856
937
  };
938
+ OAuth2Client.prototype._debug = function () {
939
+ var args = [];
940
+ for (var _i = 0; _i < arguments.length; _i++) {
941
+ args[_i] = arguments[_i];
942
+ }
943
+ if (this.logDebugMessages) {
944
+ console.log.apply(console, __spreadArray(['[OAuth2Client]'], args, false));
945
+ }
946
+ };
947
+ OAuth2Client.prototype._initialize = function () {
948
+ return __awaiter(this, void 0, void 0, function () {
949
+ var data, error, callbackError_1, err_1, error_7;
950
+ var _a;
951
+ return __generator(this, function (_b) {
952
+ switch (_b.label) {
953
+ case 0:
954
+ _b.trys.push([0, 11, 12, 13]);
955
+ if (!this.getInitialSession) {
956
+ this._debug('#_initialize()', 'no getInitialSession callback set, skipping');
957
+ return [2, { error: null }];
958
+ }
959
+ this._debug('#_initialize()', 'calling getInitialSession callback');
960
+ _b.label = 1;
961
+ case 1:
962
+ _b.trys.push([1, 9, , 10]);
963
+ return [4, this.getInitialSession()];
964
+ case 2:
965
+ data = (_a = _b.sent(), _a.data), error = _a.error;
966
+ if (!(data === null || data === void 0 ? void 0 : data.session)) return [3, 4];
967
+ this._debug('#_initialize()', 'session obtained from getInitialSession', data.session);
968
+ return [4, this.localCredentials.setCredentials(data === null || data === void 0 ? void 0 : data.session)];
969
+ case 3:
970
+ _b.sent();
971
+ _b.label = 4;
972
+ case 4:
973
+ if (!this.onInitialSessionObtained) return [3, 8];
974
+ this._debug('#_initialize()', 'calling onInitialSessionObtained callback');
975
+ _b.label = 5;
976
+ case 5:
977
+ _b.trys.push([5, 7, , 8]);
978
+ return [4, this.onInitialSessionObtained(data, error)];
979
+ case 6:
980
+ _b.sent();
981
+ return [3, 8];
982
+ case 7:
983
+ callbackError_1 = _b.sent();
984
+ this._debug('#_initialize()', 'error in onInitialSessionObtained', callbackError_1);
985
+ return [3, 8];
986
+ case 8:
987
+ if (error) {
988
+ this._debug('#_initialize()', 'error from getInitialSession', error);
989
+ return [2, { error: error }];
990
+ }
991
+ return [2, { error: null }];
992
+ case 9:
993
+ err_1 = _b.sent();
994
+ this._debug('#_initialize()', 'exception during getInitialSession', err_1);
995
+ return [2, { error: err_1 instanceof Error ? err_1 : new Error(String(err_1)) }];
996
+ case 10: return [3, 13];
997
+ case 11:
998
+ error_7 = _b.sent();
999
+ this._debug('#_initialize()', 'unexpected error', error_7);
1000
+ return [2, { error: error_7 instanceof Error ? error_7 : new Error(String(error_7)) }];
1001
+ case 12:
1002
+ this._debug('#_initialize()', 'end');
1003
+ return [7];
1004
+ case 13: return [2];
1005
+ }
1006
+ });
1007
+ });
1008
+ };
1009
+ OAuth2Client.prototype._acquireLock = function (acquireTimeout, fn) {
1010
+ return __awaiter(this, void 0, void 0, function () {
1011
+ var last_1, result_1, result_2, waitOn;
1012
+ var _this = this;
1013
+ return __generator(this, function (_a) {
1014
+ switch (_a.label) {
1015
+ case 0:
1016
+ this._debug('#_acquireLock', 'begin', acquireTimeout);
1017
+ _a.label = 1;
1018
+ case 1:
1019
+ _a.trys.push([1, , 10, 11]);
1020
+ if (this.lockAcquired) {
1021
+ last_1 = this.pendingInLock.length ? this.pendingInLock[this.pendingInLock.length - 1] : Promise.resolve();
1022
+ result_1 = (function () { return __awaiter(_this, void 0, void 0, function () {
1023
+ return __generator(this, function (_a) {
1024
+ switch (_a.label) {
1025
+ case 0: return [4, last_1];
1026
+ case 1:
1027
+ _a.sent();
1028
+ return [4, fn()];
1029
+ case 2: return [2, _a.sent()];
1030
+ }
1031
+ });
1032
+ }); })();
1033
+ this.pendingInLock.push((function () { return __awaiter(_this, void 0, void 0, function () {
1034
+ var _e_1;
1035
+ return __generator(this, function (_a) {
1036
+ switch (_a.label) {
1037
+ case 0:
1038
+ _a.trys.push([0, 2, , 3]);
1039
+ return [4, result_1];
1040
+ case 1:
1041
+ _a.sent();
1042
+ return [3, 3];
1043
+ case 2:
1044
+ _e_1 = _a.sent();
1045
+ return [3, 3];
1046
+ case 3: return [2];
1047
+ }
1048
+ });
1049
+ }); })());
1050
+ return [2, result_1];
1051
+ }
1052
+ this._debug('#_acquireLock', 'acquiring lock for client', this.clientId);
1053
+ _a.label = 2;
1054
+ case 2:
1055
+ _a.trys.push([2, , 8, 9]);
1056
+ this.lockAcquired = true;
1057
+ result_2 = fn();
1058
+ this.pendingInLock.push((function () { return __awaiter(_this, void 0, void 0, function () {
1059
+ var _e_2;
1060
+ return __generator(this, function (_a) {
1061
+ switch (_a.label) {
1062
+ case 0:
1063
+ _a.trys.push([0, 2, , 3]);
1064
+ return [4, result_2];
1065
+ case 1:
1066
+ _a.sent();
1067
+ return [3, 3];
1068
+ case 2:
1069
+ _e_2 = _a.sent();
1070
+ return [3, 3];
1071
+ case 3: return [2];
1072
+ }
1073
+ });
1074
+ }); })());
1075
+ return [4, result_2];
1076
+ case 3:
1077
+ _a.sent();
1078
+ _a.label = 4;
1079
+ case 4:
1080
+ if (!this.pendingInLock.length) return [3, 6];
1081
+ waitOn = __spreadArray([], this.pendingInLock, true);
1082
+ return [4, Promise.all(waitOn)];
1083
+ case 5:
1084
+ _a.sent();
1085
+ this.pendingInLock.splice(0, waitOn.length);
1086
+ return [3, 4];
1087
+ case 6: return [4, result_2];
1088
+ case 7: return [2, _a.sent()];
1089
+ case 8:
1090
+ this._debug('#_acquireLock', 'releasing lock for client', this.clientId);
1091
+ this.lockAcquired = false;
1092
+ return [7];
1093
+ case 9: return [3, 11];
1094
+ case 10:
1095
+ this._debug('#_acquireLock', 'end');
1096
+ return [7];
1097
+ case 11: return [2];
1098
+ }
1099
+ });
1100
+ });
1101
+ };
1102
+ OAuth2Client.prototype._getCredentials = function () {
1103
+ var _a, _b, _c;
1104
+ return __awaiter(this, void 0, void 0, function () {
1105
+ var credentials, msg, error_8, msg;
1106
+ return __generator(this, function (_d) {
1107
+ switch (_d.label) {
1108
+ case 0: return [4, this.localCredentials.getCredentials()];
1109
+ case 1:
1110
+ credentials = _d.sent();
1111
+ if (!credentials) {
1112
+ msg = 'credentials not found';
1113
+ (_a = this.onCredentialsError) === null || _a === void 0 ? void 0 : _a.call(this, { msg: msg });
1114
+ return [2, this.unAuthenticatedError(msg)];
1115
+ }
1116
+ if (!isCredentialsExpired(credentials)) return [3, 12];
1117
+ if (!credentials.refresh_token) return [3, 9];
1118
+ _d.label = 2;
1119
+ case 2:
1120
+ _d.trys.push([2, 4, , 8]);
1121
+ return [4, this._refreshToken(credentials)];
1122
+ case 3:
1123
+ credentials = _d.sent();
1124
+ return [3, 8];
1125
+ case 4:
1126
+ error_8 = _d.sent();
1127
+ if (!(credentials.scope === 'anonymous')) return [3, 6];
1128
+ return [4, this.anonymousLogin(credentials)];
1129
+ case 5:
1130
+ credentials = _d.sent();
1131
+ return [3, 7];
1132
+ case 6:
1133
+ (_b = this.onCredentialsError) === null || _b === void 0 ? void 0 : _b.call(this, { msg: error_8.error_description });
1134
+ return [2, Promise.reject(error_8)];
1135
+ case 7: return [3, 8];
1136
+ case 8: return [3, 12];
1137
+ case 9:
1138
+ if (!(credentials.scope === 'anonymous')) return [3, 11];
1139
+ return [4, this.anonymousLogin(credentials)];
1140
+ case 10:
1141
+ credentials = _d.sent();
1142
+ return [3, 12];
1143
+ case 11:
1144
+ msg = 'no refresh token found in credentials';
1145
+ (_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
1146
+ return [2, this.unAuthenticatedError(msg)];
1147
+ case 12: return [2, credentials];
1148
+ }
1149
+ });
1150
+ });
1151
+ };
857
1152
  OAuth2Client.defaultRetry = 2;
858
1153
  OAuth2Client.minRetry = 0;
859
1154
  OAuth2Client.maxRetry = 5;
860
1155
  OAuth2Client.retryInterval = 1000;
861
1156
  return OAuth2Client;
862
1157
  }());
863
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts'\nimport { ApiUrls, ApiUrlsV2, AUTH_API_PREFIX } from '../auth/consts'\n\nimport { AuthClient, SimpleStorage } from './interface'\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models'\n\nimport { uuidv4 } from '../utils/uuid'\nimport { getPathName } from '../utils/index'\n\nimport { SinglePromise } from '../utils/function/single-promise'\nimport { weBtoa } from '../utils/base64'\nimport { isMatch } from '../utils/cloudbase-adapter-wx_mp'\nimport { AuthOptions } from '../auth/apis'\nimport { ICloudbaseConfig } from '@cloudbase/types'\nimport { langEvent } from '@cloudbase/utilities'\n\nconst RequestIdHeaderName = 'x-request-id'\nconst DeviceIdHeaderName = 'x-device-id'\nconst DeviceIdSectionName = 'device_id'\n\ndeclare const wx: any\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType\n  error_description?: string | null\n  error_uri?: string | null\n  details?: any | null\n}\n\nexport const defaultRequest: RequestFunction = async function <T>(url: string, options?: RequestOptions): Promise<T> {\n  let result: T | null = null\n  let responseError: ResponseError | null = null\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options)\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET'\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body)\n    }\n    const responseResult: Response = await fetch(url, copyOptions)\n    const jsonResponse = await responseResult.json()\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError\n      responseError.error_uri = new URL(url).pathname\n    } else {\n      result = jsonResponse as T\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    }\n  }\n  if (responseError) {\n    throw responseError\n  } else {\n    return result\n  }\n}\n\nexport const toResponseError = (error: ResponseError | Error, options?: ToResponseErrorOptions): ResponseError => {\n  let responseError: ResponseError\n  const formatOptions: ToResponseErrorOptions = options || {}\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    }\n  } else {\n    const formatError: ToResponseErrorOptions = error || {}\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    }\n  }\n  return responseError\n}\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4()\n}\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n   * 缓存key统一使用后缀区分\n   */\n  private readonly _env: string\n\n  constructor(opts?: { env: string }) {\n    this._env = opts?.env || ''\n  }\n  /**\n   * Get item.\n   * @param {string} key\n   */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Remove item.\n   * @param {string} key\n   */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Set item.\n   * @param {string} key\n   * @param {string} value\n   */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(`${key}${this._env}`, value)\n  }\n\n  /**\n   * Get item sync.\n   * @param {string} key\n   */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Remove item sync.\n   * @param {string} key\n   */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Set item sync.\n   * @param {string} key\n   * @param {string} value\n   */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(`${key}${this._env}`, value)\n  }\n}\n\nexport const defaultStorage = new DefaultStorage()\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string\n  storage: SimpleStorage\n  clientId: string\n  credentials?: Credentials\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date()\n  }\n  return isExpired\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nclass LocalCredentials {\n  private tokenSectionName: string\n\n  private storage: SimpleStorage\n\n  private clientId: string\n\n  private credentials: Credentials | null = null\n\n  private singlePromise: SinglePromise = null\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this.tokenSectionName = options.tokenSectionName\n    this.storage = options.storage\n    this.clientId = options.clientId\n    this.singlePromise = new SinglePromise({ clientId: this.clientId })\n    this.credentials = options.credentials || null\n    if (this.credentials) {\n      this.setCredentials(this.credentials)\n    }\n  }\n\n  public getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null\n    const tokenStr: string = this.storage.getItemSync(this.tokenSectionName)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr)\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at)\n        }\n      } catch (error) {\n        this.storage.removeItem(this.tokenSectionName)\n        credentials = null\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      if (!credentials?.expires_at) {\n        credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000)\n      }\n      if (this.storage) {\n        const tokenStr: string = JSON.stringify(credentials)\n        await this.storage.setItem(this.tokenSectionName, tokenStr)\n      }\n      this.credentials = credentials\n    } else {\n      if (this.storage) {\n        await this.storage.removeItem(this.tokenSectionName)\n      }\n      this.credentials = null\n    }\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this.credentials)) {\n        this.credentials = await this.getStorageCredentials()\n      }\n      return this.credentials\n    })\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async getStorageCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null\n      const tokenStr: string = await this.storage.getItem(this.tokenSectionName)\n      if (tokenStr !== undefined && tokenStr !== null) {\n        try {\n          credentials = JSON.parse(tokenStr)\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at)\n          }\n        } catch (error) {\n          await this.storage.removeItem(this.tokenSectionName)\n          credentials = null\n        }\n      }\n      return credentials\n    })\n  }\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static defaultRetry = 2\n  private static minRetry = 0\n  private static maxRetry = 5\n  private static retryInterval = 1000\n\n  private apiOrigin: string\n  private apiPath: string\n  private clientId: string\n  private i18n: ICloudbaseConfig['i18n']\n  private retry: number\n  private clientSecret?: string\n  private baseRequest: <T>(url: string, options?: RequestOptions) => Promise<T>\n  private localCredentials: LocalCredentials\n  private storage: SimpleStorage\n  private deviceID?: string\n  private tokenInURL?: boolean\n  private refreshTokenFunc: (refreshToken?: string, credentials?: Credentials) => Promise<Credentials>\n  private headers?: { [key: string]: string }\n  private singlePromise: SinglePromise = null\n  private anonymousSignInFunc: (Credentials) => Promise<Credentials | void>\n  private wxCloud: any\n  private basicAuth: string\n  private onCredentialsError: AuthOptions['onCredentialsError'] | undefined\n  private publishable_key: ICloudbaseConfig['publishable_key']\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    if (!options.clientSecret) {\n      options.clientSecret = ''\n    }\n\n    if (!options.clientId && options.env) {\n      options.clientId = options.env\n    }\n\n    this.apiOrigin = options.apiOrigin\n    this.apiPath = options.apiPath || AUTH_API_PREFIX\n    this.clientId = options.clientId\n    this.i18n = options.i18n\n    this.publishable_key = options.publishable_key\n    this.singlePromise = new SinglePromise({ clientId: this.clientId })\n    this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry)\n    if (options.baseRequest) {\n      this.baseRequest = options.baseRequest\n    } else {\n      this.baseRequest = defaultRequest\n    }\n    this.tokenInURL = options.tokenInURL\n    this.headers = options.headers\n    // @ts-ignore\n    this.storage = options.storage || defaultStorage\n    this.localCredentials = new LocalCredentials({\n      tokenSectionName: `credentials_${options.clientId}`,\n      storage: this.storage,\n      clientId: options.clientId,\n      credentials: this.publishable_key ? {\n        access_token: this.publishable_key,\n        token_type: 'Bearer',\n        scope: 'publishable_key',\n        expires_at: new Date(+new Date() + +new Date()),\n        expires_in: +new Date() + +new Date(),\n      } : null,\n    })\n\n    this.clientSecret = options.clientSecret\n    if (options.clientId) {\n      this.basicAuth = `Basic ${weBtoa(`${options.clientId}:${this.clientSecret}`)}`\n    }\n    this.wxCloud = options.wxCloud\n    try {\n      if (isMatch() && this.wxCloud === undefined && options.env) {\n        wx.cloud.init({ env: options.env })\n        this.wxCloud = wx.cloud\n      }\n    } catch (error) {\n      //\n    }\n    this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc\n    this.anonymousSignInFunc = options.anonymousSignInFunc\n    this.onCredentialsError = options.onCredentialsError\n\n    langEvent.bus.on(langEvent.LANG_CHANGE_EVENT, (params) => {\n      this.i18n = params.data?.i18n || this.i18n\n    })\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public setCredentials(credentials?: Credentials): Promise<void> {\n    return this.localCredentials.setCredentials(credentials)\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    const credentials: Credentials = await this.getCredentials()\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token)\n    }\n    const respErr: ResponseError = { error: ErrorType.UNAUTHENTICATED }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(url: string, options?: AuthClientRequestOptions): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    const retry: number = this.formatRetry(options.retry, this.retry)\n    options.headers = { ...options.headers, [this.i18n?.LANG_HEADER_KEY]: this.i18n?.lang }\n    if (this.headers) {\n      options.headers = {\n        ...this.headers,\n        ...options.headers,\n      }\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId()\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this.getDeviceId()\n      options.headers[DeviceIdHeaderName] = deviceId\n    }\n    if (options?.withBasicAuth && this.basicAuth) {\n      options.headers.Authorization = this.basicAuth\n    }\n    if (options?.withCredentials) {\n      const credentials = await this.getCredentials()\n      if (credentials) {\n        if (this.tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?'\n          }\n          url += `access_token=${credentials.access_token}`\n        } else {\n          options.headers.Authorization = `${credentials.token_type} ${credentials.access_token}`\n        }\n      }\n    } else {\n      if (this.clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&'\n        url += `client_id=${this.clientId}`\n      }\n    }\n    if (url.startsWith('/')) {\n      url = `${this.apiOrigin}${this.apiPath}${url}`\n    }\n    let response: T | null = null\n    const maxRequestTimes: number = retry + 1\n    for (let requestTime = 0; requestTime < maxRequestTimes; requestTime++) {\n      try {\n        if (options.useWxCloud) {\n          response = await this.wxCloudCallFunction<T>(url, options)\n        } else {\n          response = await this.baseRequest<T>(url, options)\n        }\n        break\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null)\n          return Promise.reject(responseError)\n        }\n\n        if (requestTime === retry || !responseError || responseError.error !== 'unreachable') {\n          return Promise.reject(responseError)\n        }\n      }\n      await this.sleep(OAuth2Client.retryInterval)\n    }\n    return response\n  }\n\n  public async wxCloudCallFunction<T>(url: string, options?: RequestOptions): Promise<T> {\n    let result: T | null = null\n    let responseError: ResponseError | null = null\n    try {\n      let userAgent = ''\n      try {\n        userAgent = await wx.getRendererUserAgent()\n      } catch (error) {}\n      const { result: responseResult } = await this.wxCloud.callFunction({\n        name: 'httpOverCallFunction',\n        data: {\n          url,\n          method: options.method,\n          headers: {\n            origin: 'https://servicewechat.com',\n            'User-Agent': userAgent,\n            ...options.headers,\n          },\n          body: options.body,\n        },\n      })\n\n      if (responseResult?.body?.error_code) {\n        responseError = responseResult?.body as ResponseError\n        responseError.error_uri = getPathName(url)\n      } else {\n        result = responseResult?.body as T\n      }\n    } catch (error) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: error.message,\n        error_uri: getPathName(url),\n      }\n    }\n\n    if (responseError) {\n      throw responseError\n    } else {\n      return result\n    }\n  }\n\n  /**\n   * Get credentials.\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    if (isCredentialsExpired(credentials)) {\n      if (credentials.refresh_token) {\n        try {\n          credentials = await this.refreshToken(credentials)\n        } catch (error) {\n          if (credentials.scope === 'anonymous') {\n            credentials = await this.anonymousLogin(credentials)\n          } else {\n            this.onCredentialsError?.({ msg: error.error_description })\n            return Promise.reject(error)\n          }\n        }\n      } else if (credentials.scope === 'anonymous') {\n        credentials = await this.anonymousLogin(credentials)\n      } else {\n        const msg = 'no refresh token found in credentials'\n        this.onCredentialsError?.({ msg })\n        return this.unAuthenticatedError(msg)\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * @deprecated 废弃接口，勿用. 如需获取凭证信息请使用 getCredentials 方法\n   */\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this.localCredentials.getStorageCredentialsSync()\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    return credentials.scope\n  }\n\n  public async getGroups(): Promise<string[]> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    return credentials.groups\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  public async refreshToken(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        const msg = 'no refresh token found in credentials'\n        this.onCredentialsError?.({ msg })\n        return this.unAuthenticatedError(msg)\n      }\n      try {\n        const newCredentials: Credentials = await this.refreshTokenFunc(credentials.refresh_token, credentials)\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          const msg = error.error_description\n          this.onCredentialsError?.({ msg })\n          return this.unAuthenticatedError(msg)\n        }\n        this.onCredentialsError?.({ msg: error.error_description })\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  private async anonymousLogin(credentials: Credentials) {\n    return this.singlePromise.run('_anonymousLogin', async () => {\n      if (this.anonymousSignInFunc) {\n        const c = await this.anonymousSignInFunc(credentials)\n        credentials = c || (await this.localCredentials.getCredentials())\n      } else {\n        credentials = await this.anonymousSignIn(credentials)\n      }\n\n      return credentials\n    })\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null\n    if (typeof retry !== 'number' || retry < OAuth2Client.minRetry || retry > OAuth2Client.maxRetry) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      }\n    }\n    if (responseError) {\n      throw responseError\n    }\n    return retry\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale\n    }\n    return this.checkRetry(retry)\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve()\n      }, ms)\n    })\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this.unAuthenticatedError('no anonymous in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.request(ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL, {\n          method: 'POST',\n          withBasicAuth: true,\n          body: {},\n        })\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private async defaultRefreshTokenFunc(refreshToken?: string, credentials?: Credentials): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      const msg = 'refresh token not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n\n    let url: string = ApiUrls.AUTH_TOKEN_URL\n\n    if (credentials?.version === 'v2') {\n      url = ApiUrlsV2.AUTH_TOKEN_URL\n    }\n\n    const newCredentials: Credentials = await this.request(url, {\n      method: 'POST',\n      body: {\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    })\n\n    return { ...newCredentials, version: credentials?.version || 'v1' }\n  }\n\n  /**\n   * Get deviceId\n   */\n  private async getDeviceId(): Promise<string> {\n    if (this.deviceID) {\n      return this.deviceID\n    }\n    let deviceId: string = await this.storage.getItem(DeviceIdSectionName)\n    if (!(typeof deviceId === 'string' && deviceId.length >= 16 && deviceId.length <= 48)) {\n      deviceId = uuidv4()\n      await this.storage.setItem(DeviceIdSectionName, deviceId)\n    }\n    this.deviceID = deviceId\n    return deviceId\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private unAuthenticatedError<T>(err?: string): Promise<T> {\n    const respErr: ResponseError = {\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    }\n    return Promise.reject(respErr)\n  }\n}\n"]}
1158
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"oauth2client.js","sourceRoot":"","sources":["../../../src/oauth2client/oauth2client.ts"],"names":[],"mappings":"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","sourcesContent":["import { ErrorType } from './consts'\nimport { ApiUrls, ApiUrlsV2, AUTH_API_PREFIX, AUTH_STATE_CHANGED_TYPE, EVENTS } from '../auth/consts'\n\nimport { AuthClient, SimpleStorage } from './interface'\n\nimport {\n  Credentials,\n  ResponseError,\n  RequestOptions,\n  RequestFunction,\n  OAuth2ClientOptions,\n  AuthClientRequestOptions,\n} from './models'\n\nimport { uuidv4 } from '../utils/uuid'\nimport { getPathName } from '../utils/index'\n\nimport { SinglePromise } from '../utils/function/single-promise'\nimport { weBtoa } from '../utils/base64'\nimport { isMp } from '../utils/mp'\nimport { AuthOptions } from '../auth/apis'\nimport { ICloudbaseConfig } from '@cloudbase/types'\nimport { langEvent } from '@cloudbase/utilities'\n\nconst RequestIdHeaderName = 'x-request-id'\nconst DeviceIdHeaderName = 'x-device-id'\nconst DeviceIdSectionName = 'device_id'\n\ndeclare const wx: any\n\nexport interface ToResponseErrorOptions {\n  error?: ErrorType\n  error_description?: string | null\n  error_uri?: string | null\n  details?: any | null\n}\n\nexport const defaultRequest: RequestFunction = async function <T>(url: string, options?: RequestOptions): Promise<T> {\n  let result: T | null = null\n  let responseError: ResponseError | null = null\n  try {\n    // Objects must be copied to prevent modification of data such as body.\n    const copyOptions = Object.assign({}, options)\n    if (!copyOptions.method) {\n      copyOptions.method = 'GET'\n    }\n    if (copyOptions.body && typeof copyOptions.body !== 'string') {\n      copyOptions.body = JSON.stringify(copyOptions.body)\n    }\n    const responseResult: Response = await fetch(url, copyOptions)\n    const jsonResponse = await responseResult.json()\n    if (jsonResponse?.error) {\n      responseError = jsonResponse as ResponseError\n      responseError.error_uri = new URL(url).pathname\n    } else {\n      result = jsonResponse as T\n    }\n  } catch (error) {\n    responseError = {\n      error: ErrorType.UNREACHABLE,\n      error_description: error.message,\n      error_uri: new URL(url).pathname,\n    }\n  }\n  if (responseError) {\n    throw responseError\n  } else {\n    return result\n  }\n}\n\nexport const toResponseError = (error: ResponseError | Error, options?: ToResponseErrorOptions): ResponseError => {\n  let responseError: ResponseError\n  const formatOptions: ToResponseErrorOptions = options || {}\n  if (error instanceof Error) {\n    responseError = {\n      error: formatOptions.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || error.message,\n      error_uri: formatOptions.error_uri,\n      details: formatOptions.details || error.stack,\n    }\n  } else {\n    const formatError: ToResponseErrorOptions = error || {}\n    responseError = {\n      error: formatOptions.error || formatError.error || ErrorType.LOCAL,\n      error_description: formatOptions.error_description || formatError.error_description,\n      error_uri: formatOptions.error_uri || formatError.error_uri,\n      details: formatOptions.details || formatError.details,\n    }\n  }\n  return responseError\n}\n\n/**\n * Generate request id.\n * @return {string}\n */\nexport function generateRequestId(): string {\n  return uuidv4()\n}\n\n/**\n * Default Storage.\n */\nclass DefaultStorage implements SimpleStorage {\n  /**\n   * 缓存key统一使用后缀区分\n   */\n  // eslint-disable-next-line @typescript-eslint/naming-convention\n  private readonly _env: string\n\n  constructor(opts?: { env: string }) {\n    this._env = opts?.env || ''\n  }\n  /**\n   * Get item.\n   * @param {string} key\n   */\n  async getItem(key: string): Promise<string | null> {\n    return window.localStorage.getItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Remove item.\n   * @param {string} key\n   */\n  async removeItem(key: string): Promise<void> {\n    window.localStorage.removeItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Set item.\n   * @param {string} key\n   * @param {string} value\n   */\n  async setItem(key: string, value: string): Promise<void> {\n    window.localStorage.setItem(`${key}${this._env}`, value)\n  }\n\n  /**\n   * Get item sync.\n   * @param {string} key\n   */\n  getItemSync(key: string): string | null {\n    return window.localStorage.getItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Remove item sync.\n   * @param {string} key\n   */\n  removeItemSync(key: string): void {\n    window.localStorage.removeItem(`${key}${this._env}`)\n  }\n\n  /**\n   * Set item sync.\n   * @param {string} key\n   * @param {string} value\n   */\n  setItemSync(key: string, value: string): void {\n    window.localStorage.setItem(`${key}${this._env}`, value)\n  }\n}\n\nexport const defaultStorage = new DefaultStorage()\n\ninterface LocalCredentialsOptions {\n  tokenSectionName: string\n  storage: SimpleStorage\n  clientId: string\n  credentials?: Credentials\n}\n\n/**\n * Check if credentials is expired.\n * @param {Credentials} credentials\n * @return {boolean}\n */\nfunction isCredentialsExpired(credentials: Credentials): boolean {\n  let isExpired = true\n  if (credentials?.expires_at && credentials?.access_token) {\n    isExpired = credentials.expires_at < new Date()\n  }\n  return isExpired\n}\n\n/**\n * Local credentials.\n * Local credentials, with memory cache and storage cache.\n * If the memory cache expires, the storage cache is automatically loaded.\n */\nclass LocalCredentials {\n  private tokenSectionName: string\n\n  private storage: SimpleStorage\n\n  private clientId: string\n\n  private credentials: Credentials | null = null\n  // 来自accessKey的身份，不持久化\n  private accessKeyCredentials: Credentials | null = null\n\n  private singlePromise: SinglePromise = null\n\n  /**\n   * constructor\n   * @param {LocalCredentialsOptions} options\n   */\n  constructor(options: LocalCredentialsOptions) {\n    this.tokenSectionName = options.tokenSectionName\n    this.storage = options.storage\n    this.clientId = options.clientId\n    this.singlePromise = new SinglePromise({ clientId: this.clientId })\n    this.credentials = options.credentials || null\n  }\n\n  public getStorageCredentialsSync(): Credentials | null {\n    let credentials: Credentials = null\n    const tokenStr: string = this.storage.getItemSync(this.tokenSectionName)\n    if (tokenStr !== undefined && tokenStr !== null) {\n      try {\n        credentials = JSON.parse(tokenStr)\n        if (credentials?.expires_at) {\n          credentials.expires_at = new Date(credentials.expires_at)\n        }\n      } catch (error) {\n        this.storage.removeItem(this.tokenSectionName)\n        credentials = null\n      }\n    }\n    return credentials\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    if (credentials?.expires_in) {\n      if (!credentials?.expires_at) {\n        credentials.expires_at = new Date(Date.now() + (credentials.expires_in - 30) * 1000)\n      }\n      if (this.storage) {\n        const tokenStr: string = JSON.stringify(credentials)\n        await this.storage.setItem(this.tokenSectionName, tokenStr)\n      }\n      this.credentials = credentials\n    } else {\n      if (this.storage) {\n        await this.storage.removeItem(this.tokenSectionName)\n      }\n      this.credentials = null\n    }\n  }\n\n  /**\n   * set credentials from accessKey\n   * @param {Credentials} credentials\n   */\n  public setAccessKeyCredentials(credentials?: Credentials) {\n    this.accessKeyCredentials = credentials\n  }\n\n  /**\n   * Get credentials.\n   * @return {Promise<Credentials | null>}\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    return this.singlePromise.run('getCredentials', async () => {\n      if (isCredentialsExpired(this.credentials)) {\n        const { credentials, isAccessKeyCredentials } = await this.getStorageCredentials()\n        if (isAccessKeyCredentials) {\n          return credentials\n        }\n        this.credentials = credentials\n      }\n      return this.credentials\n    })\n  }\n\n  /**\n   * Get storage credentials.\n   */\n  private async getStorageCredentials(): Promise<{ credentials: Credentials | null; isAccessKeyCredentials: boolean }> {\n    return this.singlePromise.run('_getStorageCredentials', async () => {\n      let credentials: Credentials = null\n      let isAccessKeyCredentials = false\n      const tokenStr: string = await this.storage.getItem(this.tokenSectionName)\n      if (!!tokenStr) {\n        try {\n          credentials = JSON.parse(tokenStr)\n          if (credentials?.expires_at) {\n            credentials.expires_at = new Date(credentials.expires_at)\n          }\n        } catch (error) {\n          await this.storage.removeItem(this.tokenSectionName)\n          credentials = null\n        }\n      } else {\n        credentials = this.accessKeyCredentials || null\n        isAccessKeyCredentials = true\n      }\n      return { credentials, isAccessKeyCredentials }\n    })\n  }\n}\n\n/**\n * OAuth2Client\n */\nexport class OAuth2Client implements AuthClient {\n  private static defaultRetry = 2\n  private static minRetry = 0\n  private static maxRetry = 5\n  private static retryInterval = 1000\n\n  public localCredentials: LocalCredentials\n  /**\n   * Keeps track of the async client initialization.\n   * When null or not yet resolved the auth state is `unknown`\n   * Once resolved the auth state is known and it's safe to call any further client methods.\n   */\n  public initializePromise: Promise<{ error: Error | null }> | null = null\n  protected lockAcquired = false\n  protected pendingInLock: Promise<any>[] = []\n  protected logDebugMessages: boolean\n  protected getInitialSession?: () => Promise<{\n    data: { session: Credentials; user?: any } | null\n    error: Error | null\n  }>\n  private apiOrigin: string\n  private apiPath: string\n  private clientId: string\n  private i18n: ICloudbaseConfig['i18n']\n  private retry: number\n  private clientSecret?: string\n  private baseRequest: <T>(url: string, options?: RequestOptions) => Promise<T>\n  private storage: SimpleStorage\n  private deviceID?: string\n  private tokenInURL?: boolean\n  private refreshTokenFunc: (refreshToken?: string, credentials?: Credentials) => Promise<Credentials>\n  private headers?: { [key: string]: string }\n  private singlePromise: SinglePromise = null\n  private anonymousSignInFunc: (Credentials) => Promise<Credentials | void>\n  private wxCloud: any\n  private useWxCloud: boolean\n  private eventBus: any\n  private basicAuth: string\n  private onCredentialsError: AuthOptions['onCredentialsError'] | undefined\n  private onInitialSessionObtained?: (data: { session: Credentials; user?: any }, error?: any) => void | Promise<void>\n\n  /**\n   * constructor\n   * @param {OAuth2ClientOptions} options\n   */\n  constructor(options: OAuth2ClientOptions) {\n    if (!options.clientSecret) {\n      options.clientSecret = ''\n    }\n\n    if (!options.clientId && options.env) {\n      options.clientId = options.env\n    }\n\n    this.apiOrigin = options.apiOrigin\n    this.apiPath = options.apiPath || AUTH_API_PREFIX\n    this.clientId = options.clientId\n    this.i18n = options.i18n\n    this.eventBus = options.eventBus\n    this.singlePromise = new SinglePromise({ clientId: this.clientId })\n    this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry)\n    if (options.baseRequest) {\n      this.baseRequest = options.baseRequest\n    } else {\n      this.baseRequest = defaultRequest\n    }\n    this.tokenInURL = options.tokenInURL\n    this.headers = options.headers\n    // @ts-ignore\n    this.storage = options.storage || defaultStorage\n    this.localCredentials = new LocalCredentials({\n      tokenSectionName: `credentials_${options.clientId}`,\n      storage: this.storage,\n      clientId: options.clientId,\n    })\n\n    this.clientSecret = options.clientSecret\n    if (options.clientId) {\n      this.basicAuth = `Basic ${weBtoa(`${options.clientId}:${this.clientSecret}`)}`\n    }\n    this.wxCloud = options.wxCloud\n    try {\n      if (isMp()) {\n        this.useWxCloud = options.useWxCloud\n        if (this.wxCloud === undefined && options.env) {\n          wx.cloud.init({ env: options.env })\n          this.wxCloud = wx.cloud\n        }\n      }\n    } catch (error) {\n      //\n    }\n    this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc\n    this.anonymousSignInFunc = options.anonymousSignInFunc\n    this.onCredentialsError = options.onCredentialsError\n\n    // New options for session detection\n    this.getInitialSession = options.getInitialSession\n    this.onInitialSessionObtained = options.onInitialSessionObtained\n    this.logDebugMessages = options.debug ?? false\n\n    langEvent.bus.on(langEvent.LANG_CHANGE_EVENT, (params: any) => {\n      this.i18n = params.data?.i18n || this.i18n\n    })\n\n    // Note: Auto-initialize is NOT called here to allow CloudbaseOAuth to set getInitialSession first\n    // CloudbaseOAuth.constructor will call initialize() after setting up the callback\n  }\n\n  /**\n   * Sets the getInitialSession callback.\n   * This callback is called during initialize() to get the initial session (e.g., from OAuth callback in URL).\n   * @param callback The callback function to get initial session\n   */\n  public setGetInitialSession(callback: () => Promise<{\n    data: { session: Credentials; user?: any } | null\n    error: Error | null\n  }>,): void {\n    this.getInitialSession = callback\n  }\n\n  /**\n   * Sets the onInitialSessionObtained callback.\n   * This callback is invoked after initial session is obtained and stored,\n   * allowing upper layers to handle user info storage.\n   * @param callback The callback function to handle session and user data\n   */\n  public setOnInitialSessionObtained(callback: (data: { session: Credentials; user?: any }) => void | Promise<void>,): void {\n    this.onInitialSessionObtained = callback\n  }\n\n  /**\n   * Initializes the client session either from the url or from storage.\n   * This method is automatically called when instantiating the client with detectSessionInUrl=true,\n   * but should also be called manually when checking for an error from an auth redirect.\n   * @param onInitialSessionObtained Optional callback to set before initialization starts\n   */\n  async initialize(func?:  Promise<{ error: Error | null }>): Promise<{ error: Error | null }> {\n    // eslint-disable-next-line @typescript-eslint/no-misused-promises\n    if (this.initializePromise) {\n      return await this.initializePromise\n    }\n\n    if (func !== undefined) {\n      this.initializePromise = func\n      return await this.initializePromise\n    }\n\n    this.initializePromise = (async () => await this._acquireLock(-1, async () => await this._initialize()))()\n\n    return await this.initializePromise\n  }\n\n  /**\n   * setCredentials Provides an alternative fetch api request implementation with auth credentials\n   * @param {Credentials} credentials\n   * @return {Promise<void>}\n   */\n  public async setCredentials(credentials?: Credentials): Promise<void> {\n    // If initialization is in progress, wait for it first\n    await this.initializePromise\n    return this._acquireLock(-1, async () => this.localCredentials.setCredentials(credentials))\n  }\n\n  /**\n   * set credentials from accessKey\n   * @param {Credentials} credentials\n   */\n  public setAccessKeyCredentials(credentials?: Credentials) {\n    return this.localCredentials.setAccessKeyCredentials(credentials)\n  }\n\n  /**\n   * getAccessToken return a validate access token\n   */\n  public async getAccessToken(): Promise<string> {\n    // If initialization is in progress, wait for it first\n    await this.initializePromise\n    const credentials: Credentials = await this.getCredentials()\n    if (credentials?.access_token) {\n      return Promise.resolve(credentials.access_token)\n    }\n    const respErr: ResponseError = { error: ErrorType.UNAUTHENTICATED }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * request http like simple fetch api, exp:request('/v1/user/me', {withCredentials:true})\n   * @param {string} url\n   * @param {AuthClientRequestOptions} options\n   */\n  public async request<T>(url: string, options?: AuthClientRequestOptions): Promise<T> {\n    if (!options) {\n      options = {}\n    }\n    const retry: number = this.formatRetry(options.retry, this.retry)\n    options.headers = { ...options.headers, [this.i18n?.LANG_HEADER_KEY]: this.i18n?.lang }\n    if (this.headers) {\n      options.headers = {\n        ...this.headers,\n        ...options.headers,\n      }\n    }\n    if (!options.headers[RequestIdHeaderName]) {\n      options.headers[RequestIdHeaderName] = generateRequestId()\n    }\n    if (!options.headers[DeviceIdHeaderName]) {\n      const deviceId = await this.getDeviceId()\n      options.headers[DeviceIdHeaderName] = deviceId\n    }\n    if (options?.withBasicAuth && this.basicAuth) {\n      options.headers.Authorization = this.basicAuth\n    }\n    if (options?.withCredentials) {\n      // Use custom getCredentials function if provided, otherwise use default\n      // Custom getCredentials avoids default getCredentials() call which may cause deadlock during initialization\n      const credentials = options.getCredentials ? await options.getCredentials() : await this.getCredentials()\n      if (credentials) {\n        if (this.tokenInURL) {\n          if (url.indexOf('?') < 0) {\n            url += '?'\n          }\n          url += `access_token=${credentials.access_token}`\n        } else {\n          options.headers.Authorization = `${credentials.token_type} ${credentials.access_token}`\n        }\n      }\n    } else {\n      if (this.clientId && url.indexOf('client_id') < 0) {\n        url += url.indexOf('?') < 0 ? '?' : '&'\n        url += `client_id=${this.clientId}`\n      }\n    }\n    if (url.startsWith('/')) {\n      url = `${this.apiOrigin}${this.apiPath}${url}`\n    }\n    let response: T | null = null\n    const maxRequestTimes: number = retry + 1\n    for (let requestTime = 0; requestTime < maxRequestTimes; requestTime++) {\n      try {\n        if (options.useWxCloud || this.useWxCloud) {\n          response = await this.wxCloudCallFunction<T>(url, options)\n        } else {\n          response = await this.baseRequest<T>(url, options)\n        }\n\n        if (!!(response as any)?.code) {\n          throw ({\n            error: (response as any).code,\n            error_description: (response as any).message,\n            error_uri: new URL(url).pathname,\n          })\n        }\n\n        break\n      } catch (responseError) {\n        if (options.withCredentials && responseError && responseError.error === ErrorType.UNAUTHENTICATED) {\n          await this.setCredentials(null)\n          return Promise.reject(responseError)\n        }\n\n        if (requestTime === retry || !responseError || responseError.error !== 'unreachable') {\n          return Promise.reject(responseError)\n        }\n      }\n      await this.sleep(OAuth2Client.retryInterval)\n    }\n    return response\n  }\n\n  public async wxCloudCallFunction<T>(url: string, options?: RequestOptions): Promise<T> {\n    let result: T | null = null\n    let responseError: ResponseError | null = null\n    try {\n      let userAgent = ''\n      try {\n        userAgent = await wx.getRendererUserAgent()\n      } catch (error) {}\n      const { result: responseResult } = await this.wxCloud.callFunction({\n        name: 'httpOverCallFunction',\n        data: {\n          url,\n          method: options.method,\n          headers: {\n            origin: 'https://servicewechat.com',\n            'User-Agent': userAgent,\n            ...options.headers,\n          },\n          body: options.body,\n        },\n      })\n\n      if (responseResult?.body?.error_code) {\n        responseError = responseResult?.body as ResponseError\n        responseError.error_uri = getPathName(url)\n      } else {\n        result = responseResult?.body as T\n      }\n    } catch (error) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: error.message,\n        error_uri: getPathName(url),\n      }\n    }\n\n    if (responseError) {\n      throw responseError\n    } else {\n      return result\n    }\n  }\n\n  /**\n   * Get credentials.\n   */\n  public async getCredentials(): Promise<Credentials | null> {\n    // If initialization is in progress, wait for it first\n    await this.initializePromise\n\n    return this._acquireLock(-1, async () => this._getCredentials())\n  }\n\n  /**\n   * @deprecated 废弃接口，勿用. 如需获取凭证信息请使用 getCredentials 方法\n   */\n  public getCredentialsSync(): Credentials | null {\n    const credentials: Credentials = this.localCredentials.getStorageCredentialsSync()\n    return credentials\n  }\n\n  public getCredentialsAsync(): Promise<Credentials | null> {\n    return this.getCredentials()\n  }\n\n  public async getScope(): Promise<string> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    return credentials.scope\n  }\n\n  public async getGroups(): Promise<string[]> {\n    const credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    return credentials.groups\n  }\n\n  /**\n   * Refresh expired token.\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  public async refreshToken(credentials: Credentials, options?: { throwError?: boolean }): Promise<Credentials> {\n    // If initialization is in progress, wait for it first\n    await this.initializePromise\n\n    return this._acquireLock(-1, async () => this._refreshToken(credentials, options))\n  }\n\n  /**\n   * Internal refresh token method (called within lock)\n   */\n  private async _refreshToken(credentials: Credentials, options?: { throwError?: boolean }): Promise<Credentials> {\n    return this.singlePromise.run('_refreshToken', async () => {\n      if (!credentials || !credentials.refresh_token) {\n        const msg = 'no refresh token found in credentials'\n        this.onCredentialsError?.({ msg })\n        return this.unAuthenticatedError(msg)\n      }\n      try {\n        const newCredentials: Credentials = await this.refreshTokenFunc(credentials.refresh_token, credentials)\n        await this.localCredentials.setCredentials(newCredentials)\n\n        this.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.TOKEN_REFRESHED })\n\n        return newCredentials\n      } catch (error) {\n        if (options?.throwError) {\n          throw error\n        }\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          const msg = error.error_description\n          this.onCredentialsError?.({ msg })\n          return this.unAuthenticatedError(msg)\n        }\n        this.onCredentialsError?.({ msg: error.error_description })\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  private async anonymousLogin(credentials: Credentials) {\n    return this.singlePromise.run('_anonymousLogin', async () => {\n      if (this.anonymousSignInFunc) {\n        const c = await this.anonymousSignInFunc(credentials)\n        credentials = c || (await this.localCredentials.getCredentials())\n      } else {\n        credentials = await this.anonymousSignIn(credentials)\n      }\n\n      return credentials\n    })\n  }\n\n  /**\n   * Check retry value.\n   * @param {number} retry\n   * @return {number}\n   */\n  private checkRetry(retry: number): number {\n    let responseError: ResponseError | null = null\n    if (typeof retry !== 'number' || retry < OAuth2Client.minRetry || retry > OAuth2Client.maxRetry) {\n      responseError = {\n        error: ErrorType.UNREACHABLE,\n        error_description: 'wrong options param: retry',\n      }\n    }\n    if (responseError) {\n      throw responseError\n    }\n    return retry\n  }\n\n  /**\n   * Format retry value.\n   * @param {number} retry\n   * @param {number} defaultVale\n   * @return {number}\n   */\n  private formatRetry(retry: number, defaultVale: number): number {\n    if (typeof retry === 'undefined') {\n      return defaultVale\n    }\n    return this.checkRetry(retry)\n  }\n\n  /**\n   * Sleep.\n   * @param {number} ms\n   * @return {Promise<void>}\n   */\n  private async sleep(ms: number): Promise<void> {\n    return new Promise<void>((resolve) => {\n      setTimeout(() => {\n        resolve()\n      }, ms)\n    })\n  }\n\n  /**\n   * anonymous signIn\n   * @param {Credentials} credentials\n   * @return {Promise<Credentials>}\n   */\n  private async anonymousSignIn(credentials: Credentials): Promise<Credentials> {\n    return this.singlePromise.run('_anonymous', async () => {\n      if (!credentials || credentials.scope !== 'anonymous') {\n        return this.unAuthenticatedError('no anonymous in credentials')\n      }\n      try {\n        const newCredentials: Credentials = await this.request(ApiUrls.AUTH_SIGN_IN_ANONYMOUSLY_URL, {\n          method: 'POST',\n          withBasicAuth: true,\n          body: {},\n        })\n        await this.localCredentials.setCredentials(newCredentials)\n        return newCredentials\n      } catch (error) {\n        if (error.error === ErrorType.INVALID_GRANT) {\n          await this.localCredentials.setCredentials(null)\n          return this.unAuthenticatedError(error.error_description)\n        }\n        return Promise.reject(error)\n      }\n    })\n  }\n\n  /**\n   * Default refresh token function.\n   * @param {string} refreshToken\n   * @return {Promise<Credentials>}\n   */\n  private async defaultRefreshTokenFunc(refreshToken?: string, credentials?: Credentials): Promise<Credentials> {\n    if (refreshToken === undefined || refreshToken === '') {\n      const msg = 'refresh token not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n\n    let url: string = ApiUrls.AUTH_TOKEN_URL\n\n    if (credentials?.version === 'v2') {\n      url = ApiUrlsV2.AUTH_TOKEN_URL\n    }\n\n    const newCredentials: Credentials = await this.request(url, {\n      method: 'POST',\n      body: {\n        client_id: this.clientId,\n        client_secret: this.clientSecret,\n        grant_type: 'refresh_token',\n        refresh_token: refreshToken,\n      },\n    })\n\n    return { ...newCredentials, version: credentials?.version || 'v1' }\n  }\n\n  /**\n   * Get deviceId\n   */\n  private async getDeviceId(): Promise<string> {\n    if (this.deviceID) {\n      return this.deviceID\n    }\n    let deviceId: string = await this.storage.getItem(DeviceIdSectionName)\n    if (!(typeof deviceId === 'string' && deviceId.length >= 16 && deviceId.length <= 48)) {\n      deviceId = uuidv4()\n      await this.storage.setItem(DeviceIdSectionName, deviceId)\n    }\n    this.deviceID = deviceId\n    return deviceId\n  }\n  /**\n   * Generate unAuthenticated error.\n   * @param {string} err\n   * @return {Promise<T>}\n   */\n  private unAuthenticatedError<T>(err?: string): Promise<T> {\n    const respErr: ResponseError = {\n      error: ErrorType.UNAUTHENTICATED,\n      error_description: err,\n    }\n    return Promise.reject(respErr)\n  }\n\n  /**\n   * Debug logging helper\n   */\n  private _debug(...args: any[]): void {\n    if (this.logDebugMessages) {\n      console.log('[OAuth2Client]', ...args)\n    }\n  }\n\n  /**\n   * IMPORTANT:\n   * 1. Never throw in this method, as it is called from the constructor\n   * 2. Never return a session from this method as it would be cached over\n   *    the whole lifetime of the client\n   */\n  private async _initialize(): Promise<{ error: Error | null }> {\n    try {\n      // If no getInitialSession callback is set, nothing to do\n      if (!this.getInitialSession) {\n        this._debug('#_initialize()', 'no getInitialSession callback set, skipping')\n        return { error: null }\n      }\n\n      this._debug('#_initialize()', 'calling getInitialSession callback')\n\n      try {\n        const { data, error } = await this.getInitialSession()\n\n        if (data?.session) {\n          this._debug('#_initialize()', 'session obtained from getInitialSession', data.session)\n          await this.localCredentials.setCredentials(data?.session)\n        }\n\n        // Invoke callback for upper layer to handle user storage\n        // This is called BEFORE lock is released so user storage is atomic with session\n        if (this.onInitialSessionObtained) {\n          this._debug('#_initialize()', 'calling onInitialSessionObtained callback')\n          try {\n            await this.onInitialSessionObtained(data, error)\n          } catch (callbackError) {\n            this._debug('#_initialize()', 'error in onInitialSessionObtained', callbackError)\n            // Don't fail initialization if callback fails\n          }\n        }\n        if (error) {\n          this._debug('#_initialize()', 'error from getInitialSession', error)\n          return { error }\n        }\n\n        return { error: null }\n      } catch (err) {\n        this._debug('#_initialize()', 'exception during getInitialSession', err)\n        return { error: err instanceof Error ? err : new Error(String(err)) }\n      }\n    } catch (error) {\n      this._debug('#_initialize()', 'unexpected error', error)\n      return { error: error instanceof Error ? error : new Error(String(error)) }\n    } finally {\n      this._debug('#_initialize()', 'end')\n    }\n  }\n\n  /**\n   * Acquires a global lock based on the client ID.\n   * This ensures that only one operation can modify credentials at a time.\n   */\n  private async _acquireLock<R>(acquireTimeout: number, fn: () => Promise<R>): Promise<R> {\n    this._debug('#_acquireLock', 'begin', acquireTimeout)\n\n    try {\n      if (this.lockAcquired) {\n        // Lock is already acquired, queue the operation\n        const last = this.pendingInLock.length ? this.pendingInLock[this.pendingInLock.length - 1] : Promise.resolve()\n\n        const result = (async () => {\n          await last\n          return await fn()\n        })()\n\n        this.pendingInLock.push((async () => {\n          try {\n            await result\n          } catch (_e: any) {\n            // we just care if it finished\n          }\n        })(),)\n\n        return result\n      }\n\n      // Acquire the lock\n      this._debug('#_acquireLock', 'acquiring lock for client', this.clientId)\n\n      try {\n        this.lockAcquired = true\n\n        const result = fn()\n\n        this.pendingInLock.push((async () => {\n          try {\n            await result\n          } catch (_e: any) {\n            // we just care if it finished\n          }\n        })(),)\n\n        await result\n\n        // keep draining the queue until there's nothing to wait on\n        while (this.pendingInLock.length) {\n          const waitOn = [...this.pendingInLock]\n          await Promise.all(waitOn)\n          this.pendingInLock.splice(0, waitOn.length)\n        }\n\n        return await result\n      } finally {\n        this._debug('#_acquireLock', 'releasing lock for client', this.clientId)\n        this.lockAcquired = false\n      }\n    } finally {\n      this._debug('#_acquireLock', 'end')\n    }\n  }\n\n  /**\n   * Internal method to get credentials (called within lock)\n   */\n  private async _getCredentials(): Promise<Credentials | null> {\n    let credentials: Credentials = await this.localCredentials.getCredentials()\n    if (!credentials) {\n      const msg = 'credentials not found'\n      this.onCredentialsError?.({ msg })\n      return this.unAuthenticatedError(msg)\n    }\n    if (isCredentialsExpired(credentials)) {\n      if (credentials.refresh_token) {\n        try {\n          credentials = await this._refreshToken(credentials)\n        } catch (error) {\n          if (credentials.scope === 'anonymous') {\n            credentials = await this.anonymousLogin(credentials)\n          } else {\n            this.onCredentialsError?.({ msg: error.error_description })\n            return Promise.reject(error)\n          }\n        }\n      } else if (credentials.scope === 'anonymous') {\n        credentials = await this.anonymousLogin(credentials)\n      } else {\n        const msg = 'no refresh token found in credentials'\n        this.onCredentialsError?.({ msg })\n        return this.unAuthenticatedError(msg)\n      }\n    }\n    return credentials\n  }\n}\n"]}