@cloudbase/auth 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.
- package/dist/cjs/adapter.js +19 -16
- package/dist/cjs/index.d.ts +107 -33
- package/dist/cjs/index.js +1529 -428
- package/dist/cjs/type.d.ts +242 -0
- package/dist/cjs/type.js +3 -0
- package/dist/cjs/utils.d.ts +5 -0
- package/dist/cjs/utils.js +59 -0
- package/dist/esm/adapter.js +19 -16
- package/dist/esm/index.d.ts +107 -33
- package/dist/esm/index.js +1527 -426
- package/dist/esm/type.d.ts +242 -0
- package/dist/esm/type.js +2 -0
- package/dist/esm/utils.d.ts +5 -0
- package/dist/esm/utils.js +51 -0
- package/dist/miniprogram/index.js +1 -1
- package/package.json +6 -6
- package/src/adapter.ts +13 -8
- package/src/index.ts +1606 -363
- package/src/type.ts +306 -0
- package/src/utils.ts +69 -0
- package/tsconfig.json +1 -1
package/dist/cjs/index.js
CHANGED
|
@@ -55,25 +55,30 @@ var __generator = (this && this.__generator) || function (thisArg, body) {
|
|
|
55
55
|
if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
|
|
56
56
|
}
|
|
57
57
|
};
|
|
58
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
59
|
+
var t = {};
|
|
60
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
61
|
+
t[p] = s[p];
|
|
62
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
63
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
64
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
65
|
+
t[p[i]] = s[p[i]];
|
|
66
|
+
}
|
|
67
|
+
return t;
|
|
68
|
+
};
|
|
58
69
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|
59
|
-
exports.registerAuth = exports.Auth = exports.generateAuthInstance = exports.LoginState = void 0;
|
|
70
|
+
exports.registerAuth = exports.Auth = exports.generateAuthInstance = exports.LoginState = exports.User = void 0;
|
|
60
71
|
var oauth_1 = require("@cloudbase/oauth");
|
|
61
72
|
var adapter_1 = require("./adapter");
|
|
62
73
|
var utilities_1 = require("./utilities");
|
|
74
|
+
var utils_1 = require("./utils");
|
|
75
|
+
var utilities_2 = require("@cloudbase/utilities");
|
|
76
|
+
var isBrowser = function () { return typeof window !== 'undefined' && typeof document !== 'undefined'; };
|
|
63
77
|
var COMPONENT_NAME = 'auth';
|
|
64
|
-
var
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
};
|
|
69
|
-
var EVENTS = {
|
|
70
|
-
LOGIN_STATE_CHANGED: 'loginStateChanged',
|
|
71
|
-
};
|
|
72
|
-
var eventBus = new utilities_1.CloudbaseEventEmitter();
|
|
73
|
-
var onCredentialsError = function (params) {
|
|
74
|
-
eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, __assign(__assign({}, params), { eventType: LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR }));
|
|
75
|
-
};
|
|
76
|
-
var User = (function () {
|
|
78
|
+
var onCredentialsError = function (eventBus) { return function (params) {
|
|
79
|
+
eventBus.fire(oauth_1.EVENTS.LOGIN_STATE_CHANGED, __assign(__assign({}, params), { eventType: oauth_1.LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR }));
|
|
80
|
+
}; };
|
|
81
|
+
var User = exports.User = (function () {
|
|
77
82
|
function User(options) {
|
|
78
83
|
var cache = options.cache, oauthInstance = options.oauthInstance;
|
|
79
84
|
this.cache = cache;
|
|
@@ -159,7 +164,9 @@ var User = (function () {
|
|
|
159
164
|
case 0: return [4, this.oauthInstance.authApi.updateUserBasicInfo(__assign({}, params))];
|
|
160
165
|
case 1:
|
|
161
166
|
_a.sent();
|
|
162
|
-
this.
|
|
167
|
+
return [4, this.refresh()];
|
|
168
|
+
case 2:
|
|
169
|
+
_a.sent();
|
|
163
170
|
return [2];
|
|
164
171
|
}
|
|
165
172
|
});
|
|
@@ -187,6 +194,10 @@ var User = (function () {
|
|
|
187
194
|
case 0: return [4, this.oauthInstance.authApi.getUserInfo(params)];
|
|
188
195
|
case 1:
|
|
189
196
|
newUserInfo = _a.sent();
|
|
197
|
+
if (newUserInfo.code === 'INVALID_ACCESS_TOKEN') {
|
|
198
|
+
this.setLocalUserInfo({});
|
|
199
|
+
throw newUserInfo;
|
|
200
|
+
}
|
|
190
201
|
this.setLocalUserInfo(newUserInfo);
|
|
191
202
|
return [2, newUserInfo];
|
|
192
203
|
}
|
|
@@ -196,8 +207,15 @@ var User = (function () {
|
|
|
196
207
|
User.prototype.getLocalUserInfo = function (key) {
|
|
197
208
|
var userInfoKey = this.cache.keys.userInfoKey;
|
|
198
209
|
var userInfo = this.cache.getStore(userInfoKey);
|
|
210
|
+
if (!key)
|
|
211
|
+
return userInfo || {};
|
|
199
212
|
return userInfo[key];
|
|
200
213
|
};
|
|
214
|
+
User.prototype.setLocalUserInfo = function (userInfo) {
|
|
215
|
+
var userInfoKey = this.cache.keys.userInfoKey;
|
|
216
|
+
this.cache.setStore(userInfoKey, userInfo);
|
|
217
|
+
this.setUserInfo();
|
|
218
|
+
};
|
|
201
219
|
User.prototype.getLocalUserInfoAsync = function (key) {
|
|
202
220
|
return __awaiter(this, void 0, void 0, function () {
|
|
203
221
|
var userInfoKey, userInfo;
|
|
@@ -232,15 +250,11 @@ var User = (function () {
|
|
|
232
250
|
'created_from',
|
|
233
251
|
'providers',
|
|
234
252
|
'username',
|
|
253
|
+
'created_at',
|
|
235
254
|
].forEach(function (infoKey) {
|
|
236
255
|
_this[infoKey] = userInfo[infoKey];
|
|
237
256
|
});
|
|
238
257
|
};
|
|
239
|
-
User.prototype.setLocalUserInfo = function (userInfo) {
|
|
240
|
-
var userInfoKey = this.cache.keys.userInfoKey;
|
|
241
|
-
this.cache.setStore(userInfoKey, userInfo);
|
|
242
|
-
this.setUserInfo();
|
|
243
|
-
};
|
|
244
258
|
__decorate([
|
|
245
259
|
(0, utilities_1.catchErrorsDecorator)({
|
|
246
260
|
title: '更新用户信息失败',
|
|
@@ -337,12 +351,13 @@ var LoginState = (function () {
|
|
|
337
351
|
exports.LoginState = LoginState;
|
|
338
352
|
var Auth = (function () {
|
|
339
353
|
function Auth(config) {
|
|
354
|
+
this.listeners = new Map();
|
|
355
|
+
this.hasListenerSetUp = false;
|
|
340
356
|
this.config = config;
|
|
341
|
-
this.cache = config.cache;
|
|
342
357
|
this.oauthInstance = config.oauthInstance;
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
358
|
+
this.cache = config.cache;
|
|
359
|
+
this.init();
|
|
360
|
+
this.setAccessKey();
|
|
346
361
|
}
|
|
347
362
|
Auth.prototype.bindPhoneNumber = function (params) {
|
|
348
363
|
return __awaiter(this, void 0, void 0, function () {
|
|
@@ -378,7 +393,7 @@ var Auth = (function () {
|
|
|
378
393
|
Object.defineProperty(Auth.prototype, "currentUser", {
|
|
379
394
|
get: function () {
|
|
380
395
|
if (this.cache.mode === 'async') {
|
|
381
|
-
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getCurrentUser
|
|
396
|
+
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getCurrentUser instead');
|
|
382
397
|
return;
|
|
383
398
|
}
|
|
384
399
|
var loginState = this.hasLoginState();
|
|
@@ -392,35 +407,23 @@ var Auth = (function () {
|
|
|
392
407
|
});
|
|
393
408
|
Auth.prototype.getCurrentUser = function () {
|
|
394
409
|
return __awaiter(this, void 0, void 0, function () {
|
|
395
|
-
var loginState;
|
|
410
|
+
var loginState, userInfo;
|
|
396
411
|
return __generator(this, function (_a) {
|
|
397
412
|
switch (_a.label) {
|
|
398
413
|
case 0: return [4, this.getLoginState()];
|
|
399
414
|
case 1:
|
|
400
415
|
loginState = _a.sent();
|
|
401
416
|
if (!loginState) return [3, 3];
|
|
417
|
+
userInfo = loginState.user.getLocalUserInfo();
|
|
402
418
|
return [4, loginState.user.checkLocalInfoAsync()];
|
|
403
419
|
case 2:
|
|
404
420
|
_a.sent();
|
|
405
|
-
return [2, loginState.user
|
|
421
|
+
return [2, __assign(__assign({}, loginState.user), userInfo)];
|
|
406
422
|
case 3: return [2, null];
|
|
407
423
|
}
|
|
408
424
|
});
|
|
409
425
|
});
|
|
410
426
|
};
|
|
411
|
-
Auth.prototype.signInAnonymously = function (data) {
|
|
412
|
-
if (data === void 0) { data = {}; }
|
|
413
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
414
|
-
return __generator(this, function (_a) {
|
|
415
|
-
switch (_a.label) {
|
|
416
|
-
case 0: return [4, this.oauthInstance.authApi.signInAnonymously(data)];
|
|
417
|
-
case 1:
|
|
418
|
-
_a.sent();
|
|
419
|
-
return [2, this.createLoginState()];
|
|
420
|
-
}
|
|
421
|
-
});
|
|
422
|
-
});
|
|
423
|
-
};
|
|
424
427
|
Auth.prototype.signInAnonymouslyInWx = function (_a) {
|
|
425
428
|
var _b = _a === void 0 ? {} : _a, useWxCloud = _b.useWxCloud;
|
|
426
429
|
return __awaiter(this, void 0, void 0, function () {
|
|
@@ -584,96 +587,9 @@ var Auth = (function () {
|
|
|
584
587
|
});
|
|
585
588
|
});
|
|
586
589
|
};
|
|
587
|
-
Auth.prototype.signInWithOpenId = function (_a) {
|
|
588
|
-
var _b = _a === void 0 ? {} : _a, _c = _b.useWxCloud, useWxCloud = _c === void 0 ? true : _c;
|
|
589
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
590
|
-
var wxInfo, mainFunc;
|
|
591
|
-
var _this = this;
|
|
592
|
-
return __generator(this, function (_d) {
|
|
593
|
-
switch (_d.label) {
|
|
594
|
-
case 0:
|
|
595
|
-
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
596
|
-
throw Error('wx api undefined');
|
|
597
|
-
}
|
|
598
|
-
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
599
|
-
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
600
|
-
var result, credentials, error_5;
|
|
601
|
-
return __generator(this, function (_a) {
|
|
602
|
-
switch (_a.label) {
|
|
603
|
-
case 0:
|
|
604
|
-
result = undefined;
|
|
605
|
-
credentials = undefined;
|
|
606
|
-
_a.label = 1;
|
|
607
|
-
case 1:
|
|
608
|
-
_a.trys.push([1, 4, , 5]);
|
|
609
|
-
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
610
|
-
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
611
|
-
provider_code: code,
|
|
612
|
-
provider_params: {
|
|
613
|
-
provider_code_type: 'open_id',
|
|
614
|
-
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
615
|
-
},
|
|
616
|
-
}, useWxCloud)];
|
|
617
|
-
case 2:
|
|
618
|
-
result = _a.sent();
|
|
619
|
-
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
620
|
-
throw result;
|
|
621
|
-
}
|
|
622
|
-
return [4, this.oauthInstance.authApi.signInWithProvider({ provider_token: result.provider_token }, useWxCloud)];
|
|
623
|
-
case 3:
|
|
624
|
-
credentials = _a.sent();
|
|
625
|
-
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
626
|
-
throw credentials;
|
|
627
|
-
}
|
|
628
|
-
return [3, 5];
|
|
629
|
-
case 4:
|
|
630
|
-
error_5 = _a.sent();
|
|
631
|
-
throw error_5;
|
|
632
|
-
case 5: return [4, this.oauthInstance.oauth2client.setCredentials(credentials)];
|
|
633
|
-
case 6:
|
|
634
|
-
_a.sent();
|
|
635
|
-
return [2];
|
|
636
|
-
}
|
|
637
|
-
});
|
|
638
|
-
}); };
|
|
639
|
-
return [4, new Promise(function (resolve, reject) {
|
|
640
|
-
wx.login({
|
|
641
|
-
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
642
|
-
var error_6;
|
|
643
|
-
return __generator(this, function (_a) {
|
|
644
|
-
switch (_a.label) {
|
|
645
|
-
case 0:
|
|
646
|
-
_a.trys.push([0, 2, , 3]);
|
|
647
|
-
return [4, mainFunc(res.code)];
|
|
648
|
-
case 1:
|
|
649
|
-
_a.sent();
|
|
650
|
-
resolve(true);
|
|
651
|
-
return [3, 3];
|
|
652
|
-
case 2:
|
|
653
|
-
error_6 = _a.sent();
|
|
654
|
-
reject(error_6);
|
|
655
|
-
return [3, 3];
|
|
656
|
-
case 3: return [2];
|
|
657
|
-
}
|
|
658
|
-
});
|
|
659
|
-
}); },
|
|
660
|
-
fail: function (res) {
|
|
661
|
-
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
662
|
-
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
663
|
-
reject(error);
|
|
664
|
-
},
|
|
665
|
-
});
|
|
666
|
-
})];
|
|
667
|
-
case 1:
|
|
668
|
-
_d.sent();
|
|
669
|
-
return [2, this.createLoginState()];
|
|
670
|
-
}
|
|
671
|
-
});
|
|
672
|
-
});
|
|
673
|
-
};
|
|
674
590
|
Auth.prototype.signInWithUnionId = function () {
|
|
675
591
|
return __awaiter(this, void 0, void 0, function () {
|
|
676
|
-
var
|
|
592
|
+
var error_5;
|
|
677
593
|
var _this = this;
|
|
678
594
|
return __generator(this, function (_a) {
|
|
679
595
|
switch (_a.label) {
|
|
@@ -688,7 +604,7 @@ var Auth = (function () {
|
|
|
688
604
|
var wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
689
605
|
wx.login({
|
|
690
606
|
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
691
|
-
var providerId, result, providerToken, signInRes,
|
|
607
|
+
var providerId, result, providerToken, signInRes, error_6;
|
|
692
608
|
return __generator(this, function (_a) {
|
|
693
609
|
switch (_a.label) {
|
|
694
610
|
case 0:
|
|
@@ -724,8 +640,8 @@ var Auth = (function () {
|
|
|
724
640
|
resolve(true);
|
|
725
641
|
return [3, 5];
|
|
726
642
|
case 4:
|
|
727
|
-
|
|
728
|
-
reject(
|
|
643
|
+
error_6 = _a.sent();
|
|
644
|
+
reject(error_6);
|
|
729
645
|
return [3, 5];
|
|
730
646
|
case 5: return [2];
|
|
731
647
|
}
|
|
@@ -742,71 +658,13 @@ var Auth = (function () {
|
|
|
742
658
|
_a.sent();
|
|
743
659
|
return [3, 4];
|
|
744
660
|
case 3:
|
|
745
|
-
|
|
746
|
-
throw
|
|
661
|
+
error_5 = _a.sent();
|
|
662
|
+
throw error_5;
|
|
747
663
|
case 4: return [2, this.createLoginState()];
|
|
748
664
|
}
|
|
749
665
|
});
|
|
750
666
|
});
|
|
751
667
|
};
|
|
752
|
-
Auth.prototype.signInWithPhoneAuth = function (_a) {
|
|
753
|
-
var _b = _a.phoneCode, phoneCode = _b === void 0 ? '' : _b;
|
|
754
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
755
|
-
var wxInfo, providerInfo, code, providerToken, signInRes, error_9;
|
|
756
|
-
return __generator(this, function (_c) {
|
|
757
|
-
switch (_c.label) {
|
|
758
|
-
case 0:
|
|
759
|
-
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
760
|
-
throw Error('wx api undefined');
|
|
761
|
-
}
|
|
762
|
-
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
763
|
-
providerInfo = {
|
|
764
|
-
provider_params: { provider_code_type: 'phone' },
|
|
765
|
-
provider_id: wxInfo.appId,
|
|
766
|
-
};
|
|
767
|
-
return [4, wx.login()];
|
|
768
|
-
case 1:
|
|
769
|
-
code = (_c.sent()).code;
|
|
770
|
-
providerInfo.provider_code = code;
|
|
771
|
-
_c.label = 2;
|
|
772
|
-
case 2:
|
|
773
|
-
_c.trys.push([2, 6, , 7]);
|
|
774
|
-
return [4, this.oauthInstance.authApi.grantProviderToken(providerInfo)];
|
|
775
|
-
case 3:
|
|
776
|
-
providerToken = _c.sent();
|
|
777
|
-
if (providerToken.error_code) {
|
|
778
|
-
throw providerToken;
|
|
779
|
-
}
|
|
780
|
-
return [4, this.oauthInstance.authApi.patchProviderToken({
|
|
781
|
-
provider_token: providerToken.provider_token,
|
|
782
|
-
provider_id: wxInfo.appId,
|
|
783
|
-
provider_params: {
|
|
784
|
-
code: phoneCode,
|
|
785
|
-
provider_code_type: 'phone',
|
|
786
|
-
},
|
|
787
|
-
})];
|
|
788
|
-
case 4:
|
|
789
|
-
providerToken = _c.sent();
|
|
790
|
-
if (providerToken.error_code) {
|
|
791
|
-
throw providerToken;
|
|
792
|
-
}
|
|
793
|
-
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
794
|
-
provider_token: providerToken.provider_token,
|
|
795
|
-
})];
|
|
796
|
-
case 5:
|
|
797
|
-
signInRes = _c.sent();
|
|
798
|
-
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
799
|
-
throw signInRes;
|
|
800
|
-
}
|
|
801
|
-
return [3, 7];
|
|
802
|
-
case 6:
|
|
803
|
-
error_9 = _c.sent();
|
|
804
|
-
throw error_9;
|
|
805
|
-
case 7: return [2, this.createLoginState()];
|
|
806
|
-
}
|
|
807
|
-
});
|
|
808
|
-
});
|
|
809
|
-
};
|
|
810
668
|
Auth.prototype.signInWithSms = function (_a) {
|
|
811
669
|
var _b = _a.verificationInfo, verificationInfo = _b === void 0 ? { verification_id: '', is_user: false } : _b, _c = _a.verificationCode, verificationCode = _c === void 0 ? '' : _c, _d = _a.phoneNum, phoneNum = _d === void 0 ? '' : _d, _e = _a.bindInfo, bindInfo = _e === void 0 ? undefined : _e;
|
|
812
670
|
return __awaiter(this, void 0, void 0, function () {
|
|
@@ -850,18 +708,6 @@ var Auth = (function () {
|
|
|
850
708
|
Auth.prototype.setCustomSignFunc = function (getTickFn) {
|
|
851
709
|
this.oauthInstance.authApi.setCustomSignFunc(getTickFn);
|
|
852
710
|
};
|
|
853
|
-
Auth.prototype.signInWithCustomTicket = function () {
|
|
854
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
855
|
-
return __generator(this, function (_a) {
|
|
856
|
-
switch (_a.label) {
|
|
857
|
-
case 0: return [4, this.oauthInstance.authApi.signInWithCustomTicket()];
|
|
858
|
-
case 1:
|
|
859
|
-
_a.sent();
|
|
860
|
-
return [2, this.createLoginState()];
|
|
861
|
-
}
|
|
862
|
-
});
|
|
863
|
-
});
|
|
864
|
-
};
|
|
865
711
|
Auth.prototype.signIn = function (params) {
|
|
866
712
|
return __awaiter(this, void 0, void 0, function () {
|
|
867
713
|
return __generator(this, function (_a) {
|
|
@@ -874,18 +720,6 @@ var Auth = (function () {
|
|
|
874
720
|
});
|
|
875
721
|
});
|
|
876
722
|
};
|
|
877
|
-
Auth.prototype.signUp = function (params) {
|
|
878
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
879
|
-
return __generator(this, function (_a) {
|
|
880
|
-
switch (_a.label) {
|
|
881
|
-
case 0: return [4, this.oauthInstance.authApi.signUp(params)];
|
|
882
|
-
case 1:
|
|
883
|
-
_a.sent();
|
|
884
|
-
return [2, this.createLoginState()];
|
|
885
|
-
}
|
|
886
|
-
});
|
|
887
|
-
});
|
|
888
|
-
};
|
|
889
723
|
Auth.prototype.setPassword = function (params) {
|
|
890
724
|
return __awaiter(this, void 0, void 0, function () {
|
|
891
725
|
return __generator(this, function (_a) {
|
|
@@ -910,29 +744,10 @@ var Auth = (function () {
|
|
|
910
744
|
});
|
|
911
745
|
});
|
|
912
746
|
};
|
|
913
|
-
Auth.prototype.signOut = function (params) {
|
|
914
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
915
|
-
var userInfoKey, res;
|
|
916
|
-
return __generator(this, function (_a) {
|
|
917
|
-
switch (_a.label) {
|
|
918
|
-
case 0:
|
|
919
|
-
userInfoKey = this.cache.keys.userInfoKey;
|
|
920
|
-
return [4, this.oauthInstance.authApi.signOut(params)];
|
|
921
|
-
case 1:
|
|
922
|
-
res = _a.sent();
|
|
923
|
-
return [4, this.cache.removeStoreAsync(userInfoKey)];
|
|
924
|
-
case 2:
|
|
925
|
-
_a.sent();
|
|
926
|
-
eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_OUT });
|
|
927
|
-
return [2, res];
|
|
928
|
-
}
|
|
929
|
-
});
|
|
930
|
-
});
|
|
931
|
-
};
|
|
932
747
|
Auth.prototype.hasLoginState = function () {
|
|
933
748
|
var _a;
|
|
934
749
|
if (this.cache.mode === 'async') {
|
|
935
|
-
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getLoginState
|
|
750
|
+
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getLoginState instead');
|
|
936
751
|
return;
|
|
937
752
|
}
|
|
938
753
|
var oauthLoginState = (_a = this.oauthInstance) === null || _a === void 0 ? void 0 : _a.authApi.hasLoginStateSync();
|
|
@@ -948,7 +763,7 @@ var Auth = (function () {
|
|
|
948
763
|
};
|
|
949
764
|
Auth.prototype.getLoginState = function () {
|
|
950
765
|
return __awaiter(this, void 0, void 0, function () {
|
|
951
|
-
var oauthLoginState,
|
|
766
|
+
var oauthLoginState, error_7, loginState;
|
|
952
767
|
return __generator(this, function (_a) {
|
|
953
768
|
switch (_a.label) {
|
|
954
769
|
case 0:
|
|
@@ -961,7 +776,7 @@ var Auth = (function () {
|
|
|
961
776
|
oauthLoginState = _a.sent();
|
|
962
777
|
return [3, 4];
|
|
963
778
|
case 3:
|
|
964
|
-
|
|
779
|
+
error_7 = _a.sent();
|
|
965
780
|
return [2, null];
|
|
966
781
|
case 4:
|
|
967
782
|
if (oauthLoginState) {
|
|
@@ -977,10 +792,10 @@ var Auth = (function () {
|
|
|
977
792
|
});
|
|
978
793
|
});
|
|
979
794
|
};
|
|
980
|
-
Auth.prototype.getUserInfo = function (
|
|
795
|
+
Auth.prototype.getUserInfo = function () {
|
|
981
796
|
return __awaiter(this, void 0, void 0, function () {
|
|
982
797
|
return __generator(this, function (_a) {
|
|
983
|
-
return [2, this.
|
|
798
|
+
return [2, this.getCurrentUser()];
|
|
984
799
|
});
|
|
985
800
|
});
|
|
986
801
|
};
|
|
@@ -1151,19 +966,20 @@ var Auth = (function () {
|
|
|
1151
966
|
});
|
|
1152
967
|
};
|
|
1153
968
|
Auth.prototype.onLoginStateChanged = function (callback) {
|
|
969
|
+
var _a;
|
|
1154
970
|
return __awaiter(this, void 0, void 0, function () {
|
|
1155
971
|
var loginState;
|
|
1156
972
|
var _this = this;
|
|
1157
|
-
return __generator(this, function (
|
|
1158
|
-
switch (
|
|
973
|
+
return __generator(this, function (_b) {
|
|
974
|
+
switch (_b.label) {
|
|
1159
975
|
case 0:
|
|
1160
|
-
eventBus.on(EVENTS.LOGIN_STATE_CHANGED, function (params) { return __awaiter(_this, void 0, void 0, function () {
|
|
976
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.on(oauth_1.EVENTS.LOGIN_STATE_CHANGED, function (params) { return __awaiter(_this, void 0, void 0, function () {
|
|
1161
977
|
var loginState, _a;
|
|
1162
978
|
var _b;
|
|
1163
979
|
return __generator(this, function (_c) {
|
|
1164
980
|
switch (_c.label) {
|
|
1165
981
|
case 0:
|
|
1166
|
-
if (!(((_b = params === null || params === void 0 ? void 0 : params.data) === null || _b === void 0 ? void 0 : _b.eventType) !== LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR)) return [3, 2];
|
|
982
|
+
if (!(((_b = params === null || params === void 0 ? void 0 : params.data) === null || _b === void 0 ? void 0 : _b.eventType) !== oauth_1.LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR)) return [3, 2];
|
|
1167
983
|
return [4, this.getLoginState()];
|
|
1168
984
|
case 1:
|
|
1169
985
|
_a = _c.sent();
|
|
@@ -1180,7 +996,7 @@ var Auth = (function () {
|
|
|
1180
996
|
}); });
|
|
1181
997
|
return [4, this.getLoginState()];
|
|
1182
998
|
case 1:
|
|
1183
|
-
loginState =
|
|
999
|
+
loginState = _b.sent();
|
|
1184
1000
|
callback.call(this, loginState);
|
|
1185
1001
|
return [2];
|
|
1186
1002
|
}
|
|
@@ -1269,57 +1085,10 @@ var Auth = (function () {
|
|
|
1269
1085
|
});
|
|
1270
1086
|
});
|
|
1271
1087
|
};
|
|
1272
|
-
Auth.prototype.toDefaultLoginPage = function (params) {
|
|
1273
|
-
if (params === void 0) { params = {}; }
|
|
1274
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1275
|
-
var configVersion, redirectUri, urlObj, loginPage;
|
|
1276
|
-
return __generator(this, function (_a) {
|
|
1277
|
-
configVersion = params.config_version || 'env';
|
|
1278
|
-
if (utilities_1.adapterForWxMp.isMatch()) {
|
|
1279
|
-
wx.navigateTo({ url: '/packages/$wd_system/pages/login/index' });
|
|
1280
|
-
}
|
|
1281
|
-
else {
|
|
1282
|
-
redirectUri = params.redirect_uri || window.location.href;
|
|
1283
|
-
urlObj = new URL(redirectUri);
|
|
1284
|
-
loginPage = "".concat(urlObj.origin, "/__auth/?app_id=").concat(params.app_id || '', "&env_id=").concat(this.config.env, "&client_id=").concat(this.config.clientId, "&config_version=").concat(configVersion, "&redirect_uri=").concat(encodeURIComponent(redirectUri));
|
|
1285
|
-
window.location.href = loginPage;
|
|
1286
|
-
}
|
|
1287
|
-
return [2];
|
|
1288
|
-
});
|
|
1289
|
-
});
|
|
1290
|
-
};
|
|
1291
|
-
Auth.prototype.createLoginState = function (params, options) {
|
|
1292
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1293
|
-
var loginState;
|
|
1294
|
-
return __generator(this, function (_a) {
|
|
1295
|
-
switch (_a.label) {
|
|
1296
|
-
case 0:
|
|
1297
|
-
loginState = new LoginState({
|
|
1298
|
-
envId: this.config.env,
|
|
1299
|
-
cache: this.cache,
|
|
1300
|
-
oauthInstance: this.oauthInstance,
|
|
1301
|
-
});
|
|
1302
|
-
return [4, loginState.checkLocalStateAsync()];
|
|
1303
|
-
case 1:
|
|
1304
|
-
_a.sent();
|
|
1305
|
-
if (!(options === null || options === void 0 ? void 0 : options.asyncRefreshUser)) return [3, 2];
|
|
1306
|
-
loginState.user.refresh(params);
|
|
1307
|
-
return [3, 4];
|
|
1308
|
-
case 2: return [4, loginState.user.refresh(params)];
|
|
1309
|
-
case 3:
|
|
1310
|
-
_a.sent();
|
|
1311
|
-
_a.label = 4;
|
|
1312
|
-
case 4:
|
|
1313
|
-
eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_IN });
|
|
1314
|
-
return [2, loginState];
|
|
1315
|
-
}
|
|
1316
|
-
});
|
|
1317
|
-
});
|
|
1318
|
-
};
|
|
1319
1088
|
Auth.prototype.signInWithUsername = function (_a) {
|
|
1320
1089
|
var _b = _a.verificationInfo, verificationInfo = _b === void 0 ? { verification_id: '', is_user: false } : _b, _c = _a.verificationCode, verificationCode = _c === void 0 ? '' : _c, _d = _a.username, rawUsername = _d === void 0 ? '' : _d, _e = _a.bindInfo, bindInfo = _e === void 0 ? undefined : _e, _f = _a.loginType, loginType = _f === void 0 ? '' : _f;
|
|
1321
1090
|
return __awaiter(this, void 0, void 0, function () {
|
|
1322
|
-
var verifyRes, verification_token, username, signUpParam, signInRes, bindRes, signUpRes,
|
|
1091
|
+
var verifyRes, verification_token, username, signUpParam, signInRes, bindRes, signUpRes, error_8;
|
|
1323
1092
|
return __generator(this, function (_g) {
|
|
1324
1093
|
switch (_g.label) {
|
|
1325
1094
|
case 0:
|
|
@@ -1334,7 +1103,7 @@ var Auth = (function () {
|
|
|
1334
1103
|
throw verifyRes;
|
|
1335
1104
|
}
|
|
1336
1105
|
verification_token = verifyRes.verification_token;
|
|
1337
|
-
username = "+86 ".concat(rawUsername);
|
|
1106
|
+
username = /^\+\d{1,3}\s+/.test(rawUsername) ? rawUsername : "+86 ".concat(rawUsername);
|
|
1338
1107
|
signUpParam = { phone_number: username };
|
|
1339
1108
|
if (loginType === 'email') {
|
|
1340
1109
|
username = rawUsername;
|
|
@@ -1370,21 +1139,1405 @@ var Auth = (function () {
|
|
|
1370
1139
|
_g.label = 7;
|
|
1371
1140
|
case 7: return [2, this.createLoginState()];
|
|
1372
1141
|
case 8:
|
|
1373
|
-
|
|
1374
|
-
throw
|
|
1142
|
+
error_8 = _g.sent();
|
|
1143
|
+
throw error_8;
|
|
1375
1144
|
case 9: return [2];
|
|
1376
1145
|
}
|
|
1377
1146
|
});
|
|
1378
1147
|
});
|
|
1379
1148
|
};
|
|
1380
|
-
|
|
1381
|
-
|
|
1382
|
-
|
|
1383
|
-
|
|
1384
|
-
|
|
1385
|
-
|
|
1386
|
-
|
|
1387
|
-
|
|
1149
|
+
Auth.prototype.createLoginState = function (params, options) {
|
|
1150
|
+
var _a, _b;
|
|
1151
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1152
|
+
var loginState;
|
|
1153
|
+
return __generator(this, function (_c) {
|
|
1154
|
+
switch (_c.label) {
|
|
1155
|
+
case 0:
|
|
1156
|
+
loginState = new LoginState({
|
|
1157
|
+
envId: this.config.env,
|
|
1158
|
+
cache: this.cache,
|
|
1159
|
+
oauthInstance: this.oauthInstance,
|
|
1160
|
+
});
|
|
1161
|
+
return [4, loginState.checkLocalStateAsync()];
|
|
1162
|
+
case 1:
|
|
1163
|
+
_c.sent();
|
|
1164
|
+
if (!(options === null || options === void 0 ? void 0 : options.userInfo)) return [3, 2];
|
|
1165
|
+
loginState.user.setLocalUserInfo(options.userInfo);
|
|
1166
|
+
return [3, 5];
|
|
1167
|
+
case 2:
|
|
1168
|
+
if (!(options === null || options === void 0 ? void 0 : options.asyncRefreshUser)) return [3, 3];
|
|
1169
|
+
loginState.user.refresh(params);
|
|
1170
|
+
return [3, 5];
|
|
1171
|
+
case 3: return [4, loginState.user.refresh(params)];
|
|
1172
|
+
case 4:
|
|
1173
|
+
_c.sent();
|
|
1174
|
+
_c.label = 5;
|
|
1175
|
+
case 5:
|
|
1176
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.LOGIN_STATE_CHANGED, { eventType: oauth_1.LOGIN_STATE_CHANGED_TYPE.SIGN_IN });
|
|
1177
|
+
(_b = this.config.eventBus) === null || _b === void 0 ? void 0 : _b.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.SIGNED_IN });
|
|
1178
|
+
return [2, loginState];
|
|
1179
|
+
}
|
|
1180
|
+
});
|
|
1181
|
+
});
|
|
1182
|
+
};
|
|
1183
|
+
Auth.prototype.setAccessKey = function () {
|
|
1184
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1185
|
+
return __generator(this, function (_a) {
|
|
1186
|
+
if (this.config.accessKey) {
|
|
1187
|
+
try {
|
|
1188
|
+
this.oauthInstance.oauth2client.setAccessKeyCredentials({
|
|
1189
|
+
access_token: this.config.accessKey,
|
|
1190
|
+
token_type: 'Bearer',
|
|
1191
|
+
scope: 'accessKey',
|
|
1192
|
+
expires_at: new Date(+new Date() + +new Date()),
|
|
1193
|
+
expires_in: +new Date() + +new Date(),
|
|
1194
|
+
});
|
|
1195
|
+
}
|
|
1196
|
+
catch (error) {
|
|
1197
|
+
console.warn('accessKey error: ', error);
|
|
1198
|
+
}
|
|
1199
|
+
}
|
|
1200
|
+
return [2];
|
|
1201
|
+
});
|
|
1202
|
+
});
|
|
1203
|
+
};
|
|
1204
|
+
Auth.prototype.signInAnonymously = function (params) {
|
|
1205
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1206
|
+
var loginState, _a, _b, session, error_9;
|
|
1207
|
+
return __generator(this, function (_c) {
|
|
1208
|
+
switch (_c.label) {
|
|
1209
|
+
case 0:
|
|
1210
|
+
_c.trys.push([0, 4, , 5]);
|
|
1211
|
+
return [4, this.oauthInstance.authApi.signInAnonymously(params)];
|
|
1212
|
+
case 1:
|
|
1213
|
+
_c.sent();
|
|
1214
|
+
return [4, this.createLoginState()];
|
|
1215
|
+
case 2:
|
|
1216
|
+
loginState = _c.sent();
|
|
1217
|
+
return [4, this.getSession()];
|
|
1218
|
+
case 3:
|
|
1219
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1220
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
1221
|
+
case 4:
|
|
1222
|
+
error_9 = _c.sent();
|
|
1223
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_9) }];
|
|
1224
|
+
case 5: return [2];
|
|
1225
|
+
}
|
|
1226
|
+
});
|
|
1227
|
+
});
|
|
1228
|
+
};
|
|
1229
|
+
Auth.prototype.signUp = function (params) {
|
|
1230
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1231
|
+
var verificationInfo_1, error_10;
|
|
1232
|
+
var _this = this;
|
|
1233
|
+
return __generator(this, function (_a) {
|
|
1234
|
+
switch (_a.label) {
|
|
1235
|
+
case 0:
|
|
1236
|
+
if (!(params.phone_number || params.verification_code || params.verification_token || params.provider_token)) return [3, 2];
|
|
1237
|
+
return [4, this.oauthInstance.authApi.signUp(params)];
|
|
1238
|
+
case 1:
|
|
1239
|
+
_a.sent();
|
|
1240
|
+
return [2, this.createLoginState()];
|
|
1241
|
+
case 2:
|
|
1242
|
+
_a.trys.push([2, 4, , 5]);
|
|
1243
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
1244
|
+
return [4, this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })];
|
|
1245
|
+
case 3:
|
|
1246
|
+
verificationInfo_1 = _a.sent();
|
|
1247
|
+
return [2, {
|
|
1248
|
+
data: {
|
|
1249
|
+
verifyOtp: function (_a) {
|
|
1250
|
+
var token = _a.token, _b = _a.messageId, messageId = _b === void 0 ? verificationInfo_1.verification_id : _b;
|
|
1251
|
+
return __awaiter(_this, void 0, void 0, function () {
|
|
1252
|
+
var verificationTokenRes, data, _c, _d, session, error_11;
|
|
1253
|
+
return __generator(this, function (_e) {
|
|
1254
|
+
switch (_e.label) {
|
|
1255
|
+
case 0:
|
|
1256
|
+
_e.trys.push([0, 8, , 9]);
|
|
1257
|
+
return [4, this.verify({
|
|
1258
|
+
verification_id: messageId || verificationInfo_1.verification_id,
|
|
1259
|
+
verification_code: token,
|
|
1260
|
+
})];
|
|
1261
|
+
case 1:
|
|
1262
|
+
verificationTokenRes = _e.sent();
|
|
1263
|
+
if (!verificationInfo_1.is_user) return [3, 3];
|
|
1264
|
+
return [4, this.signIn({
|
|
1265
|
+
username: params.email || this.formatPhone(params.phone),
|
|
1266
|
+
verification_token: verificationTokenRes.verification_token,
|
|
1267
|
+
})];
|
|
1268
|
+
case 2:
|
|
1269
|
+
_e.sent();
|
|
1270
|
+
return [3, 6];
|
|
1271
|
+
case 3:
|
|
1272
|
+
data = JSON.parse(JSON.stringify(params));
|
|
1273
|
+
delete data.email;
|
|
1274
|
+
delete data.phone;
|
|
1275
|
+
return [4, this.oauthInstance.authApi.signUp(__assign(__assign(__assign({}, data), (params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })), { verification_token: verificationTokenRes.verification_token, verification_code: token }))];
|
|
1276
|
+
case 4:
|
|
1277
|
+
_e.sent();
|
|
1278
|
+
return [4, this.createLoginState()];
|
|
1279
|
+
case 5:
|
|
1280
|
+
_e.sent();
|
|
1281
|
+
_e.label = 6;
|
|
1282
|
+
case 6: return [4, this.getSession()];
|
|
1283
|
+
case 7:
|
|
1284
|
+
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
1285
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1286
|
+
case 8:
|
|
1287
|
+
error_11 = _e.sent();
|
|
1288
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_11) }];
|
|
1289
|
+
case 9: return [2];
|
|
1290
|
+
}
|
|
1291
|
+
});
|
|
1292
|
+
});
|
|
1293
|
+
},
|
|
1294
|
+
},
|
|
1295
|
+
error: null,
|
|
1296
|
+
}];
|
|
1297
|
+
case 4:
|
|
1298
|
+
error_10 = _a.sent();
|
|
1299
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_10) }];
|
|
1300
|
+
case 5: return [2];
|
|
1301
|
+
}
|
|
1302
|
+
});
|
|
1303
|
+
});
|
|
1304
|
+
};
|
|
1305
|
+
Auth.prototype.signOut = function (params) {
|
|
1306
|
+
var _a, _b;
|
|
1307
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1308
|
+
var userInfoKey, res, error_12;
|
|
1309
|
+
return __generator(this, function (_c) {
|
|
1310
|
+
switch (_c.label) {
|
|
1311
|
+
case 0:
|
|
1312
|
+
_c.trys.push([0, 3, , 4]);
|
|
1313
|
+
userInfoKey = this.cache.keys.userInfoKey;
|
|
1314
|
+
return [4, this.oauthInstance.authApi.signOut(params)];
|
|
1315
|
+
case 1:
|
|
1316
|
+
res = _c.sent();
|
|
1317
|
+
return [4, this.cache.removeStoreAsync(userInfoKey)];
|
|
1318
|
+
case 2:
|
|
1319
|
+
_c.sent();
|
|
1320
|
+
this.setAccessKey();
|
|
1321
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.LOGIN_STATE_CHANGED, { eventType: oauth_1.LOGIN_STATE_CHANGED_TYPE.SIGN_OUT });
|
|
1322
|
+
(_b = this.config.eventBus) === null || _b === void 0 ? void 0 : _b.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.SIGNED_OUT });
|
|
1323
|
+
return [2, __assign(__assign({}, res), { data: {}, error: null })];
|
|
1324
|
+
case 3:
|
|
1325
|
+
error_12 = _c.sent();
|
|
1326
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_12) }];
|
|
1327
|
+
case 4: return [2];
|
|
1328
|
+
}
|
|
1329
|
+
});
|
|
1330
|
+
});
|
|
1331
|
+
};
|
|
1332
|
+
Auth.prototype.onAuthStateChange = function (callback) {
|
|
1333
|
+
var _this = this;
|
|
1334
|
+
if (!this.hasListenerSetUp) {
|
|
1335
|
+
this.setupListeners();
|
|
1336
|
+
this.hasListenerSetUp = true;
|
|
1337
|
+
}
|
|
1338
|
+
var id = Math.random().toString(36);
|
|
1339
|
+
if (!this.listeners.has(id)) {
|
|
1340
|
+
this.listeners.set(id, new Set());
|
|
1341
|
+
}
|
|
1342
|
+
this.listeners.get(id).add(callback);
|
|
1343
|
+
var subscription = {
|
|
1344
|
+
id: id,
|
|
1345
|
+
callback: callback,
|
|
1346
|
+
unsubscribe: function () {
|
|
1347
|
+
var callbacks = _this.listeners.get(id);
|
|
1348
|
+
if (callbacks) {
|
|
1349
|
+
callbacks.delete(callback);
|
|
1350
|
+
if (callbacks.size === 0) {
|
|
1351
|
+
_this.listeners.delete(id);
|
|
1352
|
+
}
|
|
1353
|
+
}
|
|
1354
|
+
},
|
|
1355
|
+
};
|
|
1356
|
+
return {
|
|
1357
|
+
data: { subscription: subscription },
|
|
1358
|
+
};
|
|
1359
|
+
};
|
|
1360
|
+
Auth.prototype.signInWithPassword = function (params) {
|
|
1361
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1362
|
+
var _a, _b, session, error_13;
|
|
1363
|
+
return __generator(this, function (_c) {
|
|
1364
|
+
switch (_c.label) {
|
|
1365
|
+
case 0:
|
|
1366
|
+
_c.trys.push([0, 3, , 4]);
|
|
1367
|
+
this.validateAtLeastOne(params, [['username'], ['email'], ['phone']], 'You must provide either username, email, or phone');
|
|
1368
|
+
this.validateParams(params, {
|
|
1369
|
+
password: { required: true, message: 'Password is required' },
|
|
1370
|
+
});
|
|
1371
|
+
return [4, this.signIn(__assign({ username: params.username || params.email || this.formatPhone(params.phone), password: params.password }, (params.is_encrypt ? { isEncrypt: true, version: 'v2' } : {})))];
|
|
1372
|
+
case 1:
|
|
1373
|
+
_c.sent();
|
|
1374
|
+
return [4, this.getSession()];
|
|
1375
|
+
case 2:
|
|
1376
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1377
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1378
|
+
case 3:
|
|
1379
|
+
error_13 = _c.sent();
|
|
1380
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_13) }];
|
|
1381
|
+
case 4: return [2];
|
|
1382
|
+
}
|
|
1383
|
+
});
|
|
1384
|
+
});
|
|
1385
|
+
};
|
|
1386
|
+
Auth.prototype.signInWithIdToken = function (params) {
|
|
1387
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1388
|
+
var _a, _b, session, error_14;
|
|
1389
|
+
return __generator(this, function (_c) {
|
|
1390
|
+
switch (_c.label) {
|
|
1391
|
+
case 0:
|
|
1392
|
+
_c.trys.push([0, 3, , 4]);
|
|
1393
|
+
this.validateParams(params, {
|
|
1394
|
+
token: { required: true, message: 'Token is required' },
|
|
1395
|
+
});
|
|
1396
|
+
return [4, this.signInWithProvider({
|
|
1397
|
+
provider_token: params.token,
|
|
1398
|
+
})];
|
|
1399
|
+
case 1:
|
|
1400
|
+
_c.sent();
|
|
1401
|
+
return [4, this.getSession()];
|
|
1402
|
+
case 2:
|
|
1403
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1404
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1405
|
+
case 3:
|
|
1406
|
+
error_14 = _c.sent();
|
|
1407
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_14) }];
|
|
1408
|
+
case 4: return [2];
|
|
1409
|
+
}
|
|
1410
|
+
});
|
|
1411
|
+
});
|
|
1412
|
+
};
|
|
1413
|
+
Auth.prototype.signInWithOtp = function (params) {
|
|
1414
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1415
|
+
var verificationInfo_2, error_15;
|
|
1416
|
+
var _this = this;
|
|
1417
|
+
return __generator(this, function (_a) {
|
|
1418
|
+
switch (_a.label) {
|
|
1419
|
+
case 0:
|
|
1420
|
+
_a.trys.push([0, 2, , 3]);
|
|
1421
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
1422
|
+
return [4, this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })];
|
|
1423
|
+
case 1:
|
|
1424
|
+
verificationInfo_2 = _a.sent();
|
|
1425
|
+
return [2, {
|
|
1426
|
+
data: {
|
|
1427
|
+
user: null,
|
|
1428
|
+
session: null,
|
|
1429
|
+
verifyOtp: function (_a) {
|
|
1430
|
+
var token = _a.token, _b = _a.messageId, messageId = _b === void 0 ? verificationInfo_2.verification_id : _b;
|
|
1431
|
+
return __awaiter(_this, void 0, void 0, function () {
|
|
1432
|
+
return __generator(this, function (_c) {
|
|
1433
|
+
return [2, this.verifyOtp({
|
|
1434
|
+
email: params.email,
|
|
1435
|
+
phone: params.phone,
|
|
1436
|
+
token: token,
|
|
1437
|
+
messageId: messageId,
|
|
1438
|
+
})];
|
|
1439
|
+
});
|
|
1440
|
+
});
|
|
1441
|
+
},
|
|
1442
|
+
},
|
|
1443
|
+
error: null,
|
|
1444
|
+
}];
|
|
1445
|
+
case 2:
|
|
1446
|
+
error_15 = _a.sent();
|
|
1447
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_15) }];
|
|
1448
|
+
case 3: return [2];
|
|
1449
|
+
}
|
|
1450
|
+
});
|
|
1451
|
+
});
|
|
1452
|
+
};
|
|
1453
|
+
Auth.prototype.verifyOAuth = function (params) {
|
|
1454
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1455
|
+
var data, code, state, cacheData, provider, token, res, localSearch, error_16;
|
|
1456
|
+
return __generator(this, function (_a) {
|
|
1457
|
+
switch (_a.label) {
|
|
1458
|
+
case 0:
|
|
1459
|
+
data = {};
|
|
1460
|
+
_a.label = 1;
|
|
1461
|
+
case 1:
|
|
1462
|
+
_a.trys.push([1, 7, , 8]);
|
|
1463
|
+
code = (params === null || params === void 0 ? void 0 : params.code) || utilities_2.utils.getQuery('code');
|
|
1464
|
+
state = (params === null || params === void 0 ? void 0 : params.state) || utilities_2.utils.getQuery('state');
|
|
1465
|
+
if (!code) {
|
|
1466
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'Code is required' }) }];
|
|
1467
|
+
}
|
|
1468
|
+
if (!state) {
|
|
1469
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'State is required' }) }];
|
|
1470
|
+
}
|
|
1471
|
+
cacheData = (0, utils_1.getBrowserSession)(state);
|
|
1472
|
+
data.type = cacheData === null || cacheData === void 0 ? void 0 : cacheData.type;
|
|
1473
|
+
provider = (params === null || params === void 0 ? void 0 : params.provider) || (cacheData === null || cacheData === void 0 ? void 0 : cacheData.provider) || utilities_2.utils.getQuery('provider');
|
|
1474
|
+
if (!provider) {
|
|
1475
|
+
return [2, { data: data, error: new oauth_1.AuthError({ message: 'Provider is required' }) }];
|
|
1476
|
+
}
|
|
1477
|
+
return [4, this.grantProviderToken({
|
|
1478
|
+
provider_id: provider,
|
|
1479
|
+
provider_redirect_uri: location.origin + location.pathname,
|
|
1480
|
+
provider_code: code,
|
|
1481
|
+
})];
|
|
1482
|
+
case 2:
|
|
1483
|
+
token = (_a.sent()).provider_token;
|
|
1484
|
+
res = void 0;
|
|
1485
|
+
if (!(cacheData.type === oauth_1.OAUTH_TYPE.BIND_IDENTITY)) return [3, 4];
|
|
1486
|
+
return [4, this.oauthInstance.authApi.toBindIdentity({ provider_token: token, provider: provider, fireEvent: true })];
|
|
1487
|
+
case 3:
|
|
1488
|
+
res = _a.sent();
|
|
1489
|
+
return [3, 6];
|
|
1490
|
+
case 4: return [4, this.signInWithIdToken({
|
|
1491
|
+
token: token,
|
|
1492
|
+
})];
|
|
1493
|
+
case 5:
|
|
1494
|
+
res = _a.sent();
|
|
1495
|
+
res.data = __assign(__assign({}, data), res.data);
|
|
1496
|
+
_a.label = 6;
|
|
1497
|
+
case 6:
|
|
1498
|
+
localSearch = new URLSearchParams(location === null || location === void 0 ? void 0 : location.search);
|
|
1499
|
+
localSearch.delete('code');
|
|
1500
|
+
localSearch.delete('state');
|
|
1501
|
+
(0, utils_1.addUrlSearch)((cacheData === null || cacheData === void 0 ? void 0 : cacheData.search) === undefined ? "?".concat(localSearch.toString()) : cacheData === null || cacheData === void 0 ? void 0 : cacheData.search, (cacheData === null || cacheData === void 0 ? void 0 : cacheData.hash) || location.hash);
|
|
1502
|
+
(0, utils_1.removeBrowserSession)(state);
|
|
1503
|
+
return [2, res];
|
|
1504
|
+
case 7:
|
|
1505
|
+
error_16 = _a.sent();
|
|
1506
|
+
return [2, { data: data, error: new oauth_1.AuthError(error_16) }];
|
|
1507
|
+
case 8: return [2];
|
|
1508
|
+
}
|
|
1509
|
+
});
|
|
1510
|
+
});
|
|
1511
|
+
};
|
|
1512
|
+
Auth.prototype.signInWithOAuth = function (params) {
|
|
1513
|
+
var _a, _b, _c, _d, _e;
|
|
1514
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1515
|
+
var href, urlObject, provider_redirect_uri, state, uri, decodedUri, finalUri, url_1, error_17;
|
|
1516
|
+
return __generator(this, function (_f) {
|
|
1517
|
+
switch (_f.label) {
|
|
1518
|
+
case 0:
|
|
1519
|
+
_f.trys.push([0, 2, , 3]);
|
|
1520
|
+
this.validateParams(params, {
|
|
1521
|
+
provider: { required: true, message: 'Provider is required' },
|
|
1522
|
+
});
|
|
1523
|
+
href = ((_a = params.options) === null || _a === void 0 ? void 0 : _a.redirectTo) || location.href;
|
|
1524
|
+
urlObject = new URL(href);
|
|
1525
|
+
provider_redirect_uri = urlObject.origin + urlObject.pathname;
|
|
1526
|
+
state = ((_b = params.options) === null || _b === void 0 ? void 0 : _b.state) || "prd-".concat(params.provider, "-").concat(Math.random().toString(36)
|
|
1527
|
+
.slice(2));
|
|
1528
|
+
return [4, this.genProviderRedirectUri({
|
|
1529
|
+
provider_id: params.provider,
|
|
1530
|
+
provider_redirect_uri: provider_redirect_uri,
|
|
1531
|
+
state: state,
|
|
1532
|
+
})];
|
|
1533
|
+
case 1:
|
|
1534
|
+
uri = (_f.sent()).uri;
|
|
1535
|
+
decodedUri = decodeURIComponent(uri);
|
|
1536
|
+
finalUri = decodedUri;
|
|
1537
|
+
if ((_c = params.options) === null || _c === void 0 ? void 0 : _c.queryParams) {
|
|
1538
|
+
url_1 = new URL(decodedUri);
|
|
1539
|
+
Object.entries(params.options.queryParams).forEach(function (_a) {
|
|
1540
|
+
var key = _a[0], value = _a[1];
|
|
1541
|
+
url_1.searchParams.set(key, value);
|
|
1542
|
+
});
|
|
1543
|
+
finalUri = url_1.toString();
|
|
1544
|
+
}
|
|
1545
|
+
(0, utils_1.saveToBrowserSession)(state, {
|
|
1546
|
+
provider: params.provider,
|
|
1547
|
+
search: urlObject.search,
|
|
1548
|
+
hash: urlObject.hash,
|
|
1549
|
+
type: ((_d = params.options) === null || _d === void 0 ? void 0 : _d.type) || oauth_1.OAUTH_TYPE.SIGN_IN,
|
|
1550
|
+
});
|
|
1551
|
+
if (isBrowser() && !((_e = params.options) === null || _e === void 0 ? void 0 : _e.skipBrowserRedirect)) {
|
|
1552
|
+
window.location.assign(finalUri);
|
|
1553
|
+
}
|
|
1554
|
+
return [2, { data: { url: finalUri, provider: params.provider }, error: null }];
|
|
1555
|
+
case 2:
|
|
1556
|
+
error_17 = _f.sent();
|
|
1557
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_17) }];
|
|
1558
|
+
case 3: return [2];
|
|
1559
|
+
}
|
|
1560
|
+
});
|
|
1561
|
+
});
|
|
1562
|
+
};
|
|
1563
|
+
Auth.prototype.getClaims = function () {
|
|
1564
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1565
|
+
var accessToken, parsedToken, error_18;
|
|
1566
|
+
return __generator(this, function (_a) {
|
|
1567
|
+
switch (_a.label) {
|
|
1568
|
+
case 0:
|
|
1569
|
+
_a.trys.push([0, 2, , 3]);
|
|
1570
|
+
return [4, this.getAccessToken()];
|
|
1571
|
+
case 1:
|
|
1572
|
+
accessToken = (_a.sent()).accessToken;
|
|
1573
|
+
parsedToken = (0, oauth_1.weAppJwtDecodeAll)(accessToken);
|
|
1574
|
+
return [2, { data: parsedToken, error: null }];
|
|
1575
|
+
case 2:
|
|
1576
|
+
error_18 = _a.sent();
|
|
1577
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_18) }];
|
|
1578
|
+
case 3: return [2];
|
|
1579
|
+
}
|
|
1580
|
+
});
|
|
1581
|
+
});
|
|
1582
|
+
};
|
|
1583
|
+
Auth.prototype.resetPasswordForEmail = function (emailOrPhone, options) {
|
|
1584
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1585
|
+
var redirectTo_1, isEmail_1, verificationParams, formattedPhone, verificationInfo_3, error_19;
|
|
1586
|
+
var _this = this;
|
|
1587
|
+
return __generator(this, function (_a) {
|
|
1588
|
+
switch (_a.label) {
|
|
1589
|
+
case 0:
|
|
1590
|
+
_a.trys.push([0, 2, , 3]);
|
|
1591
|
+
this.validateParams({ emailOrPhone: emailOrPhone }, {
|
|
1592
|
+
emailOrPhone: { required: true, message: 'Email or phone is required' },
|
|
1593
|
+
});
|
|
1594
|
+
redirectTo_1 = (options || {}).redirectTo;
|
|
1595
|
+
isEmail_1 = emailOrPhone.includes('@');
|
|
1596
|
+
verificationParams = void 0;
|
|
1597
|
+
if (isEmail_1) {
|
|
1598
|
+
verificationParams = { email: emailOrPhone };
|
|
1599
|
+
}
|
|
1600
|
+
else {
|
|
1601
|
+
formattedPhone = this.formatPhone(emailOrPhone);
|
|
1602
|
+
verificationParams = { phone_number: formattedPhone };
|
|
1603
|
+
}
|
|
1604
|
+
return [4, this.getVerification(verificationParams)];
|
|
1605
|
+
case 1:
|
|
1606
|
+
verificationInfo_3 = _a.sent();
|
|
1607
|
+
return [2, {
|
|
1608
|
+
data: {
|
|
1609
|
+
updateUser: function (attributes) { return __awaiter(_this, void 0, void 0, function () {
|
|
1610
|
+
var verificationTokenRes, res, error_20;
|
|
1611
|
+
var _a;
|
|
1612
|
+
return __generator(this, function (_b) {
|
|
1613
|
+
switch (_b.label) {
|
|
1614
|
+
case 0:
|
|
1615
|
+
this.validateParams(attributes, {
|
|
1616
|
+
nonce: { required: true, message: 'Nonce is required' },
|
|
1617
|
+
password: { required: true, message: 'Password is required' },
|
|
1618
|
+
});
|
|
1619
|
+
_b.label = 1;
|
|
1620
|
+
case 1:
|
|
1621
|
+
_b.trys.push([1, 5, , 6]);
|
|
1622
|
+
return [4, this.verify({
|
|
1623
|
+
verification_id: verificationInfo_3.verification_id,
|
|
1624
|
+
verification_code: attributes.nonce,
|
|
1625
|
+
})];
|
|
1626
|
+
case 2:
|
|
1627
|
+
verificationTokenRes = _b.sent();
|
|
1628
|
+
return [4, this.oauthInstance.authApi.resetPassword({
|
|
1629
|
+
email: isEmail_1 ? emailOrPhone : undefined,
|
|
1630
|
+
phone_number: !isEmail_1 ? emailOrPhone : undefined,
|
|
1631
|
+
new_password: attributes.password,
|
|
1632
|
+
verification_token: verificationTokenRes.verification_token,
|
|
1633
|
+
})];
|
|
1634
|
+
case 3:
|
|
1635
|
+
_b.sent();
|
|
1636
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, {
|
|
1637
|
+
event: oauth_1.AUTH_STATE_CHANGED_TYPE.PASSWORD_RECOVERY,
|
|
1638
|
+
});
|
|
1639
|
+
return [4, this.signInWithPassword({
|
|
1640
|
+
email: isEmail_1 ? emailOrPhone : undefined,
|
|
1641
|
+
phone: !isEmail_1 ? emailOrPhone : undefined,
|
|
1642
|
+
password: attributes.password,
|
|
1643
|
+
})];
|
|
1644
|
+
case 4:
|
|
1645
|
+
res = _b.sent();
|
|
1646
|
+
if (redirectTo_1 && isBrowser()) {
|
|
1647
|
+
window.location.assign(redirectTo_1);
|
|
1648
|
+
}
|
|
1649
|
+
return [2, res];
|
|
1650
|
+
case 5:
|
|
1651
|
+
error_20 = _b.sent();
|
|
1652
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_20) }];
|
|
1653
|
+
case 6: return [2];
|
|
1654
|
+
}
|
|
1655
|
+
});
|
|
1656
|
+
}); },
|
|
1657
|
+
},
|
|
1658
|
+
error: null,
|
|
1659
|
+
}];
|
|
1660
|
+
case 2:
|
|
1661
|
+
error_19 = _a.sent();
|
|
1662
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_19) }];
|
|
1663
|
+
case 3: return [2];
|
|
1664
|
+
}
|
|
1665
|
+
});
|
|
1666
|
+
});
|
|
1667
|
+
};
|
|
1668
|
+
Auth.prototype.resetPasswordForOld = function (params) {
|
|
1669
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1670
|
+
var _a, _b, session, error_21;
|
|
1671
|
+
return __generator(this, function (_c) {
|
|
1672
|
+
switch (_c.label) {
|
|
1673
|
+
case 0:
|
|
1674
|
+
_c.trys.push([0, 3, , 4]);
|
|
1675
|
+
return [4, this.oauthInstance.authApi.updatePasswordByOld({
|
|
1676
|
+
old_password: params.old_password,
|
|
1677
|
+
new_password: params.new_password,
|
|
1678
|
+
})];
|
|
1679
|
+
case 1:
|
|
1680
|
+
_c.sent();
|
|
1681
|
+
return [4, this.getSession()];
|
|
1682
|
+
case 2:
|
|
1683
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1684
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1685
|
+
case 3:
|
|
1686
|
+
error_21 = _c.sent();
|
|
1687
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_21) }];
|
|
1688
|
+
case 4: return [2];
|
|
1689
|
+
}
|
|
1690
|
+
});
|
|
1691
|
+
});
|
|
1692
|
+
};
|
|
1693
|
+
Auth.prototype.verifyOtp = function (params) {
|
|
1694
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1695
|
+
var type, _a, _b, session, error_22;
|
|
1696
|
+
return __generator(this, function (_c) {
|
|
1697
|
+
switch (_c.label) {
|
|
1698
|
+
case 0:
|
|
1699
|
+
_c.trys.push([0, 6, , 7]);
|
|
1700
|
+
type = params.type;
|
|
1701
|
+
this.validateParams(params, {
|
|
1702
|
+
token: { required: true, message: 'Token is required' },
|
|
1703
|
+
messageId: { required: true, message: 'messageId is required' },
|
|
1704
|
+
});
|
|
1705
|
+
if (!['phone_change', 'email_change'].includes(type)) return [3, 2];
|
|
1706
|
+
return [4, this.verify({
|
|
1707
|
+
verification_id: params.messageId,
|
|
1708
|
+
verification_code: params.token,
|
|
1709
|
+
})];
|
|
1710
|
+
case 1:
|
|
1711
|
+
_c.sent();
|
|
1712
|
+
return [3, 4];
|
|
1713
|
+
case 2: return [4, this.signInWithUsername({
|
|
1714
|
+
verificationInfo: { verification_id: params.messageId, is_user: true },
|
|
1715
|
+
verificationCode: params.token,
|
|
1716
|
+
username: params.email || this.formatPhone(params.phone) || '',
|
|
1717
|
+
loginType: params.email ? 'email' : 'phone',
|
|
1718
|
+
})];
|
|
1719
|
+
case 3:
|
|
1720
|
+
_c.sent();
|
|
1721
|
+
_c.label = 4;
|
|
1722
|
+
case 4: return [4, this.getSession()];
|
|
1723
|
+
case 5:
|
|
1724
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1725
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1726
|
+
case 6:
|
|
1727
|
+
error_22 = _c.sent();
|
|
1728
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_22) }];
|
|
1729
|
+
case 7: return [2];
|
|
1730
|
+
}
|
|
1731
|
+
});
|
|
1732
|
+
});
|
|
1733
|
+
};
|
|
1734
|
+
Auth.prototype.getSession = function () {
|
|
1735
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1736
|
+
var credentials, _a, _b, user, error_23;
|
|
1737
|
+
return __generator(this, function (_c) {
|
|
1738
|
+
switch (_c.label) {
|
|
1739
|
+
case 0:
|
|
1740
|
+
_c.trys.push([0, 3, , 4]);
|
|
1741
|
+
return [4, this.oauthInstance.oauth2client.getCredentials()];
|
|
1742
|
+
case 1:
|
|
1743
|
+
credentials = _c.sent();
|
|
1744
|
+
if (!credentials || credentials.scope === 'accessKey') {
|
|
1745
|
+
return [2, { data: { session: null }, error: null }];
|
|
1746
|
+
}
|
|
1747
|
+
return [4, this.getUser()];
|
|
1748
|
+
case 2:
|
|
1749
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
1750
|
+
return [2, { data: { session: __assign(__assign({}, credentials), { user: user }), user: user }, error: null }];
|
|
1751
|
+
case 3:
|
|
1752
|
+
error_23 = _c.sent();
|
|
1753
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_23) }];
|
|
1754
|
+
case 4: return [2];
|
|
1755
|
+
}
|
|
1756
|
+
});
|
|
1757
|
+
});
|
|
1758
|
+
};
|
|
1759
|
+
Auth.prototype.refreshSession = function (refresh_token) {
|
|
1760
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1761
|
+
var credentials, newTokens, _a, _b, user, error_24;
|
|
1762
|
+
return __generator(this, function (_c) {
|
|
1763
|
+
switch (_c.label) {
|
|
1764
|
+
case 0:
|
|
1765
|
+
_c.trys.push([0, 4, , 5]);
|
|
1766
|
+
return [4, this.oauthInstance.oauth2client.localCredentials.getCredentials()];
|
|
1767
|
+
case 1:
|
|
1768
|
+
credentials = _c.sent();
|
|
1769
|
+
credentials.refresh_token = refresh_token || credentials.refresh_token;
|
|
1770
|
+
return [4, this.oauthInstance.oauth2client.refreshToken(credentials)];
|
|
1771
|
+
case 2:
|
|
1772
|
+
newTokens = _c.sent();
|
|
1773
|
+
return [4, this.getUser()];
|
|
1774
|
+
case 3:
|
|
1775
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
1776
|
+
return [2, { data: { user: user, session: __assign(__assign({}, newTokens), { user: user }) }, error: null }];
|
|
1777
|
+
case 4:
|
|
1778
|
+
error_24 = _c.sent();
|
|
1779
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_24) }];
|
|
1780
|
+
case 5: return [2];
|
|
1781
|
+
}
|
|
1782
|
+
});
|
|
1783
|
+
});
|
|
1784
|
+
};
|
|
1785
|
+
Auth.prototype.getUser = function () {
|
|
1786
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1787
|
+
var user, _a, error_25;
|
|
1788
|
+
return __generator(this, function (_b) {
|
|
1789
|
+
switch (_b.label) {
|
|
1790
|
+
case 0:
|
|
1791
|
+
_b.trys.push([0, 2, , 3]);
|
|
1792
|
+
_a = this.convertToUser;
|
|
1793
|
+
return [4, this.getUserInfo()];
|
|
1794
|
+
case 1:
|
|
1795
|
+
user = _a.apply(this, [_b.sent()]);
|
|
1796
|
+
return [2, { data: { user: user }, error: null }];
|
|
1797
|
+
case 2:
|
|
1798
|
+
error_25 = _b.sent();
|
|
1799
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_25) }];
|
|
1800
|
+
case 3: return [2];
|
|
1801
|
+
}
|
|
1802
|
+
});
|
|
1803
|
+
});
|
|
1804
|
+
};
|
|
1805
|
+
Auth.prototype.refreshUser = function () {
|
|
1806
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1807
|
+
var _a, _b, session, error_26;
|
|
1808
|
+
return __generator(this, function (_c) {
|
|
1809
|
+
switch (_c.label) {
|
|
1810
|
+
case 0:
|
|
1811
|
+
_c.trys.push([0, 3, , 4]);
|
|
1812
|
+
return [4, this.currentUser.refresh()];
|
|
1813
|
+
case 1:
|
|
1814
|
+
_c.sent();
|
|
1815
|
+
return [4, this.getSession()];
|
|
1816
|
+
case 2:
|
|
1817
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1818
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1819
|
+
case 3:
|
|
1820
|
+
error_26 = _c.sent();
|
|
1821
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_26) }];
|
|
1822
|
+
case 4: return [2];
|
|
1823
|
+
}
|
|
1824
|
+
});
|
|
1825
|
+
});
|
|
1826
|
+
};
|
|
1827
|
+
Auth.prototype.updateUser = function (params) {
|
|
1828
|
+
var _a;
|
|
1829
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1830
|
+
var hasValue, email, phone, restParams, needsEmailVerification_1, needsPhoneVerification, extraRes, verificationParams, verificationType_1, formattedPhone, verificationInfo_4, _b, user, error_27;
|
|
1831
|
+
var _this = this;
|
|
1832
|
+
return __generator(this, function (_c) {
|
|
1833
|
+
switch (_c.label) {
|
|
1834
|
+
case 0:
|
|
1835
|
+
_c.trys.push([0, 8, , 9]);
|
|
1836
|
+
hasValue = Object.keys(params).some(function (key) { return params[key] !== undefined && params[key] !== null && params[key] !== ''; });
|
|
1837
|
+
if (!hasValue) {
|
|
1838
|
+
throw new oauth_1.AuthError({ message: 'At least one field must be provided for update' });
|
|
1839
|
+
}
|
|
1840
|
+
email = params.email, phone = params.phone, restParams = __rest(params, ["email", "phone"]);
|
|
1841
|
+
needsEmailVerification_1 = email !== undefined;
|
|
1842
|
+
needsPhoneVerification = phone !== undefined;
|
|
1843
|
+
extraRes = {};
|
|
1844
|
+
if (!(needsEmailVerification_1 || needsPhoneVerification)) return [3, 4];
|
|
1845
|
+
verificationParams = void 0;
|
|
1846
|
+
if (needsEmailVerification_1) {
|
|
1847
|
+
verificationParams = { email: params.email };
|
|
1848
|
+
verificationType_1 = 'email_change';
|
|
1849
|
+
}
|
|
1850
|
+
else {
|
|
1851
|
+
formattedPhone = this.formatPhone(params.phone);
|
|
1852
|
+
verificationParams = { phone_number: formattedPhone };
|
|
1853
|
+
verificationType_1 = 'phone_change';
|
|
1854
|
+
}
|
|
1855
|
+
return [4, this.getVerification(verificationParams)];
|
|
1856
|
+
case 1:
|
|
1857
|
+
verificationInfo_4 = _c.sent();
|
|
1858
|
+
_b = Object.keys(restParams).length > 0;
|
|
1859
|
+
if (!_b) return [3, 3];
|
|
1860
|
+
return [4, this.updateUserBasicInfo(restParams)];
|
|
1861
|
+
case 2:
|
|
1862
|
+
_b = (_c.sent());
|
|
1863
|
+
_c.label = 3;
|
|
1864
|
+
case 3:
|
|
1865
|
+
_b;
|
|
1866
|
+
extraRes = {
|
|
1867
|
+
messageId: verificationInfo_4.verification_id,
|
|
1868
|
+
verifyOtp: function (verifyParams) { return __awaiter(_this, void 0, void 0, function () {
|
|
1869
|
+
var user_1, error_28;
|
|
1870
|
+
var _a;
|
|
1871
|
+
return __generator(this, function (_b) {
|
|
1872
|
+
switch (_b.label) {
|
|
1873
|
+
case 0:
|
|
1874
|
+
_b.trys.push([0, 11, , 12]);
|
|
1875
|
+
if (!(verifyParams.email && params.email === verifyParams.email)) return [3, 3];
|
|
1876
|
+
return [4, this.verifyOtp({
|
|
1877
|
+
type: 'email_change',
|
|
1878
|
+
email: params.email,
|
|
1879
|
+
token: verifyParams.token,
|
|
1880
|
+
messageId: verificationInfo_4.verification_id,
|
|
1881
|
+
})];
|
|
1882
|
+
case 1:
|
|
1883
|
+
_b.sent();
|
|
1884
|
+
return [4, this.updateUserBasicInfo({ email: params.email })];
|
|
1885
|
+
case 2:
|
|
1886
|
+
_b.sent();
|
|
1887
|
+
return [3, 9];
|
|
1888
|
+
case 3:
|
|
1889
|
+
if (!(verifyParams.phone && params.phone === verifyParams.phone)) return [3, 6];
|
|
1890
|
+
return [4, this.verifyOtp({
|
|
1891
|
+
type: 'phone_change',
|
|
1892
|
+
phone: params.phone,
|
|
1893
|
+
token: verifyParams.token,
|
|
1894
|
+
messageId: verificationInfo_4.verification_id,
|
|
1895
|
+
})];
|
|
1896
|
+
case 4:
|
|
1897
|
+
_b.sent();
|
|
1898
|
+
return [4, this.updateUserBasicInfo({ phone: this.formatPhone(params.phone) })];
|
|
1899
|
+
case 5:
|
|
1900
|
+
_b.sent();
|
|
1901
|
+
return [3, 9];
|
|
1902
|
+
case 6: return [4, this.verifyOtp({
|
|
1903
|
+
type: verificationType_1,
|
|
1904
|
+
email: needsEmailVerification_1 ? params.email : undefined,
|
|
1905
|
+
phone: !needsEmailVerification_1 ? params.phone : undefined,
|
|
1906
|
+
token: verifyParams.token,
|
|
1907
|
+
messageId: verificationInfo_4.verification_id,
|
|
1908
|
+
})];
|
|
1909
|
+
case 7:
|
|
1910
|
+
_b.sent();
|
|
1911
|
+
return [4, this.updateUserBasicInfo(params)];
|
|
1912
|
+
case 8:
|
|
1913
|
+
_b.sent();
|
|
1914
|
+
_b.label = 9;
|
|
1915
|
+
case 9: return [4, this.getUser()];
|
|
1916
|
+
case 10:
|
|
1917
|
+
user_1 = (_b.sent()).data.user;
|
|
1918
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.USER_UPDATED });
|
|
1919
|
+
return [2, { data: { user: user_1 }, error: null }];
|
|
1920
|
+
case 11:
|
|
1921
|
+
error_28 = _b.sent();
|
|
1922
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_28) }];
|
|
1923
|
+
case 12: return [2];
|
|
1924
|
+
}
|
|
1925
|
+
});
|
|
1926
|
+
}); },
|
|
1927
|
+
};
|
|
1928
|
+
return [3, 6];
|
|
1929
|
+
case 4: return [4, this.updateUserBasicInfo(params)];
|
|
1930
|
+
case 5:
|
|
1931
|
+
_c.sent();
|
|
1932
|
+
_c.label = 6;
|
|
1933
|
+
case 6: return [4, this.getUser()];
|
|
1934
|
+
case 7:
|
|
1935
|
+
user = (_c.sent()).data.user;
|
|
1936
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.USER_UPDATED });
|
|
1937
|
+
return [2, { data: __assign({ user: user }, extraRes), error: null }];
|
|
1938
|
+
case 8:
|
|
1939
|
+
error_27 = _c.sent();
|
|
1940
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_27) }];
|
|
1941
|
+
case 9: return [2];
|
|
1942
|
+
}
|
|
1943
|
+
});
|
|
1944
|
+
});
|
|
1945
|
+
};
|
|
1946
|
+
Auth.prototype.getUserIdentities = function () {
|
|
1947
|
+
var _a;
|
|
1948
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1949
|
+
var providers, error_29;
|
|
1950
|
+
return __generator(this, function (_b) {
|
|
1951
|
+
switch (_b.label) {
|
|
1952
|
+
case 0:
|
|
1953
|
+
_b.trys.push([0, 2, , 3]);
|
|
1954
|
+
return [4, this.oauthInstance.authApi.getProviders()];
|
|
1955
|
+
case 1:
|
|
1956
|
+
providers = _b.sent();
|
|
1957
|
+
return [2, { data: { identities: (_a = providers === null || providers === void 0 ? void 0 : providers.data) === null || _a === void 0 ? void 0 : _a.filter(function (v) { return !!v.bind; }) }, error: null }];
|
|
1958
|
+
case 2:
|
|
1959
|
+
error_29 = _b.sent();
|
|
1960
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_29) }];
|
|
1961
|
+
case 3: return [2];
|
|
1962
|
+
}
|
|
1963
|
+
});
|
|
1964
|
+
});
|
|
1965
|
+
};
|
|
1966
|
+
Auth.prototype.linkIdentity = function (params) {
|
|
1967
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1968
|
+
var error_30;
|
|
1969
|
+
return __generator(this, function (_a) {
|
|
1970
|
+
switch (_a.label) {
|
|
1971
|
+
case 0:
|
|
1972
|
+
_a.trys.push([0, 2, , 3]);
|
|
1973
|
+
this.validateParams(params, {
|
|
1974
|
+
provider: { required: true, message: 'Provider is required' },
|
|
1975
|
+
});
|
|
1976
|
+
return [4, this.signInWithOAuth({
|
|
1977
|
+
provider: params.provider,
|
|
1978
|
+
options: {
|
|
1979
|
+
type: oauth_1.OAUTH_TYPE.BIND_IDENTITY,
|
|
1980
|
+
},
|
|
1981
|
+
})];
|
|
1982
|
+
case 1:
|
|
1983
|
+
_a.sent();
|
|
1984
|
+
return [2, { data: { provider: params.provider }, error: null }];
|
|
1985
|
+
case 2:
|
|
1986
|
+
error_30 = _a.sent();
|
|
1987
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_30) }];
|
|
1988
|
+
case 3: return [2];
|
|
1989
|
+
}
|
|
1990
|
+
});
|
|
1991
|
+
});
|
|
1992
|
+
};
|
|
1993
|
+
Auth.prototype.unlinkIdentity = function (params) {
|
|
1994
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
1995
|
+
var error_31;
|
|
1996
|
+
return __generator(this, function (_a) {
|
|
1997
|
+
switch (_a.label) {
|
|
1998
|
+
case 0:
|
|
1999
|
+
_a.trys.push([0, 2, , 3]);
|
|
2000
|
+
this.validateParams(params, {
|
|
2001
|
+
provider: { required: true, message: 'Provider is required' },
|
|
2002
|
+
});
|
|
2003
|
+
return [4, this.oauthInstance.authApi.unbindProvider({ provider_id: params.provider })];
|
|
2004
|
+
case 1:
|
|
2005
|
+
_a.sent();
|
|
2006
|
+
return [2, { data: {}, error: null }];
|
|
2007
|
+
case 2:
|
|
2008
|
+
error_31 = _a.sent();
|
|
2009
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_31) }];
|
|
2010
|
+
case 3: return [2];
|
|
2011
|
+
}
|
|
2012
|
+
});
|
|
2013
|
+
});
|
|
2014
|
+
};
|
|
2015
|
+
Auth.prototype.reauthenticate = function () {
|
|
2016
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2017
|
+
var user, userInfo_1, verificationInfo_5, error_32;
|
|
2018
|
+
var _this = this;
|
|
2019
|
+
return __generator(this, function (_a) {
|
|
2020
|
+
switch (_a.label) {
|
|
2021
|
+
case 0:
|
|
2022
|
+
_a.trys.push([0, 3, , 4]);
|
|
2023
|
+
return [4, this.getUser()];
|
|
2024
|
+
case 1:
|
|
2025
|
+
user = (_a.sent()).data.user;
|
|
2026
|
+
this.validateAtLeastOne(user, [['email', 'phone']], 'You must provide either an email or phone number');
|
|
2027
|
+
userInfo_1 = user.email ? { email: user.email } : { phone_number: this.formatPhone(user.phone) };
|
|
2028
|
+
return [4, this.getVerification(userInfo_1)];
|
|
2029
|
+
case 2:
|
|
2030
|
+
verificationInfo_5 = _a.sent();
|
|
2031
|
+
return [2, {
|
|
2032
|
+
data: {
|
|
2033
|
+
updateUser: function (attributes) { return __awaiter(_this, void 0, void 0, function () {
|
|
2034
|
+
var verificationTokenRes, sudoRes, _a, _b, session, error_33;
|
|
2035
|
+
return __generator(this, function (_c) {
|
|
2036
|
+
switch (_c.label) {
|
|
2037
|
+
case 0:
|
|
2038
|
+
this.validateParams(attributes, {
|
|
2039
|
+
nonce: { required: true, message: 'Nonce is required' },
|
|
2040
|
+
});
|
|
2041
|
+
_c.label = 1;
|
|
2042
|
+
case 1:
|
|
2043
|
+
_c.trys.push([1, 9, , 10]);
|
|
2044
|
+
if (!attributes.password) return [3, 5];
|
|
2045
|
+
return [4, this.verify({
|
|
2046
|
+
verification_id: verificationInfo_5.verification_id,
|
|
2047
|
+
verification_code: attributes.nonce,
|
|
2048
|
+
})];
|
|
2049
|
+
case 2:
|
|
2050
|
+
verificationTokenRes = _c.sent();
|
|
2051
|
+
return [4, this.oauthInstance.authApi.sudo({
|
|
2052
|
+
verification_token: verificationTokenRes.verification_token,
|
|
2053
|
+
})];
|
|
2054
|
+
case 3:
|
|
2055
|
+
sudoRes = _c.sent();
|
|
2056
|
+
return [4, this.oauthInstance.authApi.setPassword({
|
|
2057
|
+
new_password: attributes.password,
|
|
2058
|
+
sudo_token: sudoRes.sudo_token,
|
|
2059
|
+
})];
|
|
2060
|
+
case 4:
|
|
2061
|
+
_c.sent();
|
|
2062
|
+
return [3, 7];
|
|
2063
|
+
case 5: return [4, this.signInWithUsername(__assign(__assign({ verificationInfo: verificationInfo_5, verificationCode: attributes.nonce }, userInfo_1), { loginType: userInfo_1.email ? 'email' : 'phone' }))];
|
|
2064
|
+
case 6:
|
|
2065
|
+
_c.sent();
|
|
2066
|
+
_c.label = 7;
|
|
2067
|
+
case 7: return [4, this.getSession()];
|
|
2068
|
+
case 8:
|
|
2069
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
2070
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
2071
|
+
case 9:
|
|
2072
|
+
error_33 = _c.sent();
|
|
2073
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_33) }];
|
|
2074
|
+
case 10: return [2];
|
|
2075
|
+
}
|
|
2076
|
+
});
|
|
2077
|
+
}); },
|
|
2078
|
+
},
|
|
2079
|
+
error: null,
|
|
2080
|
+
}];
|
|
2081
|
+
case 3:
|
|
2082
|
+
error_32 = _a.sent();
|
|
2083
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_32) }];
|
|
2084
|
+
case 4: return [2];
|
|
2085
|
+
}
|
|
2086
|
+
});
|
|
2087
|
+
});
|
|
2088
|
+
};
|
|
2089
|
+
Auth.prototype.resend = function (params) {
|
|
2090
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2091
|
+
var target, data, verificationId, error_34;
|
|
2092
|
+
return __generator(this, function (_a) {
|
|
2093
|
+
switch (_a.label) {
|
|
2094
|
+
case 0:
|
|
2095
|
+
_a.trys.push([0, 2, , 3]);
|
|
2096
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
2097
|
+
target = params.type === 'signup' ? 'ANY' : 'USER';
|
|
2098
|
+
data = { target: target };
|
|
2099
|
+
if ('email' in params) {
|
|
2100
|
+
data.email = params.email;
|
|
2101
|
+
}
|
|
2102
|
+
if ('phone' in params) {
|
|
2103
|
+
data.phone_number = this.formatPhone(params.phone);
|
|
2104
|
+
}
|
|
2105
|
+
return [4, this.oauthInstance.authApi.getVerification(data)];
|
|
2106
|
+
case 1:
|
|
2107
|
+
verificationId = (_a.sent()).verification_id;
|
|
2108
|
+
return [2, {
|
|
2109
|
+
data: { messageId: verificationId },
|
|
2110
|
+
error: null,
|
|
2111
|
+
}];
|
|
2112
|
+
case 2:
|
|
2113
|
+
error_34 = _a.sent();
|
|
2114
|
+
return [2, {
|
|
2115
|
+
data: {},
|
|
2116
|
+
error: new oauth_1.AuthError(error_34),
|
|
2117
|
+
}];
|
|
2118
|
+
case 3: return [2];
|
|
2119
|
+
}
|
|
2120
|
+
});
|
|
2121
|
+
});
|
|
2122
|
+
};
|
|
2123
|
+
Auth.prototype.setSession = function (params) {
|
|
2124
|
+
var _a;
|
|
2125
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2126
|
+
var _b, _c, session, error_35;
|
|
2127
|
+
return __generator(this, function (_d) {
|
|
2128
|
+
switch (_d.label) {
|
|
2129
|
+
case 0:
|
|
2130
|
+
_d.trys.push([0, 3, , 4]);
|
|
2131
|
+
this.validateParams(params, {
|
|
2132
|
+
access_token: { required: true, message: 'Access token is required' },
|
|
2133
|
+
refresh_token: { required: true, message: 'Refresh token is required' },
|
|
2134
|
+
});
|
|
2135
|
+
return [4, this.oauthInstance.oauth2client.refreshToken(params, { throwError: true })];
|
|
2136
|
+
case 1:
|
|
2137
|
+
_d.sent();
|
|
2138
|
+
return [4, this.getSession()];
|
|
2139
|
+
case 2:
|
|
2140
|
+
_b = (_d.sent()).data, _c = _b === void 0 ? {} : _b, session = _c.session;
|
|
2141
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.SIGNED_IN });
|
|
2142
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
2143
|
+
case 3:
|
|
2144
|
+
error_35 = _d.sent();
|
|
2145
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_35) }];
|
|
2146
|
+
case 4: return [2];
|
|
2147
|
+
}
|
|
2148
|
+
});
|
|
2149
|
+
});
|
|
2150
|
+
};
|
|
2151
|
+
Auth.prototype.exchangeCodeForSession = function () {
|
|
2152
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2153
|
+
return __generator(this, function (_a) {
|
|
2154
|
+
return [2];
|
|
2155
|
+
});
|
|
2156
|
+
});
|
|
2157
|
+
};
|
|
2158
|
+
Auth.prototype.deleteUser = function (params) {
|
|
2159
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2160
|
+
var sudo_token, error_36;
|
|
2161
|
+
return __generator(this, function (_a) {
|
|
2162
|
+
switch (_a.label) {
|
|
2163
|
+
case 0:
|
|
2164
|
+
_a.trys.push([0, 3, , 4]);
|
|
2165
|
+
this.validateParams(params, {
|
|
2166
|
+
password: { required: true, message: 'Password is required' },
|
|
2167
|
+
});
|
|
2168
|
+
return [4, this.oauthInstance.authApi.sudo(params)];
|
|
2169
|
+
case 1:
|
|
2170
|
+
sudo_token = (_a.sent()).sudo_token;
|
|
2171
|
+
return [4, this.oauthInstance.authApi.deleteMe({ sudo_token: sudo_token })];
|
|
2172
|
+
case 2:
|
|
2173
|
+
_a.sent();
|
|
2174
|
+
return [2, { data: {}, error: null }];
|
|
2175
|
+
case 3:
|
|
2176
|
+
error_36 = _a.sent();
|
|
2177
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_36) }];
|
|
2178
|
+
case 4: return [2];
|
|
2179
|
+
}
|
|
2180
|
+
});
|
|
2181
|
+
});
|
|
2182
|
+
};
|
|
2183
|
+
Auth.prototype.toDefaultLoginPage = function (params) {
|
|
2184
|
+
if (params === void 0) { params = {}; }
|
|
2185
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2186
|
+
var configVersion, query, redirectUri, urlObj, loginPage;
|
|
2187
|
+
return __generator(this, function (_a) {
|
|
2188
|
+
try {
|
|
2189
|
+
configVersion = params.config_version || 'env';
|
|
2190
|
+
query = Object.keys(params.query || {})
|
|
2191
|
+
.map(function (key) { return "".concat(key, "=").concat(params.query[key]); })
|
|
2192
|
+
.join('&');
|
|
2193
|
+
if (utilities_1.adapterForWxMp.isMatch()) {
|
|
2194
|
+
wx.navigateTo({ url: "/packages/$wd_system/pages/login/index".concat(query ? "?".concat(query) : '') });
|
|
2195
|
+
}
|
|
2196
|
+
else {
|
|
2197
|
+
redirectUri = params.redirect_uri || window.location.href;
|
|
2198
|
+
urlObj = new URL(redirectUri);
|
|
2199
|
+
loginPage = "".concat(urlObj.origin, "/__auth/?app_id=").concat(params.app_id || '', "&env_id=").concat(this.config.env, "&client_id=").concat(this.config.clientId || this.config.env, "&config_version=").concat(configVersion, "&redirect_uri=").concat(encodeURIComponent(redirectUri)).concat(query ? "&".concat(query) : '');
|
|
2200
|
+
window.location.href = loginPage;
|
|
2201
|
+
}
|
|
2202
|
+
return [2, { data: {}, error: null }];
|
|
2203
|
+
}
|
|
2204
|
+
catch (error) {
|
|
2205
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error) }];
|
|
2206
|
+
}
|
|
2207
|
+
return [2];
|
|
2208
|
+
});
|
|
2209
|
+
});
|
|
2210
|
+
};
|
|
2211
|
+
Auth.prototype.signInWithCustomTicket = function (getTickFn) {
|
|
2212
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2213
|
+
var loginState, _a, _b, session, error_37;
|
|
2214
|
+
return __generator(this, function (_c) {
|
|
2215
|
+
switch (_c.label) {
|
|
2216
|
+
case 0:
|
|
2217
|
+
if (getTickFn) {
|
|
2218
|
+
this.setCustomSignFunc(getTickFn);
|
|
2219
|
+
}
|
|
2220
|
+
_c.label = 1;
|
|
2221
|
+
case 1:
|
|
2222
|
+
_c.trys.push([1, 5, , 6]);
|
|
2223
|
+
return [4, this.oauthInstance.authApi.signInWithCustomTicket()];
|
|
2224
|
+
case 2:
|
|
2225
|
+
_c.sent();
|
|
2226
|
+
return [4, this.createLoginState()];
|
|
2227
|
+
case 3:
|
|
2228
|
+
loginState = _c.sent();
|
|
2229
|
+
return [4, this.getSession()];
|
|
2230
|
+
case 4:
|
|
2231
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
2232
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
2233
|
+
case 5:
|
|
2234
|
+
error_37 = _c.sent();
|
|
2235
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_37) }];
|
|
2236
|
+
case 6: return [2];
|
|
2237
|
+
}
|
|
2238
|
+
});
|
|
2239
|
+
});
|
|
2240
|
+
};
|
|
2241
|
+
Auth.prototype.signInWithOpenId = function (_a) {
|
|
2242
|
+
var _b = _a === void 0 ? {} : _a, _c = _b.useWxCloud, useWxCloud = _c === void 0 ? true : _c;
|
|
2243
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2244
|
+
var wxInfo, mainFunc, loginState, _d, _e, session, error_38;
|
|
2245
|
+
var _this = this;
|
|
2246
|
+
return __generator(this, function (_f) {
|
|
2247
|
+
switch (_f.label) {
|
|
2248
|
+
case 0:
|
|
2249
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
2250
|
+
throw Error('wx api undefined');
|
|
2251
|
+
}
|
|
2252
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
2253
|
+
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
2254
|
+
var result, credentials, error_39;
|
|
2255
|
+
return __generator(this, function (_a) {
|
|
2256
|
+
switch (_a.label) {
|
|
2257
|
+
case 0:
|
|
2258
|
+
result = undefined;
|
|
2259
|
+
credentials = undefined;
|
|
2260
|
+
_a.label = 1;
|
|
2261
|
+
case 1:
|
|
2262
|
+
_a.trys.push([1, 4, , 5]);
|
|
2263
|
+
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
2264
|
+
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
2265
|
+
provider_code: code,
|
|
2266
|
+
provider_params: {
|
|
2267
|
+
provider_code_type: 'open_id',
|
|
2268
|
+
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
2269
|
+
},
|
|
2270
|
+
}, useWxCloud)];
|
|
2271
|
+
case 2:
|
|
2272
|
+
result = _a.sent();
|
|
2273
|
+
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
2274
|
+
throw result;
|
|
2275
|
+
}
|
|
2276
|
+
return [4, this.oauthInstance.authApi.signInWithProvider({ provider_token: result.provider_token }, useWxCloud)];
|
|
2277
|
+
case 3:
|
|
2278
|
+
credentials = _a.sent();
|
|
2279
|
+
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
2280
|
+
throw credentials;
|
|
2281
|
+
}
|
|
2282
|
+
return [3, 5];
|
|
2283
|
+
case 4:
|
|
2284
|
+
error_39 = _a.sent();
|
|
2285
|
+
throw error_39;
|
|
2286
|
+
case 5: return [4, this.oauthInstance.oauth2client.setCredentials(credentials)];
|
|
2287
|
+
case 6:
|
|
2288
|
+
_a.sent();
|
|
2289
|
+
return [2];
|
|
2290
|
+
}
|
|
2291
|
+
});
|
|
2292
|
+
}); };
|
|
2293
|
+
_f.label = 1;
|
|
2294
|
+
case 1:
|
|
2295
|
+
_f.trys.push([1, 5, , 6]);
|
|
2296
|
+
return [4, new Promise(function (resolve, reject) {
|
|
2297
|
+
wx.login({
|
|
2298
|
+
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
2299
|
+
var error_40;
|
|
2300
|
+
return __generator(this, function (_a) {
|
|
2301
|
+
switch (_a.label) {
|
|
2302
|
+
case 0:
|
|
2303
|
+
_a.trys.push([0, 2, , 3]);
|
|
2304
|
+
return [4, mainFunc(res.code)];
|
|
2305
|
+
case 1:
|
|
2306
|
+
_a.sent();
|
|
2307
|
+
resolve(true);
|
|
2308
|
+
return [3, 3];
|
|
2309
|
+
case 2:
|
|
2310
|
+
error_40 = _a.sent();
|
|
2311
|
+
reject(error_40);
|
|
2312
|
+
return [3, 3];
|
|
2313
|
+
case 3: return [2];
|
|
2314
|
+
}
|
|
2315
|
+
});
|
|
2316
|
+
}); },
|
|
2317
|
+
fail: function (res) {
|
|
2318
|
+
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
2319
|
+
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
2320
|
+
reject(error);
|
|
2321
|
+
},
|
|
2322
|
+
});
|
|
2323
|
+
})];
|
|
2324
|
+
case 2:
|
|
2325
|
+
_f.sent();
|
|
2326
|
+
return [4, this.createLoginState()];
|
|
2327
|
+
case 3:
|
|
2328
|
+
loginState = _f.sent();
|
|
2329
|
+
return [4, this.getSession()];
|
|
2330
|
+
case 4:
|
|
2331
|
+
_d = (_f.sent()).data, _e = _d === void 0 ? {} : _d, session = _e.session;
|
|
2332
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
2333
|
+
case 5:
|
|
2334
|
+
error_38 = _f.sent();
|
|
2335
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_38) }];
|
|
2336
|
+
case 6: return [2];
|
|
2337
|
+
}
|
|
2338
|
+
});
|
|
2339
|
+
});
|
|
2340
|
+
};
|
|
2341
|
+
Auth.prototype.signInWithPhoneAuth = function (_a) {
|
|
2342
|
+
var _b = _a.phoneCode, phoneCode = _b === void 0 ? '' : _b;
|
|
2343
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2344
|
+
var wxInfo, providerInfo, code, providerToken, signInRes, error_41, loginState, _c, _d, session;
|
|
2345
|
+
return __generator(this, function (_e) {
|
|
2346
|
+
switch (_e.label) {
|
|
2347
|
+
case 0:
|
|
2348
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
2349
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'wx api undefined' }) }];
|
|
2350
|
+
}
|
|
2351
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
2352
|
+
providerInfo = {
|
|
2353
|
+
provider_params: { provider_code_type: 'phone' },
|
|
2354
|
+
provider_id: wxInfo.appId,
|
|
2355
|
+
};
|
|
2356
|
+
return [4, wx.login()];
|
|
2357
|
+
case 1:
|
|
2358
|
+
code = (_e.sent()).code;
|
|
2359
|
+
providerInfo.provider_code = code;
|
|
2360
|
+
_e.label = 2;
|
|
2361
|
+
case 2:
|
|
2362
|
+
_e.trys.push([2, 6, , 7]);
|
|
2363
|
+
return [4, this.oauthInstance.authApi.grantProviderToken(providerInfo)];
|
|
2364
|
+
case 3:
|
|
2365
|
+
providerToken = _e.sent();
|
|
2366
|
+
if (providerToken.error_code) {
|
|
2367
|
+
throw providerToken;
|
|
2368
|
+
}
|
|
2369
|
+
return [4, this.oauthInstance.authApi.patchProviderToken({
|
|
2370
|
+
provider_token: providerToken.provider_token,
|
|
2371
|
+
provider_id: wxInfo.appId,
|
|
2372
|
+
provider_params: {
|
|
2373
|
+
code: phoneCode,
|
|
2374
|
+
provider_code_type: 'phone',
|
|
2375
|
+
},
|
|
2376
|
+
})];
|
|
2377
|
+
case 4:
|
|
2378
|
+
providerToken = _e.sent();
|
|
2379
|
+
if (providerToken.error_code) {
|
|
2380
|
+
throw providerToken;
|
|
2381
|
+
}
|
|
2382
|
+
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
2383
|
+
provider_token: providerToken.provider_token,
|
|
2384
|
+
})];
|
|
2385
|
+
case 5:
|
|
2386
|
+
signInRes = _e.sent();
|
|
2387
|
+
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
2388
|
+
throw signInRes;
|
|
2389
|
+
}
|
|
2390
|
+
return [3, 7];
|
|
2391
|
+
case 6:
|
|
2392
|
+
error_41 = _e.sent();
|
|
2393
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_41) }];
|
|
2394
|
+
case 7: return [4, this.createLoginState()];
|
|
2395
|
+
case 8:
|
|
2396
|
+
loginState = _e.sent();
|
|
2397
|
+
return [4, this.getSession()];
|
|
2398
|
+
case 9:
|
|
2399
|
+
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
2400
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
2401
|
+
}
|
|
2402
|
+
});
|
|
2403
|
+
});
|
|
2404
|
+
};
|
|
2405
|
+
Auth.prototype.formatPhone = function (phone) {
|
|
2406
|
+
if (!/\s+/.test(phone) && /^\+\d{1,3}\d+/.test(phone)) {
|
|
2407
|
+
return phone.replace(/^(\+\d{1,2})(\d+)$/, '$1 $2');
|
|
2408
|
+
}
|
|
2409
|
+
return /^\+\d{1,3}\s+/.test(phone) ? phone : "+86 ".concat(phone);
|
|
2410
|
+
};
|
|
2411
|
+
Auth.prototype.notifyListeners = function (event, session, info) {
|
|
2412
|
+
this.listeners.forEach(function (callbacks) {
|
|
2413
|
+
callbacks.forEach(function (callback) {
|
|
2414
|
+
try {
|
|
2415
|
+
callback(event, session, info);
|
|
2416
|
+
}
|
|
2417
|
+
catch (error) {
|
|
2418
|
+
console.error('Error in auth state change callback:', error);
|
|
2419
|
+
}
|
|
2420
|
+
});
|
|
2421
|
+
});
|
|
2422
|
+
return;
|
|
2423
|
+
};
|
|
2424
|
+
Auth.prototype.setupListeners = function () {
|
|
2425
|
+
var _this = this;
|
|
2426
|
+
var _a;
|
|
2427
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.on(oauth_1.EVENTS.AUTH_STATE_CHANGED, function (params) { return __awaiter(_this, void 0, void 0, function () {
|
|
2428
|
+
var event, info, session;
|
|
2429
|
+
var _a, _b;
|
|
2430
|
+
return __generator(this, function (_c) {
|
|
2431
|
+
switch (_c.label) {
|
|
2432
|
+
case 0:
|
|
2433
|
+
event = (_a = params === null || params === void 0 ? void 0 : params.data) === null || _a === void 0 ? void 0 : _a.event;
|
|
2434
|
+
info = (_b = params === null || params === void 0 ? void 0 : params.data) === null || _b === void 0 ? void 0 : _b.info;
|
|
2435
|
+
return [4, this.getSession()];
|
|
2436
|
+
case 1:
|
|
2437
|
+
session = (_c.sent()).data.session;
|
|
2438
|
+
this.notifyListeners(event, session, info);
|
|
2439
|
+
return [2];
|
|
2440
|
+
}
|
|
2441
|
+
});
|
|
2442
|
+
}); });
|
|
2443
|
+
};
|
|
2444
|
+
Auth.prototype.convertToUser = function (userInfo) {
|
|
2445
|
+
var _a, _b, _c;
|
|
2446
|
+
if (!userInfo)
|
|
2447
|
+
return null;
|
|
2448
|
+
var email = (userInfo === null || userInfo === void 0 ? void 0 : userInfo.email) || '';
|
|
2449
|
+
var phone = (userInfo === null || userInfo === void 0 ? void 0 : userInfo.phone_number) || '';
|
|
2450
|
+
var userId = (userInfo === null || userInfo === void 0 ? void 0 : userInfo.sub) || (userInfo === null || userInfo === void 0 ? void 0 : userInfo.uid) || '';
|
|
2451
|
+
return {
|
|
2452
|
+
id: userId,
|
|
2453
|
+
aud: 'authenticated',
|
|
2454
|
+
role: userInfo.groups.map(function (group) { return (typeof group === 'string' ? group : group.id); }),
|
|
2455
|
+
email: email || '',
|
|
2456
|
+
email_confirmed_at: (userInfo === null || userInfo === void 0 ? void 0 : userInfo.email_verified) ? userInfo.created_at : userInfo.created_at,
|
|
2457
|
+
phone: phone,
|
|
2458
|
+
phone_confirmed_at: phone ? userInfo.created_at : undefined,
|
|
2459
|
+
confirmed_at: userInfo.created_at,
|
|
2460
|
+
last_sign_in_at: userInfo.last_sign_in_at,
|
|
2461
|
+
app_metadata: {
|
|
2462
|
+
provider: ((_a = userInfo.loginType) === null || _a === void 0 ? void 0 : _a.toLowerCase()) || 'cloudbase',
|
|
2463
|
+
providers: [((_b = userInfo.loginType) === null || _b === void 0 ? void 0 : _b.toLowerCase()) || 'cloudbase'],
|
|
2464
|
+
},
|
|
2465
|
+
user_metadata: {
|
|
2466
|
+
name: userInfo === null || userInfo === void 0 ? void 0 : userInfo.name,
|
|
2467
|
+
picture: userInfo === null || userInfo === void 0 ? void 0 : userInfo.picture,
|
|
2468
|
+
username: userInfo === null || userInfo === void 0 ? void 0 : userInfo.username,
|
|
2469
|
+
gender: userInfo === null || userInfo === void 0 ? void 0 : userInfo.gender,
|
|
2470
|
+
locale: userInfo === null || userInfo === void 0 ? void 0 : userInfo.locale,
|
|
2471
|
+
uid: userInfo.uid,
|
|
2472
|
+
nickName: userInfo.nickName,
|
|
2473
|
+
avatarUrl: userInfo.avatarUrl || userInfo.picture,
|
|
2474
|
+
location: userInfo.location,
|
|
2475
|
+
hasPassword: userInfo.hasPassword,
|
|
2476
|
+
},
|
|
2477
|
+
identities: ((_c = userInfo === null || userInfo === void 0 ? void 0 : userInfo.providers) === null || _c === void 0 ? void 0 : _c.map(function (p) { return ({
|
|
2478
|
+
id: p.id || '',
|
|
2479
|
+
identity_id: p.id || '',
|
|
2480
|
+
user_id: userId,
|
|
2481
|
+
identity_data: {
|
|
2482
|
+
provider_id: p.id,
|
|
2483
|
+
provider_user_id: p.provider_user_id,
|
|
2484
|
+
name: p.name,
|
|
2485
|
+
},
|
|
2486
|
+
provider: p.id || 'cloudbase',
|
|
2487
|
+
created_at: userInfo.created_at,
|
|
2488
|
+
updated_at: userInfo.updated_at,
|
|
2489
|
+
last_sign_in_at: userInfo.last_sign_in_at,
|
|
2490
|
+
}); })) || [],
|
|
2491
|
+
created_at: userInfo.created_at,
|
|
2492
|
+
updated_at: userInfo.updated_at,
|
|
2493
|
+
is_anonymous: userInfo.name === 'anonymous',
|
|
2494
|
+
};
|
|
2495
|
+
};
|
|
2496
|
+
Auth.prototype.validateParams = function (params, rules) {
|
|
2497
|
+
for (var _i = 0, _a = Object.entries(rules); _i < _a.length; _i++) {
|
|
2498
|
+
var _b = _a[_i], key = _b[0], rule = _b[1];
|
|
2499
|
+
if (rule.required && ((params === null || params === void 0 ? void 0 : params[key]) === undefined || (params === null || params === void 0 ? void 0 : params[key]) === null || (params === null || params === void 0 ? void 0 : params[key]) === '')) {
|
|
2500
|
+
throw new oauth_1.AuthError({ message: rule.message });
|
|
2501
|
+
}
|
|
2502
|
+
}
|
|
2503
|
+
};
|
|
2504
|
+
Auth.prototype.validateAtLeastOne = function (params, fieldGroups, message) {
|
|
2505
|
+
var hasValue = fieldGroups.some(function (group) { return group.some(function (field) { return (params === null || params === void 0 ? void 0 : params[field]) !== undefined && (params === null || params === void 0 ? void 0 : params[field]) !== null && (params === null || params === void 0 ? void 0 : params[field]) !== ''; }); });
|
|
2506
|
+
if (!hasValue) {
|
|
2507
|
+
throw new oauth_1.AuthError({ message: message });
|
|
2508
|
+
}
|
|
2509
|
+
};
|
|
2510
|
+
Auth.prototype.init = function () {
|
|
2511
|
+
var _a;
|
|
2512
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2513
|
+
var credentials, error_42;
|
|
2514
|
+
return __generator(this, function (_b) {
|
|
2515
|
+
switch (_b.label) {
|
|
2516
|
+
case 0:
|
|
2517
|
+
_b.trys.push([0, 2, , 3]);
|
|
2518
|
+
return [4, this.oauthInstance.oauth2client.localCredentials.getCredentials()];
|
|
2519
|
+
case 1:
|
|
2520
|
+
credentials = _b.sent();
|
|
2521
|
+
if (credentials) {
|
|
2522
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, { event: oauth_1.AUTH_STATE_CHANGED_TYPE.INITIAL_SESSION });
|
|
2523
|
+
}
|
|
2524
|
+
return [3, 3];
|
|
2525
|
+
case 2:
|
|
2526
|
+
error_42 = _b.sent();
|
|
2527
|
+
return [3, 3];
|
|
2528
|
+
case 3: return [2, { error: null }];
|
|
2529
|
+
}
|
|
2530
|
+
});
|
|
2531
|
+
});
|
|
2532
|
+
};
|
|
2533
|
+
__decorate([
|
|
2534
|
+
(0, utilities_1.catchErrorsDecorator)({
|
|
2535
|
+
title: '绑定手机号失败',
|
|
2536
|
+
messages: [
|
|
2537
|
+
'请确认以下各项:',
|
|
2538
|
+
' 1 - 调用 auth().bindPhoneNumber() 的语法或参数是否正确',
|
|
2539
|
+
' 2 - 当前环境是否开通了短信验证码登录',
|
|
2540
|
+
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1388
2541
|
],
|
|
1389
2542
|
}),
|
|
1390
2543
|
__metadata("design:type", Function),
|
|
@@ -1460,20 +2613,6 @@ var Auth = (function () {
|
|
|
1460
2613
|
__metadata("design:paramtypes", []),
|
|
1461
2614
|
__metadata("design:returntype", Promise)
|
|
1462
2615
|
], Auth.prototype, "getCurrentUser", null);
|
|
1463
|
-
__decorate([
|
|
1464
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1465
|
-
title: '匿名登录失败',
|
|
1466
|
-
messages: [
|
|
1467
|
-
'请确认以下各项:',
|
|
1468
|
-
' 1 - 当前环境是否开启了匿名登录',
|
|
1469
|
-
' 2 - 调用 auth().signInAnonymously() 的语法或参数是否正确',
|
|
1470
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1471
|
-
],
|
|
1472
|
-
}),
|
|
1473
|
-
__metadata("design:type", Function),
|
|
1474
|
-
__metadata("design:paramtypes", [Object]),
|
|
1475
|
-
__metadata("design:returntype", Promise)
|
|
1476
|
-
], Auth.prototype, "signInAnonymously", null);
|
|
1477
2616
|
__decorate([
|
|
1478
2617
|
(0, utilities_1.catchErrorsDecorator)({
|
|
1479
2618
|
title: '小程序匿名登录失败',
|
|
@@ -1502,20 +2641,6 @@ var Auth = (function () {
|
|
|
1502
2641
|
__metadata("design:paramtypes", []),
|
|
1503
2642
|
__metadata("design:returntype", Promise)
|
|
1504
2643
|
], Auth.prototype, "bindOpenId", null);
|
|
1505
|
-
__decorate([
|
|
1506
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1507
|
-
title: '小程序openId静默登录失败',
|
|
1508
|
-
messages: [
|
|
1509
|
-
'请确认以下各项:',
|
|
1510
|
-
' 1 - 当前环境是否开启了小程序openId静默登录',
|
|
1511
|
-
' 2 - 调用 auth().signInWithOpenId() 的语法或参数是否正确',
|
|
1512
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1513
|
-
],
|
|
1514
|
-
}),
|
|
1515
|
-
__metadata("design:type", Function),
|
|
1516
|
-
__metadata("design:paramtypes", [Object]),
|
|
1517
|
-
__metadata("design:returntype", Promise)
|
|
1518
|
-
], Auth.prototype, "signInWithOpenId", null);
|
|
1519
2644
|
__decorate([
|
|
1520
2645
|
(0, utilities_1.catchErrorsDecorator)({
|
|
1521
2646
|
title: '小程序unionId静默登录失败',
|
|
@@ -1530,20 +2655,6 @@ var Auth = (function () {
|
|
|
1530
2655
|
__metadata("design:paramtypes", []),
|
|
1531
2656
|
__metadata("design:returntype", Promise)
|
|
1532
2657
|
], Auth.prototype, "signInWithUnionId", null);
|
|
1533
|
-
__decorate([
|
|
1534
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1535
|
-
title: '小程序手机号授权登录失败',
|
|
1536
|
-
messages: [
|
|
1537
|
-
'请确认以下各项:',
|
|
1538
|
-
' 1 - 当前环境是否开启了小程序手机号授权登录',
|
|
1539
|
-
' 2 - 调用 auth().signInWithPhoneAuth() 的语法或参数是否正确',
|
|
1540
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1541
|
-
],
|
|
1542
|
-
}),
|
|
1543
|
-
__metadata("design:type", Function),
|
|
1544
|
-
__metadata("design:paramtypes", [Object]),
|
|
1545
|
-
__metadata("design:returntype", Promise)
|
|
1546
|
-
], Auth.prototype, "signInWithPhoneAuth", null);
|
|
1547
2658
|
__decorate([
|
|
1548
2659
|
(0, utilities_1.catchErrorsDecorator)({
|
|
1549
2660
|
title: '短信验证码登陆',
|
|
@@ -1572,36 +2683,6 @@ var Auth = (function () {
|
|
|
1572
2683
|
__metadata("design:paramtypes", [Object]),
|
|
1573
2684
|
__metadata("design:returntype", Promise)
|
|
1574
2685
|
], Auth.prototype, "signInWithEmail", null);
|
|
1575
|
-
__decorate([
|
|
1576
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1577
|
-
title: '自定义登录失败',
|
|
1578
|
-
messages: [
|
|
1579
|
-
'请确认以下各项:',
|
|
1580
|
-
' 1 - 当前环境是否开启了自定义登录',
|
|
1581
|
-
' 2 - 调用 auth().signInWithCustomTicket() 的语法或参数是否正确',
|
|
1582
|
-
' 3 - ticket 是否归属于当前环境',
|
|
1583
|
-
' 4 - 创建 ticket 的自定义登录私钥是否过期',
|
|
1584
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1585
|
-
],
|
|
1586
|
-
}),
|
|
1587
|
-
__metadata("design:type", Function),
|
|
1588
|
-
__metadata("design:paramtypes", []),
|
|
1589
|
-
__metadata("design:returntype", Promise)
|
|
1590
|
-
], Auth.prototype, "signInWithCustomTicket", null);
|
|
1591
|
-
__decorate([
|
|
1592
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1593
|
-
title: '注册失败',
|
|
1594
|
-
messages: [
|
|
1595
|
-
'请确认以下各项:',
|
|
1596
|
-
' 1 - 当前环境是否开启了指定登录方式',
|
|
1597
|
-
' 2 - 调用 auth().signUp() 的语法或参数是否正确',
|
|
1598
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1599
|
-
],
|
|
1600
|
-
}),
|
|
1601
|
-
__metadata("design:type", Function),
|
|
1602
|
-
__metadata("design:paramtypes", [Object]),
|
|
1603
|
-
__metadata("design:returntype", Promise)
|
|
1604
|
-
], Auth.prototype, "signUp", null);
|
|
1605
2686
|
__decorate([
|
|
1606
2687
|
(0, utilities_1.catchErrorsDecorator)({
|
|
1607
2688
|
title: '获取用户是否被占用失败',
|
|
@@ -1615,20 +2696,6 @@ var Auth = (function () {
|
|
|
1615
2696
|
__metadata("design:paramtypes", [String]),
|
|
1616
2697
|
__metadata("design:returntype", Promise)
|
|
1617
2698
|
], Auth.prototype, "isUsernameRegistered", null);
|
|
1618
|
-
__decorate([
|
|
1619
|
-
(0, utilities_1.catchErrorsDecorator)({
|
|
1620
|
-
title: '用户登出失败',
|
|
1621
|
-
messages: [
|
|
1622
|
-
'请确认以下各项:',
|
|
1623
|
-
' 1 - 调用 auth().signOut() 的语法或参数是否正确',
|
|
1624
|
-
' 2 - 当前用户是否为匿名登录(匿名登录不支持signOut)',
|
|
1625
|
-
"\u5982\u679C\u95EE\u9898\u4F9D\u7136\u5B58\u5728\uFF0C\u5EFA\u8BAE\u5230\u5B98\u65B9\u95EE\u7B54\u793E\u533A\u63D0\u95EE\u6216\u5BFB\u627E\u5E2E\u52A9\uFF1A".concat(utilities_1.COMMUNITY_SITE_URL),
|
|
1626
|
-
],
|
|
1627
|
-
}),
|
|
1628
|
-
__metadata("design:type", Function),
|
|
1629
|
-
__metadata("design:paramtypes", [Object]),
|
|
1630
|
-
__metadata("design:returntype", Promise)
|
|
1631
|
-
], Auth.prototype, "signOut", null);
|
|
1632
2699
|
__decorate([
|
|
1633
2700
|
(0, utilities_1.catchErrorsDecorator)({
|
|
1634
2701
|
title: '获取本地登录态失败',
|
|
@@ -1653,7 +2720,7 @@ var Auth = (function () {
|
|
|
1653
2720
|
],
|
|
1654
2721
|
}),
|
|
1655
2722
|
__metadata("design:type", Function),
|
|
1656
|
-
__metadata("design:paramtypes", [
|
|
2723
|
+
__metadata("design:paramtypes", []),
|
|
1657
2724
|
__metadata("design:returntype", Promise)
|
|
1658
2725
|
], Auth.prototype, "getUserInfo", null);
|
|
1659
2726
|
__decorate([
|
|
@@ -1701,8 +2768,9 @@ var Auth = (function () {
|
|
|
1701
2768
|
}());
|
|
1702
2769
|
exports.Auth = Auth;
|
|
1703
2770
|
function generateAuthInstance(config, options) {
|
|
1704
|
-
var
|
|
1705
|
-
var
|
|
2771
|
+
var _this = this;
|
|
2772
|
+
var _a = config.region, region = _a === void 0 ? 'ap-shanghai' : _a, i18n = config.i18n, accessKey = config.accessKey, useWxCloud = config.useWxCloud;
|
|
2773
|
+
var platform = (options === null || options === void 0 ? void 0 : options.platform) || utilities_1.useDefaultAdapter.bind(options)();
|
|
1706
2774
|
var runtime = platform.runtime, adapter = platform.adapter;
|
|
1707
2775
|
var _b = options || {}, env = _b.env, clientId = _b.clientId, debug = _b.debug, cache = _b.cache, cloudbase = _b.app;
|
|
1708
2776
|
var apiOrigin = (options || {}).apiOrigin;
|
|
@@ -1713,48 +2781,81 @@ function generateAuthInstance(config, options) {
|
|
|
1713
2781
|
env: env,
|
|
1714
2782
|
clientId: clientId,
|
|
1715
2783
|
i18n: i18n,
|
|
1716
|
-
|
|
1717
|
-
|
|
1718
|
-
|
|
1719
|
-
|
|
1720
|
-
|
|
1721
|
-
|
|
1722
|
-
|
|
1723
|
-
|
|
1724
|
-
|
|
2784
|
+
accessKey: accessKey,
|
|
2785
|
+
useWxCloud: useWxCloud,
|
|
2786
|
+
eventBus: new utilities_1.CloudbaseEventEmitter(),
|
|
2787
|
+
};
|
|
2788
|
+
var oauthInstance = new oauth_1.CloudbaseOAuth((0, adapter_1.useAuthAdapter)(__assign(__assign({}, commonOpts), { apiOrigin: apiOrigin, apiPath: (config === null || config === void 0 ? void 0 : config.apiPath) || oauth_1.AUTH_API_PREFIX, storage: config === null || config === void 0 ? void 0 : config.storage, baseRequest: config === null || config === void 0 ? void 0 : config.baseRequest, request: config === null || config === void 0 ? void 0 : config.request, anonymousSignInFunc: config === null || config === void 0 ? void 0 : config.anonymousSignInFunc, captchaOptions: config === null || config === void 0 ? void 0 : config.captchaOptions, wxCloud: config === null || config === void 0 ? void 0 : config.wxCloud, adapter: adapter, onCredentialsError: onCredentialsError(commonOpts.eventBus), headers: __assign({ 'X-SDK-Version': "@cloudbase/js-sdk/".concat(config.sdkVersion) }, (config.headers || {})), detectSessionInUrl: config.detectSessionInUrl, debug: debug })));
|
|
2789
|
+
var authInstance = new Auth(__assign(__assign({}, commonOpts), { region: region, persistence: config.persistence, debug: debug, cache: cache || new utilities_1.CloudbaseCache({
|
|
2790
|
+
persistence: config.persistence,
|
|
2791
|
+
keys: { userInfoKey: "user_info_".concat(env) },
|
|
2792
|
+
platformInfo: platform,
|
|
2793
|
+
}), runtime: runtime || 'web', _fromApp: cloudbase, oauthInstance: oauthInstance }));
|
|
2794
|
+
oauthInstance.initializeSession(function (data, error) { return __awaiter(_this, void 0, void 0, function () {
|
|
2795
|
+
return __generator(this, function (_a) {
|
|
2796
|
+
if (!data)
|
|
2797
|
+
return [2];
|
|
2798
|
+
if (data.type === oauth_1.OAUTH_TYPE.SIGN_IN) {
|
|
2799
|
+
if (error) {
|
|
2800
|
+
commonOpts.eventBus.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, {
|
|
2801
|
+
event: oauth_1.AUTH_STATE_CHANGED_TYPE.SIGNED_IN,
|
|
2802
|
+
info: __assign(__assign({}, data), { error: error }),
|
|
2803
|
+
});
|
|
2804
|
+
}
|
|
2805
|
+
else if (data.user) {
|
|
2806
|
+
authInstance.createLoginState({}, { userInfo: data.user });
|
|
2807
|
+
}
|
|
2808
|
+
}
|
|
2809
|
+
else if (data.type === oauth_1.OAUTH_TYPE.BIND_IDENTITY) {
|
|
2810
|
+
commonOpts.eventBus.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, {
|
|
2811
|
+
event: oauth_1.AUTH_STATE_CHANGED_TYPE.BIND_IDENTITY,
|
|
2812
|
+
info: __assign(__assign({}, data), { error: error }),
|
|
2813
|
+
});
|
|
2814
|
+
}
|
|
2815
|
+
return [2];
|
|
2816
|
+
});
|
|
2817
|
+
}); });
|
|
1725
2818
|
return { authInstance: authInstance, oauthInstance: oauthInstance };
|
|
1726
2819
|
}
|
|
1727
2820
|
exports.generateAuthInstance = generateAuthInstance;
|
|
2821
|
+
var NAMESPACE = 'auth';
|
|
1728
2822
|
var component = {
|
|
1729
2823
|
name: COMPONENT_NAME,
|
|
1730
|
-
namespace:
|
|
2824
|
+
namespace: NAMESPACE,
|
|
1731
2825
|
entity: function (config) {
|
|
1732
|
-
|
|
1733
|
-
|
|
1734
|
-
|
|
1735
|
-
|
|
1736
|
-
|
|
1737
|
-
|
|
1738
|
-
|
|
2826
|
+
var auth = function (config) {
|
|
2827
|
+
var _a;
|
|
2828
|
+
if (this.authInstance && !config) {
|
|
2829
|
+
return this.authInstance;
|
|
2830
|
+
}
|
|
2831
|
+
config = config || {
|
|
2832
|
+
region: '',
|
|
2833
|
+
persistence: 'local',
|
|
2834
|
+
apiPath: oauth_1.AUTH_API_PREFIX,
|
|
2835
|
+
};
|
|
2836
|
+
var adapter = this.platform.adapter;
|
|
2837
|
+
var newPersistence = config.persistence || adapter.primaryStorage;
|
|
2838
|
+
if (newPersistence && newPersistence !== this.config.persistence) {
|
|
2839
|
+
this.updateConfig({ persistence: newPersistence });
|
|
2840
|
+
}
|
|
2841
|
+
var _b = generateAuthInstance(__assign(__assign({ wxCloud: this.config.wxCloud, storage: this.config.storage }, config), { persistence: this.config.persistence, i18n: this.config.i18n, accessKey: this.config.accessKey, useWxCloud: this.config.useWxCloud, sdkVersion: this.version, detectSessionInUrl: (_a = this.config.auth) === null || _a === void 0 ? void 0 : _a.detectSessionInUrl }), {
|
|
2842
|
+
env: this.config.env,
|
|
2843
|
+
clientId: this.config.clientId,
|
|
2844
|
+
apiOrigin: this.request.getBaseEndPoint(this.config.endPointMode || 'CLOUD_API'),
|
|
2845
|
+
platform: this.platform,
|
|
2846
|
+
cache: this.cache,
|
|
2847
|
+
app: this,
|
|
2848
|
+
debug: this.config.debug,
|
|
2849
|
+
}), authInstance = _b.authInstance, oauthInstance = _b.oauthInstance;
|
|
2850
|
+
this.oauthInstance = oauthInstance;
|
|
2851
|
+
this.authInstance = authInstance;
|
|
1739
2852
|
return this.authInstance;
|
|
1740
|
-
}
|
|
1741
|
-
var
|
|
1742
|
-
|
|
1743
|
-
|
|
1744
|
-
|
|
1745
|
-
|
|
1746
|
-
var _a = generateAuthInstance(__assign(__assign({ wxCloud: this.config.wxCloud, storage: this.config.storage }, config), { persistence: this.config.persistence, i18n: this.config.i18n, publishable_key: this.config.publishable_key }), {
|
|
1747
|
-
env: this.config.env,
|
|
1748
|
-
clientId: this.config.clientId,
|
|
1749
|
-
apiOrigin: this.request.getBaseEndPoint(),
|
|
1750
|
-
platform: this.platform,
|
|
1751
|
-
cache: this.cache,
|
|
1752
|
-
app: this,
|
|
1753
|
-
debug: this.config.debug,
|
|
1754
|
-
}), authInstance = _a.authInstance, oauthInstance = _a.oauthInstance;
|
|
1755
|
-
this.oauthInstance = oauthInstance;
|
|
1756
|
-
this.authInstance = authInstance;
|
|
1757
|
-
return this.authInstance;
|
|
2853
|
+
};
|
|
2854
|
+
var authProto = auth.call(this, config);
|
|
2855
|
+
Object.assign(auth, authProto);
|
|
2856
|
+
Object.setPrototypeOf(auth, Object.getPrototypeOf(authProto));
|
|
2857
|
+
this[NAMESPACE] = auth;
|
|
2858
|
+
return auth;
|
|
1758
2859
|
},
|
|
1759
2860
|
};
|
|
1760
2861
|
try {
|
|
@@ -1770,4 +2871,4 @@ function registerAuth(app) {
|
|
|
1770
2871
|
}
|
|
1771
2872
|
}
|
|
1772
2873
|
exports.registerAuth = registerAuth;
|
|
1773
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ICloudbase, ICloudbaseConfig, ICloudbasePlatformInfo } from '@cloudbase/types'\nimport type { ICloudbaseCache } from '@cloudbase/types/cache'\nimport type { ICloudbaseRequest } from '@cloudbase/types/request'\nimport type { ICloudbaseAuthConfig, IUser, IUserInfo, ILoginState } from '@cloudbase/types/auth'\nimport type { ICloudbaseComponent } from '@cloudbase/types/component'\nimport type { GrantProviderTokenResponse, ProviderSubType } from '@cloudbase/oauth/dist/cjs/auth/models'\nimport type { authModels, AuthOptions, Credentials } from '@cloudbase/oauth'\nimport { CloudbaseOAuth, AUTH_API_PREFIX } from '@cloudbase/oauth'\nimport { useAuthAdapter } from './adapter'\nimport {\n  printWarn,\n  throwError,\n  ERRORS,\n  COMMUNITY_SITE_URL,\n  catchErrorsDecorator,\n  CloudbaseEventEmitter,\n  CloudbaseCache,\n  adapterForWxMp,\n  useDefaultAdapter,\n} from './utilities'\n\ndeclare const cloudbase: ICloudbase\ndeclare const wx: any\n\nconst COMPONENT_NAME = 'auth'\n\nconst LOGIN_STATE_CHANGED_TYPE = {\n  SIGN_OUT: 'sign_out',\n  SIGN_IN: 'sign_in',\n  CREDENTIALS_ERROR: 'credentials_error',\n}\n\nconst EVENTS = {\n  // 登录态改变后触发\n  LOGIN_STATE_CHANGED: 'loginStateChanged',\n}\n\ninterface UserInfo {\n  uid?: string\n  gender?: string\n  picture?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  username?: string\n  name?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  sub?: string\n  created_from?: string\n}\n\nconst eventBus = new CloudbaseEventEmitter()\n\nconst onCredentialsError = (params) => {\n  eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { ...params, eventType: LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR })\n}\n\ninterface IUserOptions {\n  cache: ICloudbaseCache\n  oauthInstance: CloudbaseOAuth\n}\n\nclass User implements IUser {\n  public uid?: string\n  public gender?: string\n  public picture?: string\n  public email?: string\n  public emailVerified?: boolean\n  public phoneNumber?: string\n  public username?: string\n  public name?: string\n  public providers?: {\n    id?: string\n    providerUserId?: string\n    name?: string\n  }[]\n  public birthdate?: string\n  public zoneinfo?: string\n  public locale?: string\n  public sub?: string\n  public createdFrom?: string\n\n  private cache: ICloudbaseCache\n  private oauthInstance: CloudbaseOAuth // CloudbaseOAuth 类型\n\n  constructor(options: IUserOptions) {\n    const { cache, oauthInstance } = options\n    this.cache = cache\n    this.oauthInstance = oauthInstance\n\n    this.setUserInfo()\n  }\n  /**\n   * 获取本地用户信息-同步\n   */\n  public async checkLocalInfo() {\n    this.uid = this.getLocalUserInfo('uid') as string\n    this.gender = this.getLocalUserInfo('gender') as string\n    this.picture = this.getLocalUserInfo('picture') as string\n    this.email = this.getLocalUserInfo('email') as string\n    this.emailVerified = this.getLocalUserInfo('email_verified') as boolean\n    this.phoneNumber = this.getLocalUserInfo('phone_number') as string\n    this.username = this.getLocalUserInfo('username') as string\n    this.name = this.getLocalUserInfo('name') as string\n    this.birthdate = this.getLocalUserInfo('birthdate') as string\n    this.zoneinfo = this.getLocalUserInfo('zoneinfo') as string\n    this.locale = this.getLocalUserInfo('locale') as string\n    this.sub = this.getLocalUserInfo('sub') as string\n    this.createdFrom = this.getLocalUserInfo('created_from') as string\n    this.providers = this.getLocalUserInfo('providers') as any\n  }\n  /**\n   * 获取本地用户信息-异步\n   */\n  public async checkLocalInfoAsync() {\n    this.uid = await this.getLocalUserInfoAsync('uid')\n    this.gender = await this.getLocalUserInfoAsync('gender')\n    this.picture = this.getLocalUserInfo('picture') as string\n    this.email = await this.getLocalUserInfoAsync('email')\n    this.emailVerified = this.getLocalUserInfo('email_verified') as boolean\n    this.phoneNumber = this.getLocalUserInfo('phone_number') as string\n    this.username = await this.getLocalUserInfoAsync('username')\n    this.name = this.getLocalUserInfo('name') as string\n    this.birthdate = this.getLocalUserInfo('birthdate') as string\n    this.zoneinfo = this.getLocalUserInfo('zoneinfo') as string\n    this.locale = this.getLocalUserInfo('locale') as string\n    this.sub = this.getLocalUserInfo('sub') as string\n    this.createdFrom = this.getLocalUserInfo('created_from') as string\n    this.providers = this.getLocalUserInfo('providers') as any\n  }\n\n  /**\n   * 更新用户信息\n   * @param userInfo\n   */\n  @catchErrorsDecorator({\n    title: '更新用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.update() 的语法或参数是否正确',\n      '  2 - 用户信息中是否包含非法值',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async update(userInfo: authModels.UserProfile): Promise<void> {\n    // const { name, gender, avatarUrl, province, country, city } = userInfo\n    const newUserInfo = await this.oauthInstance.authApi.setUserProfile({ ...userInfo })\n\n    this.setLocalUserInfo(newUserInfo)\n  }\n\n  public async updateUserBasicInfo(params: authModels.ModifyUserBasicInfoRequest): Promise<void> {\n    await this.oauthInstance.authApi.updateUserBasicInfo({ ...params })\n    this.setLocalUserInfo({ username: params.username })\n  }\n\n  /**\n   * 更新密码\n   * @param newPassword\n   * @param oldPassword\n   */\n  @catchErrorsDecorator({\n    title: '更新密码失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.updatePassword() 的语法或参数是否正确',\n      '  3 - 新密码中是否包含非法字符',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public updatePassword(newPassword: string, oldPassword: string) {\n    return this.oauthInstance.authApi.updatePasswordByOld({\n      old_password: oldPassword,\n      new_password: newPassword,\n    })\n  }\n\n  /**\n   * 更新用户名\n   * @param username\n   */\n  @catchErrorsDecorator({\n    title: '更新用户名失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.updateUsername() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了用户名密码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public updateUsername(username: string) {\n    if (typeof username !== 'string') {\n      throwError(ERRORS.INVALID_PARAMS, 'username must be a string')\n    }\n\n    return this.update({\n      username,\n    })\n  }\n\n  /**\n   * 刷新本地用户信息。当用户在其他客户端更新用户信息之后，可以调用此接口同步更新之后的信息。\n   */\n  @catchErrorsDecorator({\n    title: '刷新本地用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.refresh() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async refresh(params?: { version?: string; query?: any }): Promise<IUserInfo> {\n    const newUserInfo = await this.oauthInstance.authApi.getUserInfo(params)\n    this.setLocalUserInfo(newUserInfo)\n    return newUserInfo\n  }\n\n  private getLocalUserInfo(key: string): string | boolean {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = this.cache.getStore(userInfoKey)\n    return userInfo[key]\n  }\n\n  private async getLocalUserInfoAsync(key: string): Promise<string> {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = await this.cache.getStoreAsync(userInfoKey)\n    return userInfo[key]\n  }\n\n  private setUserInfo() {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = this.cache.getStore(userInfoKey)\n    ;[\n      'uid',\n      'email',\n      'name',\n      'gender',\n      'picture',\n      'email_verified',\n      'phone_number',\n      'birthdate',\n      'zoneinfo',\n      'locale',\n      'sub',\n      'created_from',\n      'providers',\n      'username',\n    ].forEach((infoKey) => {\n      this[infoKey] = userInfo[infoKey]\n    })\n  }\n\n  private setLocalUserInfo(userInfo: any) {\n    const { userInfoKey } = this.cache.keys\n    this.cache.setStore(userInfoKey, userInfo)\n    this.setUserInfo()\n  }\n}\ninterface ILoginStateOptions extends IUserOptions {\n  envId: string\n}\nexport class LoginState implements ILoginState {\n  public user: User\n  public oauthLoginState: any\n\n  private oauthInstance: CloudbaseOAuth\n  private cache: ICloudbaseCache\n\n  constructor(options: ILoginStateOptions) {\n    const { envId, cache, oauthInstance } = options\n    if (!envId) {\n      throwError(ERRORS.INVALID_PARAMS, 'envId is not defined')\n    }\n    this.cache = cache\n    this.oauthInstance = oauthInstance\n\n    this.user = new User({\n      cache: this.cache,\n      oauthInstance,\n    })\n  }\n\n  public checkLocalState() {\n    this.oauthLoginState = this.oauthInstance?.authApi.hasLoginStateSync()\n    this.user.checkLocalInfo()\n  }\n\n  public async checkLocalStateAsync() {\n    await this.oauthInstance?.authApi.getLoginState()\n    await this.user.checkLocalInfoAsync()\n  }\n}\n\nclass Auth {\n  private readonly config: ICloudbaseAuthConfig\n  private readonly cache: ICloudbaseCache\n\n  private oauthInstance: CloudbaseOAuth\n\n  constructor(config: ICloudbaseAuthConfig & { cache: ICloudbaseCache; request?: ICloudbaseRequest; runtime?: string },) {\n    this.config = config\n    this.cache = config.cache\n    this.oauthInstance = config.oauthInstance\n\n    if (config.publishable_key) {\n      this.createLoginState()\n    }\n  }\n\n  /**\n   * 绑定手机号\n   * @param phoneNumber\n   * @param phoneCode\n   */\n  @catchErrorsDecorator({\n    title: '绑定手机号失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindPhoneNumber() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了短信验证码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindPhoneNumber(params: authModels.BindPhoneRequest) {\n    return this.oauthInstance.authApi.editContact(params)\n  }\n\n  /**\n   * 解绑三方绑定\n   * @param loginType\n   */\n  @catchErrorsDecorator({\n    title: '解除三方绑定失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().unbindProvider() 的语法或参数是否正确',\n      '  2 - 当前账户是否已经与此登录方式解绑',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async unbindProvider(params: authModels.UnbindProviderRequest): Promise<void> {\n    return this.oauthInstance.authApi.unbindProvider(params)\n  }\n\n  /**\n   * 更新邮箱地址\n   * @param email\n   * @param sudo_token\n   * @param verification_token\n   */\n  @catchErrorsDecorator({\n    title: '绑定邮箱地址失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindEmail() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了邮箱密码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public bindEmail(params: authModels.BindEmailRequest) {\n    return this.oauthInstance.authApi.editContact(params)\n  }\n\n  /**\n   * verify\n   * @param {authModels.VerifyRequest} params\n   * @returns {Promise<authModels.VerifyResponse>}\n   * @memberof User\n   */\n  @catchErrorsDecorator({\n    title: '验证码验证失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().verify() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了手机验证码/邮箱登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async verify(params: authModels.VerifyRequest): Promise<authModels.VerifyResponse> {\n    return this.oauthInstance.authApi.verify(params)\n  }\n\n  /**\n   * 获取验证码\n   * @param {authModels.GetVerificationRequest} params\n   * @returns {Promise<authModels.GetVerificationResponse>}\n   * @memberof User\n   */\n  @catchErrorsDecorator({\n    title: '获取验证码失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getVerification() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了手机验证码/邮箱登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getVerification(\n    params: authModels.GetVerificationRequest,\n    options?: { withCaptcha: boolean },\n  ): Promise<authModels.GetVerificationResponse> {\n    return this.oauthInstance.authApi.getVerification(params, options)\n  }\n\n  /**\n   * 获取当前登录的用户信息-同步\n   */\n  get currentUser() {\n    if (this.cache.mode === 'async') {\n      // async storage的平台调用此API提示\n      printWarn(\n        ERRORS.INVALID_OPERATION,\n        'current platform\\'s storage is asynchronous, please use getCurrentUser insteed',\n      )\n      return\n    }\n\n    const loginState = this.hasLoginState()\n\n    if (loginState) {\n      return loginState.user || null\n    }\n    return null\n  }\n\n  /**\n   * 获取当前登录的用户信息-异步\n   */\n  @catchErrorsDecorator({\n    title: '获取用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getCurrentUser() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getCurrentUser() {\n    const loginState = await this.getLoginState()\n    if (loginState) {\n      await loginState.user.checkLocalInfoAsync()\n      return loginState.user || null\n    }\n    return null\n  }\n\n  /**\n   * 匿名登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '匿名登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了匿名登录',\n      '  2 - 调用 auth().signInAnonymously() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInAnonymously(data: {\n    provider_token?: string\n  } = {},): Promise<LoginState> {\n    await this.oauthInstance.authApi.signInAnonymously(data)\n    return this.createLoginState()\n  }\n\n  /**\n   * 匿名登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序匿名登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了匿名登录',\n      '  2 - 调用 auth().signInAnonymouslyInWx() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInAnonymouslyInWx({\n    useWxCloud,\n  }: {\n    useWxCloud?: boolean\n  } = {}): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: GrantProviderTokenResponse | undefined = undefined\n      let credentials: Credentials | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken(\n          {\n            provider_id: wxInfo?.appId,\n            provider_code: code,\n            provider_params: {\n              provider_code_type: 'open_id',\n              appid: wxInfo?.appId,\n            },\n          },\n          useWxCloud,\n        )\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        credentials = await this.oauthInstance.authApi.signInAnonymously(\n          { provider_token: result.provider_token },\n          useWxCloud,\n        )\n\n        if ((credentials as any)?.error_code) {\n          throw credentials\n        }\n      } catch (error) {\n        throw error\n      }\n    }\n\n    await new Promise((resolve, reject) => {\n      wx.login({\n        success: async (res: { code: string }) => {\n          try {\n            await mainFunc(res.code)\n            resolve(true)\n          } catch (error) {\n            reject(error)\n          }\n        },\n        fail: (res: any) => {\n          const error = new Error(res?.errMsg)\n          ;(error as any).code = res?.errno\n          reject(error)\n        },\n      })\n    })\n\n    return this.createLoginState(undefined, { asyncRefreshUser: true })\n  }\n\n  /**\n   * 小程序绑定OpenID\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序绑定OpenID失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序openId静默登录',\n      '  2 - 调用 auth().bindOpenId() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindOpenId(): Promise<void> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: GrantProviderTokenResponse | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken({\n          provider_id: wxInfo?.appId,\n          provider_code: code,\n          provider_params: {\n            provider_code_type: 'open_id',\n            appid: wxInfo?.appId,\n          },\n        })\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        await this.oauthInstance.authApi.bindWithProvider({ provider_token: result.provider_token })\n      } catch (error) {\n        throw error\n      }\n    }\n\n    await new Promise((resolve, reject) => {\n      wx.login({\n        success: async (res: { code: string }) => {\n          try {\n            await mainFunc(res.code)\n            resolve(true)\n          } catch (error) {\n            reject(error)\n          }\n        },\n        fail: (res: any) => {\n          const error = new Error(res?.errMsg)\n          ;(error as any).code = res?.errno\n          reject(error)\n        },\n      })\n    })\n\n    return\n  }\n\n  /**\n   * 小程序openId静默登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序openId静默登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序openId静默登录',\n      '  2 - 调用 auth().signInWithOpenId() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithOpenId({ useWxCloud = true } = {}): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: GrantProviderTokenResponse | undefined = undefined\n      let credentials: Credentials | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken(\n          {\n            provider_id: wxInfo?.appId,\n            provider_code: code,\n            provider_params: {\n              provider_code_type: 'open_id',\n              appid: wxInfo?.appId,\n            },\n          },\n          useWxCloud,\n        )\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        credentials = await this.oauthInstance.authApi.signInWithProvider(\n          { provider_token: result.provider_token },\n          useWxCloud,\n        )\n\n        if ((credentials as any)?.error_code) {\n          throw credentials\n        }\n      } catch (error) {\n        throw error\n      }\n      await this.oauthInstance.oauth2client.setCredentials(credentials as Credentials)\n    }\n\n    await new Promise((resolve, reject) => {\n      wx.login({\n        success: async (res: { code: string }) => {\n          try {\n            await mainFunc(res.code)\n            resolve(true)\n          } catch (error) {\n            reject(error)\n          }\n        },\n        fail: (res: any) => {\n          const error = new Error(res?.errMsg)\n          ;(error as any).code = res?.errno\n          reject(error)\n        },\n      })\n    })\n\n    return this.createLoginState()\n  }\n\n  /**\n   * 小程序unionId静默登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序unionId静默登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序unionId静默登录',\n      '  2 - 调用 auth().signInWithUnionId() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithUnionId(): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    try {\n      await new Promise((resolve, reject) => {\n        const wxInfo = wx.getAccountInfoSync().miniProgram\n        wx.login({\n          success: async (res: { code: string }) => {\n            const providerId = wxInfo?.appId\n            try {\n              const result = await this.oauthInstance.authApi.grantProviderToken({\n                provider_code: res.code,\n                provider_id: providerId,\n                provider_params: {\n                  provider_code_type: 'union_id',\n                  appid: wxInfo?.appId,\n                },\n              })\n\n              const { provider_token: providerToken } = result\n\n              if (!providerToken) {\n                reject(result)\n                return\n              }\n\n              const signInRes = await this.oauthInstance.authApi.signInWithProvider({\n                provider_id: providerId,\n                provider_token: providerToken,\n              })\n\n              if ((signInRes as any)?.error_code) {\n                reject(signInRes)\n                return\n              }\n              resolve(true)\n            } catch (error) {\n              reject(error)\n            }\n          },\n          fail: (res: any) => {\n            const error = new Error(res?.errMsg)\n            ;(error as any).code = res?.errno\n            reject(error)\n          },\n        })\n      })\n    } catch (error) {\n      throw error\n    }\n\n    return this.createLoginState()\n  }\n\n  /**\n   * 小程序手机号授权登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序手机号授权登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序手机号授权登录',\n      '  2 - 调用 auth().signInWithPhoneAuth() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithPhoneAuth({ phoneCode = '' }): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n    const providerInfo = {\n      provider_params: { provider_code_type: 'phone' },\n      provider_id: wxInfo.appId,\n    }\n\n    const { code } = await wx.login()\n    ;(providerInfo as any).provider_code = code\n\n    try {\n      let providerToken = await this.oauthInstance.authApi.grantProviderToken(providerInfo)\n      if (providerToken.error_code) {\n        throw providerToken\n      }\n\n      providerToken = await this.oauthInstance.authApi.patchProviderToken({\n        provider_token: providerToken.provider_token,\n        provider_id: wxInfo.appId,\n        provider_params: {\n          code: phoneCode,\n          provider_code_type: 'phone',\n        },\n      })\n      if (providerToken.error_code) {\n        throw providerToken\n      }\n\n      const signInRes = await this.oauthInstance.authApi.signInWithProvider({\n        provider_token: providerToken.provider_token,\n      })\n\n      if ((signInRes as any)?.error_code) {\n        throw signInRes\n      }\n    } catch (error) {\n      throw error\n    }\n\n    return this.createLoginState()\n  }\n\n  /**\n   * 小程序短信验证码登陆\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '短信验证码登陆',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序短信验证码登陆',\n      '  2 - 调用 auth().signInWithSms() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithSms({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    phoneNum = '',\n    bindInfo = undefined,\n  }): Promise<LoginState> {\n    try {\n      return this.signInWithUsername({\n        verificationInfo,\n        verificationCode,\n        bindInfo,\n        username: phoneNum,\n        loginType: 'sms',\n      })\n    } catch (error) {\n      throw error\n    }\n  }\n\n  /**\n   * 邮箱验证码登陆\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '邮箱验证码登陆',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了邮箱登陆',\n      '  2 - 调用 auth().signInWithEmail() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithEmail({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    bindInfo = undefined,\n    email = '',\n  }): Promise<LoginState> {\n    try {\n      return this.signInWithUsername({\n        verificationInfo,\n        verificationCode,\n        bindInfo,\n        username: email,\n        loginType: 'email',\n      })\n    } catch (error) {\n      throw error\n    }\n  }\n\n  /**\n   * 设置获取自定义登录 ticket 函数\n   * @param {authModels.GetCustomSignTicketFn} getTickFn\n   * @memberof Auth\n   */\n  public setCustomSignFunc(getTickFn: authModels.GetCustomSignTicketFn): void {\n    this.oauthInstance.authApi.setCustomSignFunc(getTickFn)\n  }\n\n  /**\n   *\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '自定义登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了自定义登录',\n      '  2 - 调用 auth().signInWithCustomTicket() 的语法或参数是否正确',\n      '  3 - ticket 是否归属于当前环境',\n      '  4 - 创建 ticket 的自定义登录私钥是否过期',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithCustomTicket(): Promise<LoginState> {\n    await this.oauthInstance.authApi.signInWithCustomTicket()\n    return this.createLoginState()\n  }\n\n  /**\n   *\n   * @param {authModels.SignInRequest} params\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  public async signIn(params: authModels.SignInRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.signIn(params)\n    return this.createLoginState(params)\n  }\n\n  /**\n   *\n   * @param {authModels.SignUpRequest} params\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '注册失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了指定登录方式',\n      '  2 - 调用 auth().signUp() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signUp(params: authModels.SignUpRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.signUp(params)\n    return this.createLoginState()\n  }\n\n  /**\n   * 设置密码\n   * @param {authModels.SetPasswordRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  public async setPassword(params: authModels.SetPasswordRequest): Promise<void> {\n    return this.oauthInstance.authApi.setPassword(params)\n  }\n\n  /**\n   * 检测用户名是否已经占用\n   * @param username\n   */\n  @catchErrorsDecorator({\n    title: '获取用户是否被占用失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().isUsernameRegistered() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async isUsernameRegistered(username: string): Promise<boolean> {\n    if (typeof username !== 'string') {\n      throwError(ERRORS.INVALID_PARAMS, 'username must be a string')\n    }\n\n    const { exist } = await this.oauthInstance.authApi.checkIfUserExist({ username })\n    return exist\n  }\n\n  /**\n   * 登出\n   */\n  @catchErrorsDecorator({\n    title: '用户登出失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().signOut() 的语法或参数是否正确',\n      '  2 - 当前用户是否为匿名登录（匿名登录不支持signOut）',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signOut(params?: authModels.SignoutRequest): Promise<void | authModels.SignoutReponse> {\n    const { userInfoKey } = this.cache.keys\n    const res = await this.oauthInstance.authApi.signOut(params)\n    await this.cache.removeStoreAsync(userInfoKey)\n    eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_OUT })\n    return res\n  }\n\n  /**\n   * 获取本地登录态-同步\n   */\n  public hasLoginState(): LoginState | null {\n    if (this.cache.mode === 'async') {\n      // async storage的平台调用此API提示\n      printWarn(\n        ERRORS.INVALID_OPERATION,\n        'current platform\\'s storage is asynchronous, please use getLoginState insteed',\n      )\n      return\n    }\n\n    const oauthLoginState = this.oauthInstance?.authApi.hasLoginStateSync()\n    if (oauthLoginState) {\n      const loginState = new LoginState({\n        envId: this.config.env,\n        cache: this.cache,\n        oauthInstance: this.oauthInstance,\n      })\n      return loginState\n    }\n    return null\n  }\n\n  /**\n   * 获取本地登录态-异步\n   * 此API为兼容异步storage的平台\n   */\n  @catchErrorsDecorator({\n    title: '获取本地登录态失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getLoginState() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getLoginState() {\n    let oauthLoginState = null\n\n    try {\n      oauthLoginState = await this.oauthInstance.authApi.getLoginState()\n    } catch (error) {\n      return null\n    }\n\n    if (oauthLoginState) {\n      const loginState = new LoginState({\n        envId: this.config.env,\n        cache: this.cache,\n        oauthInstance: this.oauthInstance,\n      })\n      return loginState\n    }\n\n    return null\n  }\n\n  @catchErrorsDecorator({\n    title: '获取用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 是否已登录',\n      '  2 - 调用 auth().getUserInfo() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getUserInfo(params?: { version?: string }): Promise<IUserInfo> {\n    return this.oauthInstance.authApi.getUserInfo(params)\n  }\n\n  @catchErrorsDecorator({\n    title: '获取微搭插件用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 是否已登录',\n      '  2 - 调用 auth().getWedaUserInfo() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getWedaUserInfo(): Promise<any> {\n    return this.oauthInstance.authApi.getWedaUserInfo()\n  }\n\n  public async updateUserBasicInfo(params: authModels.ModifyUserBasicInfoRequest) {\n    const loginState = await this.getLoginState()\n    if (loginState) {\n      await (loginState.user as User).updateUserBasicInfo(params)\n    }\n    return\n  }\n\n  /**\n   * getAuthHeader 兼容处理\n   * 返回空对象\n   */\n  public getAuthHeader(): {} {\n    console.error('Auth.getAuthHeader API 已废弃')\n    return {}\n  }\n\n  /**\n   * 为已有账户绑第三方账户\n   * @param {authModels.BindWithProviderRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '绑定第三方登录方式失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindWithProvider() 的语法或参数是否正确',\n      '  2 - 此账户是否已经绑定此第三方',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindWithProvider(params: authModels.BindWithProviderRequest): Promise<void> {\n    return this.oauthInstance.authApi.bindWithProvider(params)\n  }\n\n  /**\n   * 查询用户\n   * @param {authModels.QueryUserProfileRequest} appended_params\n   * @returns {Promise<authModels.UserProfile>}\n   * @memberof Auth\n   */\n  public async queryUser(queryObj: authModels.QueryUserProfileRequest): Promise<authModels.QueryUserProfileResponse> {\n    return this.oauthInstance.authApi.queryUserProfile(queryObj)\n  }\n\n  public async getAccessToken() {\n    const oauthAccessTokenRes = await this.oauthInstance.oauth2client.getAccessToken()\n    return {\n      accessToken: oauthAccessTokenRes,\n      env: this.config.env,\n    }\n  }\n\n  public async grantProviderToken(params: authModels.GrantProviderTokenRequest,): Promise<authModels.GrantProviderTokenResponse> {\n    return this.oauthInstance.authApi.grantProviderToken(params)\n  }\n\n  public async patchProviderToken(params: authModels.PatchProviderTokenRequest,): Promise<authModels.PatchProviderTokenResponse> {\n    return this.oauthInstance.authApi.patchProviderToken(params)\n  }\n\n  public async signInWithProvider(params: authModels.SignInWithProviderRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.signInWithProvider(params)\n    return this.createLoginState(params)\n  }\n\n  public async signInWithWechat(params: any = {}) {\n    await this.oauthInstance.authApi.signInWithWechat(params)\n    return this.createLoginState(params)\n  }\n\n  public async grantToken(params: authModels.GrantTokenRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.grantToken(params)\n    return this.createLoginState()\n  }\n\n  public async genProviderRedirectUri(params: authModels.GenProviderRedirectUriRequest,): Promise<authModels.GenProviderRedirectUriResponse> {\n    return this.oauthInstance.authApi.genProviderRedirectUri(params)\n  }\n\n  public async resetPassword(params: authModels.ResetPasswordRequest): Promise<void> {\n    return this.oauthInstance.authApi.resetPassword(params)\n  }\n\n  public async deviceAuthorize(params: authModels.DeviceAuthorizeRequest): Promise<authModels.DeviceAuthorizeResponse> {\n    return this.oauthInstance.authApi.deviceAuthorize(params)\n  }\n\n  public async sudo(params: authModels.SudoRequest): Promise<authModels.SudoResponse> {\n    return this.oauthInstance.authApi.sudo(params)\n  }\n\n  public async deleteMe(params: authModels.WithSudoRequest): Promise<authModels.UserProfile> {\n    return this.oauthInstance.authApi.deleteMe(params)\n  }\n\n  public async getProviders(): Promise<authModels.ProvidersResponse> {\n    return this.oauthInstance.authApi.getProviders()\n  }\n\n  public async loginScope(): Promise<string> {\n    return this.oauthInstance.authApi.loginScope()\n  }\n\n  public async loginGroups(): Promise<string[]> {\n    return this.oauthInstance.authApi.loginGroups()\n  }\n\n  public async onLoginStateChanged(callback: Function) {\n    eventBus.on(EVENTS.LOGIN_STATE_CHANGED, async (params) => {\n      // getLoginState会重复触发getCredentials，导致死循环，所以getCredentials出错不再出发getLoginState\n      const loginState = params?.data?.eventType !== LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR ? await this.getLoginState() : {}\n      callback.call(this, { ...params, ...loginState })\n    })\n    // 立刻执行一次回调\n    const loginState = await this.getLoginState()\n    callback.call(this, loginState)\n  }\n\n  /**\n   * 强制刷新token\n   * @param params\n   * @returns\n   */\n  public async refreshTokenForce(params: { version?: string }): Promise<Credentials> {\n    return this.oauthInstance.authApi.refreshTokenForce(params)\n  }\n\n  /**\n   * 获取身份信息\n   * @returns\n   */\n  public async getCredentials(): Promise<Credentials> {\n    return this.oauthInstance.authApi.getCredentials()\n  }\n  /**\n   * 写入身份信息\n   */\n  public async setCredentials(credentials: Credentials) {\n    await this.oauthInstance.oauth2client.setCredentials(credentials)\n  }\n\n  @catchErrorsDecorator({\n    title: '获取身份源类型',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getProviderSubType() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getProviderSubType(): Promise<ProviderSubType> {\n    return this.oauthInstance.authApi.getProviderSubType()\n  }\n\n  public async createCaptchaData(params: { state: string; redirect_uri?: string }) {\n    return this.oauthInstance.authApi.createCaptchaData(params)\n  }\n\n  public async verifyCaptchaData(params: { token: string; key: string }) {\n    return this.oauthInstance.authApi.verifyCaptchaData(params)\n  }\n\n  public async getMiniProgramQrCode(params: authModels.GetMiniProgramQrCodeRequest,): Promise<authModels.GetMiniProgramQrCodeResponse> {\n    return this.oauthInstance.authApi.getMiniProgramCode(params)\n  }\n\n  public async getMiniProgramQrCodeStatus(params: authModels.GetMiniProgramQrCodeStatusRequest,): Promise<authModels.GetMiniProgramQrCodeStatusResponse> {\n    return this.oauthInstance.authApi.getMiniProgramQrCodeStatus(params)\n  }\n\n  public async modifyPassword(params: authModels.ModifyUserBasicInfoRequest): Promise<void> {\n    return this.oauthInstance.authApi.modifyPassword(params)\n  }\n\n  public async modifyPasswordWithoutLogin(params: authModels.ModifyPasswordWithoutLoginRequest): Promise<void> {\n    return this.oauthInstance.authApi.modifyPasswordWithoutLogin(params)\n  }\n\n  public async getUserBehaviorLog(params: authModels.GetUserBehaviorLog): Promise<authModels.GetUserBehaviorLogRes> {\n    return this.oauthInstance.authApi.getUserBehaviorLog(params)\n  }\n\n  /**\n   * 跳转系统默认登录页\n   * @returns {Promise<authModels.ToDefaultLoginPage>}\n   * @memberof Auth\n   */\n  public async toDefaultLoginPage(params: authModels.ToDefaultLoginPage = {}): Promise<void> {\n    const configVersion = params.config_version || 'env'\n\n    if (adapterForWxMp.isMatch()) {\n      wx.navigateTo({ url: '/packages/$wd_system/pages/login/index' })\n    } else {\n      const redirectUri = params.redirect_uri || window.location.href\n      const urlObj = new URL(redirectUri)\n      const loginPage = `${urlObj.origin}/__auth/?app_id=${params.app_id || ''}&env_id=${this.config.env}&client_id=${\n        this.config.clientId\n      }&config_version=${configVersion}&redirect_uri=${encodeURIComponent(redirectUri)}`\n      window.location.href = loginPage\n    }\n  }\n\n  private async createLoginState(\n    params?: { version?: string; query?: any },\n    options?: { asyncRefreshUser?: boolean },\n  ): Promise<LoginState> {\n    const loginState = new LoginState({\n      envId: this.config.env,\n      cache: this.cache,\n      oauthInstance: this.oauthInstance,\n    })\n\n    await loginState.checkLocalStateAsync()\n    if (options?.asyncRefreshUser) {\n      loginState.user.refresh(params)\n    } else {\n      await loginState.user.refresh(params)\n    }\n    eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_IN })\n    return loginState\n  }\n\n  /**\n   * sms/email 验证码登录/注册，逻辑一致收敛\n   */\n  private async signInWithUsername({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    username: rawUsername = '',\n    bindInfo = undefined,\n    loginType = '',\n  }): Promise<LoginState> {\n    try {\n      // 1. 验证验证码\n      const verifyRes = await this.oauthInstance.authApi.verify({\n        verification_id: verificationInfo.verification_id,\n        verification_code: verificationCode,\n      })\n\n      if ((verifyRes as any)?.error_code) {\n        throw verifyRes\n      }\n\n      const { verification_token } = verifyRes\n\n      // 手机登录参数\n      let username = `+86 ${rawUsername}`\n      let signUpParam: any = { phone_number: username }\n\n      // 邮箱登录参数\n      if (loginType === 'email') {\n        username = rawUsername\n        signUpParam = { email: username }\n      }\n\n      // 2. 根据是否已经是用户，分别走登录或注册逻辑\n      if (verificationInfo.is_user) {\n        // 私有化环境或者自定义应用走v1版本的老逻辑\n        const signInRes = await this.oauthInstance.authApi.signIn({\n          username,\n          verification_token,\n        })\n\n        if ((signInRes as any)?.error_code) {\n          throw signInRes\n        }\n\n        if (bindInfo) {\n          const bindRes = await this.oauthInstance.authApi.bindWithProvider({\n            provider_token: (bindInfo as any)?.providerToken,\n          })\n\n          if ((bindRes as any)?.error_code) {\n            throw bindRes\n          }\n        }\n      } else {\n        // 自定义应用走signUp逻辑\n        const signUpRes = await this.oauthInstance.authApi.signUp({\n          ...signUpParam,\n          verification_token,\n          provider_token: (bindInfo as any)?.providerId,\n        })\n\n        if ((signUpRes as any)?.error_code) {\n          throw signUpRes\n        }\n      }\n\n      return this.createLoginState()\n    } catch (error) {\n      throw error\n    }\n  }\n}\n\ntype TInitAuthOptions = Pick<ICloudbaseAuthConfig, 'region' | 'persistence' | 'i18n' | 'publishable_key'> & Partial<AuthOptions>\n\nexport function generateAuthInstance(\n  config: TInitAuthOptions,\n  options?: {\n    clientId: ICloudbaseConfig['clientId']\n    env: ICloudbaseConfig['env']\n    apiOrigin: string\n    cache?: ICloudbaseCache\n    platform?: ICloudbase['platform']\n    app?: ICloudbase\n    debug?: ICloudbaseAuthConfig['debug']\n  },\n) {\n  const { region = 'ap-shanghai', i18n, publishable_key } = config\n  const platform = options?.platform || (useDefaultAdapter() as ICloudbasePlatformInfo)\n  const { runtime, adapter } = platform\n\n  const { env, clientId, debug, cache, app: cloudbase } = options || {}\n  let { apiOrigin } = options || {}\n  if (!apiOrigin) {\n    apiOrigin = `https://${env}.${region}.tcb-api.tencentcloudapi.com`\n  }\n\n  const commonOpts = {\n    env,\n    clientId,\n    i18n,\n    publishable_key,\n  }\n\n  const oauthInstance = new CloudbaseOAuth(useAuthAdapter({\n    ...commonOpts,\n    apiOrigin,\n    apiPath: config?.apiPath || AUTH_API_PREFIX,\n    // @todo 以下最好走adaptor处理，目前oauth模块没按adaptor接口设计\n    storage: config?.storage,\n    baseRequest: config?.baseRequest,\n    request: config?.request,\n    anonymousSignInFunc: config?.anonymousSignInFunc,\n    captchaOptions: config?.captchaOptions,\n    wxCloud: config?.wxCloud,\n    adapter,\n    onCredentialsError,\n    headers: config.headers || {},\n  }),)\n\n  const authInstance = new Auth({\n    ...commonOpts,\n    region,\n    persistence: config.persistence,\n    debug,\n    cache:\n      cache\n      || new CloudbaseCache({\n        persistence: config.persistence,\n        keys: { userInfoKey: `user_info_${env}` },\n        platformInfo: platform,\n      }),\n    runtime: runtime || 'web',\n    _fromApp: cloudbase,\n    oauthInstance,\n  })\n\n  return { authInstance, oauthInstance }\n}\n\nconst component: ICloudbaseComponent = {\n  name: COMPONENT_NAME,\n  namespace: 'auth',\n  entity(config: TInitAuthOptions = {\n    region: '',\n    persistence: 'local',\n    apiPath: AUTH_API_PREFIX,\n  },) {\n    if (this.authInstance) {\n      printWarn(ERRORS.INVALID_OPERATION, 'every cloudbase instance should has only one auth object')\n      return this.authInstance\n    }\n    const { adapter } = this.platform\n    // 如不明确指定persistence则优先取各平台adapter首选，其次localStorage\n    const newPersistence = config.persistence || adapter.primaryStorage\n    if (newPersistence && newPersistence !== this.config.persistence) {\n      this.updateConfig({ persistence: newPersistence })\n    }\n\n    const { authInstance, oauthInstance } = generateAuthInstance(\n      {\n        wxCloud: this.config.wxCloud,\n        storage: this.config.storage,\n        ...config,\n        persistence: this.config.persistence,\n        i18n: this.config.i18n,\n        publishable_key: this.config.publishable_key,\n      },\n      {\n        env: this.config.env,\n        clientId: this.config.clientId,\n        apiOrigin: this.request.getBaseEndPoint(),\n        platform: this.platform,\n        cache: this.cache,\n        app: this,\n        debug: this.config.debug,\n      },\n    )\n\n    this.oauthInstance = oauthInstance\n\n    this.authInstance = authInstance\n\n    return this.authInstance\n  },\n}\n\ntry {\n  // 尝试自动注册至全局变量cloudbase\n  // 此行为只在浏览器环境下有效\n  cloudbase.registerComponent(component)\n} catch (e) {}\n\nexport { UserInfo, Auth }\n/**\n * @api 手动注册至cloudbase app\n */\nexport function registerAuth(app: Pick<ICloudbase, 'registerComponent'>) {\n  try {\n    app.registerComponent(component)\n  } catch (e) {\n    console.warn(e)\n  }\n}\n"]}
|
|
2874
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":"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","sourcesContent":["import type { ICloudbase, ICloudbaseConfig, ICloudbasePlatformInfo } from '@cloudbase/types'\nimport type { ICloudbaseCache } from '@cloudbase/types/cache'\nimport type { ICloudbaseRequest } from '@cloudbase/types/request'\nimport type { ICloudbaseAuthConfig, IUser, ILoginState } from '@cloudbase/types/auth'\nimport type { ICloudbaseComponent } from '@cloudbase/types/component'\nimport type { AuthOptions, Credentials } from '@cloudbase/oauth'\nimport {\n  CloudbaseOAuth,\n  AUTH_API_PREFIX,\n  LOGIN_STATE_CHANGED_TYPE,\n  EVENTS,\n  AUTH_STATE_CHANGED_TYPE,\n  OAUTH_TYPE,\n  weAppJwtDecodeAll,\n  AuthError,\n  authModels,\n} from '@cloudbase/oauth'\nimport { useAuthAdapter } from './adapter'\nimport {\n  printWarn,\n  throwError,\n  ERRORS,\n  COMMUNITY_SITE_URL,\n  catchErrorsDecorator,\n  CloudbaseEventEmitter,\n  CloudbaseCache,\n  adapterForWxMp,\n  useDefaultAdapter,\n} from './utilities'\nimport { saveToBrowserSession, getBrowserSession, removeBrowserSession, addUrlSearch } from './utils'\nimport { utils } from '@cloudbase/utilities'\nimport {\n  CommonRes,\n  DeleteMeReq,\n  GetClaimsRes,\n  GetUserIdentitiesRes,\n  GetUserRes,\n  LinkIdentityReq,\n  LinkIdentityRes,\n  OnAuthStateChangeCallback,\n  ReauthenticateRes,\n  ResendReq,\n  ResendRes,\n  ResetPasswordForEmailRes,\n  ResetPasswordForOldReq,\n  SetSessionReq,\n  SignInAnonymouslyReq,\n  SignInOAuthRes,\n  SignInRes,\n  SignInWithIdTokenReq,\n  SignInWithOAuthReq,\n  SignInWithOtpReq,\n  SignInWithOtpRes,\n  SignInWithPasswordReq,\n  SignUpRes,\n  UnlinkIdentityReq,\n  UpdateUserAttributes,\n  UpdateUserReq,\n  UpdateUserWithVerificationRes,\n  VerifyOAuthReq,\n  VerifyOtpReq,\n} from './type'\n\nconst isBrowser = () => typeof window !== 'undefined' && typeof document !== 'undefined'\n\nexport type {\n  SignInRes,\n  GetUserRes,\n  CommonRes,\n  SignInWithOtpRes,\n  SignInOAuthRes,\n  GetClaimsRes,\n  ResetPasswordForEmailRes,\n  GetUserIdentitiesRes,\n  LinkIdentityRes,\n  ReauthenticateRes,\n  ResendRes,\n  UpdateUserWithVerificationRes,\n  OnAuthStateChangeCallback,\n  SignInWithPasswordReq,\n  SignInWithIdTokenReq,\n  SignInWithOAuthReq,\n  VerifyOAuthReq,\n  VerifyOtpReq,\n  LinkIdentityReq,\n  UnlinkIdentityReq,\n  UpdateUserReq,\n  SignInWithOtpReq,\n  ResetPasswordForOldReq,\n  ResendReq,\n  SetSessionReq,\n  DeleteMeReq,\n  SignUpRes,\n} from './type'\n\ndeclare const cloudbase: ICloudbase\ndeclare const wx: any\n\nconst COMPONENT_NAME = 'auth'\n\ninterface UserInfo {\n  uid?: string\n  gender?: string\n  picture?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  username?: string\n  name?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  sub?: string\n  created_from?: string\n}\n\nconst onCredentialsError = eventBus => (params) => {\n  eventBus.fire(EVENTS.LOGIN_STATE_CHANGED, { ...params, eventType: LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR })\n}\n\ninterface IUserOptions {\n  cache: ICloudbaseCache\n  oauthInstance: CloudbaseOAuth\n}\n\nexport class User implements IUser {\n  public uid?: string\n  public gender?: string\n  public picture?: string\n  public email?: string\n  public emailVerified?: boolean\n  public phoneNumber?: string\n  public username?: string // 用户名称，长度 5-24 位，支持字符中英文、数字、特殊字符（仅支持_-），不支持中文\n  public name?: string\n  public providers?: {\n    id?: string\n    providerUserId?: string\n    name?: string\n  }[]\n  public birthdate?: string\n  public zoneinfo?: string\n  public locale?: string\n  public sub?: string\n  public createdFrom?: string\n\n  private cache: ICloudbaseCache\n  private oauthInstance: CloudbaseOAuth // CloudbaseOAuth 类型\n\n  constructor(options: IUserOptions) {\n    const { cache, oauthInstance } = options\n    this.cache = cache\n    this.oauthInstance = oauthInstance\n\n    this.setUserInfo()\n  }\n  /**\n   * 获取本地用户信息-同步\n   */\n  public async checkLocalInfo() {\n    this.uid = this.getLocalUserInfo('uid') as string\n    this.gender = this.getLocalUserInfo('gender') as string\n    this.picture = this.getLocalUserInfo('picture') as string\n    this.email = this.getLocalUserInfo('email') as string\n    this.emailVerified = this.getLocalUserInfo('email_verified') as boolean\n    this.phoneNumber = this.getLocalUserInfo('phone_number') as string\n    this.username = this.getLocalUserInfo('username') as string\n    this.name = this.getLocalUserInfo('name') as string\n    this.birthdate = this.getLocalUserInfo('birthdate') as string\n    this.zoneinfo = this.getLocalUserInfo('zoneinfo') as string\n    this.locale = this.getLocalUserInfo('locale') as string\n    this.sub = this.getLocalUserInfo('sub') as string\n    this.createdFrom = this.getLocalUserInfo('created_from') as string\n    this.providers = this.getLocalUserInfo('providers') as any\n  }\n  /**\n   * 获取本地用户信息-异步\n   */\n  public async checkLocalInfoAsync() {\n    this.uid = await this.getLocalUserInfoAsync('uid')\n    this.gender = await this.getLocalUserInfoAsync('gender')\n    this.picture = this.getLocalUserInfo('picture') as string\n    this.email = await this.getLocalUserInfoAsync('email')\n    this.emailVerified = this.getLocalUserInfo('email_verified') as boolean\n    this.phoneNumber = this.getLocalUserInfo('phone_number') as string\n    this.username = await this.getLocalUserInfoAsync('username')\n    this.name = this.getLocalUserInfo('name') as string\n    this.birthdate = this.getLocalUserInfo('birthdate') as string\n    this.zoneinfo = this.getLocalUserInfo('zoneinfo') as string\n    this.locale = this.getLocalUserInfo('locale') as string\n    this.sub = this.getLocalUserInfo('sub') as string\n    this.createdFrom = this.getLocalUserInfo('created_from') as string\n    this.providers = this.getLocalUserInfo('providers') as any\n  }\n\n  /**\n   * 更新用户信息\n   * @param userInfo\n   */\n  @catchErrorsDecorator({\n    title: '更新用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.update() 的语法或参数是否正确',\n      '  2 - 用户信息中是否包含非法值',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async update(userInfo: authModels.UserProfile): Promise<void> {\n    // const { name, gender, avatarUrl, province, country, city } = userInfo\n    const newUserInfo = await this.oauthInstance.authApi.setUserProfile({ ...userInfo })\n\n    this.setLocalUserInfo(newUserInfo)\n  }\n\n  public async updateUserBasicInfo(params: authModels.ModifyUserBasicInfoRequest): Promise<void> {\n    await this.oauthInstance.authApi.updateUserBasicInfo({ ...params })\n    await this.refresh()\n  }\n\n  /**\n   * 更新密码\n   * @param newPassword\n   * @param oldPassword\n   */\n  @catchErrorsDecorator({\n    title: '更新密码失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.updatePassword() 的语法或参数是否正确',\n      '  3 - 新密码中是否包含非法字符',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public updatePassword(newPassword: string, oldPassword: string) {\n    return this.oauthInstance.authApi.updatePasswordByOld({\n      old_password: oldPassword,\n      new_password: newPassword,\n    })\n  }\n\n  /**\n   * 更新用户名\n   * @param username\n   */\n  @catchErrorsDecorator({\n    title: '更新用户名失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.updateUsername() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了用户名密码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public updateUsername(username: string) {\n    if (typeof username !== 'string') {\n      throwError(ERRORS.INVALID_PARAMS, 'username must be a string')\n    }\n\n    return this.update({\n      username,\n    })\n  }\n\n  /**\n   * 刷新本地用户信息。当用户在其他客户端更新用户信息之后，可以调用此接口同步更新之后的信息。\n   */\n  @catchErrorsDecorator({\n    title: '刷新本地用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 User.refresh() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async refresh(params?: { version?: string; query?: any }): Promise<authModels.UserInfo> {\n    const newUserInfo = await this.oauthInstance.authApi.getUserInfo(params)\n    if ((newUserInfo as any).code === 'INVALID_ACCESS_TOKEN') {\n      this.setLocalUserInfo({})\n      throw newUserInfo\n    }\n    this.setLocalUserInfo(newUserInfo)\n    return newUserInfo\n  }\n\n  public getLocalUserInfo(key?: string): string | boolean | Record<string, any> {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = this.cache.getStore(userInfoKey)\n\n    if (!key) return userInfo || {}\n\n    return userInfo[key]\n  }\n\n  public setLocalUserInfo(userInfo: any) {\n    const { userInfoKey } = this.cache.keys\n    this.cache.setStore(userInfoKey, userInfo)\n    this.setUserInfo()\n  }\n\n  private async getLocalUserInfoAsync(key: string): Promise<string> {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = await this.cache.getStoreAsync(userInfoKey)\n    return userInfo[key]\n  }\n\n  private setUserInfo() {\n    const { userInfoKey } = this.cache.keys\n    const userInfo = this.cache.getStore(userInfoKey)\n    ;[\n      'uid',\n      'email',\n      'name',\n      'gender',\n      'picture',\n      'email_verified',\n      'phone_number',\n      'birthdate',\n      'zoneinfo',\n      'locale',\n      'sub',\n      'created_from',\n      'providers',\n      'username',\n      'created_at',\n    ].forEach((infoKey) => {\n      this[infoKey] = userInfo[infoKey]\n    })\n  }\n}\ninterface ILoginStateOptions extends IUserOptions {\n  envId: string\n}\nexport class LoginState implements ILoginState {\n  public user: User\n  public oauthLoginState: any\n\n  private oauthInstance: CloudbaseOAuth\n  private cache: ICloudbaseCache\n\n  constructor(options: ILoginStateOptions) {\n    const { envId, cache, oauthInstance } = options\n    if (!envId) {\n      throwError(ERRORS.INVALID_PARAMS, 'envId is not defined')\n    }\n    this.cache = cache\n    this.oauthInstance = oauthInstance\n\n    this.user = new User({\n      cache: this.cache,\n      oauthInstance,\n    })\n  }\n\n  public checkLocalState() {\n    this.oauthLoginState = this.oauthInstance?.authApi.hasLoginStateSync()\n    this.user.checkLocalInfo()\n  }\n\n  public async checkLocalStateAsync() {\n    await this.oauthInstance?.authApi.getLoginState()\n    await this.user.checkLocalInfoAsync()\n  }\n}\n\nclass Auth {\n  readonly config: ICloudbaseAuthConfig\n  oauthInstance: CloudbaseOAuth\n  readonly cache: ICloudbaseCache\n  private listeners: Map<string, Set<OnAuthStateChangeCallback>> = new Map()\n  private hasListenerSetUp = false\n\n  constructor(config: ICloudbaseAuthConfig & {\n    cache: ICloudbaseCache\n    request?: ICloudbaseRequest\n    runtime?: string\n  },) {\n    this.config = config\n    this.oauthInstance = config.oauthInstance\n    this.cache = config.cache\n    this.init()\n    this.setAccessKey()\n  }\n\n  /**\n   * 绑定手机号\n   * @param phoneNumber\n   * @param phoneCode\n   */\n  @catchErrorsDecorator({\n    title: '绑定手机号失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindPhoneNumber() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了短信验证码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindPhoneNumber(params: authModels.BindPhoneRequest) {\n    return this.oauthInstance.authApi.editContact(params)\n  }\n\n  /**\n   * 解绑三方绑定\n   * @param loginType\n   */\n  @catchErrorsDecorator({\n    title: '解除三方绑定失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().unbindProvider() 的语法或参数是否正确',\n      '  2 - 当前账户是否已经与此登录方式解绑',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async unbindProvider(params: authModels.UnbindProviderRequest): Promise<void> {\n    return this.oauthInstance.authApi.unbindProvider(params)\n  }\n\n  /**\n   * 更新邮箱地址\n   * @param email\n   * @param sudo_token\n   * @param verification_token\n   */\n  @catchErrorsDecorator({\n    title: '绑定邮箱地址失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindEmail() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了邮箱密码登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public bindEmail(params: authModels.BindEmailRequest) {\n    return this.oauthInstance.authApi.editContact(params)\n  }\n\n  /**\n   * verify\n   * @param {authModels.VerifyRequest} params\n   * @returns {Promise<authModels.VerifyResponse>}\n   * @memberof User\n   */\n  @catchErrorsDecorator({\n    title: '验证码验证失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().verify() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了手机验证码/邮箱登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async verify(params: authModels.VerifyRequest): Promise<authModels.VerifyResponse> {\n    return this.oauthInstance.authApi.verify(params)\n  }\n\n  /**\n   * 获取验证码\n   * @param {authModels.GetVerificationRequest} params\n   * @returns {Promise<authModels.GetVerificationResponse>}\n   * @memberof User\n   */\n  @catchErrorsDecorator({\n    title: '获取验证码失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getVerification() 的语法或参数是否正确',\n      '  2 - 当前环境是否开通了手机验证码/邮箱登录',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getVerification(\n    params: authModels.GetVerificationRequest,\n    options?: { withCaptcha: boolean },\n  ): Promise<authModels.GetVerificationResponse> {\n    return this.oauthInstance.authApi.getVerification(params, options)\n  }\n\n  /**\n   * 获取当前登录的用户信息-同步\n   */\n  get currentUser() {\n    if (this.cache.mode === 'async') {\n      // async storage的平台调用此API提示\n      printWarn(\n        ERRORS.INVALID_OPERATION,\n        'current platform\\'s storage is asynchronous, please use getCurrentUser instead',\n      )\n      return\n    }\n\n    const loginState = this.hasLoginState()\n\n    if (loginState) {\n      return loginState.user || null\n    }\n    return null\n  }\n\n  /**\n   * 获取当前登录的用户信息-异步\n   */\n  @catchErrorsDecorator({\n    title: '获取用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getCurrentUser() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getCurrentUser(): Promise<(authModels.UserInfo & Partial<User>) | null> {\n    const loginState = await this.getLoginState()\n    if (loginState) {\n      const userInfo = loginState.user.getLocalUserInfo() as authModels.UserInfo\n      await loginState.user.checkLocalInfoAsync()\n      return { ...loginState.user, ...userInfo } as unknown as authModels.UserInfo & Partial<User>\n    }\n    return null\n  }\n\n  // /**\n  //  * 匿名登录\n  //  * @returns {Promise<LoginState>}\n  //  * @memberof Auth\n  //  */\n  // @catchErrorsDecorator({\n  //   title: '匿名登录失败',\n  //   messages: [\n  //     '请确认以下各项：',\n  //     '  1 - 当前环境是否开启了匿名登录',\n  //     '  2 - 调用 auth().signInAnonymously() 的语法或参数是否正确',\n  //     `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n  //   ],\n  // })\n  // public async signInAnonymously(data: {\n  //   provider_token?: string\n  // } = {},): Promise<LoginState> {\n  // await this.oauthInstance.authApi.signInAnonymously(data)\n  // return this.createLoginState()\n  // }\n\n  /**\n   * 匿名登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序匿名登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了匿名登录',\n      '  2 - 调用 auth().signInAnonymouslyInWx() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInAnonymouslyInWx({\n    useWxCloud,\n  }: {\n    useWxCloud?: boolean\n  } = {}): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: authModels.GrantProviderTokenResponse | undefined = undefined\n      let credentials: Credentials | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken(\n          {\n            provider_id: wxInfo?.appId,\n            provider_code: code,\n            provider_params: {\n              provider_code_type: 'open_id',\n              appid: wxInfo?.appId,\n            },\n          },\n          useWxCloud,\n        )\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        credentials = await this.oauthInstance.authApi.signInAnonymously(\n          { provider_token: result.provider_token },\n          useWxCloud,\n        )\n\n        if ((credentials as any)?.error_code) {\n          throw credentials\n        }\n      } catch (error) {\n        throw error\n      }\n    }\n\n    await new Promise((resolve, reject) => {\n      wx.login({\n        success: async (res: { code: string }) => {\n          try {\n            await mainFunc(res.code)\n            resolve(true)\n          } catch (error) {\n            reject(error)\n          }\n        },\n        fail: (res: any) => {\n          const error = new Error(res?.errMsg)\n          ;(error as any).code = res?.errno\n          reject(error)\n        },\n      })\n    })\n\n    return this.createLoginState(undefined, { asyncRefreshUser: true })\n  }\n\n  /**\n   * 小程序绑定OpenID\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序绑定OpenID失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序openId静默登录',\n      '  2 - 调用 auth().bindOpenId() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindOpenId(): Promise<void> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: authModels.GrantProviderTokenResponse | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken({\n          provider_id: wxInfo?.appId,\n          provider_code: code,\n          provider_params: {\n            provider_code_type: 'open_id',\n            appid: wxInfo?.appId,\n          },\n        })\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        await this.oauthInstance.authApi.bindWithProvider({ provider_token: result.provider_token })\n      } catch (error) {\n        throw error\n      }\n    }\n\n    await new Promise((resolve, reject) => {\n      wx.login({\n        success: async (res: { code: string }) => {\n          try {\n            await mainFunc(res.code)\n            resolve(true)\n          } catch (error) {\n            reject(error)\n          }\n        },\n        fail: (res: any) => {\n          const error = new Error(res?.errMsg)\n          ;(error as any).code = res?.errno\n          reject(error)\n        },\n      })\n    })\n\n    return\n  }\n\n  /**\n   * 小程序unionId静默登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '小程序unionId静默登录失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序unionId静默登录',\n      '  2 - 调用 auth().signInWithUnionId() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithUnionId(): Promise<LoginState> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    try {\n      await new Promise((resolve, reject) => {\n        const wxInfo = wx.getAccountInfoSync().miniProgram\n        wx.login({\n          success: async (res: { code: string }) => {\n            const providerId = wxInfo?.appId\n            try {\n              const result = await this.oauthInstance.authApi.grantProviderToken({\n                provider_code: res.code,\n                provider_id: providerId,\n                provider_params: {\n                  provider_code_type: 'union_id',\n                  appid: wxInfo?.appId,\n                },\n              })\n\n              const { provider_token: providerToken } = result\n\n              if (!providerToken) {\n                reject(result)\n                return\n              }\n\n              const signInRes = await this.oauthInstance.authApi.signInWithProvider({\n                provider_id: providerId,\n                provider_token: providerToken,\n              })\n\n              if ((signInRes as any)?.error_code) {\n                reject(signInRes)\n                return\n              }\n              resolve(true)\n            } catch (error) {\n              reject(error)\n            }\n          },\n          fail: (res: any) => {\n            const error = new Error(res?.errMsg)\n            ;(error as any).code = res?.errno\n            reject(error)\n          },\n        })\n      })\n    } catch (error) {\n      throw error\n    }\n\n    return this.createLoginState()\n  }\n\n  /**\n   * 小程序手机号授权登录，目前只支持全托管手机号授权登录\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  // @catchErrorsDecorator({\n  //   title: '小程序手机号授权登录失败',\n  //   messages: [\n  //     '请确认以下各项：',\n  //     '  1 - 当前环境是否开启了小程序手机号授权登录',\n  //     '  2 - 调用 auth().signInWithPhoneAuth() 的语法或参数是否正确',\n  //     `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n  //   ],\n  // })\n  // public async signInWithPhoneAuth({ phoneCode = '' }): Promise<LoginState> {\n  //   if (!adapterForWxMp.isMatch()) {\n  //     throw Error('wx api undefined')\n  //   }\n  //   const wxInfo = wx.getAccountInfoSync().miniProgram\n  //   const providerInfo = {\n  //     provider_params: { provider_code_type: 'phone' },\n  //     provider_id: wxInfo.appId,\n  //   }\n\n  //   const { code } = await wx.login()\n  //   ;(providerInfo as any).provider_code = code\n\n  //   try {\n  //     let providerToken = await this.oauthInstance.authApi.grantProviderToken(providerInfo)\n  //     if (providerToken.error_code) {\n  //       throw providerToken\n  //     }\n\n  //     providerToken = await this.oauthInstance.authApi.patchProviderToken({\n  //       provider_token: providerToken.provider_token,\n  //       provider_id: wxInfo.appId,\n  //       provider_params: {\n  //         code: phoneCode,\n  //         provider_code_type: 'phone',\n  //       },\n  //     })\n  //     if (providerToken.error_code) {\n  //       throw providerToken\n  //     }\n\n  //     const signInRes = await this.oauthInstance.authApi.signInWithProvider({\n  //       provider_token: providerToken.provider_token,\n  //     })\n\n  //     if ((signInRes as any)?.error_code) {\n  //       throw signInRes\n  //     }\n  //   } catch (error) {\n  //     throw error\n  //   }\n\n  //   return this.createLoginState()\n  // }\n\n  /**\n   * 小程序短信验证码登陆\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '短信验证码登陆',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了小程序短信验证码登陆',\n      '  2 - 调用 auth().signInWithSms() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithSms({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    phoneNum = '',\n    bindInfo = undefined,\n  }): Promise<LoginState> {\n    try {\n      return this.signInWithUsername({\n        verificationInfo,\n        verificationCode,\n        bindInfo,\n        username: phoneNum,\n        loginType: 'sms',\n      })\n    } catch (error) {\n      throw error\n    }\n  }\n\n  /**\n   * 邮箱验证码登陆\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '邮箱验证码登陆',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 当前环境是否开启了邮箱登陆',\n      '  2 - 调用 auth().signInWithEmail() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async signInWithEmail({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    bindInfo = undefined,\n    email = '',\n  }): Promise<LoginState> {\n    try {\n      return this.signInWithUsername({\n        verificationInfo,\n        verificationCode,\n        bindInfo,\n        username: email,\n        loginType: 'email',\n      })\n    } catch (error) {\n      throw error\n    }\n  }\n\n  /**\n   * 设置获取自定义登录 ticket 函数\n   * @param {authModels.GetCustomSignTicketFn} getTickFn\n   * @memberof Auth\n   */\n  public setCustomSignFunc(getTickFn: authModels.GetCustomSignTicketFn): void {\n    this.oauthInstance.authApi.setCustomSignFunc(getTickFn)\n  }\n\n  /**\n   *\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  // @catchErrorsDecorator({\n  //   title: '自定义登录失败',\n  //   messages: [\n  //     '请确认以下各项：',\n  //     '  1 - 当前环境是否开启了自定义登录',\n  //     '  2 - 调用 auth().signInWithCustomTicket() 的语法或参数是否正确',\n  //     '  3 - ticket 是否归属于当前环境',\n  //     '  4 - 创建 ticket 的自定义登录私钥是否过期',\n  //     `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n  //   ],\n  // })\n  // public async signInWithCustomTicket(): Promise<LoginState> {\n  //   await this.oauthInstance.authApi.signInWithCustomTicket()\n  //   return this.createLoginState()\n  // }\n\n  /**\n   *\n   * @param {authModels.SignInRequest} params\n   * @returns {Promise<LoginState>}\n   * @memberof Auth\n   */\n  public async signIn(params: authModels.SignInRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.signIn(params)\n    return this.createLoginState(params)\n  }\n\n  // /**\n  //  *\n  //  * @param {authModels.SignUpRequest} params\n  //  * @returns {Promise<LoginState>}\n  //  * @memberof Auth\n  //  */\n  // @catchErrorsDecorator({\n  //   title: '注册失败',\n  //   messages: [\n  //     '请确认以下各项：',\n  //     '  1 - 当前环境是否开启了指定登录方式',\n  //     '  2 - 调用 auth().signUp() 的语法或参数是否正确',\n  //     `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n  //   ],\n  // })\n  // public async signUp(params: authModels.SignUpRequest): Promise<any> {\n  //   await this.oauthInstance.authApi.signUp(params)\n  //   return this.createLoginState()\n  // }\n\n  /**\n   * 设置密码\n   * @param {authModels.SetPasswordRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  public async setPassword(params: authModels.SetPasswordRequest): Promise<void> {\n    return this.oauthInstance.authApi.setPassword(params)\n  }\n\n  /**\n   * 检测用户名是否已经占用\n   * @param username\n   */\n  @catchErrorsDecorator({\n    title: '获取用户是否被占用失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().isUsernameRegistered() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async isUsernameRegistered(username: string): Promise<boolean> {\n    if (typeof username !== 'string') {\n      throwError(ERRORS.INVALID_PARAMS, 'username must be a string')\n    }\n\n    const { exist } = await this.oauthInstance.authApi.checkIfUserExist({ username })\n    return exist\n  }\n\n  /**\n   * 获取本地登录态-同步\n   */\n  public hasLoginState(): LoginState | null {\n    if (this.cache.mode === 'async') {\n      // async storage的平台调用此API提示\n      printWarn(\n        ERRORS.INVALID_OPERATION,\n        'current platform\\'s storage is asynchronous, please use getLoginState instead',\n      )\n      return\n    }\n\n    const oauthLoginState = this.oauthInstance?.authApi.hasLoginStateSync()\n    if (oauthLoginState) {\n      const loginState = new LoginState({\n        envId: this.config.env,\n        cache: this.cache,\n        oauthInstance: this.oauthInstance,\n      })\n      return loginState\n    }\n    return null\n  }\n\n  /**\n   * 获取本地登录态-异步\n   * 此API为兼容异步storage的平台\n   */\n  @catchErrorsDecorator({\n    title: '获取本地登录态失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getLoginState() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getLoginState() {\n    let oauthLoginState = null\n\n    try {\n      oauthLoginState = await this.oauthInstance.authApi.getLoginState()\n    } catch (error) {\n      return null\n    }\n\n    if (oauthLoginState) {\n      const loginState = new LoginState({\n        envId: this.config.env,\n        cache: this.cache,\n        oauthInstance: this.oauthInstance,\n      })\n      return loginState\n    }\n\n    return null\n  }\n\n  @catchErrorsDecorator({\n    title: '获取用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 是否已登录',\n      '  2 - 调用 auth().getUserInfo() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getUserInfo(): Promise<(authModels.UserInfo & Partial<User>) | null> {\n    return this.getCurrentUser()\n  }\n\n  @catchErrorsDecorator({\n    title: '获取微搭插件用户信息失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 是否已登录',\n      '  2 - 调用 auth().getWedaUserInfo() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getWedaUserInfo(): Promise<any> {\n    return this.oauthInstance.authApi.getWedaUserInfo()\n  }\n\n  public async updateUserBasicInfo(params: authModels.ModifyUserBasicInfoRequest) {\n    const loginState = await this.getLoginState()\n    if (loginState) {\n      await (loginState.user as User).updateUserBasicInfo(params)\n    }\n    return\n  }\n\n  /**\n   * getAuthHeader 兼容处理\n   * 返回空对象\n   */\n  public getAuthHeader(): {} {\n    console.error('Auth.getAuthHeader API 已废弃')\n    return {}\n  }\n\n  /**\n   * 为已有账户绑第三方账户\n   * @param {authModels.BindWithProviderRequest} params\n   * @returns {Promise<void>}\n   * @memberof Auth\n   */\n  @catchErrorsDecorator({\n    title: '绑定第三方登录方式失败',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().bindWithProvider() 的语法或参数是否正确',\n      '  2 - 此账户是否已经绑定此第三方',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async bindWithProvider(params: authModels.BindWithProviderRequest): Promise<void> {\n    return this.oauthInstance.authApi.bindWithProvider(params)\n  }\n\n  /**\n   * 查询用户\n   * @param {authModels.QueryUserProfileRequest} appended_params\n   * @returns {Promise<authModels.UserProfile>}\n   * @memberof Auth\n   */\n  public async queryUser(queryObj: authModels.QueryUserProfileRequest): Promise<authModels.QueryUserProfileResponse> {\n    return this.oauthInstance.authApi.queryUserProfile(queryObj)\n  }\n\n  public async getAccessToken() {\n    const oauthAccessTokenRes = await this.oauthInstance.oauth2client.getAccessToken()\n    return {\n      accessToken: oauthAccessTokenRes,\n      env: this.config.env,\n    }\n  }\n\n  public async grantProviderToken(params: authModels.GrantProviderTokenRequest,): Promise<authModels.GrantProviderTokenResponse> {\n    return this.oauthInstance.authApi.grantProviderToken(params)\n  }\n\n  public async patchProviderToken(params: authModels.PatchProviderTokenRequest,): Promise<authModels.PatchProviderTokenResponse> {\n    return this.oauthInstance.authApi.patchProviderToken(params)\n  }\n\n  public async signInWithProvider(params: authModels.SignInWithProviderRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.signInWithProvider(params)\n    return this.createLoginState(params)\n  }\n\n  public async signInWithWechat(params: any = {}) {\n    await this.oauthInstance.authApi.signInWithWechat(params)\n    return this.createLoginState(params)\n  }\n\n  public async grantToken(params: authModels.GrantTokenRequest): Promise<LoginState> {\n    await this.oauthInstance.authApi.grantToken(params)\n    return this.createLoginState()\n  }\n\n  public async genProviderRedirectUri(params: authModels.GenProviderRedirectUriRequest,): Promise<authModels.GenProviderRedirectUriResponse> {\n    return this.oauthInstance.authApi.genProviderRedirectUri(params)\n  }\n\n  public async resetPassword(params: authModels.ResetPasswordRequest): Promise<void> {\n    return this.oauthInstance.authApi.resetPassword(params)\n  }\n\n  public async deviceAuthorize(params: authModels.DeviceAuthorizeRequest): Promise<authModels.DeviceAuthorizeResponse> {\n    return this.oauthInstance.authApi.deviceAuthorize(params)\n  }\n\n  public async sudo(params: authModels.SudoRequest): Promise<authModels.SudoResponse> {\n    return this.oauthInstance.authApi.sudo(params)\n  }\n\n  public async deleteMe(params: authModels.WithSudoRequest): Promise<authModels.UserProfile> {\n    return this.oauthInstance.authApi.deleteMe(params)\n  }\n\n  public async getProviders(): Promise<authModels.ProvidersResponse> {\n    return this.oauthInstance.authApi.getProviders()\n  }\n\n  public async loginScope(): Promise<string> {\n    return this.oauthInstance.authApi.loginScope()\n  }\n\n  public async loginGroups(): Promise<string[]> {\n    return this.oauthInstance.authApi.loginGroups()\n  }\n\n  public async onLoginStateChanged(callback: Function) {\n    this.config.eventBus?.on(EVENTS.LOGIN_STATE_CHANGED, async (params) => {\n      // getLoginState会重复触发getCredentials，导致死循环，所以getCredentials出错不再出发getLoginState\n      const loginState = params?.data?.eventType !== LOGIN_STATE_CHANGED_TYPE.CREDENTIALS_ERROR ? await this.getLoginState() : {}\n      callback.call(this, { ...params, ...loginState })\n    })\n    // 立刻执行一次回调\n    const loginState = await this.getLoginState()\n    callback.call(this, loginState)\n  }\n\n  /**\n   * 强制刷新token\n   * @param params\n   * @returns\n   */\n  public async refreshTokenForce(params: { version?: string }): Promise<Credentials> {\n    return this.oauthInstance.authApi.refreshTokenForce(params)\n  }\n\n  /**\n   * 获取身份信息\n   * @returns\n   */\n  public async getCredentials(): Promise<Credentials> {\n    return this.oauthInstance.authApi.getCredentials()\n  }\n  /**\n   * 写入身份信息\n   */\n  public async setCredentials(credentials: Credentials) {\n    await this.oauthInstance.oauth2client.setCredentials(credentials)\n  }\n\n  @catchErrorsDecorator({\n    title: '获取身份源类型',\n    messages: [\n      '请确认以下各项：',\n      '  1 - 调用 auth().getProviderSubType() 的语法或参数是否正确',\n      `如果问题依然存在，建议到官方问答社区提问或寻找帮助：${COMMUNITY_SITE_URL}`,\n    ],\n  })\n  public async getProviderSubType(): Promise<authModels.ProviderSubType> {\n    return this.oauthInstance.authApi.getProviderSubType()\n  }\n\n  public async createCaptchaData(params: { state: string; redirect_uri?: string }) {\n    return this.oauthInstance.authApi.createCaptchaData(params)\n  }\n\n  public async verifyCaptchaData(params: { token: string; key: string }) {\n    return this.oauthInstance.authApi.verifyCaptchaData(params)\n  }\n\n  public async getMiniProgramQrCode(params: authModels.GetMiniProgramQrCodeRequest,): Promise<authModels.GetMiniProgramQrCodeResponse> {\n    return this.oauthInstance.authApi.getMiniProgramCode(params)\n  }\n\n  public async getMiniProgramQrCodeStatus(params: authModels.GetMiniProgramQrCodeStatusRequest,): Promise<authModels.GetMiniProgramQrCodeStatusResponse> {\n    return this.oauthInstance.authApi.getMiniProgramQrCodeStatus(params)\n  }\n\n  public async modifyPassword(params: authModels.ModifyUserBasicInfoRequest): Promise<void> {\n    return this.oauthInstance.authApi.modifyPassword(params)\n  }\n\n  public async modifyPasswordWithoutLogin(params: authModels.ModifyPasswordWithoutLoginRequest): Promise<void> {\n    return this.oauthInstance.authApi.modifyPasswordWithoutLogin(params)\n  }\n\n  public async getUserBehaviorLog(params: authModels.GetUserBehaviorLog): Promise<authModels.GetUserBehaviorLogRes> {\n    return this.oauthInstance.authApi.getUserBehaviorLog(params)\n  }\n\n  /**\n   * sms/email 验证码登录/注册，逻辑一致收敛\n   */\n  public async signInWithUsername({\n    verificationInfo = { verification_id: '', is_user: false },\n    verificationCode = '',\n    username: rawUsername = '',\n    bindInfo = undefined,\n    loginType = '',\n  }: {\n    verificationInfo?: authModels.GetVerificationResponse\n    verificationCode?: string\n    username?: string\n    bindInfo?: any\n    loginType?: string\n  }): Promise<LoginState> {\n    try {\n      // 1. 验证验证码\n      const verifyRes = await this.oauthInstance.authApi.verify({\n        verification_id: verificationInfo.verification_id,\n        verification_code: verificationCode,\n      })\n\n      if ((verifyRes as any)?.error_code) {\n        throw verifyRes\n      }\n\n      // eslint-disable-next-line @typescript-eslint/naming-convention\n      const { verification_token } = verifyRes\n\n      // 手机登录参数\n      let username = /^\\+\\d{1,3}\\s+/.test(rawUsername) ? rawUsername : `+86 ${rawUsername}`\n      let signUpParam: any = { phone_number: username }\n\n      // 邮箱登录参数\n      if (loginType === 'email') {\n        username = rawUsername\n        signUpParam = { email: username }\n      }\n\n      // 2. 根据是否已经是用户，分别走登录或注册逻辑\n      if (verificationInfo.is_user) {\n        // 私有化环境或者自定义应用走v1版本的老逻辑\n        const signInRes = await this.oauthInstance.authApi.signIn({\n          username,\n          verification_token,\n        })\n\n        if ((signInRes as any)?.error_code) {\n          throw signInRes\n        }\n\n        if (bindInfo) {\n          const bindRes = await this.oauthInstance.authApi.bindWithProvider({\n            provider_token: (bindInfo as any)?.providerToken,\n          })\n\n          if ((bindRes as any)?.error_code) {\n            throw bindRes\n          }\n        }\n      } else {\n        // 自定义应用走signUp逻辑\n        const signUpRes = await this.oauthInstance.authApi.signUp({\n          ...signUpParam,\n          verification_token,\n          provider_token: (bindInfo as any)?.providerId,\n        })\n\n        if ((signUpRes as any)?.error_code) {\n          throw signUpRes\n        }\n      }\n\n      return this.createLoginState()\n    } catch (error) {\n      throw error\n    }\n  }\n\n  async createLoginState(\n    params?: { version?: string; query?: any },\n    options?: { asyncRefreshUser?: boolean; userInfo?: any },\n  ): Promise<LoginState> {\n    const loginState = new LoginState({\n      envId: this.config.env,\n      cache: this.cache,\n      oauthInstance: this.oauthInstance,\n    })\n\n    await loginState.checkLocalStateAsync()\n\n    if (options?.userInfo) {\n      loginState.user.setLocalUserInfo(options.userInfo)\n    } else {\n      if (options?.asyncRefreshUser) {\n        loginState.user.refresh(params)\n      } else {\n        await loginState.user.refresh(params)\n      }\n    }\n\n    this.config.eventBus?.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_IN })\n\n    this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.SIGNED_IN })\n    return loginState\n  }\n\n  async setAccessKey() {\n    if (this.config.accessKey) {\n      try {\n        this.oauthInstance.oauth2client.setAccessKeyCredentials({\n          access_token: this.config.accessKey,\n          token_type: 'Bearer',\n          scope: 'accessKey',\n          expires_at: new Date(+new Date() + +new Date()),\n          expires_in: +new Date() + +new Date(),\n        })\n      } catch (error) {\n        console.warn('accessKey error: ', error)\n      }\n    }\n  }\n\n  // ========== new auth api methods merged below ==========\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signinanonymously\n   * Sign in a user anonymously.\n   * const { data, error } = await auth.signInAnonymously();\n   * @param params\n   * @returns  Promise<SignInRes>\n   */\n  async signInAnonymously(params: SignInAnonymouslyReq): Promise<SignInRes> {\n    try {\n      await this.oauthInstance.authApi.signInAnonymously(params)\n      const loginState = await this.createLoginState()\n\n      const { data: { session } = {} } = await this.getSession()\n\n      // loginState返回是为了兼容v2版本\n      return { ...(loginState as any), data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signup\n   * Sign up a new user with email or phone using a one-time password (OTP). If the account not exist, a new account will be created.\n   * @param params\n   * @returns Promise<SignUpRes>\n   */\n  async signUp(params: authModels.SignUpRequest & { phone?: string }): Promise<SignUpRes> {\n    if (params.phone_number || params.verification_code || params.verification_token || params.provider_token) {\n      await this.oauthInstance.authApi.signUp(params)\n      return this.createLoginState() as any\n    }\n    try {\n      // 参数校验：email或phone必填其一\n      this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number')\n\n      // 第一步：发送验证码并存储 verificationInfo\n      const verificationInfo = await this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) },)\n\n      return {\n        data: {\n          // 第二步：等待用户输入验证码（通过 Promise 包装用户输入事件）\n          verifyOtp: async ({ token, messageId = verificationInfo.verification_id }): Promise<SignInRes> => {\n            try {\n              // 第三步：待用户输入完验证码之后，验证短信验证码\n              const verificationTokenRes = await this.verify({\n                verification_id: messageId || verificationInfo.verification_id,\n                verification_code: token,\n              })\n\n              // 第四步：注册并登录或直接登录\n              // 如果用户已经存在，直接登录\n              if (verificationInfo.is_user) {\n                await this.signIn({\n                  username: params.email || this.formatPhone(params.phone),\n                  verification_token: verificationTokenRes.verification_token,\n                })\n              } else {\n                // 如果用户不存在，注册用户\n                const data = JSON.parse(JSON.stringify(params))\n                delete data.email\n                delete data.phone\n\n                await this.oauthInstance.authApi.signUp({\n                  ...data,\n                  ...(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) }),\n                  verification_token: verificationTokenRes.verification_token,\n                  verification_code: token,\n                })\n                await this.createLoginState()\n              }\n\n              const { data: { session } = {} } = await this.getSession()\n\n              return { data: { user: session.user, session }, error: null }\n            } catch (error) {\n              return { data: {}, error: new AuthError(error) }\n            }\n          },\n        },\n        error: null,\n      }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signout\n   * const result = await auth.signOut();\n   *\n   * @param params\n   */\n  async signOut(params?: authModels.SignoutRequest,): Promise<authModels.SignoutResponse & { data: Object; error: AuthError }> {\n    try {\n      const { userInfoKey } = this.cache.keys\n      const res = await this.oauthInstance.authApi.signOut(params)\n      await this.cache.removeStoreAsync(userInfoKey)\n      this.setAccessKey()\n\n      this.config.eventBus?.fire(EVENTS.LOGIN_STATE_CHANGED, { eventType: LOGIN_STATE_CHANGED_TYPE.SIGN_OUT })\n\n      this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.SIGNED_OUT })\n\n      // res返回是为了兼容v2版本\n      return { ...res, data: {}, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-onauthstatechange\n   * Receive a notification every time an auth event happens.\n   * @param callback\n   * @returns Promise<{ data: { subscription: Subscription }, error: Error | null }>\n   */\n  onAuthStateChange(callback: OnAuthStateChangeCallback) {\n    if (!this.hasListenerSetUp) {\n      this.setupListeners()\n      this.hasListenerSetUp = true\n    }\n\n    const id = Math.random().toString(36)\n\n    if (!this.listeners.has(id)) {\n      this.listeners.set(id, new Set())\n    }\n\n    this.listeners.get(id)!.add(callback)\n\n    // 返回 Subscription 对象\n    const subscription = {\n      id,\n      callback,\n      unsubscribe: () => {\n        const callbacks = this.listeners.get(id)\n        if (callbacks) {\n          callbacks.delete(callback)\n          if (callbacks.size === 0) {\n            this.listeners.delete(id)\n          }\n        }\n      },\n    }\n\n    return {\n      data: { subscription },\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signinwithpassword\n   * Log in an existing user with an email and password or phone and password or username and password.\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async signInWithPassword(params: SignInWithPasswordReq): Promise<SignInRes> {\n    try {\n      // 参数校验：username/email/phone三选一，password必填\n      this.validateAtLeastOne(\n        params,\n        [['username'], ['email'], ['phone']],\n        'You must provide either username, email, or phone',\n      )\n      this.validateParams(params, {\n        password: { required: true, message: 'Password is required' },\n      })\n\n      await this.signIn({\n        username: params.username || params.email || this.formatPhone(params.phone),\n        password: params.password,\n        ...(params.is_encrypt ? { isEncrypt: true, version: 'v2' } : {}),\n      })\n      const { data: { session } = {} } = await this.getSession()\n\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signinwithidtoken\n   * 第三方平台登录。如果用户不存在，会根据云开发平台-登录方式中对应身份源的登录模式配置，判断是否自动注册\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async signInWithIdToken(params: SignInWithIdTokenReq): Promise<SignInRes> {\n    try {\n      // 参数校验：token必填\n      this.validateParams(params, {\n        token: { required: true, message: 'Token is required' },\n      })\n\n      await this.signInWithProvider({\n        provider_token: params.token,\n      })\n      const { data: { session } = {} } = await this.getSession()\n\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signinwithotp\n   * Log in a user using a one-time password (OTP).\n   * @param params\n   * @returns Promise<SignInWithOtpRes>\n   */\n  async signInWithOtp(params: SignInWithOtpReq): Promise<SignInWithOtpRes> {\n    try {\n      // 参数校验：email或phone必填其一\n      this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number')\n\n      // 第一步：发送验证码并存储 verificationInfo\n      const verificationInfo = await this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) },)\n\n      return {\n        data: {\n          user: null,\n          session: null,\n          // 第二步：等待用户输入验证码（通过 Promise 包装用户输入事件）\n          verifyOtp: async ({ token, messageId = verificationInfo.verification_id }): Promise<SignInRes> => this.verifyOtp({\n            email: params.email,\n            phone: params.phone,\n            token,\n            messageId,\n          }),\n        },\n        error: null,\n      }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 校验第三方平台授权登录回调\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async verifyOAuth(params?: VerifyOAuthReq): Promise<SignInRes | LinkIdentityRes> {\n    const data: any = {}\n    try {\n      // 回调至 provider_redirect_uri 地址（url query中携带 授权code，state等参数），此时检查 state 是否符合预期（如 自己设置的 wx_open)\n      const code = params?.code || utils.getQuery('code')\n      const state = params?.state || utils.getQuery('state')\n\n      // 参数校验：code和state必填\n      if (!code) {\n        return { data: {}, error: new AuthError({ message: 'Code is required' }) }\n      }\n\n      if (!state) {\n        return { data: {}, error: new AuthError({ message: 'State is required' }) }\n      }\n\n      const cacheData = getBrowserSession(state)\n      data.type = cacheData?.type\n\n      const provider = params?.provider || cacheData?.provider || utils.getQuery('provider')\n\n      if (!provider) {\n        return { data, error: new AuthError({ message: 'Provider is required' }) }\n      }\n\n      // state符合预期，则获取该三方平台token\n      const { provider_token: token } = await this.grantProviderToken({\n        provider_id: provider,\n        provider_redirect_uri: location.origin + location.pathname, // 指定三方平台跳回的 url 地址\n        provider_code: code, // 第三方平台跳转回页面时，url param 中携带的 code 参数\n      })\n\n      let res: SignInRes | LinkIdentityRes\n\n      if (cacheData.type === OAUTH_TYPE.BIND_IDENTITY) {\n        res = await this.oauthInstance.authApi.toBindIdentity({ provider_token: token, provider, fireEvent: true })\n      } else {\n        // 通过 provider_token 仅登录或登录并注册（与云开发平台-登录方式-身份源登录模式配置有关）\n        res = await this.signInWithIdToken({\n          token,\n        })\n        res.data = { ...data, ...res.data }\n      }\n\n      const localSearch = new URLSearchParams(location?.search)\n      localSearch.delete('code')\n      localSearch.delete('state')\n      addUrlSearch(\n        cacheData?.search === undefined ? `?${localSearch.toString()}` : cacheData?.search,\n        cacheData?.hash || location.hash,\n      )\n      removeBrowserSession(state)\n\n      return res\n    } catch (error) {\n      return { data, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-signinwithoauth\n   * 生成第三方平台授权 Uri （如微信二维码扫码授权网页）\n   * @param params\n   * @returns Promise<SignInOAuthRes>\n   */\n  async signInWithOAuth(params: SignInWithOAuthReq): Promise<SignInOAuthRes> {\n    try {\n      // 参数校验：provider必填\n      this.validateParams(params, {\n        provider: { required: true, message: 'Provider is required' },\n      })\n\n      const href = params.options?.redirectTo || location.href\n\n      const urlObject = new URL(href)\n\n      const provider_redirect_uri = urlObject.origin + urlObject.pathname\n\n      const state = params.options?.state || `prd-${params.provider}-${Math.random().toString(36)\n        .slice(2)}`\n\n      const { uri } = await this.genProviderRedirectUri({\n        provider_id: params.provider,\n        provider_redirect_uri,\n        state,\n      })\n\n      // 对 URL 进行解码\n      const decodedUri = decodeURIComponent(uri)\n\n      // 合并额外的查询参数\n      let finalUri = decodedUri\n\n      if (params.options?.queryParams) {\n        const url = new URL(decodedUri)\n        Object.entries(params.options.queryParams).forEach(([key, value]) => {\n          url.searchParams.set(key, value)\n        })\n        finalUri = url.toString()\n      }\n\n      saveToBrowserSession(state, {\n        provider: params.provider,\n        search: urlObject.search,\n        hash: urlObject.hash,\n        type: params.options?.type || OAUTH_TYPE.SIGN_IN,\n      })\n\n      if (isBrowser() && !params.options?.skipBrowserRedirect) {\n        window.location.assign(finalUri)\n      }\n\n      return { data: { url: finalUri, provider: params.provider }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  // https://supabase.com/docs/reference/javascript/auth-getclaims\n  async getClaims(): Promise<GetClaimsRes> {\n    try {\n      const { accessToken } = await this.getAccessToken()\n      const parsedToken = weAppJwtDecodeAll(accessToken)\n      return { data: parsedToken, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-resetpasswordforemail\n   * 通过 email 或手机号重置密码\n   * @param emailOrPhone 邮箱或手机号\n   * @returns Promise<ResetPasswordForEmailRes>\n   */\n  async resetPasswordForEmail(\n    emailOrPhone: string,\n    options?: { redirectTo?: string },\n  ): Promise<ResetPasswordForEmailRes> {\n    try {\n      // 参数校验：emailOrPhone必填\n      this.validateParams(\n        { emailOrPhone },\n        {\n          emailOrPhone: { required: true, message: 'Email or phone is required' },\n        },\n      )\n\n      const { redirectTo } = options || {}\n\n      // 判断是邮箱还是手机号\n      const isEmail = emailOrPhone.includes('@')\n      let verificationParams: { email?: string; phone_number?: string }\n\n      if (isEmail) {\n        verificationParams = { email: emailOrPhone }\n      } else {\n        // 正规化手机号\n        const formattedPhone = this.formatPhone(emailOrPhone)\n        verificationParams = { phone_number: formattedPhone }\n      }\n\n      // 第一步：发送验证码并存储 verificationInfo\n      const verificationInfo = await this.getVerification(verificationParams)\n\n      return {\n        data: {\n          // 第二步：等待用户输入验证码（通过 Promise 包装用户输入事件）\n          updateUser: async (attributes: UpdateUserAttributes): Promise<SignInRes> => {\n            this.validateParams(attributes, {\n              nonce: { required: true, message: 'Nonce is required' },\n              password: { required: true, message: 'Password is required' },\n            })\n            try {\n              // 第三步：待用户输入完验证码之后，验证验证码\n              const verificationTokenRes = await this.verify({\n                verification_id: verificationInfo.verification_id,\n                verification_code: attributes.nonce,\n              })\n\n              await this.oauthInstance.authApi.resetPassword({\n                email: isEmail ? emailOrPhone : undefined,\n                phone_number: !isEmail ? emailOrPhone : undefined,\n                new_password: attributes.password,\n                verification_token: verificationTokenRes.verification_token,\n              })\n\n              this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, {\n                event: AUTH_STATE_CHANGED_TYPE.PASSWORD_RECOVERY,\n              })\n\n              const res = await this.signInWithPassword({\n                email: isEmail ? emailOrPhone : undefined,\n                phone: !isEmail ? emailOrPhone : undefined,\n                password: attributes.password,\n              })\n\n              if (redirectTo && isBrowser()) {\n                window.location.assign(redirectTo)\n              }\n\n              return res\n            } catch (error) {\n              return { data: {}, error: new AuthError(error) }\n            }\n          },\n        },\n        error: null,\n      }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 通过旧密码重置密码\n   * @param new_password\n   * @param old_password\n   * @returns\n   */\n  async resetPasswordForOld(params: ResetPasswordForOldReq) {\n    try {\n      await this.oauthInstance.authApi.updatePasswordByOld({\n        old_password: params.old_password,\n        new_password: params.new_password,\n      })\n\n      const { data: { session } = {} } = await this.getSession()\n\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-verifyotp\n   * Log in a user given a User supplied OTP and verificationId received through mobile or email.\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async verifyOtp(params: VerifyOtpReq): Promise<SignInRes> {\n    try {\n      const { type } = params\n      // 参数校验：token和verificationInfo必填\n      this.validateParams(params, {\n        token: { required: true, message: 'Token is required' },\n        messageId: { required: true, message: 'messageId is required' },\n      })\n\n      if (['phone_change', 'email_change'].includes(type)) {\n        await this.verify({\n          verification_id: params.messageId,\n          verification_code: params.token,\n        })\n      } else {\n        await this.signInWithUsername({\n          verificationInfo: { verification_id: params.messageId, is_user: true },\n          verificationCode: params.token,\n          username: params.email || this.formatPhone(params.phone) || '',\n          loginType: params.email ? 'email' : 'phone',\n        })\n      }\n\n      const { data: { session } = {} } = await this.getSession()\n\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-getSession\n   * Returns the session, refreshing it if necessary.\n   * @returns Promise<SignInRes>\n   */\n  async getSession(): Promise<SignInRes> {\n    try {\n      const credentials: Credentials = await this.oauthInstance.oauth2client.getCredentials()\n\n      if (!credentials || credentials.scope === 'accessKey') {\n        return { data: { session: null }, error: null }\n      }\n\n      const { data: { user } = {} } = await this.getUser()\n\n      return { data: { session: { ...credentials, user }, user }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-refreshsession\n   * 无论过期状态如何，都返回一个新的会话\n   * @param refresh_token\n   * @returns Promise<SignInRes>\n   */\n  async refreshSession(refresh_token?: string): Promise<SignInRes> {\n    try {\n      const credentials: Credentials = await this.oauthInstance.oauth2client.localCredentials.getCredentials()\n      credentials.refresh_token = refresh_token || credentials.refresh_token\n      const newTokens = await this.oauthInstance.oauth2client.refreshToken(credentials)\n      const { data: { user } = {} } = await this.getUser()\n\n      return { data: { user, session: { ...newTokens, user } }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-getuser\n   * 如果存在现有会话，则获取当前用户详细信息\n   * @returns Promise<GetUserRes>\n   */\n  async getUser(): Promise<GetUserRes> {\n    try {\n      const user = this.convertToUser(await this.getUserInfo())\n      return { data: { user }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 刷新用户信息\n   * @returns Promise<CommonRes>\n   */\n  async refreshUser(): Promise<CommonRes> {\n    try {\n      await this.currentUser.refresh()\n\n      const { data: { session } = {} } = await this.getSession()\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-updateuser\n   * 更新用户信息\n   * @param params\n   * @returns Promise<GetUserRes | UpdateUserWithVerificationRes>\n   */\n  async updateUser(params: UpdateUserReq): Promise<GetUserRes | UpdateUserWithVerificationRes> {\n    try {\n      // 参数校验：至少有一个更新字段被提供\n      const hasValue = Object.keys(params).some(key => params[key] !== undefined && params[key] !== null && params[key] !== '',)\n      if (!hasValue) {\n        throw new AuthError({ message: 'At least one field must be provided for update' })\n      }\n\n      const { email, phone, ...restParams } = params\n\n      // 检查是否需要更新 email 或 phone\n      const needsEmailVerification = email !== undefined\n      const needsPhoneVerification = phone !== undefined\n\n      let extraRes = {}\n\n      if (needsEmailVerification || needsPhoneVerification) {\n        // 需要发送验证码\n        let verificationParams: { email?: string; phone_number?: string }\n        let verificationType: 'email_change' | 'phone_change'\n\n        if (needsEmailVerification) {\n          verificationParams = { email: params.email }\n          verificationType = 'email_change'\n        } else {\n          // 正规化手机号\n          const formattedPhone = this.formatPhone(params.phone)\n          verificationParams = { phone_number: formattedPhone }\n          verificationType = 'phone_change'\n        }\n\n        // 发送验证码\n        const verificationInfo = await this.getVerification(verificationParams)\n\n        Object.keys(restParams).length > 0 && (await this.updateUserBasicInfo(restParams))\n\n        extraRes = {\n          messageId: verificationInfo.verification_id,\n          verifyOtp: async (verifyParams: { email?: string; phone?: string; token: string }): Promise<GetUserRes> => {\n            try {\n              if (verifyParams.email && params.email === verifyParams.email) {\n                // 验证码验证\n                await this.verifyOtp({\n                  type: 'email_change',\n                  email: params.email,\n                  token: verifyParams.token,\n                  messageId: verificationInfo.verification_id,\n                })\n                await this.updateUserBasicInfo({ email: params.email })\n              } else if (verifyParams.phone && params.phone === verifyParams.phone) {\n                // 验证码验证\n                await this.verifyOtp({\n                  type: 'phone_change',\n                  phone: params.phone,\n                  token: verifyParams.token,\n                  messageId: verificationInfo.verification_id,\n                })\n                await this.updateUserBasicInfo({ phone: this.formatPhone(params.phone) })\n              } else {\n                await this.verifyOtp({\n                  type: verificationType,\n                  email: needsEmailVerification ? params.email : undefined,\n                  phone: !needsEmailVerification ? params.phone : undefined,\n                  token: verifyParams.token,\n                  messageId: verificationInfo.verification_id,\n                })\n                // 验证成功后更新用户信息\n                await this.updateUserBasicInfo(params)\n              }\n\n              const {\n                data: { user },\n              } = await this.getUser()\n              this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.USER_UPDATED })\n\n              return { data: { user }, error: null }\n            } catch (error) {\n              return { data: {}, error: new AuthError(error) }\n            }\n          },\n        }\n      } else {\n        // 不需要验证，直接更新\n        await this.updateUserBasicInfo(params)\n      }\n      const {\n        data: { user },\n      } = await this.getUser()\n      this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.USER_UPDATED })\n\n      return { data: { user, ...extraRes }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-getuseridentities\n   * 获取所有身份源\n   * @returns Promise<GetUserIdentitiesRes>\n   */\n  async getUserIdentities(): Promise<GetUserIdentitiesRes> {\n    try {\n      const providers = await this.oauthInstance.authApi.getProviders()\n\n      return { data: { identities: providers?.data?.filter(v => !!v.bind) as unknown as GetUserIdentitiesRes['data']['identities'] }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-linkidentity\n   * 绑定身份源到当前用户\n   * @param params\n   * @returns Promise<LinkIdentityRes>\n   */\n  async linkIdentity(params: LinkIdentityReq): Promise<LinkIdentityRes> {\n    try {\n      // 参数校验：provider必填\n      this.validateParams(params, {\n        provider: { required: true, message: 'Provider is required' },\n      })\n\n      await this.signInWithOAuth({\n        provider: params.provider,\n        options: {\n          type: OAUTH_TYPE.BIND_IDENTITY,\n        },\n      })\n\n      return { data: { provider: params.provider }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-unlinkidentity\n   * 解绑身份源\n   * @param params\n   * @returns Promise<CommonRes>\n   */\n  async unlinkIdentity(params: UnlinkIdentityReq): Promise<CommonRes> {\n    try {\n      // 参数校验：provider必填\n      this.validateParams(params, {\n        provider: { required: true, message: 'Provider is required' },\n      })\n\n      await this.oauthInstance.authApi.unbindProvider({ provider_id: params.provider })\n\n      return { data: {}, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-reauthentication\n   * 重新认证\n   * @returns Promise<ReauthenticateRes>\n   */\n  async reauthenticate(): Promise<ReauthenticateRes> {\n    try {\n      const {\n        data: { user },\n      } = await this.getUser()\n\n      this.validateAtLeastOne(user, [['email', 'phone']], 'You must provide either an email or phone number')\n      const userInfo = user.email ? { email: user.email } : { phone_number: this.formatPhone(user.phone) }\n\n      // 第一步：发送验证码并存储 verificationInfo\n      const verificationInfo = await this.getVerification(userInfo)\n\n      return {\n        data: {\n          // 第二步：等待用户输入验证码（通过 Promise 包装用户输入事件）\n          updateUser: async (attributes: UpdateUserAttributes): Promise<SignInRes> => {\n            this.validateParams(attributes, {\n              nonce: { required: true, message: 'Nonce is required' },\n            })\n            try {\n              if (attributes.password) {\n                // 第三步：待用户输入完验证码之后，验证验证码\n                const verificationTokenRes = await this.verify({\n                  verification_id: verificationInfo.verification_id,\n                  verification_code: attributes.nonce,\n                })\n\n                // 第四步：获取 sudo_token\n                const sudoRes = await this.oauthInstance.authApi.sudo({\n                  verification_token: verificationTokenRes.verification_token,\n                })\n\n                await this.oauthInstance.authApi.setPassword({\n                  new_password: attributes.password,\n                  sudo_token: sudoRes.sudo_token,\n                })\n              } else {\n                await this.signInWithUsername({\n                  verificationInfo,\n                  verificationCode: attributes.nonce,\n                  ...userInfo,\n                  loginType: userInfo.email ? 'email' : 'phone',\n                })\n              }\n\n              const { data: { session } = {} } = await this.getSession()\n\n              return { data: { user: session.user, session }, error: null }\n            } catch (error) {\n              return { data: {}, error: new AuthError(error) }\n            }\n          },\n        },\n        error: null,\n      }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-resend\n   * 重新发送验证码\n   * @param params\n   * @returns Promise<ResendRes>\n   */\n  async resend(params: ResendReq): Promise<ResendRes> {\n    try {\n      // 参数校验：email或phone必填其一\n      this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number')\n\n      const target = params.type === 'signup' ? 'ANY' : 'USER'\n      const data: { email?: string; phone_number?: string; target: 'USER' | 'ANY' } = { target }\n      if ('email' in params) {\n        data.email = params.email\n      }\n\n      if ('phone' in params) {\n        data.phone_number = this.formatPhone(params.phone)\n      }\n\n      // 重新发送验证码\n      const { verification_id: verificationId } = await this.oauthInstance.authApi.getVerification(data)\n\n      return {\n        data: { messageId: verificationId },\n        error: null,\n      }\n    } catch (error: any) {\n      return {\n        data: {},\n        error: new AuthError(error),\n      }\n    }\n  }\n\n  /**\n   * https://supabase.com/docs/reference/javascript/auth-setsession\n   * 使用access_token和refresh_token来设置会话\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async setSession(params: SetSessionReq): Promise<SignInRes> {\n    try {\n      this.validateParams(params, {\n        access_token: { required: true, message: 'Access token is required' },\n        refresh_token: { required: true, message: 'Refresh token is required' },\n      })\n\n      await this.oauthInstance.oauth2client.refreshToken(params, { throwError: true })\n\n      const { data: { session } = {} } = await this.getSession()\n\n      this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.SIGNED_IN })\n\n      return { data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  // https://supabase.com/docs/reference/javascript/auth-exchangecodeforsession\n  async exchangeCodeForSession() {\n    //\n  }\n\n  /**\n   * 删除当前用户\n   * @param params\n   * @returns\n   */\n  async deleteUser(params: DeleteMeReq): Promise<CommonRes> {\n    try {\n      this.validateParams(params, {\n        password: { required: true, message: 'Password is required' },\n      })\n\n      const { sudo_token } = await this.oauthInstance.authApi.sudo(params)\n\n      await this.oauthInstance.authApi.deleteMe({ sudo_token })\n\n      return { data: {}, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 跳转系统默认登录页\n   * @returns {Promise<authModels.ToDefaultLoginPage>}\n   * @memberof Auth\n   */\n  async toDefaultLoginPage(params: authModels.ToDefaultLoginPage = {}): Promise<CommonRes> {\n    try {\n      const configVersion = params.config_version || 'env'\n      const query = Object.keys(params.query || {})\n        .map(key => `${key}=${params.query[key]}`)\n        .join('&')\n\n      if (adapterForWxMp.isMatch()) {\n        wx.navigateTo({ url: `/packages/$wd_system/pages/login/index${query ? `?${query}` : ''}` })\n      } else {\n        const redirectUri = params.redirect_uri || window.location.href\n        const urlObj = new URL(redirectUri)\n        const loginPage = `${urlObj.origin}/__auth/?app_id=${params.app_id || ''}&env_id=${this.config.env}&client_id=${\n          this.config.clientId || this.config.env\n        }&config_version=${configVersion}&redirect_uri=${encodeURIComponent(redirectUri)}${query ? `&${query}` : ''}`\n        window.location.href = loginPage\n      }\n      return { data: {}, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 自定义登录\n   * @param getTickFn () => Promise<string>, 获取自定义登录 ticket 的函数\n   * @returns\n   */\n  async signInWithCustomTicket(getTickFn?: authModels.GetCustomSignTicketFn): Promise<SignInRes> {\n    if (getTickFn) {\n      this.setCustomSignFunc(getTickFn)\n    }\n\n    try {\n      await this.oauthInstance.authApi.signInWithCustomTicket()\n      const loginState = await this.createLoginState()\n\n      const { data: { session } = {} } = await this.getSession()\n\n      // loginState返回是为了兼容v2版本\n      return { ...(loginState as any), data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 小程序openId静默登录\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async signInWithOpenId({ useWxCloud = true } = {}): Promise<SignInRes> {\n    if (!adapterForWxMp.isMatch()) {\n      throw Error('wx api undefined')\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n\n    const mainFunc = async (code) => {\n      let result: authModels.GrantProviderTokenResponse | undefined = undefined\n      let credentials: Credentials | undefined = undefined\n\n      try {\n        result = await this.oauthInstance.authApi.grantProviderToken(\n          {\n            provider_id: wxInfo?.appId,\n            provider_code: code,\n            provider_params: {\n              provider_code_type: 'open_id',\n              appid: wxInfo?.appId,\n            },\n          },\n          useWxCloud,\n        )\n\n        if ((result as any)?.error_code || !result.provider_token) {\n          throw result\n        }\n\n        credentials = await this.oauthInstance.authApi.signInWithProvider(\n          { provider_token: result.provider_token },\n          useWxCloud,\n        )\n\n        if ((credentials as any)?.error_code) {\n          throw credentials\n        }\n      } catch (error) {\n        throw error\n      }\n      await this.oauthInstance.oauth2client.setCredentials(credentials as Credentials)\n    }\n\n    try {\n      await new Promise((resolve, reject) => {\n        wx.login({\n          success: async (res: { code: string }) => {\n            try {\n              await mainFunc(res.code)\n              resolve(true)\n            } catch (error) {\n              reject(error)\n            }\n          },\n          fail: (res: any) => {\n            const error = new Error(res?.errMsg)\n            ;(error as any).code = res?.errno\n            reject(error)\n          },\n        })\n      })\n\n      const loginState = await this.createLoginState()\n\n      const { data: { session } = {} } = await this.getSession()\n\n      // loginState返回是为了兼容v2版本\n      return { ...(loginState as any), data: { user: session.user, session }, error: null }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n  }\n\n  /**\n   * 小程序手机号授权登录，目前只支持全托管手机号授权登录\n   * @param params\n   * @returns Promise<SignInRes>\n   */\n  async signInWithPhoneAuth({ phoneCode = '' }): Promise<SignInRes> {\n    if (!adapterForWxMp.isMatch()) {\n      return { data: {}, error: new AuthError({ message: 'wx api undefined' }) }\n    }\n    const wxInfo = wx.getAccountInfoSync().miniProgram\n    const providerInfo = {\n      provider_params: { provider_code_type: 'phone' },\n      provider_id: wxInfo.appId,\n    }\n\n    const { code } = await wx.login()\n    ;(providerInfo as any).provider_code = code\n\n    try {\n      let providerToken = await this.oauthInstance.authApi.grantProviderToken(providerInfo)\n      if (providerToken.error_code) {\n        throw providerToken\n      }\n\n      providerToken = await this.oauthInstance.authApi.patchProviderToken({\n        provider_token: providerToken.provider_token,\n        provider_id: wxInfo.appId,\n        provider_params: {\n          code: phoneCode,\n          provider_code_type: 'phone',\n        },\n      })\n      if (providerToken.error_code) {\n        throw providerToken\n      }\n\n      const signInRes = await this.oauthInstance.authApi.signInWithProvider({\n        provider_token: providerToken.provider_token,\n      })\n\n      if ((signInRes as any)?.error_code) {\n        throw signInRes\n      }\n    } catch (error) {\n      return { data: {}, error: new AuthError(error) }\n    }\n\n    const loginState = await this.createLoginState()\n\n    const { data: { session } = {} } = await this.getSession()\n\n    // loginState返回是为了兼容v2版本\n    return { ...(loginState as any), data: { user: session.user, session }, error: null }\n  }\n\n  private formatPhone(phone: string) {\n    if (!/\\s+/.test(phone) && /^\\+\\d{1,3}\\d+/.test(phone)) {\n      return phone.replace(/^(\\+\\d{1,2})(\\d+)$/, '$1 $2')\n    }\n    return /^\\+\\d{1,3}\\s+/.test(phone) ? phone : `+86 ${phone}`\n  }\n\n  private notifyListeners(event, session, info): OnAuthStateChangeCallback {\n    this.listeners.forEach((callbacks) => {\n      callbacks.forEach((callback) => {\n        try {\n          callback(event, session, info)\n        } catch (error) {\n          console.error('Error in auth state change callback:', error)\n        }\n      })\n    })\n    return\n  }\n\n  private setupListeners() {\n    this.config.eventBus?.on(EVENTS.AUTH_STATE_CHANGED, async (params) => {\n      const event = params?.data?.event\n      const info = params?.data?.info\n      const {\n        data: { session },\n      } = await this.getSession()\n\n      this.notifyListeners(event, session, info)\n    })\n  }\n\n  private convertToUser(userInfo: authModels.UserInfo & Partial<User>) {\n    if (!userInfo) return null\n\n    // 优先使用 userInfo 中的数据（V3 API）\n    const email = userInfo?.email || ''\n    const phone = userInfo?.phone_number || ''\n    const userId = userInfo?.sub || userInfo?.uid || ''\n\n    return {\n      id: userId,\n      aud: 'authenticated',\n      role: userInfo.groups.map(group => (typeof group === 'string' ? group : group.id)),\n      email: email || '',\n      email_confirmed_at: userInfo?.email_verified ? userInfo.created_at : userInfo.created_at,\n      phone,\n      phone_confirmed_at: phone ? userInfo.created_at : undefined,\n      confirmed_at: userInfo.created_at,\n      last_sign_in_at: (userInfo as any).last_sign_in_at,\n      app_metadata: {\n        provider: userInfo.loginType?.toLowerCase() || 'cloudbase',\n        providers: [userInfo.loginType?.toLowerCase() || 'cloudbase'],\n      },\n      user_metadata: {\n        // V3 API 用户信息\n        name: userInfo?.name,\n        picture: userInfo?.picture,\n        username: userInfo?.username, // 用户名称，长度 5-24 位，支持字符中英文、数字、特殊字符（仅支持_-），不支持中文\n        gender: userInfo?.gender,\n        locale: userInfo?.locale,\n        // V2 API 兼容（使用 any 避免类型错误）\n        uid: userInfo.uid,\n        nickName: userInfo.nickName,\n        avatarUrl: userInfo.avatarUrl || userInfo.picture,\n        location: userInfo.location,\n        hasPassword: userInfo.hasPassword,\n      },\n      identities:\n        userInfo?.providers?.map(p => ({\n          id: p.id || '',\n          identity_id: p.id || '',\n          user_id: userId,\n          identity_data: {\n            provider_id: p.id,\n            provider_user_id: p.provider_user_id,\n            name: p.name,\n          },\n          provider: p.id || 'cloudbase',\n          created_at: userInfo.created_at,\n          updated_at: userInfo.updated_at,\n          last_sign_in_at: (userInfo as any).last_sign_in_at,\n        })) || [],\n      created_at: userInfo.created_at,\n      updated_at: userInfo.updated_at,\n      is_anonymous: userInfo.name === 'anonymous',\n    }\n  }\n\n  /**\n   * 参数校验辅助方法\n   */\n  private validateParams(params: any, rules: { [key: string]: { required?: boolean; message: string } }): void {\n    for (const [key, rule] of Object.entries(rules)) {\n      if (rule.required && (params?.[key] === undefined || params?.[key] === null || params?.[key] === '')) {\n        throw new AuthError({ message: rule.message })\n      }\n    }\n  }\n\n  /**\n   * 校验必填参数组（至少有一个参数必须有值）\n   */\n  private validateAtLeastOne(params: any, fieldGroups: string[][], message: string): void {\n    const hasValue = fieldGroups.some(group => group.some(field => params?.[field] !== undefined && params?.[field] !== null && params?.[field] !== ''),)\n\n    if (!hasValue) {\n      throw new AuthError({ message })\n    }\n  }\n\n  private async init(): Promise<{ error: Error | null }> {\n    try {\n      const credentials: Credentials = await this.oauthInstance.oauth2client.localCredentials.getCredentials()\n      if (credentials) {\n        this.config.eventBus?.fire(EVENTS.AUTH_STATE_CHANGED, { event: AUTH_STATE_CHANGED_TYPE.INITIAL_SESSION })\n      }\n    } catch (error) {\n      // Ignore errors when checking for existing credentials\n    }\n\n    return { error: null }\n  }\n}\n\ntype TInitAuthOptions = Pick<ICloudbaseAuthConfig, 'region' | 'persistence' | 'i18n' | 'accessKey' | 'useWxCloud'> &\nPartial<AuthOptions> & {\n  detectSessionInUrl?: boolean\n}\n\nexport function generateAuthInstance(\n  config: TInitAuthOptions & { sdkVersion?: string },\n  options?: {\n    clientId: ICloudbaseConfig['clientId']\n    env: ICloudbaseConfig['env']\n    apiOrigin: string\n    cache?: ICloudbaseCache\n    platform?: ICloudbase['platform']\n    app?: ICloudbase\n    debug?: ICloudbaseAuthConfig['debug']\n    detectSessionInUrl?: ICloudbaseAuthConfig['detectSessionInUrl']\n  },\n) {\n  const { region = 'ap-shanghai', i18n, accessKey, useWxCloud } = config\n  const platform = options?.platform || (useDefaultAdapter.bind(options)() as ICloudbasePlatformInfo)\n  const { runtime, adapter } = platform\n\n  const { env, clientId, debug, cache, app: cloudbase } = options || {}\n  let { apiOrigin } = options || {}\n  if (!apiOrigin) {\n    apiOrigin = `https://${env}.${region}.tcb-api.tencentcloudapi.com`\n  }\n\n  const commonOpts = {\n    env,\n    clientId,\n    i18n,\n    accessKey,\n    useWxCloud,\n    eventBus: new CloudbaseEventEmitter(),\n  }\n\n  const oauthInstance = new CloudbaseOAuth(useAuthAdapter({\n    ...commonOpts,\n    apiOrigin,\n    apiPath: config?.apiPath || AUTH_API_PREFIX,\n    // @todo 以下最好走adaptor处理，目前oauth模块没按adaptor接口设计\n    storage: config?.storage,\n    baseRequest: config?.baseRequest,\n    request: config?.request,\n    anonymousSignInFunc: config?.anonymousSignInFunc,\n    captchaOptions: config?.captchaOptions,\n    wxCloud: config?.wxCloud,\n    adapter,\n    onCredentialsError: onCredentialsError(commonOpts.eventBus),\n    headers: { 'X-SDK-Version': `@cloudbase/js-sdk/${config.sdkVersion}`, ...(config.headers || {}) },\n    detectSessionInUrl: config.detectSessionInUrl,\n    debug,\n  }),)\n\n  const authInstance = new Auth({\n    ...commonOpts,\n    region,\n    persistence: config.persistence,\n    debug,\n    cache:\n      cache || new CloudbaseCache({\n        persistence: config.persistence,\n        keys: { userInfoKey: `user_info_${env}` },\n        platformInfo: platform,\n      }),\n    runtime: runtime || 'web',\n    _fromApp: cloudbase,\n    oauthInstance,\n  })\n\n  // Initialize session with user info callback\n  // This handles OAuth callback URL detection and creates login state atomically\n  oauthInstance.initializeSession(async (data, error) => {\n    if (!data) return\n\n    if (data.type === OAUTH_TYPE.SIGN_IN) {\n      if (error) {\n        commonOpts.eventBus.fire(EVENTS.AUTH_STATE_CHANGED, {\n          event: AUTH_STATE_CHANGED_TYPE.SIGNED_IN,\n          info: { ...data, error },\n        })\n      } else if (data.user) {\n        // 使用已获取的 user 信息创建 LoginState，复用 createLoginState 逻辑\n        // 但跳过 refresh() 避免再次请求 API 导致死锁\n        authInstance.createLoginState({}, { userInfo: data.user })\n      }\n    } else if (data.type === OAUTH_TYPE.BIND_IDENTITY) {\n      commonOpts.eventBus.fire(EVENTS.AUTH_STATE_CHANGED, {\n        event: AUTH_STATE_CHANGED_TYPE.BIND_IDENTITY,\n        info: { ...data, error },\n      })\n    }\n  })\n\n  return { authInstance, oauthInstance }\n}\n\nconst NAMESPACE = 'auth'\n\nconst component: ICloudbaseComponent = {\n  name: COMPONENT_NAME,\n  namespace: NAMESPACE,\n  entity(config?: TInitAuthOptions) {\n    const auth = function (config?: TInitAuthOptions) {\n      if (this.authInstance && !config) {\n        // printWarn(ERRORS.INVALID_OPERATION, 'every cloudbase instance should has only one auth object')\n        return this.authInstance\n      }\n\n      config = config || {\n        region: '',\n        persistence: 'local',\n        apiPath: AUTH_API_PREFIX,\n      }\n      const { adapter } = this.platform\n      // 如不明确指定persistence则优先取各平台adapter首选，其次localStorage\n      const newPersistence = config.persistence || adapter.primaryStorage\n      if (newPersistence && newPersistence !== this.config.persistence) {\n        this.updateConfig({ persistence: newPersistence })\n      }\n\n      const { authInstance, oauthInstance } = generateAuthInstance(\n        {\n          wxCloud: this.config.wxCloud,\n          storage: this.config.storage,\n          ...config,\n          persistence: this.config.persistence,\n          i18n: this.config.i18n,\n          accessKey: this.config.accessKey,\n          useWxCloud: this.config.useWxCloud,\n          sdkVersion: this.version,\n          detectSessionInUrl: this.config.auth?.detectSessionInUrl,\n        },\n        {\n          env: this.config.env,\n          clientId: this.config.clientId,\n          apiOrigin: this.request.getBaseEndPoint(this.config.endPointMode || 'CLOUD_API'),\n          platform: this.platform,\n          cache: this.cache,\n          app: this,\n          debug: this.config.debug,\n        },\n      )\n\n      this.oauthInstance = oauthInstance\n\n      this.authInstance = authInstance\n\n      return this.authInstance\n    }\n\n    const authProto = auth.call(this, config)\n    Object.assign(auth, authProto)\n    Object.setPrototypeOf(auth, Object.getPrototypeOf(authProto))\n    this[NAMESPACE] = auth\n    return auth\n  },\n}\n\ntry {\n  // 尝试自动注册至全局变量cloudbase\n  // 此行为只在浏览器环境下有效\n  cloudbase.registerComponent(component)\n} catch (e) {}\n\nexport { UserInfo, Auth }\n/**\n * @api 手动注册至cloudbase app\n */\nexport function registerAuth(app: Pick<ICloudbase, 'registerComponent'>) {\n  try {\n    app.registerComponent(component)\n  } catch (e) {\n    console.warn(e)\n  }\n}\n"]}
|