@cloudbase/oauth 2.23.3 → 2.24.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/auth/apis.js +170 -14
- package/dist/cjs/auth/auth-error.js +32 -0
- package/dist/cjs/auth/consts.js +24 -2
- package/dist/cjs/auth/models.js +1 -1
- package/dist/cjs/captcha/captcha-dom.js +223 -0
- package/dist/cjs/captcha/captcha.js +11 -102
- package/dist/cjs/index.js +25 -3
- package/dist/cjs/oauth2client/interface.js +1 -1
- package/dist/cjs/oauth2client/models.js +1 -1
- package/dist/cjs/oauth2client/oauth2client.js +384 -110
- package/dist/cjs/utils/base64.js +15 -2
- package/dist/esm/auth/apis.js +113 -2
- package/dist/esm/auth/auth-error.js +9 -0
- package/dist/esm/auth/consts.js +22 -0
- package/dist/esm/captcha/captcha-dom.js +129 -0
- package/dist/esm/captcha/captcha.js +14 -97
- package/dist/esm/index.js +18 -2
- package/dist/esm/oauth2client/oauth2client.js +162 -36
- package/dist/esm/utils/base64.js +12 -0
- package/dist/miniprogram/index.js +1 -1
- package/dist/types/auth/apis.d.ts +19 -1
- package/dist/types/auth/auth-error.d.ts +6 -0
- package/dist/types/auth/consts.d.ts +22 -0
- package/dist/types/auth/models.d.ts +2 -0
- package/dist/types/captcha/captcha-dom.d.ts +3 -0
- package/dist/types/captcha/captcha.d.ts +3 -1
- package/dist/types/index.d.ts +11 -2
- package/dist/types/oauth2client/interface.d.ts +1 -1
- package/dist/types/oauth2client/models.d.ts +14 -0
- package/dist/types/oauth2client/oauth2client.d.ts +58 -2
- package/dist/types/utils/base64.d.ts +5 -0
- package/package.json +4 -4
- package/src/auth/apis.ts +189 -4
- package/src/auth/auth-error.ts +21 -0
- package/src/auth/consts.ts +28 -0
- package/src/auth/models.ts +2 -0
- package/src/captcha/captcha-dom.ts +178 -0
- package/src/captcha/captcha.ts +25 -115
- package/src/index.ts +51 -3
- package/src/oauth2client/interface.ts +1 -1
- package/src/oauth2client/models.ts +28 -0
- package/src/oauth2client/oauth2client.ts +254 -34
- package/src/utils/base64.ts +12 -0
|
@@ -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");
|
|
@@ -321,6 +330,10 @@ var LocalCredentials = (function () {
|
|
|
321
330
|
var OAuth2Client = exports.OAuth2Client = (function () {
|
|
322
331
|
function OAuth2Client(options) {
|
|
323
332
|
var _this = this;
|
|
333
|
+
var _a;
|
|
334
|
+
this.initializePromise = null;
|
|
335
|
+
this.lockAcquired = false;
|
|
336
|
+
this.pendingInLock = [];
|
|
324
337
|
this.singlePromise = null;
|
|
325
338
|
if (!options.clientSecret) {
|
|
326
339
|
options.clientSecret = '';
|
|
@@ -332,6 +345,7 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
332
345
|
this.apiPath = options.apiPath || consts_2.AUTH_API_PREFIX;
|
|
333
346
|
this.clientId = options.clientId;
|
|
334
347
|
this.i18n = options.i18n;
|
|
348
|
+
this.eventBus = options.eventBus;
|
|
335
349
|
this.singlePromise = new single_promise_1.SinglePromise({ clientId: this.clientId });
|
|
336
350
|
this.retry = this.formatRetry(options.retry, OAuth2Client.defaultRetry);
|
|
337
351
|
if (options.baseRequest) {
|
|
@@ -367,13 +381,64 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
367
381
|
this.refreshTokenFunc = options.refreshTokenFunc || this.defaultRefreshTokenFunc;
|
|
368
382
|
this.anonymousSignInFunc = options.anonymousSignInFunc;
|
|
369
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;
|
|
370
387
|
utilities_1.langEvent.bus.on(utilities_1.langEvent.LANG_CHANGE_EVENT, function (params) {
|
|
371
388
|
var _a;
|
|
372
389
|
_this.i18n = ((_a = params.data) === null || _a === void 0 ? void 0 : _a.i18n) || _this.i18n;
|
|
373
390
|
});
|
|
374
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 () {
|
|
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
|
+
this.initializePromise = (function () { return __awaiter(_this, void 0, void 0, function () {
|
|
409
|
+
var _this = this;
|
|
410
|
+
return __generator(this, function (_a) {
|
|
411
|
+
switch (_a.label) {
|
|
412
|
+
case 0: return [4, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
|
413
|
+
switch (_a.label) {
|
|
414
|
+
case 0: return [4, this._initialize()];
|
|
415
|
+
case 1: return [2, _a.sent()];
|
|
416
|
+
}
|
|
417
|
+
}); }); })];
|
|
418
|
+
case 1: return [2, _a.sent()];
|
|
419
|
+
}
|
|
420
|
+
});
|
|
421
|
+
}); })();
|
|
422
|
+
return [4, this.initializePromise];
|
|
423
|
+
case 3: return [2, _a.sent()];
|
|
424
|
+
}
|
|
425
|
+
});
|
|
426
|
+
});
|
|
427
|
+
};
|
|
375
428
|
OAuth2Client.prototype.setCredentials = function (credentials) {
|
|
376
|
-
return this
|
|
429
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
430
|
+
var _this = this;
|
|
431
|
+
return __generator(this, function (_a) {
|
|
432
|
+
switch (_a.label) {
|
|
433
|
+
case 0: return [4, this.initializePromise];
|
|
434
|
+
case 1:
|
|
435
|
+
_a.sent();
|
|
436
|
+
return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
|
437
|
+
return [2, this.localCredentials.setCredentials(credentials)];
|
|
438
|
+
}); }); })];
|
|
439
|
+
}
|
|
440
|
+
});
|
|
441
|
+
});
|
|
377
442
|
};
|
|
378
443
|
OAuth2Client.prototype.setAccessKeyCredentials = function (credentials) {
|
|
379
444
|
return this.localCredentials.setAccessKeyCredentials(credentials);
|
|
@@ -383,8 +448,11 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
383
448
|
var credentials, respErr;
|
|
384
449
|
return __generator(this, function (_a) {
|
|
385
450
|
switch (_a.label) {
|
|
386
|
-
case 0: return [4, this.
|
|
451
|
+
case 0: return [4, this.initializePromise];
|
|
387
452
|
case 1:
|
|
453
|
+
_a.sent();
|
|
454
|
+
return [4, this.getCredentials()];
|
|
455
|
+
case 2:
|
|
388
456
|
credentials = _a.sent();
|
|
389
457
|
if (credentials === null || credentials === void 0 ? void 0 : credentials.access_token) {
|
|
390
458
|
return [2, Promise.resolve(credentials.access_token)];
|
|
@@ -398,16 +466,16 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
398
466
|
OAuth2Client.prototype.request = function (url, options) {
|
|
399
467
|
var _a, _b;
|
|
400
468
|
return __awaiter(this, void 0, void 0, function () {
|
|
401
|
-
var retry, deviceId, credentials, response, maxRequestTimes, requestTime, responseError_1;
|
|
402
|
-
var
|
|
403
|
-
return __generator(this, function (
|
|
404
|
-
switch (
|
|
469
|
+
var retry, deviceId, credentials, _c, response, maxRequestTimes, requestTime, responseError_1;
|
|
470
|
+
var _d;
|
|
471
|
+
return __generator(this, function (_f) {
|
|
472
|
+
switch (_f.label) {
|
|
405
473
|
case 0:
|
|
406
474
|
if (!options) {
|
|
407
475
|
options = {};
|
|
408
476
|
}
|
|
409
477
|
retry = this.formatRetry(options.retry, this.retry);
|
|
410
|
-
options.headers = __assign(__assign({}, options.headers), (
|
|
478
|
+
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));
|
|
411
479
|
if (this.headers) {
|
|
412
480
|
options.headers = __assign(__assign({}, this.headers), options.headers);
|
|
413
481
|
}
|
|
@@ -417,17 +485,25 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
417
485
|
if (!!options.headers[DeviceIdHeaderName]) return [3, 2];
|
|
418
486
|
return [4, this.getDeviceId()];
|
|
419
487
|
case 1:
|
|
420
|
-
deviceId =
|
|
488
|
+
deviceId = _f.sent();
|
|
421
489
|
options.headers[DeviceIdHeaderName] = deviceId;
|
|
422
|
-
|
|
490
|
+
_f.label = 2;
|
|
423
491
|
case 2:
|
|
424
492
|
if ((options === null || options === void 0 ? void 0 : options.withBasicAuth) && this.basicAuth) {
|
|
425
493
|
options.headers.Authorization = this.basicAuth;
|
|
426
494
|
}
|
|
427
|
-
if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3,
|
|
428
|
-
return [
|
|
495
|
+
if (!(options === null || options === void 0 ? void 0 : options.withCredentials)) return [3, 7];
|
|
496
|
+
if (!options.getCredentials) return [3, 4];
|
|
497
|
+
return [4, options.getCredentials()];
|
|
429
498
|
case 3:
|
|
430
|
-
|
|
499
|
+
_c = _f.sent();
|
|
500
|
+
return [3, 6];
|
|
501
|
+
case 4: return [4, this.getCredentials()];
|
|
502
|
+
case 5:
|
|
503
|
+
_c = _f.sent();
|
|
504
|
+
_f.label = 6;
|
|
505
|
+
case 6:
|
|
506
|
+
credentials = _c;
|
|
431
507
|
if (credentials) {
|
|
432
508
|
if (this.tokenInURL) {
|
|
433
509
|
if (url.indexOf('?') < 0) {
|
|
@@ -439,56 +515,56 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
439
515
|
options.headers.Authorization = "".concat(credentials.token_type, " ").concat(credentials.access_token);
|
|
440
516
|
}
|
|
441
517
|
}
|
|
442
|
-
return [3,
|
|
443
|
-
case
|
|
518
|
+
return [3, 8];
|
|
519
|
+
case 7:
|
|
444
520
|
if (this.clientId && url.indexOf('client_id') < 0) {
|
|
445
521
|
url += url.indexOf('?') < 0 ? '?' : '&';
|
|
446
522
|
url += "client_id=".concat(this.clientId);
|
|
447
523
|
}
|
|
448
|
-
|
|
449
|
-
case
|
|
524
|
+
_f.label = 8;
|
|
525
|
+
case 8:
|
|
450
526
|
if (url.startsWith('/')) {
|
|
451
527
|
url = "".concat(this.apiOrigin).concat(this.apiPath).concat(url);
|
|
452
528
|
}
|
|
453
529
|
response = null;
|
|
454
530
|
maxRequestTimes = retry + 1;
|
|
455
531
|
requestTime = 0;
|
|
456
|
-
|
|
457
|
-
case
|
|
458
|
-
if (!(requestTime < maxRequestTimes)) return [3,
|
|
459
|
-
|
|
460
|
-
case 7:
|
|
461
|
-
_d.trys.push([7, 12, , 15]);
|
|
462
|
-
if (!(options.useWxCloud || this.useWxCloud)) return [3, 9];
|
|
463
|
-
return [4, this.wxCloudCallFunction(url, options)];
|
|
464
|
-
case 8:
|
|
465
|
-
response = _d.sent();
|
|
466
|
-
return [3, 11];
|
|
467
|
-
case 9: return [4, this.baseRequest(url, options)];
|
|
532
|
+
_f.label = 9;
|
|
533
|
+
case 9:
|
|
534
|
+
if (!(requestTime < maxRequestTimes)) return [3, 21];
|
|
535
|
+
_f.label = 10;
|
|
468
536
|
case 10:
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
case
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
537
|
+
_f.trys.push([10, 15, , 18]);
|
|
538
|
+
if (!(options.useWxCloud || this.useWxCloud)) return [3, 12];
|
|
539
|
+
return [4, this.wxCloudCallFunction(url, options)];
|
|
540
|
+
case 11:
|
|
541
|
+
response = _f.sent();
|
|
542
|
+
return [3, 14];
|
|
543
|
+
case 12: return [4, this.baseRequest(url, options)];
|
|
476
544
|
case 13:
|
|
477
|
-
|
|
545
|
+
response = _f.sent();
|
|
546
|
+
_f.label = 14;
|
|
547
|
+
case 14: return [3, 21];
|
|
548
|
+
case 15:
|
|
549
|
+
responseError_1 = _f.sent();
|
|
550
|
+
if (!(options.withCredentials && responseError_1 && responseError_1.error === consts_1.ErrorType.UNAUTHENTICATED)) return [3, 17];
|
|
551
|
+
return [4, this.setCredentials(null)];
|
|
552
|
+
case 16:
|
|
553
|
+
_f.sent();
|
|
478
554
|
return [2, Promise.reject(responseError_1)];
|
|
479
|
-
case
|
|
555
|
+
case 17:
|
|
480
556
|
if (requestTime === retry || !responseError_1 || responseError_1.error !== 'unreachable') {
|
|
481
557
|
return [2, Promise.reject(responseError_1)];
|
|
482
558
|
}
|
|
483
|
-
return [3,
|
|
484
|
-
case
|
|
485
|
-
case
|
|
486
|
-
|
|
487
|
-
|
|
488
|
-
case
|
|
559
|
+
return [3, 18];
|
|
560
|
+
case 18: return [4, this.sleep(OAuth2Client.retryInterval)];
|
|
561
|
+
case 19:
|
|
562
|
+
_f.sent();
|
|
563
|
+
_f.label = 20;
|
|
564
|
+
case 20:
|
|
489
565
|
requestTime++;
|
|
490
|
-
return [3,
|
|
491
|
-
case
|
|
566
|
+
return [3, 9];
|
|
567
|
+
case 21: return [2, response];
|
|
492
568
|
}
|
|
493
569
|
});
|
|
494
570
|
});
|
|
@@ -556,51 +632,16 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
556
632
|
});
|
|
557
633
|
};
|
|
558
634
|
OAuth2Client.prototype.getCredentials = function () {
|
|
559
|
-
var _a, _b, _c;
|
|
560
635
|
return __awaiter(this, void 0, void 0, function () {
|
|
561
|
-
var
|
|
562
|
-
return __generator(this, function (
|
|
563
|
-
switch (
|
|
564
|
-
case 0: return [4, this.
|
|
636
|
+
var _this = this;
|
|
637
|
+
return __generator(this, function (_a) {
|
|
638
|
+
switch (_a.label) {
|
|
639
|
+
case 0: return [4, this.initializePromise];
|
|
565
640
|
case 1:
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
return [2, this.unAuthenticatedError(msg)];
|
|
571
|
-
}
|
|
572
|
-
if (!isCredentialsExpired(credentials)) return [3, 12];
|
|
573
|
-
if (!credentials.refresh_token) return [3, 9];
|
|
574
|
-
_d.label = 2;
|
|
575
|
-
case 2:
|
|
576
|
-
_d.trys.push([2, 4, , 8]);
|
|
577
|
-
return [4, this.refreshToken(credentials)];
|
|
578
|
-
case 3:
|
|
579
|
-
credentials = _d.sent();
|
|
580
|
-
return [3, 8];
|
|
581
|
-
case 4:
|
|
582
|
-
error_5 = _d.sent();
|
|
583
|
-
if (!(credentials.scope === 'anonymous')) return [3, 6];
|
|
584
|
-
return [4, this.anonymousLogin(credentials)];
|
|
585
|
-
case 5:
|
|
586
|
-
credentials = _d.sent();
|
|
587
|
-
return [3, 7];
|
|
588
|
-
case 6:
|
|
589
|
-
(_b = this.onCredentialsError) === null || _b === void 0 ? void 0 : _b.call(this, { msg: error_5.error_description });
|
|
590
|
-
return [2, Promise.reject(error_5)];
|
|
591
|
-
case 7: return [3, 8];
|
|
592
|
-
case 8: return [3, 12];
|
|
593
|
-
case 9:
|
|
594
|
-
if (!(credentials.scope === 'anonymous')) return [3, 11];
|
|
595
|
-
return [4, this.anonymousLogin(credentials)];
|
|
596
|
-
case 10:
|
|
597
|
-
credentials = _d.sent();
|
|
598
|
-
return [3, 12];
|
|
599
|
-
case 11:
|
|
600
|
-
msg = 'no refresh token found in credentials';
|
|
601
|
-
(_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
|
|
602
|
-
return [2, this.unAuthenticatedError(msg)];
|
|
603
|
-
case 12: return [2, credentials];
|
|
641
|
+
_a.sent();
|
|
642
|
+
return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
|
643
|
+
return [2, this._getCredentials()];
|
|
644
|
+
}); }); })];
|
|
604
645
|
}
|
|
605
646
|
});
|
|
606
647
|
});
|
|
@@ -650,43 +691,62 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
650
691
|
});
|
|
651
692
|
});
|
|
652
693
|
};
|
|
653
|
-
OAuth2Client.prototype.refreshToken = function (credentials) {
|
|
694
|
+
OAuth2Client.prototype.refreshToken = function (credentials, options) {
|
|
695
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
696
|
+
var _this = this;
|
|
697
|
+
return __generator(this, function (_a) {
|
|
698
|
+
switch (_a.label) {
|
|
699
|
+
case 0: return [4, this.initializePromise];
|
|
700
|
+
case 1:
|
|
701
|
+
_a.sent();
|
|
702
|
+
return [2, this._acquireLock(-1, function () { return __awaiter(_this, void 0, void 0, function () { return __generator(this, function (_a) {
|
|
703
|
+
return [2, this._refreshToken(credentials, options)];
|
|
704
|
+
}); }); })];
|
|
705
|
+
}
|
|
706
|
+
});
|
|
707
|
+
});
|
|
708
|
+
};
|
|
709
|
+
OAuth2Client.prototype._refreshToken = function (credentials, options) {
|
|
654
710
|
return __awaiter(this, void 0, void 0, function () {
|
|
655
711
|
var _this = this;
|
|
656
712
|
return __generator(this, function (_a) {
|
|
657
713
|
return [2, this.singlePromise.run('_refreshToken', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
658
|
-
var msg, newCredentials,
|
|
659
|
-
var _a, _b, _c;
|
|
660
|
-
return __generator(this, function (
|
|
661
|
-
switch (
|
|
714
|
+
var msg, newCredentials, error_5, msg;
|
|
715
|
+
var _a, _b, _c, _d;
|
|
716
|
+
return __generator(this, function (_f) {
|
|
717
|
+
switch (_f.label) {
|
|
662
718
|
case 0:
|
|
663
719
|
if (!credentials || !credentials.refresh_token) {
|
|
664
720
|
msg = 'no refresh token found in credentials';
|
|
665
721
|
(_a = this.onCredentialsError) === null || _a === void 0 ? void 0 : _a.call(this, { msg: msg });
|
|
666
722
|
return [2, this.unAuthenticatedError(msg)];
|
|
667
723
|
}
|
|
668
|
-
|
|
724
|
+
_f.label = 1;
|
|
669
725
|
case 1:
|
|
670
|
-
|
|
726
|
+
_f.trys.push([1, 4, , 7]);
|
|
671
727
|
return [4, this.refreshTokenFunc(credentials.refresh_token, credentials)];
|
|
672
728
|
case 2:
|
|
673
|
-
newCredentials =
|
|
729
|
+
newCredentials = _f.sent();
|
|
674
730
|
return [4, this.localCredentials.setCredentials(newCredentials)];
|
|
675
731
|
case 3:
|
|
676
|
-
|
|
732
|
+
_f.sent();
|
|
733
|
+
(_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 });
|
|
677
734
|
return [2, newCredentials];
|
|
678
735
|
case 4:
|
|
679
|
-
|
|
680
|
-
if (
|
|
736
|
+
error_5 = _f.sent();
|
|
737
|
+
if (options === null || options === void 0 ? void 0 : options.throwError) {
|
|
738
|
+
throw error_5;
|
|
739
|
+
}
|
|
740
|
+
if (!(error_5.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
|
|
681
741
|
return [4, this.localCredentials.setCredentials(null)];
|
|
682
742
|
case 5:
|
|
683
|
-
|
|
684
|
-
msg =
|
|
685
|
-
(
|
|
743
|
+
_f.sent();
|
|
744
|
+
msg = error_5.error_description;
|
|
745
|
+
(_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
|
|
686
746
|
return [2, this.unAuthenticatedError(msg)];
|
|
687
747
|
case 6:
|
|
688
|
-
(
|
|
689
|
-
return [2, Promise.reject(
|
|
748
|
+
(_d = this.onCredentialsError) === null || _d === void 0 ? void 0 : _d.call(this, { msg: error_5.error_description });
|
|
749
|
+
return [2, Promise.reject(error_5)];
|
|
690
750
|
case 7: return [2];
|
|
691
751
|
}
|
|
692
752
|
});
|
|
@@ -762,7 +822,7 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
762
822
|
var _this = this;
|
|
763
823
|
return __generator(this, function (_a) {
|
|
764
824
|
return [2, this.singlePromise.run('_anonymous', function () { return __awaiter(_this, void 0, void 0, function () {
|
|
765
|
-
var newCredentials,
|
|
825
|
+
var newCredentials, error_6;
|
|
766
826
|
return __generator(this, function (_a) {
|
|
767
827
|
switch (_a.label) {
|
|
768
828
|
case 0:
|
|
@@ -784,13 +844,13 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
784
844
|
_a.sent();
|
|
785
845
|
return [2, newCredentials];
|
|
786
846
|
case 4:
|
|
787
|
-
|
|
788
|
-
if (!(
|
|
847
|
+
error_6 = _a.sent();
|
|
848
|
+
if (!(error_6.error === consts_1.ErrorType.INVALID_GRANT)) return [3, 6];
|
|
789
849
|
return [4, this.localCredentials.setCredentials(null)];
|
|
790
850
|
case 5:
|
|
791
851
|
_a.sent();
|
|
792
|
-
return [2, this.unAuthenticatedError(
|
|
793
|
-
case 6: return [2, Promise.reject(
|
|
852
|
+
return [2, this.unAuthenticatedError(error_6.error_description)];
|
|
853
|
+
case 6: return [2, Promise.reject(error_6)];
|
|
794
854
|
case 7: return [2];
|
|
795
855
|
}
|
|
796
856
|
});
|
|
@@ -862,10 +922,224 @@ var OAuth2Client = exports.OAuth2Client = (function () {
|
|
|
862
922
|
};
|
|
863
923
|
return Promise.reject(respErr);
|
|
864
924
|
};
|
|
925
|
+
OAuth2Client.prototype._debug = function () {
|
|
926
|
+
var args = [];
|
|
927
|
+
for (var _i = 0; _i < arguments.length; _i++) {
|
|
928
|
+
args[_i] = arguments[_i];
|
|
929
|
+
}
|
|
930
|
+
if (this.logDebugMessages) {
|
|
931
|
+
console.log.apply(console, __spreadArray(['[OAuth2Client]'], args, false));
|
|
932
|
+
}
|
|
933
|
+
};
|
|
934
|
+
OAuth2Client.prototype._initialize = function () {
|
|
935
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
936
|
+
var data, error, callbackError_1, err_1, error_7;
|
|
937
|
+
var _a;
|
|
938
|
+
return __generator(this, function (_b) {
|
|
939
|
+
switch (_b.label) {
|
|
940
|
+
case 0:
|
|
941
|
+
_b.trys.push([0, 11, 12, 13]);
|
|
942
|
+
if (!this.getInitialSession) {
|
|
943
|
+
this._debug('#_initialize()', 'no getInitialSession callback set, skipping');
|
|
944
|
+
return [2, { error: null }];
|
|
945
|
+
}
|
|
946
|
+
this._debug('#_initialize()', 'calling getInitialSession callback');
|
|
947
|
+
_b.label = 1;
|
|
948
|
+
case 1:
|
|
949
|
+
_b.trys.push([1, 9, , 10]);
|
|
950
|
+
return [4, this.getInitialSession()];
|
|
951
|
+
case 2:
|
|
952
|
+
data = (_a = _b.sent(), _a.data), error = _a.error;
|
|
953
|
+
if (!(data === null || data === void 0 ? void 0 : data.session)) return [3, 4];
|
|
954
|
+
this._debug('#_initialize()', 'session obtained from getInitialSession', data.session);
|
|
955
|
+
return [4, this.localCredentials.setCredentials(data === null || data === void 0 ? void 0 : data.session)];
|
|
956
|
+
case 3:
|
|
957
|
+
_b.sent();
|
|
958
|
+
_b.label = 4;
|
|
959
|
+
case 4:
|
|
960
|
+
if (!this.onInitialSessionObtained) return [3, 8];
|
|
961
|
+
this._debug('#_initialize()', 'calling onInitialSessionObtained callback');
|
|
962
|
+
_b.label = 5;
|
|
963
|
+
case 5:
|
|
964
|
+
_b.trys.push([5, 7, , 8]);
|
|
965
|
+
return [4, this.onInitialSessionObtained(data, error)];
|
|
966
|
+
case 6:
|
|
967
|
+
_b.sent();
|
|
968
|
+
return [3, 8];
|
|
969
|
+
case 7:
|
|
970
|
+
callbackError_1 = _b.sent();
|
|
971
|
+
this._debug('#_initialize()', 'error in onInitialSessionObtained', callbackError_1);
|
|
972
|
+
return [3, 8];
|
|
973
|
+
case 8:
|
|
974
|
+
if (error) {
|
|
975
|
+
this._debug('#_initialize()', 'error from getInitialSession', error);
|
|
976
|
+
return [2, { error: error }];
|
|
977
|
+
}
|
|
978
|
+
return [2, { error: null }];
|
|
979
|
+
case 9:
|
|
980
|
+
err_1 = _b.sent();
|
|
981
|
+
this._debug('#_initialize()', 'exception during getInitialSession', err_1);
|
|
982
|
+
return [2, { error: err_1 instanceof Error ? err_1 : new Error(String(err_1)) }];
|
|
983
|
+
case 10: return [3, 13];
|
|
984
|
+
case 11:
|
|
985
|
+
error_7 = _b.sent();
|
|
986
|
+
this._debug('#_initialize()', 'unexpected error', error_7);
|
|
987
|
+
return [2, { error: error_7 instanceof Error ? error_7 : new Error(String(error_7)) }];
|
|
988
|
+
case 12:
|
|
989
|
+
this._debug('#_initialize()', 'end');
|
|
990
|
+
return [7];
|
|
991
|
+
case 13: return [2];
|
|
992
|
+
}
|
|
993
|
+
});
|
|
994
|
+
});
|
|
995
|
+
};
|
|
996
|
+
OAuth2Client.prototype._acquireLock = function (acquireTimeout, fn) {
|
|
997
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
998
|
+
var last_1, result_1, result_2, waitOn;
|
|
999
|
+
var _this = this;
|
|
1000
|
+
return __generator(this, function (_a) {
|
|
1001
|
+
switch (_a.label) {
|
|
1002
|
+
case 0:
|
|
1003
|
+
this._debug('#_acquireLock', 'begin', acquireTimeout);
|
|
1004
|
+
_a.label = 1;
|
|
1005
|
+
case 1:
|
|
1006
|
+
_a.trys.push([1, , 10, 11]);
|
|
1007
|
+
if (this.lockAcquired) {
|
|
1008
|
+
last_1 = this.pendingInLock.length ? this.pendingInLock[this.pendingInLock.length - 1] : Promise.resolve();
|
|
1009
|
+
result_1 = (function () { return __awaiter(_this, void 0, void 0, function () {
|
|
1010
|
+
return __generator(this, function (_a) {
|
|
1011
|
+
switch (_a.label) {
|
|
1012
|
+
case 0: return [4, last_1];
|
|
1013
|
+
case 1:
|
|
1014
|
+
_a.sent();
|
|
1015
|
+
return [4, fn()];
|
|
1016
|
+
case 2: return [2, _a.sent()];
|
|
1017
|
+
}
|
|
1018
|
+
});
|
|
1019
|
+
}); })();
|
|
1020
|
+
this.pendingInLock.push((function () { return __awaiter(_this, void 0, void 0, function () {
|
|
1021
|
+
var _e_1;
|
|
1022
|
+
return __generator(this, function (_a) {
|
|
1023
|
+
switch (_a.label) {
|
|
1024
|
+
case 0:
|
|
1025
|
+
_a.trys.push([0, 2, , 3]);
|
|
1026
|
+
return [4, result_1];
|
|
1027
|
+
case 1:
|
|
1028
|
+
_a.sent();
|
|
1029
|
+
return [3, 3];
|
|
1030
|
+
case 2:
|
|
1031
|
+
_e_1 = _a.sent();
|
|
1032
|
+
return [3, 3];
|
|
1033
|
+
case 3: return [2];
|
|
1034
|
+
}
|
|
1035
|
+
});
|
|
1036
|
+
}); })());
|
|
1037
|
+
return [2, result_1];
|
|
1038
|
+
}
|
|
1039
|
+
this._debug('#_acquireLock', 'acquiring lock for client', this.clientId);
|
|
1040
|
+
_a.label = 2;
|
|
1041
|
+
case 2:
|
|
1042
|
+
_a.trys.push([2, , 8, 9]);
|
|
1043
|
+
this.lockAcquired = true;
|
|
1044
|
+
result_2 = fn();
|
|
1045
|
+
this.pendingInLock.push((function () { return __awaiter(_this, void 0, void 0, function () {
|
|
1046
|
+
var _e_2;
|
|
1047
|
+
return __generator(this, function (_a) {
|
|
1048
|
+
switch (_a.label) {
|
|
1049
|
+
case 0:
|
|
1050
|
+
_a.trys.push([0, 2, , 3]);
|
|
1051
|
+
return [4, result_2];
|
|
1052
|
+
case 1:
|
|
1053
|
+
_a.sent();
|
|
1054
|
+
return [3, 3];
|
|
1055
|
+
case 2:
|
|
1056
|
+
_e_2 = _a.sent();
|
|
1057
|
+
return [3, 3];
|
|
1058
|
+
case 3: return [2];
|
|
1059
|
+
}
|
|
1060
|
+
});
|
|
1061
|
+
}); })());
|
|
1062
|
+
return [4, result_2];
|
|
1063
|
+
case 3:
|
|
1064
|
+
_a.sent();
|
|
1065
|
+
_a.label = 4;
|
|
1066
|
+
case 4:
|
|
1067
|
+
if (!this.pendingInLock.length) return [3, 6];
|
|
1068
|
+
waitOn = __spreadArray([], this.pendingInLock, true);
|
|
1069
|
+
return [4, Promise.all(waitOn)];
|
|
1070
|
+
case 5:
|
|
1071
|
+
_a.sent();
|
|
1072
|
+
this.pendingInLock.splice(0, waitOn.length);
|
|
1073
|
+
return [3, 4];
|
|
1074
|
+
case 6: return [4, result_2];
|
|
1075
|
+
case 7: return [2, _a.sent()];
|
|
1076
|
+
case 8:
|
|
1077
|
+
this._debug('#_acquireLock', 'releasing lock for client', this.clientId);
|
|
1078
|
+
this.lockAcquired = false;
|
|
1079
|
+
return [7];
|
|
1080
|
+
case 9: return [3, 11];
|
|
1081
|
+
case 10:
|
|
1082
|
+
this._debug('#_acquireLock', 'end');
|
|
1083
|
+
return [7];
|
|
1084
|
+
case 11: return [2];
|
|
1085
|
+
}
|
|
1086
|
+
});
|
|
1087
|
+
});
|
|
1088
|
+
};
|
|
1089
|
+
OAuth2Client.prototype._getCredentials = function () {
|
|
1090
|
+
var _a, _b, _c;
|
|
1091
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1092
|
+
var credentials, msg, error_8, msg;
|
|
1093
|
+
return __generator(this, function (_d) {
|
|
1094
|
+
switch (_d.label) {
|
|
1095
|
+
case 0: return [4, this.localCredentials.getCredentials()];
|
|
1096
|
+
case 1:
|
|
1097
|
+
credentials = _d.sent();
|
|
1098
|
+
if (!credentials) {
|
|
1099
|
+
msg = 'credentials not found';
|
|
1100
|
+
(_a = this.onCredentialsError) === null || _a === void 0 ? void 0 : _a.call(this, { msg: msg });
|
|
1101
|
+
return [2, this.unAuthenticatedError(msg)];
|
|
1102
|
+
}
|
|
1103
|
+
if (!isCredentialsExpired(credentials)) return [3, 12];
|
|
1104
|
+
if (!credentials.refresh_token) return [3, 9];
|
|
1105
|
+
_d.label = 2;
|
|
1106
|
+
case 2:
|
|
1107
|
+
_d.trys.push([2, 4, , 8]);
|
|
1108
|
+
return [4, this._refreshToken(credentials)];
|
|
1109
|
+
case 3:
|
|
1110
|
+
credentials = _d.sent();
|
|
1111
|
+
return [3, 8];
|
|
1112
|
+
case 4:
|
|
1113
|
+
error_8 = _d.sent();
|
|
1114
|
+
if (!(credentials.scope === 'anonymous')) return [3, 6];
|
|
1115
|
+
return [4, this.anonymousLogin(credentials)];
|
|
1116
|
+
case 5:
|
|
1117
|
+
credentials = _d.sent();
|
|
1118
|
+
return [3, 7];
|
|
1119
|
+
case 6:
|
|
1120
|
+
(_b = this.onCredentialsError) === null || _b === void 0 ? void 0 : _b.call(this, { msg: error_8.error_description });
|
|
1121
|
+
return [2, Promise.reject(error_8)];
|
|
1122
|
+
case 7: return [3, 8];
|
|
1123
|
+
case 8: return [3, 12];
|
|
1124
|
+
case 9:
|
|
1125
|
+
if (!(credentials.scope === 'anonymous')) return [3, 11];
|
|
1126
|
+
return [4, this.anonymousLogin(credentials)];
|
|
1127
|
+
case 10:
|
|
1128
|
+
credentials = _d.sent();
|
|
1129
|
+
return [3, 12];
|
|
1130
|
+
case 11:
|
|
1131
|
+
msg = 'no refresh token found in credentials';
|
|
1132
|
+
(_c = this.onCredentialsError) === null || _c === void 0 ? void 0 : _c.call(this, { msg: msg });
|
|
1133
|
+
return [2, this.unAuthenticatedError(msg)];
|
|
1134
|
+
case 12: return [2, credentials];
|
|
1135
|
+
}
|
|
1136
|
+
});
|
|
1137
|
+
});
|
|
1138
|
+
};
|
|
865
1139
|
OAuth2Client.defaultRetry = 2;
|
|
866
1140
|
OAuth2Client.minRetry = 0;
|
|
867
1141
|
OAuth2Client.maxRetry = 5;
|
|
868
1142
|
OAuth2Client.retryInterval = 1000;
|
|
869
1143
|
return OAuth2Client;
|
|
870
1144
|
}());
|
|
871
|
-
//# 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 { 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  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 useWxCloud: boolean\n  private basicAuth: string\n  private onCredentialsError: AuthOptions['onCredentialsError'] | undefined\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.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    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   * 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    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 || this.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"]}
|
|
1145
|
+
//# 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(): 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    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        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"]}
|