@cloudbase/auth 3.1.9 → 3.1.10
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/index.d.ts +61 -61
- package/dist/cjs/index.js +1675 -1676
- package/dist/esm/index.d.ts +61 -61
- package/dist/esm/index.js +1675 -1676
- package/dist/miniprogram/index.js +1 -1
- package/package.json +5 -5
- package/src/index.ts +1615 -1639
package/dist/cjs/index.js
CHANGED
|
@@ -382,2086 +382,2086 @@ var Auth = (function (_super) {
|
|
|
382
382
|
_this.setAccessKey();
|
|
383
383
|
return _this;
|
|
384
384
|
}
|
|
385
|
-
Auth.prototype.
|
|
385
|
+
Auth.prototype.signInAnonymously = function (params) {
|
|
386
386
|
return __awaiter(this, void 0, void 0, function () {
|
|
387
|
-
|
|
388
|
-
|
|
387
|
+
var loginState, _a, _b, session, error_1;
|
|
388
|
+
return __generator(this, function (_c) {
|
|
389
|
+
switch (_c.label) {
|
|
390
|
+
case 0:
|
|
391
|
+
_c.trys.push([0, 4, , 5]);
|
|
392
|
+
return [4, this.oauthInstance.authApi.signInAnonymously(params)];
|
|
393
|
+
case 1:
|
|
394
|
+
_c.sent();
|
|
395
|
+
return [4, this.createLoginState()];
|
|
396
|
+
case 2:
|
|
397
|
+
loginState = _c.sent();
|
|
398
|
+
return [4, this.getSession()];
|
|
399
|
+
case 3:
|
|
400
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
401
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
402
|
+
case 4:
|
|
403
|
+
error_1 = _c.sent();
|
|
404
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_1) }];
|
|
405
|
+
case 5: return [2];
|
|
406
|
+
}
|
|
389
407
|
});
|
|
390
408
|
});
|
|
391
409
|
};
|
|
392
|
-
Auth.prototype.
|
|
410
|
+
Auth.prototype.signUp = function (params) {
|
|
393
411
|
return __awaiter(this, void 0, void 0, function () {
|
|
412
|
+
var verificationInfo_1, error_2;
|
|
413
|
+
var _this = this;
|
|
394
414
|
return __generator(this, function (_a) {
|
|
395
|
-
|
|
415
|
+
switch (_a.label) {
|
|
416
|
+
case 0:
|
|
417
|
+
if (!(params.phone_number || params.verification_code || params.verification_token || params.provider_token)) return [3, 2];
|
|
418
|
+
params.phone_number = this.formatPhone(params.phone_number);
|
|
419
|
+
return [4, this.oauthInstance.authApi.signUp(params)];
|
|
420
|
+
case 1:
|
|
421
|
+
_a.sent();
|
|
422
|
+
return [2, this.createLoginState()];
|
|
423
|
+
case 2:
|
|
424
|
+
_a.trys.push([2, 4, , 5]);
|
|
425
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
426
|
+
return [4, this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })];
|
|
427
|
+
case 3:
|
|
428
|
+
verificationInfo_1 = _a.sent();
|
|
429
|
+
return [2, {
|
|
430
|
+
data: {
|
|
431
|
+
verifyOtp: function (_a) {
|
|
432
|
+
var token = _a.token, _b = _a.messageId, messageId = _b === void 0 ? verificationInfo_1.verification_id : _b;
|
|
433
|
+
return __awaiter(_this, void 0, void 0, function () {
|
|
434
|
+
var verificationTokenRes, data, _c, _d, session, error_3;
|
|
435
|
+
return __generator(this, function (_e) {
|
|
436
|
+
switch (_e.label) {
|
|
437
|
+
case 0:
|
|
438
|
+
_e.trys.push([0, 8, , 9]);
|
|
439
|
+
return [4, this.verify({
|
|
440
|
+
verification_id: messageId || verificationInfo_1.verification_id,
|
|
441
|
+
verification_code: token,
|
|
442
|
+
})];
|
|
443
|
+
case 1:
|
|
444
|
+
verificationTokenRes = _e.sent();
|
|
445
|
+
if (!verificationInfo_1.is_user) return [3, 3];
|
|
446
|
+
return [4, this.signIn({
|
|
447
|
+
username: params.email || this.formatPhone(params.phone),
|
|
448
|
+
verification_token: verificationTokenRes.verification_token,
|
|
449
|
+
})];
|
|
450
|
+
case 2:
|
|
451
|
+
_e.sent();
|
|
452
|
+
return [3, 6];
|
|
453
|
+
case 3:
|
|
454
|
+
data = JSON.parse(JSON.stringify(params));
|
|
455
|
+
delete data.email;
|
|
456
|
+
delete data.phone;
|
|
457
|
+
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 }))];
|
|
458
|
+
case 4:
|
|
459
|
+
_e.sent();
|
|
460
|
+
return [4, this.createLoginState()];
|
|
461
|
+
case 5:
|
|
462
|
+
_e.sent();
|
|
463
|
+
_e.label = 6;
|
|
464
|
+
case 6: return [4, this.getSession()];
|
|
465
|
+
case 7:
|
|
466
|
+
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
467
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
468
|
+
case 8:
|
|
469
|
+
error_3 = _e.sent();
|
|
470
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_3) }];
|
|
471
|
+
case 9: return [2];
|
|
472
|
+
}
|
|
473
|
+
});
|
|
474
|
+
});
|
|
475
|
+
},
|
|
476
|
+
},
|
|
477
|
+
error: null,
|
|
478
|
+
}];
|
|
479
|
+
case 4:
|
|
480
|
+
error_2 = _a.sent();
|
|
481
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_2) }];
|
|
482
|
+
case 5: return [2];
|
|
483
|
+
}
|
|
396
484
|
});
|
|
397
485
|
});
|
|
398
486
|
};
|
|
399
|
-
Auth.prototype.
|
|
400
|
-
|
|
401
|
-
};
|
|
402
|
-
Auth.prototype.verify = function (params) {
|
|
487
|
+
Auth.prototype.signOut = function (params) {
|
|
488
|
+
var _a, _b;
|
|
403
489
|
return __awaiter(this, void 0, void 0, function () {
|
|
404
|
-
|
|
405
|
-
|
|
490
|
+
var userInfoKey, res, error_4;
|
|
491
|
+
return __generator(this, function (_c) {
|
|
492
|
+
switch (_c.label) {
|
|
493
|
+
case 0:
|
|
494
|
+
_c.trys.push([0, 3, , 4]);
|
|
495
|
+
userInfoKey = this.cache.keys.userInfoKey;
|
|
496
|
+
return [4, this.oauthInstance.authApi.signOut(params)];
|
|
497
|
+
case 1:
|
|
498
|
+
res = _c.sent();
|
|
499
|
+
return [4, this.cache.removeStoreAsync(userInfoKey)];
|
|
500
|
+
case 2:
|
|
501
|
+
_c.sent();
|
|
502
|
+
this.setAccessKey();
|
|
503
|
+
(_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 });
|
|
504
|
+
(_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 });
|
|
505
|
+
return [2, __assign(__assign({}, res), { data: {}, error: null })];
|
|
506
|
+
case 3:
|
|
507
|
+
error_4 = _c.sent();
|
|
508
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_4) }];
|
|
509
|
+
case 4: return [2];
|
|
510
|
+
}
|
|
406
511
|
});
|
|
407
512
|
});
|
|
408
513
|
};
|
|
409
|
-
Auth.prototype.
|
|
514
|
+
Auth.prototype.onAuthStateChange = function (callback) {
|
|
515
|
+
var _this = this;
|
|
516
|
+
if (!this.hasListenerSetUp) {
|
|
517
|
+
this.setupListeners();
|
|
518
|
+
this.hasListenerSetUp = true;
|
|
519
|
+
}
|
|
520
|
+
var id = Math.random().toString(36);
|
|
521
|
+
if (!this.listeners.has(id)) {
|
|
522
|
+
this.listeners.set(id, new Set());
|
|
523
|
+
}
|
|
524
|
+
this.listeners.get(id).add(callback);
|
|
525
|
+
var subscription = {
|
|
526
|
+
id: id,
|
|
527
|
+
callback: callback,
|
|
528
|
+
unsubscribe: function () {
|
|
529
|
+
var callbacks = _this.listeners.get(id);
|
|
530
|
+
if (callbacks) {
|
|
531
|
+
callbacks.delete(callback);
|
|
532
|
+
if (callbacks.size === 0) {
|
|
533
|
+
_this.listeners.delete(id);
|
|
534
|
+
}
|
|
535
|
+
}
|
|
536
|
+
},
|
|
537
|
+
};
|
|
538
|
+
return {
|
|
539
|
+
data: { subscription: subscription },
|
|
540
|
+
};
|
|
541
|
+
};
|
|
542
|
+
Auth.prototype.signInWithPassword = function (params) {
|
|
543
|
+
var _a, _b;
|
|
410
544
|
return __awaiter(this, void 0, void 0, function () {
|
|
411
|
-
|
|
412
|
-
|
|
413
|
-
|
|
545
|
+
var _c, _d, session, error_5, authError;
|
|
546
|
+
return __generator(this, function (_e) {
|
|
547
|
+
switch (_e.label) {
|
|
548
|
+
case 0:
|
|
549
|
+
_e.trys.push([0, 3, , 4]);
|
|
550
|
+
this.validateAtLeastOne(params, [['username'], ['email'], ['phone']], 'You must provide either username, email, or phone');
|
|
551
|
+
this.validateParams(params, {
|
|
552
|
+
password: { required: true, message: 'Password is required' },
|
|
553
|
+
});
|
|
554
|
+
return [4, this.signIn(__assign({ username: params.username || params.email || this.formatPhone(params.phone), password: params.password }, (params.is_encrypt ? { isEncrypt: true, version: 'v2' } : {})))];
|
|
555
|
+
case 1:
|
|
556
|
+
_e.sent();
|
|
557
|
+
return [4, this.getSession()];
|
|
558
|
+
case 2:
|
|
559
|
+
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
560
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
561
|
+
case 3:
|
|
562
|
+
error_5 = _e.sent();
|
|
563
|
+
authError = new oauth_1.AuthError(error_5);
|
|
564
|
+
if (((_a = authError.message) === null || _a === void 0 ? void 0 : _a.includes('密码不正确')) || ((_b = authError.message) === null || _b === void 0 ? void 0 : _b.includes('password'))) {
|
|
565
|
+
console.warn('[CloudBase Auth] 登录失败提示:\n'
|
|
566
|
+
+ ' 1. 请确认用户名/邮箱/手机号是否正确\n'
|
|
567
|
+
+ ' 2. 请确认密码是否正确\n'
|
|
568
|
+
+ ' 3. 如果用户不存在,请先通过 auth.signUp() 注册用户,或在云开发控制台手动创建用户\n'
|
|
569
|
+
+ ' 4. 确认当前环境已开启对应的登录方式(控制台 → 环境 → 登录授权)');
|
|
570
|
+
}
|
|
571
|
+
return [2, { data: {}, error: authError }];
|
|
572
|
+
case 4: return [2];
|
|
414
573
|
}
|
|
415
|
-
return [2, this.oauthInstance.authApi.getVerification(params, options)];
|
|
416
574
|
});
|
|
417
575
|
});
|
|
418
576
|
};
|
|
419
|
-
|
|
420
|
-
get: function () {
|
|
421
|
-
if (this.cache.mode === 'async') {
|
|
422
|
-
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getCurrentUser instead');
|
|
423
|
-
return;
|
|
424
|
-
}
|
|
425
|
-
var loginState = this.hasLoginState();
|
|
426
|
-
if (loginState) {
|
|
427
|
-
return loginState.user || null;
|
|
428
|
-
}
|
|
429
|
-
return null;
|
|
430
|
-
},
|
|
431
|
-
enumerable: false,
|
|
432
|
-
configurable: true
|
|
433
|
-
});
|
|
434
|
-
Auth.prototype.getCurrentUser = function () {
|
|
577
|
+
Auth.prototype.signInWithIdToken = function (params) {
|
|
435
578
|
return __awaiter(this, void 0, void 0, function () {
|
|
436
|
-
var
|
|
437
|
-
return __generator(this, function (
|
|
438
|
-
switch (
|
|
439
|
-
case 0:
|
|
579
|
+
var _a, _b, session, error_6;
|
|
580
|
+
return __generator(this, function (_c) {
|
|
581
|
+
switch (_c.label) {
|
|
582
|
+
case 0:
|
|
583
|
+
_c.trys.push([0, 3, , 4]);
|
|
584
|
+
this.validateParams(params, {
|
|
585
|
+
token: { required: true, message: 'Token is required' },
|
|
586
|
+
});
|
|
587
|
+
return [4, this.signInWithProvider({
|
|
588
|
+
provider_token: params.token,
|
|
589
|
+
})];
|
|
440
590
|
case 1:
|
|
441
|
-
|
|
442
|
-
|
|
443
|
-
userInfo = loginState.user.getLocalUserInfo();
|
|
444
|
-
return [4, loginState.user.checkLocalInfoAsync()];
|
|
591
|
+
_c.sent();
|
|
592
|
+
return [4, this.getSession()];
|
|
445
593
|
case 2:
|
|
446
|
-
_a.sent();
|
|
447
|
-
return [2,
|
|
448
|
-
case 3:
|
|
594
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
595
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
596
|
+
case 3:
|
|
597
|
+
error_6 = _c.sent();
|
|
598
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_6) }];
|
|
599
|
+
case 4: return [2];
|
|
449
600
|
}
|
|
450
601
|
});
|
|
451
602
|
});
|
|
452
603
|
};
|
|
453
|
-
Auth.prototype.
|
|
454
|
-
var
|
|
604
|
+
Auth.prototype.signInWithOtp = function (params) {
|
|
605
|
+
var _a, _b;
|
|
455
606
|
return __awaiter(this, void 0, void 0, function () {
|
|
456
|
-
var
|
|
607
|
+
var verificationInfo_2, error_7;
|
|
457
608
|
var _this = this;
|
|
458
609
|
return __generator(this, function (_c) {
|
|
459
610
|
switch (_c.label) {
|
|
460
611
|
case 0:
|
|
461
|
-
if (
|
|
462
|
-
|
|
612
|
+
if (((_a = params.options) === null || _a === void 0 ? void 0 : _a.shouldCreateUser) === undefined || !!((_b = params.options) === null || _b === void 0 ? void 0 : _b.shouldCreateUser)) {
|
|
613
|
+
return [2, this.signUp({
|
|
614
|
+
email: params.email,
|
|
615
|
+
phone: params.phone,
|
|
616
|
+
})];
|
|
463
617
|
}
|
|
464
|
-
|
|
465
|
-
|
|
466
|
-
|
|
467
|
-
|
|
468
|
-
|
|
469
|
-
|
|
470
|
-
|
|
471
|
-
|
|
472
|
-
|
|
473
|
-
|
|
474
|
-
|
|
475
|
-
|
|
476
|
-
|
|
477
|
-
|
|
478
|
-
|
|
479
|
-
|
|
480
|
-
|
|
481
|
-
|
|
482
|
-
|
|
483
|
-
|
|
484
|
-
|
|
485
|
-
|
|
486
|
-
throw result;
|
|
487
|
-
}
|
|
488
|
-
return [4, this.oauthInstance.authApi.signInAnonymously({ provider_token: result.provider_token }, useWxCloud)];
|
|
489
|
-
case 3:
|
|
490
|
-
credentials = _a.sent();
|
|
491
|
-
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
492
|
-
throw credentials;
|
|
493
|
-
}
|
|
494
|
-
return [3, 5];
|
|
495
|
-
case 4:
|
|
496
|
-
error_1 = _a.sent();
|
|
497
|
-
throw error_1;
|
|
498
|
-
case 5: return [2];
|
|
499
|
-
}
|
|
500
|
-
});
|
|
501
|
-
}); };
|
|
502
|
-
return [4, new Promise(function (resolve, reject) {
|
|
503
|
-
wx.login({
|
|
504
|
-
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
505
|
-
var error_2;
|
|
506
|
-
return __generator(this, function (_a) {
|
|
507
|
-
switch (_a.label) {
|
|
508
|
-
case 0:
|
|
509
|
-
_a.trys.push([0, 2, , 3]);
|
|
510
|
-
return [4, mainFunc(res.code)];
|
|
511
|
-
case 1:
|
|
512
|
-
_a.sent();
|
|
513
|
-
resolve(true);
|
|
514
|
-
return [3, 3];
|
|
515
|
-
case 2:
|
|
516
|
-
error_2 = _a.sent();
|
|
517
|
-
reject(error_2);
|
|
518
|
-
return [3, 3];
|
|
519
|
-
case 3: return [2];
|
|
520
|
-
}
|
|
618
|
+
_c.label = 1;
|
|
619
|
+
case 1:
|
|
620
|
+
_c.trys.push([1, 3, , 4]);
|
|
621
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
622
|
+
return [4, this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })];
|
|
623
|
+
case 2:
|
|
624
|
+
verificationInfo_2 = _c.sent();
|
|
625
|
+
return [2, {
|
|
626
|
+
data: {
|
|
627
|
+
user: null,
|
|
628
|
+
session: null,
|
|
629
|
+
verifyOtp: function (_a) {
|
|
630
|
+
var token = _a.token, _b = _a.messageId, messageId = _b === void 0 ? verificationInfo_2.verification_id : _b;
|
|
631
|
+
return __awaiter(_this, void 0, void 0, function () {
|
|
632
|
+
return __generator(this, function (_c) {
|
|
633
|
+
return [2, this.verifyOtp({
|
|
634
|
+
email: params.email,
|
|
635
|
+
phone: params.phone,
|
|
636
|
+
token: token,
|
|
637
|
+
messageId: messageId,
|
|
638
|
+
})];
|
|
639
|
+
});
|
|
521
640
|
});
|
|
522
|
-
}); },
|
|
523
|
-
fail: function (res) {
|
|
524
|
-
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
525
|
-
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
526
|
-
reject(error);
|
|
527
641
|
},
|
|
528
|
-
}
|
|
529
|
-
|
|
530
|
-
|
|
531
|
-
|
|
532
|
-
|
|
642
|
+
},
|
|
643
|
+
error: null,
|
|
644
|
+
}];
|
|
645
|
+
case 3:
|
|
646
|
+
error_7 = _c.sent();
|
|
647
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_7) }];
|
|
648
|
+
case 4: return [2];
|
|
533
649
|
}
|
|
534
650
|
});
|
|
535
651
|
});
|
|
536
652
|
};
|
|
537
|
-
Auth.prototype.
|
|
653
|
+
Auth.prototype.verifyOAuth = function (params) {
|
|
538
654
|
return __awaiter(this, void 0, void 0, function () {
|
|
539
|
-
var
|
|
540
|
-
var _this = this;
|
|
655
|
+
var data, code, state, cacheData, provider, token, res, localSearch, error_8;
|
|
541
656
|
return __generator(this, function (_a) {
|
|
542
657
|
switch (_a.label) {
|
|
543
658
|
case 0:
|
|
544
|
-
|
|
545
|
-
|
|
659
|
+
data = {};
|
|
660
|
+
_a.label = 1;
|
|
661
|
+
case 1:
|
|
662
|
+
_a.trys.push([1, 7, , 8]);
|
|
663
|
+
code = (params === null || params === void 0 ? void 0 : params.code) || utilities_2.utils.getQuery('code');
|
|
664
|
+
state = (params === null || params === void 0 ? void 0 : params.state) || utilities_2.utils.getQuery('state');
|
|
665
|
+
if (!code) {
|
|
666
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'Code is required' }) }];
|
|
546
667
|
}
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
552
|
-
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
|
|
559
|
-
|
|
560
|
-
|
|
561
|
-
|
|
562
|
-
|
|
563
|
-
|
|
564
|
-
|
|
565
|
-
|
|
566
|
-
|
|
567
|
-
|
|
568
|
-
|
|
569
|
-
|
|
570
|
-
|
|
571
|
-
|
|
572
|
-
|
|
573
|
-
|
|
574
|
-
|
|
575
|
-
|
|
576
|
-
|
|
577
|
-
|
|
578
|
-
|
|
579
|
-
|
|
580
|
-
|
|
581
|
-
|
|
582
|
-
|
|
583
|
-
|
|
584
|
-
|
|
585
|
-
|
|
586
|
-
|
|
587
|
-
|
|
588
|
-
|
|
589
|
-
|
|
590
|
-
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
599
|
-
|
|
600
|
-
|
|
601
|
-
|
|
602
|
-
|
|
603
|
-
|
|
604
|
-
|
|
605
|
-
|
|
606
|
-
|
|
607
|
-
|
|
668
|
+
if (!state) {
|
|
669
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'State is required' }) }];
|
|
670
|
+
}
|
|
671
|
+
cacheData = (0, utils_1.getBrowserSession)(state);
|
|
672
|
+
data.type = cacheData === null || cacheData === void 0 ? void 0 : cacheData.type;
|
|
673
|
+
provider = (params === null || params === void 0 ? void 0 : params.provider) || (cacheData === null || cacheData === void 0 ? void 0 : cacheData.provider) || utilities_2.utils.getQuery('provider');
|
|
674
|
+
if (!provider) {
|
|
675
|
+
return [2, { data: data, error: new oauth_1.AuthError({ message: 'Provider is required' }) }];
|
|
676
|
+
}
|
|
677
|
+
return [4, this.grantProviderToken({
|
|
678
|
+
provider_id: provider,
|
|
679
|
+
provider_redirect_uri: location.origin + location.pathname,
|
|
680
|
+
provider_code: code,
|
|
681
|
+
})];
|
|
682
|
+
case 2:
|
|
683
|
+
token = (_a.sent()).provider_token;
|
|
684
|
+
res = void 0;
|
|
685
|
+
if (!(cacheData.type === oauth_1.OAUTH_TYPE.BIND_IDENTITY)) return [3, 4];
|
|
686
|
+
return [4, this.oauthInstance.authApi.toBindIdentity({ provider_token: token, provider: provider, fireEvent: true })];
|
|
687
|
+
case 3:
|
|
688
|
+
res = _a.sent();
|
|
689
|
+
return [3, 6];
|
|
690
|
+
case 4: return [4, this.signInWithIdToken({
|
|
691
|
+
token: token,
|
|
692
|
+
})];
|
|
693
|
+
case 5:
|
|
694
|
+
res = _a.sent();
|
|
695
|
+
res.data = __assign(__assign({}, data), res.data);
|
|
696
|
+
_a.label = 6;
|
|
697
|
+
case 6:
|
|
698
|
+
localSearch = new URLSearchParams(location === null || location === void 0 ? void 0 : location.search);
|
|
699
|
+
localSearch.delete('code');
|
|
700
|
+
localSearch.delete('state');
|
|
701
|
+
res.data.redirectUrl = (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);
|
|
702
|
+
(0, utils_1.removeBrowserSession)(state);
|
|
703
|
+
return [2, res];
|
|
704
|
+
case 7:
|
|
705
|
+
error_8 = _a.sent();
|
|
706
|
+
return [2, { data: data, error: new oauth_1.AuthError(error_8) }];
|
|
707
|
+
case 8: return [2];
|
|
708
|
+
}
|
|
709
|
+
});
|
|
710
|
+
});
|
|
711
|
+
};
|
|
712
|
+
Auth.prototype.signInWithOAuth = function (params) {
|
|
713
|
+
var _a, _b, _c, _d, _e;
|
|
714
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
715
|
+
var href, urlObject, provider_redirect_uri, state, uri, decodedUri, finalUri, url_1, error_9;
|
|
716
|
+
return __generator(this, function (_f) {
|
|
717
|
+
switch (_f.label) {
|
|
718
|
+
case 0:
|
|
719
|
+
_f.trys.push([0, 2, , 3]);
|
|
720
|
+
this.validateParams(params, {
|
|
721
|
+
provider: { required: true, message: 'Provider is required' },
|
|
722
|
+
});
|
|
723
|
+
href = ((_a = params.options) === null || _a === void 0 ? void 0 : _a.redirectTo) || location.href;
|
|
724
|
+
urlObject = new URL(href);
|
|
725
|
+
provider_redirect_uri = urlObject.origin + urlObject.pathname;
|
|
726
|
+
state = ((_b = params.options) === null || _b === void 0 ? void 0 : _b.state) || "prd-".concat(params.provider, "-").concat(Math.random().toString(36)
|
|
727
|
+
.slice(2));
|
|
728
|
+
return [4, this.genProviderRedirectUri({
|
|
729
|
+
provider_id: params.provider,
|
|
730
|
+
provider_redirect_uri: provider_redirect_uri,
|
|
731
|
+
state: state,
|
|
608
732
|
})];
|
|
609
733
|
case 1:
|
|
610
|
-
|
|
611
|
-
|
|
734
|
+
uri = (_f.sent()).uri;
|
|
735
|
+
decodedUri = decodeURIComponent(uri);
|
|
736
|
+
finalUri = decodedUri;
|
|
737
|
+
if ((_c = params.options) === null || _c === void 0 ? void 0 : _c.queryParams) {
|
|
738
|
+
url_1 = new URL(decodedUri);
|
|
739
|
+
Object.entries(params.options.queryParams).forEach(function (_a) {
|
|
740
|
+
var key = _a[0], value = _a[1];
|
|
741
|
+
url_1.searchParams.set(key, value);
|
|
742
|
+
});
|
|
743
|
+
finalUri = url_1.toString();
|
|
744
|
+
}
|
|
745
|
+
(0, utils_1.saveToBrowserSession)(state, {
|
|
746
|
+
provider: params.provider,
|
|
747
|
+
search: urlObject.search,
|
|
748
|
+
hash: urlObject.hash,
|
|
749
|
+
type: ((_d = params.options) === null || _d === void 0 ? void 0 : _d.type) || oauth_1.OAUTH_TYPE.SIGN_IN,
|
|
750
|
+
});
|
|
751
|
+
if (isBrowser() && !((_e = params.options) === null || _e === void 0 ? void 0 : _e.skipBrowserRedirect)) {
|
|
752
|
+
window.location.assign(finalUri);
|
|
753
|
+
}
|
|
754
|
+
return [2, { data: { url: finalUri, provider: params.provider }, error: null }];
|
|
755
|
+
case 2:
|
|
756
|
+
error_9 = _f.sent();
|
|
757
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_9) }];
|
|
758
|
+
case 3: return [2];
|
|
612
759
|
}
|
|
613
760
|
});
|
|
614
761
|
});
|
|
615
762
|
};
|
|
616
|
-
Auth.prototype.
|
|
763
|
+
Auth.prototype.getClaims = function () {
|
|
764
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
765
|
+
var accessToken, parsedToken, error_10;
|
|
766
|
+
return __generator(this, function (_a) {
|
|
767
|
+
switch (_a.label) {
|
|
768
|
+
case 0:
|
|
769
|
+
_a.trys.push([0, 2, , 3]);
|
|
770
|
+
return [4, this.getAccessToken()];
|
|
771
|
+
case 1:
|
|
772
|
+
accessToken = (_a.sent()).accessToken;
|
|
773
|
+
parsedToken = (0, oauth_1.weAppJwtDecodeAll)(accessToken);
|
|
774
|
+
return [2, { data: parsedToken, error: null }];
|
|
775
|
+
case 2:
|
|
776
|
+
error_10 = _a.sent();
|
|
777
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_10) }];
|
|
778
|
+
case 3: return [2];
|
|
779
|
+
}
|
|
780
|
+
});
|
|
781
|
+
});
|
|
782
|
+
};
|
|
783
|
+
Auth.prototype.resetPasswordForEmail = function (emailOrPhone, options) {
|
|
617
784
|
return __awaiter(this, void 0, void 0, function () {
|
|
618
|
-
var
|
|
785
|
+
var redirectTo_1, isEmail_1, verificationParams, formattedPhone, verificationInfo_3, error_11;
|
|
619
786
|
var _this = this;
|
|
620
787
|
return __generator(this, function (_a) {
|
|
621
788
|
switch (_a.label) {
|
|
622
789
|
case 0:
|
|
623
|
-
|
|
624
|
-
|
|
790
|
+
_a.trys.push([0, 2, , 3]);
|
|
791
|
+
this.validateParams({ emailOrPhone: emailOrPhone }, {
|
|
792
|
+
emailOrPhone: { required: true, message: 'Email or phone is required' },
|
|
793
|
+
});
|
|
794
|
+
redirectTo_1 = (options || {}).redirectTo;
|
|
795
|
+
isEmail_1 = emailOrPhone.includes('@');
|
|
796
|
+
verificationParams = void 0;
|
|
797
|
+
if (isEmail_1) {
|
|
798
|
+
verificationParams = { email: emailOrPhone };
|
|
625
799
|
}
|
|
626
|
-
|
|
627
|
-
|
|
628
|
-
|
|
629
|
-
|
|
630
|
-
|
|
631
|
-
|
|
632
|
-
|
|
633
|
-
|
|
634
|
-
|
|
635
|
-
|
|
800
|
+
else {
|
|
801
|
+
formattedPhone = this.formatPhone(emailOrPhone);
|
|
802
|
+
verificationParams = { phone_number: formattedPhone };
|
|
803
|
+
}
|
|
804
|
+
return [4, this.getVerification(verificationParams)];
|
|
805
|
+
case 1:
|
|
806
|
+
verificationInfo_3 = _a.sent();
|
|
807
|
+
return [2, {
|
|
808
|
+
data: {
|
|
809
|
+
updateUser: function (attributes) { return __awaiter(_this, void 0, void 0, function () {
|
|
810
|
+
var verificationTokenRes, res, error_12;
|
|
811
|
+
var _a;
|
|
812
|
+
return __generator(this, function (_b) {
|
|
813
|
+
switch (_b.label) {
|
|
636
814
|
case 0:
|
|
637
|
-
|
|
638
|
-
|
|
815
|
+
this.validateParams(attributes, {
|
|
816
|
+
nonce: { required: true, message: 'Nonce is required' },
|
|
817
|
+
password: { required: true, message: 'Password is required' },
|
|
818
|
+
});
|
|
819
|
+
_b.label = 1;
|
|
639
820
|
case 1:
|
|
640
|
-
|
|
641
|
-
return [4, this.
|
|
642
|
-
|
|
643
|
-
|
|
644
|
-
provider_params: {
|
|
645
|
-
provider_code_type: 'union_id',
|
|
646
|
-
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
647
|
-
},
|
|
821
|
+
_b.trys.push([1, 5, , 6]);
|
|
822
|
+
return [4, this.verify({
|
|
823
|
+
verification_id: verificationInfo_3.verification_id,
|
|
824
|
+
verification_code: attributes.nonce,
|
|
648
825
|
})];
|
|
649
826
|
case 2:
|
|
650
|
-
|
|
651
|
-
|
|
652
|
-
|
|
653
|
-
|
|
654
|
-
|
|
655
|
-
|
|
656
|
-
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
657
|
-
provider_id: providerId,
|
|
658
|
-
provider_token: providerToken,
|
|
827
|
+
verificationTokenRes = _b.sent();
|
|
828
|
+
return [4, this.oauthInstance.authApi.resetPassword({
|
|
829
|
+
email: isEmail_1 ? emailOrPhone : undefined,
|
|
830
|
+
phone_number: !isEmail_1 ? emailOrPhone : undefined,
|
|
831
|
+
new_password: attributes.password,
|
|
832
|
+
verification_token: verificationTokenRes.verification_token,
|
|
659
833
|
})];
|
|
660
834
|
case 3:
|
|
661
|
-
|
|
662
|
-
|
|
663
|
-
|
|
664
|
-
|
|
665
|
-
|
|
666
|
-
|
|
667
|
-
|
|
835
|
+
_b.sent();
|
|
836
|
+
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, {
|
|
837
|
+
event: oauth_1.AUTH_STATE_CHANGED_TYPE.PASSWORD_RECOVERY,
|
|
838
|
+
});
|
|
839
|
+
return [4, this.signInWithPassword({
|
|
840
|
+
email: isEmail_1 ? emailOrPhone : undefined,
|
|
841
|
+
phone: !isEmail_1 ? emailOrPhone : undefined,
|
|
842
|
+
password: attributes.password,
|
|
843
|
+
})];
|
|
668
844
|
case 4:
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
|
|
672
|
-
|
|
845
|
+
res = _b.sent();
|
|
846
|
+
if (redirectTo_1 && isBrowser()) {
|
|
847
|
+
window.location.assign(redirectTo_1);
|
|
848
|
+
}
|
|
849
|
+
return [2, res];
|
|
850
|
+
case 5:
|
|
851
|
+
error_12 = _b.sent();
|
|
852
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_12) }];
|
|
853
|
+
case 6: return [2];
|
|
673
854
|
}
|
|
674
855
|
});
|
|
675
856
|
}); },
|
|
676
|
-
|
|
677
|
-
|
|
678
|
-
|
|
679
|
-
reject(error);
|
|
680
|
-
},
|
|
681
|
-
});
|
|
682
|
-
})];
|
|
857
|
+
},
|
|
858
|
+
error: null,
|
|
859
|
+
}];
|
|
683
860
|
case 2:
|
|
684
|
-
_a.sent();
|
|
685
|
-
return [
|
|
686
|
-
case 3:
|
|
687
|
-
error_5 = _a.sent();
|
|
688
|
-
throw error_5;
|
|
689
|
-
case 4: return [2, this.createLoginState()];
|
|
861
|
+
error_11 = _a.sent();
|
|
862
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_11) }];
|
|
863
|
+
case 3: return [2];
|
|
690
864
|
}
|
|
691
865
|
});
|
|
692
866
|
});
|
|
693
867
|
};
|
|
694
|
-
Auth.prototype.
|
|
695
|
-
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;
|
|
868
|
+
Auth.prototype.resetPasswordForOld = function (params) {
|
|
696
869
|
return __awaiter(this, void 0, void 0, function () {
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
|
|
700
|
-
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
|
|
705
|
-
|
|
706
|
-
|
|
707
|
-
|
|
708
|
-
|
|
870
|
+
var _a, _b, session, error_13;
|
|
871
|
+
return __generator(this, function (_c) {
|
|
872
|
+
switch (_c.label) {
|
|
873
|
+
case 0:
|
|
874
|
+
_c.trys.push([0, 3, , 4]);
|
|
875
|
+
return [4, this.oauthInstance.authApi.updatePasswordByOld({
|
|
876
|
+
old_password: params.old_password,
|
|
877
|
+
new_password: params.new_password,
|
|
878
|
+
})];
|
|
879
|
+
case 1:
|
|
880
|
+
_c.sent();
|
|
881
|
+
return [4, this.getSession()];
|
|
882
|
+
case 2:
|
|
883
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
884
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
885
|
+
case 3:
|
|
886
|
+
error_13 = _c.sent();
|
|
887
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_13) }];
|
|
888
|
+
case 4: return [2];
|
|
709
889
|
}
|
|
710
|
-
return [2];
|
|
711
890
|
});
|
|
712
891
|
});
|
|
713
892
|
};
|
|
714
|
-
Auth.prototype.
|
|
715
|
-
var _b = _a.verificationInfo, verificationInfo = _b === void 0 ? { verification_id: '', is_user: false } : _b, _c = _a.verificationCode, verificationCode = _c === void 0 ? '' : _c, _d = _a.bindInfo, bindInfo = _d === void 0 ? undefined : _d, _e = _a.email, email = _e === void 0 ? '' : _e;
|
|
893
|
+
Auth.prototype.verifyOtp = function (params) {
|
|
716
894
|
return __awaiter(this, void 0, void 0, function () {
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
895
|
+
var type, _a, _b, session, error_14;
|
|
896
|
+
return __generator(this, function (_c) {
|
|
897
|
+
switch (_c.label) {
|
|
898
|
+
case 0:
|
|
899
|
+
_c.trys.push([0, 6, , 7]);
|
|
900
|
+
type = params.type;
|
|
901
|
+
this.validateParams(params, {
|
|
902
|
+
token: { required: true, message: 'Token is required' },
|
|
903
|
+
messageId: { required: true, message: 'messageId is required' },
|
|
904
|
+
});
|
|
905
|
+
if (!['phone_change', 'email_change'].includes(type)) return [3, 2];
|
|
906
|
+
return [4, this.verify({
|
|
907
|
+
verification_id: params.messageId,
|
|
908
|
+
verification_code: params.token,
|
|
909
|
+
})];
|
|
910
|
+
case 1:
|
|
911
|
+
_c.sent();
|
|
912
|
+
return [3, 4];
|
|
913
|
+
case 2: return [4, this.signInWithUsername({
|
|
914
|
+
verificationInfo: { verification_id: params.messageId, is_user: true },
|
|
915
|
+
verificationCode: params.token,
|
|
916
|
+
username: params.email || this.formatPhone(params.phone) || '',
|
|
917
|
+
loginType: params.email ? 'email' : 'phone',
|
|
725
918
|
})];
|
|
919
|
+
case 3:
|
|
920
|
+
_c.sent();
|
|
921
|
+
_c.label = 4;
|
|
922
|
+
case 4: return [4, this.getSession()];
|
|
923
|
+
case 5:
|
|
924
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
925
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
926
|
+
case 6:
|
|
927
|
+
error_14 = _c.sent();
|
|
928
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_14) }];
|
|
929
|
+
case 7: return [2];
|
|
726
930
|
}
|
|
727
|
-
catch (error) {
|
|
728
|
-
throw error;
|
|
729
|
-
}
|
|
730
|
-
return [2];
|
|
731
931
|
});
|
|
732
932
|
});
|
|
733
933
|
};
|
|
734
|
-
Auth.prototype.
|
|
735
|
-
this.oauthInstance.authApi.setCustomSignFunc(getTickFn);
|
|
736
|
-
};
|
|
737
|
-
Auth.prototype.signIn = function (params) {
|
|
934
|
+
Auth.prototype.getSession = function () {
|
|
738
935
|
return __awaiter(this, void 0, void 0, function () {
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
936
|
+
var credentials, _a, _b, user, error_15;
|
|
937
|
+
return __generator(this, function (_c) {
|
|
938
|
+
switch (_c.label) {
|
|
939
|
+
case 0:
|
|
940
|
+
_c.trys.push([0, 3, , 4]);
|
|
941
|
+
return [4, this.oauthInstance.oauth2client.getCredentials()];
|
|
742
942
|
case 1:
|
|
743
|
-
|
|
744
|
-
|
|
943
|
+
credentials = _c.sent();
|
|
944
|
+
if (!credentials || credentials.scope === 'accessKey') {
|
|
945
|
+
return [2, { data: { session: null }, error: null }];
|
|
946
|
+
}
|
|
947
|
+
return [4, this.getUser()];
|
|
948
|
+
case 2:
|
|
949
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
950
|
+
return [2, { data: { session: __assign(__assign({}, credentials), { user: user }), user: user }, error: null }];
|
|
951
|
+
case 3:
|
|
952
|
+
error_15 = _c.sent();
|
|
953
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_15) }];
|
|
954
|
+
case 4: return [2];
|
|
745
955
|
}
|
|
746
956
|
});
|
|
747
957
|
});
|
|
748
958
|
};
|
|
749
|
-
Auth.prototype.
|
|
959
|
+
Auth.prototype.refreshSession = function (refresh_token) {
|
|
750
960
|
return __awaiter(this, void 0, void 0, function () {
|
|
751
|
-
|
|
752
|
-
|
|
961
|
+
var credentials, newTokens, _a, _b, user, error_16;
|
|
962
|
+
return __generator(this, function (_c) {
|
|
963
|
+
switch (_c.label) {
|
|
964
|
+
case 0:
|
|
965
|
+
_c.trys.push([0, 4, , 5]);
|
|
966
|
+
return [4, this.oauthInstance.oauth2client.localCredentials.getCredentials()];
|
|
967
|
+
case 1:
|
|
968
|
+
credentials = _c.sent();
|
|
969
|
+
credentials.refresh_token = refresh_token || credentials.refresh_token;
|
|
970
|
+
return [4, this.oauthInstance.oauth2client.refreshToken(credentials)];
|
|
971
|
+
case 2:
|
|
972
|
+
newTokens = _c.sent();
|
|
973
|
+
return [4, this.getUser()];
|
|
974
|
+
case 3:
|
|
975
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
976
|
+
return [2, { data: { user: user, session: __assign(__assign({}, newTokens), { user: user }) }, error: null }];
|
|
977
|
+
case 4:
|
|
978
|
+
error_16 = _c.sent();
|
|
979
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_16) }];
|
|
980
|
+
case 5: return [2];
|
|
981
|
+
}
|
|
753
982
|
});
|
|
754
983
|
});
|
|
755
984
|
};
|
|
756
|
-
Auth.prototype.
|
|
985
|
+
Auth.prototype.getUser = function () {
|
|
757
986
|
return __awaiter(this, void 0, void 0, function () {
|
|
758
|
-
var
|
|
759
|
-
return __generator(this, function (
|
|
760
|
-
switch (
|
|
987
|
+
var user, _a, error_17;
|
|
988
|
+
return __generator(this, function (_b) {
|
|
989
|
+
switch (_b.label) {
|
|
761
990
|
case 0:
|
|
762
|
-
|
|
763
|
-
|
|
764
|
-
|
|
765
|
-
return [4, this.oauthInstance.authApi.checkIfUserExist({ username: username })];
|
|
991
|
+
_b.trys.push([0, 2, , 3]);
|
|
992
|
+
_a = this.convertToUser;
|
|
993
|
+
return [4, this.getCurrentUser()];
|
|
766
994
|
case 1:
|
|
767
|
-
|
|
768
|
-
return [2,
|
|
995
|
+
user = _a.apply(this, [_b.sent()]);
|
|
996
|
+
return [2, { data: { user: user }, error: null }];
|
|
997
|
+
case 2:
|
|
998
|
+
error_17 = _b.sent();
|
|
999
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_17) }];
|
|
1000
|
+
case 3: return [2];
|
|
769
1001
|
}
|
|
770
1002
|
});
|
|
771
1003
|
});
|
|
772
1004
|
};
|
|
773
|
-
Auth.prototype.
|
|
774
|
-
var _a;
|
|
775
|
-
if (this.cache.mode === 'async') {
|
|
776
|
-
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getLoginState instead');
|
|
777
|
-
return;
|
|
778
|
-
}
|
|
779
|
-
var oauthLoginState = (_a = this.oauthInstance) === null || _a === void 0 ? void 0 : _a.authApi.hasLoginStateSync();
|
|
780
|
-
if (oauthLoginState) {
|
|
781
|
-
var loginState = new LoginState({
|
|
782
|
-
envId: this.config.env,
|
|
783
|
-
cache: this.cache,
|
|
784
|
-
oauthInstance: this.oauthInstance,
|
|
785
|
-
});
|
|
786
|
-
return loginState;
|
|
787
|
-
}
|
|
788
|
-
return null;
|
|
789
|
-
};
|
|
790
|
-
Auth.prototype.getLoginState = function () {
|
|
1005
|
+
Auth.prototype.refreshUser = function () {
|
|
791
1006
|
return __awaiter(this, void 0, void 0, function () {
|
|
792
|
-
var
|
|
793
|
-
return __generator(this, function (
|
|
794
|
-
switch (
|
|
1007
|
+
var _a, _b, session, error_18;
|
|
1008
|
+
return __generator(this, function (_c) {
|
|
1009
|
+
switch (_c.label) {
|
|
795
1010
|
case 0:
|
|
796
|
-
|
|
797
|
-
|
|
1011
|
+
_c.trys.push([0, 3, , 4]);
|
|
1012
|
+
return [4, this.currentUser.refresh()];
|
|
798
1013
|
case 1:
|
|
799
|
-
|
|
800
|
-
return [4, this.
|
|
1014
|
+
_c.sent();
|
|
1015
|
+
return [4, this.getSession()];
|
|
801
1016
|
case 2:
|
|
802
|
-
|
|
803
|
-
return [
|
|
1017
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1018
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
804
1019
|
case 3:
|
|
805
|
-
|
|
806
|
-
return [2,
|
|
807
|
-
case 4:
|
|
808
|
-
if (oauthLoginState) {
|
|
809
|
-
loginState = new LoginState({
|
|
810
|
-
envId: this.config.env,
|
|
811
|
-
cache: this.cache,
|
|
812
|
-
oauthInstance: this.oauthInstance,
|
|
813
|
-
});
|
|
814
|
-
return [2, loginState];
|
|
815
|
-
}
|
|
816
|
-
return [2, null];
|
|
1020
|
+
error_18 = _c.sent();
|
|
1021
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_18) }];
|
|
1022
|
+
case 4: return [2];
|
|
817
1023
|
}
|
|
818
1024
|
});
|
|
819
1025
|
});
|
|
820
1026
|
};
|
|
821
|
-
Auth.prototype.
|
|
822
|
-
|
|
823
|
-
return __generator(this, function (_a) {
|
|
824
|
-
return [2, this.getCurrentUser()];
|
|
825
|
-
});
|
|
826
|
-
});
|
|
827
|
-
};
|
|
828
|
-
Auth.prototype.getWedaUserInfo = function () {
|
|
829
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
830
|
-
return __generator(this, function (_a) {
|
|
831
|
-
return [2, this.oauthInstance.authApi.getWedaUserInfo()];
|
|
832
|
-
});
|
|
833
|
-
});
|
|
834
|
-
};
|
|
835
|
-
Auth.prototype.updateUserBasicInfo = function (params) {
|
|
1027
|
+
Auth.prototype.updateUser = function (params) {
|
|
1028
|
+
var _a;
|
|
836
1029
|
return __awaiter(this, void 0, void 0, function () {
|
|
837
|
-
var
|
|
838
|
-
|
|
839
|
-
|
|
840
|
-
|
|
1030
|
+
var hasValue, email, phone, restParams, needsEmailVerification_1, needsPhoneVerification, extraRes, verificationParams, verificationType_1, formattedPhone, verificationInfo_4, _b, user, error_19;
|
|
1031
|
+
var _this = this;
|
|
1032
|
+
return __generator(this, function (_c) {
|
|
1033
|
+
switch (_c.label) {
|
|
1034
|
+
case 0:
|
|
1035
|
+
_c.trys.push([0, 8, , 9]);
|
|
1036
|
+
hasValue = Object.keys(params).some(function (key) { return params[key] !== undefined && params[key] !== null && params[key] !== ''; });
|
|
1037
|
+
if (!hasValue) {
|
|
1038
|
+
throw new oauth_1.AuthError({ message: 'At least one field must be provided for update' });
|
|
1039
|
+
}
|
|
1040
|
+
email = params.email, phone = params.phone, restParams = __rest(params, ["email", "phone"]);
|
|
1041
|
+
needsEmailVerification_1 = email !== undefined;
|
|
1042
|
+
needsPhoneVerification = phone !== undefined;
|
|
1043
|
+
extraRes = {};
|
|
1044
|
+
if (!(needsEmailVerification_1 || needsPhoneVerification)) return [3, 4];
|
|
1045
|
+
verificationParams = void 0;
|
|
1046
|
+
if (needsEmailVerification_1) {
|
|
1047
|
+
verificationParams = { email: params.email };
|
|
1048
|
+
verificationType_1 = 'email_change';
|
|
1049
|
+
}
|
|
1050
|
+
else {
|
|
1051
|
+
formattedPhone = this.formatPhone(params.phone);
|
|
1052
|
+
verificationParams = { phone_number: formattedPhone };
|
|
1053
|
+
verificationType_1 = 'phone_change';
|
|
1054
|
+
}
|
|
1055
|
+
return [4, this.getVerification(verificationParams)];
|
|
841
1056
|
case 1:
|
|
842
|
-
|
|
843
|
-
|
|
844
|
-
return [
|
|
1057
|
+
verificationInfo_4 = _c.sent();
|
|
1058
|
+
_b = Object.keys(restParams).length > 0;
|
|
1059
|
+
if (!_b) return [3, 3];
|
|
1060
|
+
return [4, this.updateUserBasicInfo(restParams)];
|
|
845
1061
|
case 2:
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
case 3:
|
|
1062
|
+
_b = (_c.sent());
|
|
1063
|
+
_c.label = 3;
|
|
1064
|
+
case 3:
|
|
1065
|
+
_b;
|
|
1066
|
+
extraRes = {
|
|
1067
|
+
messageId: verificationInfo_4.verification_id,
|
|
1068
|
+
verifyOtp: function (verifyParams) { return __awaiter(_this, void 0, void 0, function () {
|
|
1069
|
+
var user_1, error_20;
|
|
1070
|
+
var _a;
|
|
1071
|
+
return __generator(this, function (_b) {
|
|
1072
|
+
switch (_b.label) {
|
|
1073
|
+
case 0:
|
|
1074
|
+
_b.trys.push([0, 11, , 12]);
|
|
1075
|
+
if (!(verifyParams.email && params.email === verifyParams.email)) return [3, 3];
|
|
1076
|
+
return [4, this.verifyOtp({
|
|
1077
|
+
type: 'email_change',
|
|
1078
|
+
email: params.email,
|
|
1079
|
+
token: verifyParams.token,
|
|
1080
|
+
messageId: verificationInfo_4.verification_id,
|
|
1081
|
+
})];
|
|
1082
|
+
case 1:
|
|
1083
|
+
_b.sent();
|
|
1084
|
+
return [4, this.updateUserBasicInfo({ email: params.email })];
|
|
1085
|
+
case 2:
|
|
1086
|
+
_b.sent();
|
|
1087
|
+
return [3, 9];
|
|
1088
|
+
case 3:
|
|
1089
|
+
if (!(verifyParams.phone && params.phone === verifyParams.phone)) return [3, 6];
|
|
1090
|
+
return [4, this.verifyOtp({
|
|
1091
|
+
type: 'phone_change',
|
|
1092
|
+
phone: params.phone,
|
|
1093
|
+
token: verifyParams.token,
|
|
1094
|
+
messageId: verificationInfo_4.verification_id,
|
|
1095
|
+
})];
|
|
1096
|
+
case 4:
|
|
1097
|
+
_b.sent();
|
|
1098
|
+
return [4, this.updateUserBasicInfo({ phone: this.formatPhone(params.phone) })];
|
|
1099
|
+
case 5:
|
|
1100
|
+
_b.sent();
|
|
1101
|
+
return [3, 9];
|
|
1102
|
+
case 6: return [4, this.verifyOtp({
|
|
1103
|
+
type: verificationType_1,
|
|
1104
|
+
email: needsEmailVerification_1 ? params.email : undefined,
|
|
1105
|
+
phone: !needsEmailVerification_1 ? params.phone : undefined,
|
|
1106
|
+
token: verifyParams.token,
|
|
1107
|
+
messageId: verificationInfo_4.verification_id,
|
|
1108
|
+
})];
|
|
1109
|
+
case 7:
|
|
1110
|
+
_b.sent();
|
|
1111
|
+
return [4, this.updateUserBasicInfo(params)];
|
|
1112
|
+
case 8:
|
|
1113
|
+
_b.sent();
|
|
1114
|
+
_b.label = 9;
|
|
1115
|
+
case 9: return [4, this.getUser()];
|
|
1116
|
+
case 10:
|
|
1117
|
+
user_1 = (_b.sent()).data.user;
|
|
1118
|
+
(_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 });
|
|
1119
|
+
return [2, { data: { user: user_1 }, error: null }];
|
|
1120
|
+
case 11:
|
|
1121
|
+
error_20 = _b.sent();
|
|
1122
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_20) }];
|
|
1123
|
+
case 12: return [2];
|
|
1124
|
+
}
|
|
1125
|
+
});
|
|
1126
|
+
}); },
|
|
1127
|
+
};
|
|
1128
|
+
return [3, 6];
|
|
1129
|
+
case 4: return [4, this.updateUserBasicInfo(params)];
|
|
1130
|
+
case 5:
|
|
1131
|
+
_c.sent();
|
|
1132
|
+
_c.label = 6;
|
|
1133
|
+
case 6: return [4, this.getUser()];
|
|
1134
|
+
case 7:
|
|
1135
|
+
user = (_c.sent()).data.user;
|
|
1136
|
+
(_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 });
|
|
1137
|
+
return [2, { data: __assign({ user: user }, extraRes), error: null }];
|
|
1138
|
+
case 8:
|
|
1139
|
+
error_19 = _c.sent();
|
|
1140
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_19) }];
|
|
1141
|
+
case 9: return [2];
|
|
849
1142
|
}
|
|
850
1143
|
});
|
|
851
1144
|
});
|
|
852
1145
|
};
|
|
853
|
-
Auth.prototype.
|
|
854
|
-
|
|
855
|
-
return {};
|
|
856
|
-
};
|
|
857
|
-
Auth.prototype.bindWithProvider = function (params) {
|
|
858
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
859
|
-
return __generator(this, function (_a) {
|
|
860
|
-
return [2, this.oauthInstance.authApi.bindWithProvider(params)];
|
|
861
|
-
});
|
|
862
|
-
});
|
|
863
|
-
};
|
|
864
|
-
Auth.prototype.queryUser = function (queryObj) {
|
|
865
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
866
|
-
return __generator(this, function (_a) {
|
|
867
|
-
return [2, this.oauthInstance.authApi.queryUserProfile(queryObj)];
|
|
868
|
-
});
|
|
869
|
-
});
|
|
870
|
-
};
|
|
871
|
-
Auth.prototype.getAccessToken = function () {
|
|
1146
|
+
Auth.prototype.getUserIdentities = function () {
|
|
1147
|
+
var _a;
|
|
872
1148
|
return __awaiter(this, void 0, void 0, function () {
|
|
873
|
-
var
|
|
874
|
-
return __generator(this, function (
|
|
875
|
-
switch (
|
|
876
|
-
case 0:
|
|
1149
|
+
var providers, error_21;
|
|
1150
|
+
return __generator(this, function (_b) {
|
|
1151
|
+
switch (_b.label) {
|
|
1152
|
+
case 0:
|
|
1153
|
+
_b.trys.push([0, 2, , 3]);
|
|
1154
|
+
return [4, this.oauthInstance.authApi.getProviders()];
|
|
877
1155
|
case 1:
|
|
878
|
-
|
|
1156
|
+
providers = _b.sent();
|
|
879
1157
|
return [2, {
|
|
880
|
-
|
|
881
|
-
|
|
1158
|
+
data: {
|
|
1159
|
+
identities: (_a = providers === null || providers === void 0 ? void 0 : providers.data) === null || _a === void 0 ? void 0 : _a.filter(function (v) { return !!v.bind; }),
|
|
1160
|
+
},
|
|
1161
|
+
error: null,
|
|
882
1162
|
}];
|
|
1163
|
+
case 2:
|
|
1164
|
+
error_21 = _b.sent();
|
|
1165
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_21) }];
|
|
1166
|
+
case 3: return [2];
|
|
883
1167
|
}
|
|
884
1168
|
});
|
|
885
1169
|
});
|
|
886
1170
|
};
|
|
887
|
-
Auth.prototype.
|
|
888
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
889
|
-
return __generator(this, function (_a) {
|
|
890
|
-
return [2, this.oauthInstance.authApi.grantProviderToken(params)];
|
|
891
|
-
});
|
|
892
|
-
});
|
|
893
|
-
};
|
|
894
|
-
Auth.prototype.patchProviderToken = function (params) {
|
|
895
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
896
|
-
return __generator(this, function (_a) {
|
|
897
|
-
return [2, this.oauthInstance.authApi.patchProviderToken(params)];
|
|
898
|
-
});
|
|
899
|
-
});
|
|
900
|
-
};
|
|
901
|
-
Auth.prototype.signInWithProvider = function (params) {
|
|
1171
|
+
Auth.prototype.linkIdentity = function (params) {
|
|
902
1172
|
return __awaiter(this, void 0, void 0, function () {
|
|
1173
|
+
var error_22;
|
|
903
1174
|
return __generator(this, function (_a) {
|
|
904
1175
|
switch (_a.label) {
|
|
905
|
-
case 0:
|
|
1176
|
+
case 0:
|
|
1177
|
+
_a.trys.push([0, 2, , 3]);
|
|
1178
|
+
this.validateParams(params, {
|
|
1179
|
+
provider: { required: true, message: 'Provider is required' },
|
|
1180
|
+
});
|
|
1181
|
+
return [4, this.signInWithOAuth({
|
|
1182
|
+
provider: params.provider,
|
|
1183
|
+
options: {
|
|
1184
|
+
type: oauth_1.OAUTH_TYPE.BIND_IDENTITY,
|
|
1185
|
+
},
|
|
1186
|
+
})];
|
|
906
1187
|
case 1:
|
|
907
1188
|
_a.sent();
|
|
908
|
-
return [2,
|
|
1189
|
+
return [2, { data: { provider: params.provider }, error: null }];
|
|
1190
|
+
case 2:
|
|
1191
|
+
error_22 = _a.sent();
|
|
1192
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_22) }];
|
|
1193
|
+
case 3: return [2];
|
|
909
1194
|
}
|
|
910
1195
|
});
|
|
911
1196
|
});
|
|
912
1197
|
};
|
|
913
|
-
Auth.prototype.
|
|
914
|
-
if (params === void 0) { params = {}; }
|
|
1198
|
+
Auth.prototype.unlinkIdentity = function (params) {
|
|
915
1199
|
return __awaiter(this, void 0, void 0, function () {
|
|
1200
|
+
var error_23;
|
|
916
1201
|
return __generator(this, function (_a) {
|
|
917
1202
|
switch (_a.label) {
|
|
918
|
-
case 0:
|
|
1203
|
+
case 0:
|
|
1204
|
+
_a.trys.push([0, 2, , 3]);
|
|
1205
|
+
this.validateParams(params, {
|
|
1206
|
+
provider: { required: true, message: 'Provider is required' },
|
|
1207
|
+
});
|
|
1208
|
+
return [4, this.oauthInstance.authApi.unbindProvider({ provider_id: params.provider })];
|
|
919
1209
|
case 1:
|
|
920
1210
|
_a.sent();
|
|
921
|
-
return [2,
|
|
1211
|
+
return [2, { data: {}, error: null }];
|
|
1212
|
+
case 2:
|
|
1213
|
+
error_23 = _a.sent();
|
|
1214
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_23) }];
|
|
1215
|
+
case 3: return [2];
|
|
922
1216
|
}
|
|
923
1217
|
});
|
|
924
1218
|
});
|
|
925
1219
|
};
|
|
926
|
-
Auth.prototype.
|
|
1220
|
+
Auth.prototype.reauthenticate = function () {
|
|
927
1221
|
return __awaiter(this, void 0, void 0, function () {
|
|
1222
|
+
var user, userInfo_1, verificationInfo_5, error_24;
|
|
1223
|
+
var _this = this;
|
|
928
1224
|
return __generator(this, function (_a) {
|
|
929
1225
|
switch (_a.label) {
|
|
930
|
-
case 0:
|
|
1226
|
+
case 0:
|
|
1227
|
+
_a.trys.push([0, 3, , 4]);
|
|
1228
|
+
return [4, this.getUser()];
|
|
931
1229
|
case 1:
|
|
932
|
-
_a.sent();
|
|
933
|
-
|
|
1230
|
+
user = (_a.sent()).data.user;
|
|
1231
|
+
this.validateAtLeastOne(user, [['email', 'phone']], 'You must provide either an email or phone number');
|
|
1232
|
+
userInfo_1 = user.email ? { email: user.email } : { phone_number: this.formatPhone(user.phone) };
|
|
1233
|
+
return [4, this.getVerification(userInfo_1)];
|
|
1234
|
+
case 2:
|
|
1235
|
+
verificationInfo_5 = _a.sent();
|
|
1236
|
+
return [2, {
|
|
1237
|
+
data: {
|
|
1238
|
+
updateUser: function (attributes) { return __awaiter(_this, void 0, void 0, function () {
|
|
1239
|
+
var verificationTokenRes, sudoRes, _a, _b, session, error_25;
|
|
1240
|
+
return __generator(this, function (_c) {
|
|
1241
|
+
switch (_c.label) {
|
|
1242
|
+
case 0:
|
|
1243
|
+
this.validateParams(attributes, {
|
|
1244
|
+
nonce: { required: true, message: 'Nonce is required' },
|
|
1245
|
+
});
|
|
1246
|
+
_c.label = 1;
|
|
1247
|
+
case 1:
|
|
1248
|
+
_c.trys.push([1, 9, , 10]);
|
|
1249
|
+
if (!attributes.password) return [3, 5];
|
|
1250
|
+
return [4, this.verify({
|
|
1251
|
+
verification_id: verificationInfo_5.verification_id,
|
|
1252
|
+
verification_code: attributes.nonce,
|
|
1253
|
+
})];
|
|
1254
|
+
case 2:
|
|
1255
|
+
verificationTokenRes = _c.sent();
|
|
1256
|
+
return [4, this.oauthInstance.authApi.sudo({
|
|
1257
|
+
verification_token: verificationTokenRes.verification_token,
|
|
1258
|
+
})];
|
|
1259
|
+
case 3:
|
|
1260
|
+
sudoRes = _c.sent();
|
|
1261
|
+
return [4, this.oauthInstance.authApi.setPassword({
|
|
1262
|
+
new_password: attributes.password,
|
|
1263
|
+
sudo_token: sudoRes.sudo_token,
|
|
1264
|
+
})];
|
|
1265
|
+
case 4:
|
|
1266
|
+
_c.sent();
|
|
1267
|
+
return [3, 7];
|
|
1268
|
+
case 5: return [4, this.signInWithUsername(__assign(__assign({ verificationInfo: verificationInfo_5, verificationCode: attributes.nonce }, userInfo_1), { loginType: userInfo_1.email ? 'email' : 'phone' }))];
|
|
1269
|
+
case 6:
|
|
1270
|
+
_c.sent();
|
|
1271
|
+
_c.label = 7;
|
|
1272
|
+
case 7: return [4, this.getSession()];
|
|
1273
|
+
case 8:
|
|
1274
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1275
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1276
|
+
case 9:
|
|
1277
|
+
error_25 = _c.sent();
|
|
1278
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_25) }];
|
|
1279
|
+
case 10: return [2];
|
|
1280
|
+
}
|
|
1281
|
+
});
|
|
1282
|
+
}); },
|
|
1283
|
+
},
|
|
1284
|
+
error: null,
|
|
1285
|
+
}];
|
|
1286
|
+
case 3:
|
|
1287
|
+
error_24 = _a.sent();
|
|
1288
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_24) }];
|
|
1289
|
+
case 4: return [2];
|
|
934
1290
|
}
|
|
935
1291
|
});
|
|
936
1292
|
});
|
|
937
1293
|
};
|
|
938
|
-
Auth.prototype.
|
|
939
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
940
|
-
return __generator(this, function (_a) {
|
|
941
|
-
return [2, this.oauthInstance.authApi.genProviderRedirectUri(params)];
|
|
942
|
-
});
|
|
943
|
-
});
|
|
944
|
-
};
|
|
945
|
-
Auth.prototype.resetPassword = function (params) {
|
|
946
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
947
|
-
return __generator(this, function (_a) {
|
|
948
|
-
return [2, this.oauthInstance.authApi.resetPassword(params)];
|
|
949
|
-
});
|
|
950
|
-
});
|
|
951
|
-
};
|
|
952
|
-
Auth.prototype.deviceAuthorize = function (params) {
|
|
1294
|
+
Auth.prototype.resend = function (params) {
|
|
953
1295
|
return __awaiter(this, void 0, void 0, function () {
|
|
1296
|
+
var target, data, verificationId, error_26;
|
|
954
1297
|
return __generator(this, function (_a) {
|
|
955
|
-
|
|
1298
|
+
switch (_a.label) {
|
|
1299
|
+
case 0:
|
|
1300
|
+
_a.trys.push([0, 2, , 3]);
|
|
1301
|
+
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
1302
|
+
target = params.type === 'signup' ? 'ANY' : 'USER';
|
|
1303
|
+
data = { target: target };
|
|
1304
|
+
if ('email' in params) {
|
|
1305
|
+
data.email = params.email;
|
|
1306
|
+
}
|
|
1307
|
+
if ('phone' in params) {
|
|
1308
|
+
data.phone_number = this.formatPhone(params.phone);
|
|
1309
|
+
}
|
|
1310
|
+
return [4, this.oauthInstance.authApi.getVerification(data)];
|
|
1311
|
+
case 1:
|
|
1312
|
+
verificationId = (_a.sent()).verification_id;
|
|
1313
|
+
return [2, {
|
|
1314
|
+
data: { messageId: verificationId },
|
|
1315
|
+
error: null,
|
|
1316
|
+
}];
|
|
1317
|
+
case 2:
|
|
1318
|
+
error_26 = _a.sent();
|
|
1319
|
+
return [2, {
|
|
1320
|
+
data: {},
|
|
1321
|
+
error: new oauth_1.AuthError(error_26),
|
|
1322
|
+
}];
|
|
1323
|
+
case 3: return [2];
|
|
1324
|
+
}
|
|
956
1325
|
});
|
|
957
1326
|
});
|
|
958
1327
|
};
|
|
959
|
-
Auth.prototype.
|
|
1328
|
+
Auth.prototype.setSession = function (params) {
|
|
1329
|
+
var _a;
|
|
960
1330
|
return __awaiter(this, void 0, void 0, function () {
|
|
961
|
-
|
|
962
|
-
|
|
1331
|
+
var _b, _c, session, error_27;
|
|
1332
|
+
return __generator(this, function (_d) {
|
|
1333
|
+
switch (_d.label) {
|
|
1334
|
+
case 0:
|
|
1335
|
+
_d.trys.push([0, 3, , 4]);
|
|
1336
|
+
this.validateParams(params, {
|
|
1337
|
+
access_token: { required: true, message: 'Access token is required' },
|
|
1338
|
+
refresh_token: { required: true, message: 'Refresh token is required' },
|
|
1339
|
+
});
|
|
1340
|
+
return [4, this.oauthInstance.oauth2client.refreshToken(params, { throwError: true })];
|
|
1341
|
+
case 1:
|
|
1342
|
+
_d.sent();
|
|
1343
|
+
return [4, this.getSession()];
|
|
1344
|
+
case 2:
|
|
1345
|
+
_b = (_d.sent()).data, _c = _b === void 0 ? {} : _b, session = _c.session;
|
|
1346
|
+
(_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 });
|
|
1347
|
+
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1348
|
+
case 3:
|
|
1349
|
+
error_27 = _d.sent();
|
|
1350
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_27) }];
|
|
1351
|
+
case 4: return [2];
|
|
1352
|
+
}
|
|
963
1353
|
});
|
|
964
1354
|
});
|
|
965
1355
|
};
|
|
966
|
-
Auth.prototype.
|
|
1356
|
+
Auth.prototype.exchangeCodeForSession = function () {
|
|
967
1357
|
return __awaiter(this, void 0, void 0, function () {
|
|
968
1358
|
return __generator(this, function (_a) {
|
|
969
|
-
return [2
|
|
1359
|
+
return [2];
|
|
970
1360
|
});
|
|
971
1361
|
});
|
|
972
1362
|
};
|
|
973
|
-
Auth.prototype.
|
|
1363
|
+
Auth.prototype.deleteUser = function (params) {
|
|
974
1364
|
return __awaiter(this, void 0, void 0, function () {
|
|
1365
|
+
var sudo_token, error_28;
|
|
975
1366
|
return __generator(this, function (_a) {
|
|
976
|
-
|
|
1367
|
+
switch (_a.label) {
|
|
1368
|
+
case 0:
|
|
1369
|
+
_a.trys.push([0, 3, , 4]);
|
|
1370
|
+
this.validateParams(params, {
|
|
1371
|
+
password: { required: true, message: 'Password is required' },
|
|
1372
|
+
});
|
|
1373
|
+
return [4, this.oauthInstance.authApi.sudo(params)];
|
|
1374
|
+
case 1:
|
|
1375
|
+
sudo_token = (_a.sent()).sudo_token;
|
|
1376
|
+
return [4, this.oauthInstance.authApi.deleteMe({ sudo_token: sudo_token })];
|
|
1377
|
+
case 2:
|
|
1378
|
+
_a.sent();
|
|
1379
|
+
return [2, { data: {}, error: null }];
|
|
1380
|
+
case 3:
|
|
1381
|
+
error_28 = _a.sent();
|
|
1382
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_28) }];
|
|
1383
|
+
case 4: return [2];
|
|
1384
|
+
}
|
|
977
1385
|
});
|
|
978
1386
|
});
|
|
979
1387
|
};
|
|
980
|
-
Auth.prototype.
|
|
1388
|
+
Auth.prototype.toDefaultLoginPage = function (params) {
|
|
1389
|
+
if (params === void 0) { params = {}; }
|
|
981
1390
|
return __awaiter(this, void 0, void 0, function () {
|
|
1391
|
+
var configVersion, query, redirectUri, urlObj, loginPage;
|
|
982
1392
|
return __generator(this, function (_a) {
|
|
983
|
-
|
|
1393
|
+
try {
|
|
1394
|
+
configVersion = params.config_version || 'env';
|
|
1395
|
+
query = Object.keys(params.query || {})
|
|
1396
|
+
.map(function (key) { return "".concat(key, "=").concat(params.query[key]); })
|
|
1397
|
+
.join('&');
|
|
1398
|
+
if (utilities_1.adapterForWxMp.isMatch()) {
|
|
1399
|
+
wx.navigateTo({ url: "/packages/$wd_system/pages/login/index".concat(query ? "?".concat(query) : '') });
|
|
1400
|
+
}
|
|
1401
|
+
else {
|
|
1402
|
+
redirectUri = params.redirect_uri || window.location.href;
|
|
1403
|
+
urlObj = new URL(redirectUri);
|
|
1404
|
+
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) : '');
|
|
1405
|
+
window.location.href = loginPage;
|
|
1406
|
+
}
|
|
1407
|
+
return [2, { data: {}, error: null }];
|
|
1408
|
+
}
|
|
1409
|
+
catch (error) {
|
|
1410
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error) }];
|
|
1411
|
+
}
|
|
1412
|
+
return [2];
|
|
984
1413
|
});
|
|
985
1414
|
});
|
|
986
1415
|
};
|
|
987
|
-
Auth.prototype.
|
|
1416
|
+
Auth.prototype.signInWithCustomTicket = function (getTickFn) {
|
|
988
1417
|
return __awaiter(this, void 0, void 0, function () {
|
|
989
|
-
|
|
990
|
-
|
|
1418
|
+
var loginState, _a, _b, session, error_29;
|
|
1419
|
+
return __generator(this, function (_c) {
|
|
1420
|
+
switch (_c.label) {
|
|
1421
|
+
case 0:
|
|
1422
|
+
if (getTickFn) {
|
|
1423
|
+
this.setCustomSignFunc(getTickFn);
|
|
1424
|
+
}
|
|
1425
|
+
_c.label = 1;
|
|
1426
|
+
case 1:
|
|
1427
|
+
_c.trys.push([1, 5, , 6]);
|
|
1428
|
+
return [4, this.oauthInstance.authApi.signInWithCustomTicket()];
|
|
1429
|
+
case 2:
|
|
1430
|
+
_c.sent();
|
|
1431
|
+
return [4, this.createLoginState()];
|
|
1432
|
+
case 3:
|
|
1433
|
+
loginState = _c.sent();
|
|
1434
|
+
return [4, this.getSession()];
|
|
1435
|
+
case 4:
|
|
1436
|
+
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1437
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
1438
|
+
case 5:
|
|
1439
|
+
error_29 = _c.sent();
|
|
1440
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_29) }];
|
|
1441
|
+
case 6: return [2];
|
|
1442
|
+
}
|
|
991
1443
|
});
|
|
992
1444
|
});
|
|
993
1445
|
};
|
|
994
|
-
Auth.prototype.
|
|
995
|
-
var _a;
|
|
1446
|
+
Auth.prototype.signInWithOpenId = function (_a) {
|
|
1447
|
+
var _b = _a === void 0 ? {} : _a, _c = _b.useWxCloud, useWxCloud = _c === void 0 ? true : _c;
|
|
996
1448
|
return __awaiter(this, void 0, void 0, function () {
|
|
997
|
-
var loginState;
|
|
1449
|
+
var wxInfo, mainFunc, loginState, _d, _e, session, error_30;
|
|
998
1450
|
var _this = this;
|
|
999
|
-
return __generator(this, function (
|
|
1000
|
-
switch (
|
|
1451
|
+
return __generator(this, function (_f) {
|
|
1452
|
+
switch (_f.label) {
|
|
1001
1453
|
case 0:
|
|
1002
|
-
|
|
1003
|
-
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1454
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
1455
|
+
throw Error('wx api undefined');
|
|
1456
|
+
}
|
|
1457
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
1458
|
+
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
1459
|
+
var result, credentials, error_31;
|
|
1460
|
+
return __generator(this, function (_a) {
|
|
1461
|
+
switch (_a.label) {
|
|
1007
1462
|
case 0:
|
|
1008
|
-
|
|
1009
|
-
|
|
1463
|
+
result = undefined;
|
|
1464
|
+
credentials = undefined;
|
|
1465
|
+
_a.label = 1;
|
|
1010
1466
|
case 1:
|
|
1011
|
-
_a
|
|
1012
|
-
return [
|
|
1467
|
+
_a.trys.push([1, 4, , 5]);
|
|
1468
|
+
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
1469
|
+
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1470
|
+
provider_code: code,
|
|
1471
|
+
provider_params: {
|
|
1472
|
+
provider_code_type: 'open_id',
|
|
1473
|
+
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1474
|
+
},
|
|
1475
|
+
}, useWxCloud)];
|
|
1013
1476
|
case 2:
|
|
1014
|
-
|
|
1015
|
-
|
|
1477
|
+
result = _a.sent();
|
|
1478
|
+
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
1479
|
+
throw result;
|
|
1480
|
+
}
|
|
1481
|
+
return [4, this.oauthInstance.authApi.signInWithProvider({ provider_token: result.provider_token }, useWxCloud)];
|
|
1016
1482
|
case 3:
|
|
1017
|
-
|
|
1018
|
-
|
|
1019
|
-
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
|
|
1023
|
-
|
|
1483
|
+
credentials = _a.sent();
|
|
1484
|
+
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
1485
|
+
throw credentials;
|
|
1486
|
+
}
|
|
1487
|
+
return [3, 5];
|
|
1488
|
+
case 4:
|
|
1489
|
+
error_31 = _a.sent();
|
|
1490
|
+
throw error_31;
|
|
1491
|
+
case 5: return [4, this.oauthInstance.oauth2client.setCredentials(credentials)];
|
|
1492
|
+
case 6:
|
|
1493
|
+
_a.sent();
|
|
1494
|
+
return [2];
|
|
1495
|
+
}
|
|
1496
|
+
});
|
|
1497
|
+
}); };
|
|
1498
|
+
_f.label = 1;
|
|
1024
1499
|
case 1:
|
|
1025
|
-
|
|
1026
|
-
|
|
1027
|
-
|
|
1500
|
+
_f.trys.push([1, 5, , 6]);
|
|
1501
|
+
return [4, new Promise(function (resolve, reject) {
|
|
1502
|
+
wx.login({
|
|
1503
|
+
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
1504
|
+
var error_32;
|
|
1505
|
+
return __generator(this, function (_a) {
|
|
1506
|
+
switch (_a.label) {
|
|
1507
|
+
case 0:
|
|
1508
|
+
_a.trys.push([0, 2, , 3]);
|
|
1509
|
+
return [4, mainFunc(res.code)];
|
|
1510
|
+
case 1:
|
|
1511
|
+
_a.sent();
|
|
1512
|
+
resolve(true);
|
|
1513
|
+
return [3, 3];
|
|
1514
|
+
case 2:
|
|
1515
|
+
error_32 = _a.sent();
|
|
1516
|
+
reject(error_32);
|
|
1517
|
+
return [3, 3];
|
|
1518
|
+
case 3: return [2];
|
|
1519
|
+
}
|
|
1520
|
+
});
|
|
1521
|
+
}); },
|
|
1522
|
+
fail: function (res) {
|
|
1523
|
+
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
1524
|
+
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
1525
|
+
reject(error);
|
|
1526
|
+
},
|
|
1527
|
+
});
|
|
1528
|
+
})];
|
|
1529
|
+
case 2:
|
|
1530
|
+
_f.sent();
|
|
1531
|
+
return [4, this.createLoginState()];
|
|
1532
|
+
case 3:
|
|
1533
|
+
loginState = _f.sent();
|
|
1534
|
+
return [4, this.getSession()];
|
|
1535
|
+
case 4:
|
|
1536
|
+
_d = (_f.sent()).data, _e = _d === void 0 ? {} : _d, session = _e.session;
|
|
1537
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
1538
|
+
case 5:
|
|
1539
|
+
error_30 = _f.sent();
|
|
1540
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_30) }];
|
|
1541
|
+
case 6: return [2];
|
|
1028
1542
|
}
|
|
1029
1543
|
});
|
|
1030
1544
|
});
|
|
1031
1545
|
};
|
|
1032
|
-
Auth.prototype.
|
|
1033
|
-
|
|
1034
|
-
return __generator(this, function (_a) {
|
|
1035
|
-
return [2, this.oauthInstance.authApi.refreshTokenForce(params)];
|
|
1036
|
-
});
|
|
1037
|
-
});
|
|
1038
|
-
};
|
|
1039
|
-
Auth.prototype.getCredentials = function () {
|
|
1040
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1041
|
-
return __generator(this, function (_a) {
|
|
1042
|
-
return [2, this.oauthInstance.authApi.getCredentials()];
|
|
1043
|
-
});
|
|
1044
|
-
});
|
|
1045
|
-
};
|
|
1046
|
-
Auth.prototype.setCredentials = function (credentials) {
|
|
1546
|
+
Auth.prototype.signInWithPhoneAuth = function (_a) {
|
|
1547
|
+
var _b = _a.phoneCode, phoneCode = _b === void 0 ? '' : _b;
|
|
1047
1548
|
return __awaiter(this, void 0, void 0, function () {
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1549
|
+
var wxInfo, providerInfo, code, providerToken, signInRes, error_33, loginState, _c, _d, session;
|
|
1550
|
+
return __generator(this, function (_e) {
|
|
1551
|
+
switch (_e.label) {
|
|
1552
|
+
case 0:
|
|
1553
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
1554
|
+
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'wx api undefined' }) }];
|
|
1555
|
+
}
|
|
1556
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
1557
|
+
providerInfo = {
|
|
1558
|
+
provider_params: { provider_code_type: 'phone' },
|
|
1559
|
+
provider_id: wxInfo.appId,
|
|
1560
|
+
};
|
|
1561
|
+
return [4, wx.login()];
|
|
1051
1562
|
case 1:
|
|
1052
|
-
|
|
1053
|
-
|
|
1563
|
+
code = (_e.sent()).code;
|
|
1564
|
+
providerInfo.provider_code = code;
|
|
1565
|
+
_e.label = 2;
|
|
1566
|
+
case 2:
|
|
1567
|
+
_e.trys.push([2, 6, , 7]);
|
|
1568
|
+
return [4, this.oauthInstance.authApi.grantProviderToken(providerInfo)];
|
|
1569
|
+
case 3:
|
|
1570
|
+
providerToken = _e.sent();
|
|
1571
|
+
if (providerToken.error_code) {
|
|
1572
|
+
throw providerToken;
|
|
1573
|
+
}
|
|
1574
|
+
return [4, this.oauthInstance.authApi.patchProviderToken({
|
|
1575
|
+
provider_token: providerToken.provider_token,
|
|
1576
|
+
provider_id: wxInfo.appId,
|
|
1577
|
+
provider_params: {
|
|
1578
|
+
code: phoneCode,
|
|
1579
|
+
provider_code_type: 'phone',
|
|
1580
|
+
},
|
|
1581
|
+
})];
|
|
1582
|
+
case 4:
|
|
1583
|
+
providerToken = _e.sent();
|
|
1584
|
+
if (providerToken.error_code) {
|
|
1585
|
+
throw providerToken;
|
|
1586
|
+
}
|
|
1587
|
+
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
1588
|
+
provider_token: providerToken.provider_token,
|
|
1589
|
+
})];
|
|
1590
|
+
case 5:
|
|
1591
|
+
signInRes = _e.sent();
|
|
1592
|
+
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
1593
|
+
throw signInRes;
|
|
1594
|
+
}
|
|
1595
|
+
return [3, 7];
|
|
1596
|
+
case 6:
|
|
1597
|
+
error_33 = _e.sent();
|
|
1598
|
+
return [2, { data: {}, error: new oauth_1.AuthError(error_33) }];
|
|
1599
|
+
case 7: return [4, this.createLoginState()];
|
|
1600
|
+
case 8:
|
|
1601
|
+
loginState = _e.sent();
|
|
1602
|
+
return [4, this.getSession()];
|
|
1603
|
+
case 9:
|
|
1604
|
+
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
1605
|
+
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
1054
1606
|
}
|
|
1055
1607
|
});
|
|
1056
1608
|
});
|
|
1057
1609
|
};
|
|
1058
|
-
Auth.prototype.
|
|
1059
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1060
|
-
return __generator(this, function (_a) {
|
|
1061
|
-
return [2, this.oauthInstance.authApi.getProviderSubType()];
|
|
1062
|
-
});
|
|
1063
|
-
});
|
|
1064
|
-
};
|
|
1065
|
-
Auth.prototype.createCaptchaData = function (params) {
|
|
1066
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1067
|
-
return __generator(this, function (_a) {
|
|
1068
|
-
return [2, this.oauthInstance.authApi.createCaptchaData(params)];
|
|
1069
|
-
});
|
|
1070
|
-
});
|
|
1071
|
-
};
|
|
1072
|
-
Auth.prototype.verifyCaptchaData = function (params) {
|
|
1610
|
+
Auth.prototype.bindPhoneNumber = function (params) {
|
|
1073
1611
|
return __awaiter(this, void 0, void 0, function () {
|
|
1074
1612
|
return __generator(this, function (_a) {
|
|
1075
|
-
return [2, this.oauthInstance.authApi.
|
|
1613
|
+
return [2, this.oauthInstance.authApi.editContact(params)];
|
|
1076
1614
|
});
|
|
1077
1615
|
});
|
|
1078
1616
|
};
|
|
1079
|
-
Auth.prototype.
|
|
1617
|
+
Auth.prototype.unbindProvider = function (params) {
|
|
1080
1618
|
return __awaiter(this, void 0, void 0, function () {
|
|
1081
1619
|
return __generator(this, function (_a) {
|
|
1082
|
-
return [2, this.oauthInstance.authApi.
|
|
1620
|
+
return [2, this.oauthInstance.authApi.unbindProvider(params)];
|
|
1083
1621
|
});
|
|
1084
1622
|
});
|
|
1085
1623
|
};
|
|
1086
|
-
Auth.prototype.
|
|
1087
|
-
return
|
|
1088
|
-
return __generator(this, function (_a) {
|
|
1089
|
-
return [2, this.oauthInstance.authApi.getMiniProgramQrCodeStatus(params)];
|
|
1090
|
-
});
|
|
1091
|
-
});
|
|
1624
|
+
Auth.prototype.bindEmail = function (params) {
|
|
1625
|
+
return this.oauthInstance.authApi.editContact(params);
|
|
1092
1626
|
};
|
|
1093
|
-
Auth.prototype.
|
|
1627
|
+
Auth.prototype.verify = function (params) {
|
|
1094
1628
|
return __awaiter(this, void 0, void 0, function () {
|
|
1095
1629
|
return __generator(this, function (_a) {
|
|
1096
|
-
return [2, this.oauthInstance.authApi.
|
|
1630
|
+
return [2, this.oauthInstance.authApi.verify(params)];
|
|
1097
1631
|
});
|
|
1098
1632
|
});
|
|
1099
1633
|
};
|
|
1100
|
-
Auth.prototype.
|
|
1634
|
+
Auth.prototype.getVerification = function (params, options) {
|
|
1101
1635
|
return __awaiter(this, void 0, void 0, function () {
|
|
1102
1636
|
return __generator(this, function (_a) {
|
|
1103
|
-
|
|
1637
|
+
if (params.phone_number) {
|
|
1638
|
+
params.phone_number = this.formatPhone(params.phone_number);
|
|
1639
|
+
}
|
|
1640
|
+
return [2, this.oauthInstance.authApi.getVerification(params, options)];
|
|
1104
1641
|
});
|
|
1105
1642
|
});
|
|
1106
1643
|
};
|
|
1107
|
-
Auth.prototype
|
|
1644
|
+
Object.defineProperty(Auth.prototype, "currentUser", {
|
|
1645
|
+
get: function () {
|
|
1646
|
+
if (this.cache.mode === 'async') {
|
|
1647
|
+
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getCurrentUser instead');
|
|
1648
|
+
return;
|
|
1649
|
+
}
|
|
1650
|
+
var loginState = this.hasLoginState();
|
|
1651
|
+
if (loginState) {
|
|
1652
|
+
return loginState.user || null;
|
|
1653
|
+
}
|
|
1654
|
+
return null;
|
|
1655
|
+
},
|
|
1656
|
+
enumerable: false,
|
|
1657
|
+
configurable: true
|
|
1658
|
+
});
|
|
1659
|
+
Auth.prototype.getCurrentUser = function () {
|
|
1108
1660
|
return __awaiter(this, void 0, void 0, function () {
|
|
1661
|
+
var loginState, userInfo;
|
|
1109
1662
|
return __generator(this, function (_a) {
|
|
1110
|
-
|
|
1111
|
-
|
|
1112
|
-
});
|
|
1113
|
-
};
|
|
1114
|
-
Auth.prototype.signInWithUsername = function (_a) {
|
|
1115
|
-
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;
|
|
1116
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1117
|
-
var verifyRes, verification_token, username, signUpParam, signInRes, bindRes, signUpRes, error_8;
|
|
1118
|
-
return __generator(this, function (_g) {
|
|
1119
|
-
switch (_g.label) {
|
|
1120
|
-
case 0:
|
|
1121
|
-
_g.trys.push([0, 8, , 9]);
|
|
1122
|
-
return [4, this.oauthInstance.authApi.verify({
|
|
1123
|
-
verification_id: verificationInfo.verification_id,
|
|
1124
|
-
verification_code: verificationCode,
|
|
1125
|
-
})];
|
|
1663
|
+
switch (_a.label) {
|
|
1664
|
+
case 0: return [4, this.getLoginState()];
|
|
1126
1665
|
case 1:
|
|
1127
|
-
|
|
1128
|
-
if (
|
|
1129
|
-
|
|
1130
|
-
|
|
1131
|
-
verification_token = verifyRes.verification_token;
|
|
1132
|
-
username = this.formatPhone(rawUsername);
|
|
1133
|
-
signUpParam = { phone_number: username };
|
|
1134
|
-
if (loginType === 'email') {
|
|
1135
|
-
username = rawUsername;
|
|
1136
|
-
signUpParam = { email: username };
|
|
1137
|
-
}
|
|
1138
|
-
if (!verificationInfo.is_user) return [3, 5];
|
|
1139
|
-
return [4, this.oauthInstance.authApi.signIn({
|
|
1140
|
-
username: username,
|
|
1141
|
-
verification_token: verification_token,
|
|
1142
|
-
})];
|
|
1666
|
+
loginState = _a.sent();
|
|
1667
|
+
if (!loginState) return [3, 3];
|
|
1668
|
+
userInfo = loginState.user.getLocalUserInfo();
|
|
1669
|
+
return [4, loginState.user.checkLocalInfoAsync()];
|
|
1143
1670
|
case 2:
|
|
1144
|
-
|
|
1145
|
-
|
|
1146
|
-
|
|
1147
|
-
}
|
|
1148
|
-
if (!bindInfo) return [3, 4];
|
|
1149
|
-
return [4, this.oauthInstance.authApi.bindWithProvider({
|
|
1150
|
-
provider_token: bindInfo === null || bindInfo === void 0 ? void 0 : bindInfo.providerToken,
|
|
1151
|
-
})];
|
|
1152
|
-
case 3:
|
|
1153
|
-
bindRes = _g.sent();
|
|
1154
|
-
if (bindRes === null || bindRes === void 0 ? void 0 : bindRes.error_code) {
|
|
1155
|
-
throw bindRes;
|
|
1156
|
-
}
|
|
1157
|
-
_g.label = 4;
|
|
1158
|
-
case 4: return [3, 7];
|
|
1159
|
-
case 5: return [4, this.oauthInstance.authApi.signUp(__assign(__assign({}, signUpParam), { verification_token: verification_token, provider_token: bindInfo === null || bindInfo === void 0 ? void 0 : bindInfo.providerId }))];
|
|
1160
|
-
case 6:
|
|
1161
|
-
signUpRes = _g.sent();
|
|
1162
|
-
if (signUpRes === null || signUpRes === void 0 ? void 0 : signUpRes.error_code) {
|
|
1163
|
-
throw signUpRes;
|
|
1164
|
-
}
|
|
1165
|
-
_g.label = 7;
|
|
1166
|
-
case 7: return [2, this.createLoginState()];
|
|
1167
|
-
case 8:
|
|
1168
|
-
error_8 = _g.sent();
|
|
1169
|
-
throw error_8;
|
|
1170
|
-
case 9: return [2];
|
|
1671
|
+
_a.sent();
|
|
1672
|
+
return [2, __assign(__assign({}, loginState.user), userInfo)];
|
|
1673
|
+
case 3: return [2, null];
|
|
1171
1674
|
}
|
|
1172
1675
|
});
|
|
1173
1676
|
});
|
|
1174
1677
|
};
|
|
1175
|
-
Auth.prototype.
|
|
1176
|
-
var _a, _b;
|
|
1678
|
+
Auth.prototype.signInAnonymouslyInWx = function (_a) {
|
|
1679
|
+
var _b = _a === void 0 ? {} : _a, useWxCloud = _b.useWxCloud;
|
|
1177
1680
|
return __awaiter(this, void 0, void 0, function () {
|
|
1178
|
-
var
|
|
1681
|
+
var wxInfo, mainFunc;
|
|
1682
|
+
var _this = this;
|
|
1179
1683
|
return __generator(this, function (_c) {
|
|
1180
1684
|
switch (_c.label) {
|
|
1181
1685
|
case 0:
|
|
1182
|
-
|
|
1183
|
-
|
|
1184
|
-
|
|
1185
|
-
|
|
1186
|
-
|
|
1187
|
-
|
|
1686
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
1687
|
+
throw Error('wx api undefined');
|
|
1688
|
+
}
|
|
1689
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
1690
|
+
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
1691
|
+
var result, credentials, error_34;
|
|
1692
|
+
return __generator(this, function (_a) {
|
|
1693
|
+
switch (_a.label) {
|
|
1694
|
+
case 0:
|
|
1695
|
+
result = undefined;
|
|
1696
|
+
credentials = undefined;
|
|
1697
|
+
_a.label = 1;
|
|
1698
|
+
case 1:
|
|
1699
|
+
_a.trys.push([1, 4, , 5]);
|
|
1700
|
+
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
1701
|
+
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1702
|
+
provider_code: code,
|
|
1703
|
+
provider_params: {
|
|
1704
|
+
provider_code_type: 'open_id',
|
|
1705
|
+
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1706
|
+
},
|
|
1707
|
+
}, useWxCloud)];
|
|
1708
|
+
case 2:
|
|
1709
|
+
result = _a.sent();
|
|
1710
|
+
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
1711
|
+
throw result;
|
|
1712
|
+
}
|
|
1713
|
+
return [4, this.oauthInstance.authApi.signInAnonymously({ provider_token: result.provider_token }, useWxCloud)];
|
|
1714
|
+
case 3:
|
|
1715
|
+
credentials = _a.sent();
|
|
1716
|
+
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
1717
|
+
throw credentials;
|
|
1718
|
+
}
|
|
1719
|
+
return [3, 5];
|
|
1720
|
+
case 4:
|
|
1721
|
+
error_34 = _a.sent();
|
|
1722
|
+
throw error_34;
|
|
1723
|
+
case 5: return [2];
|
|
1724
|
+
}
|
|
1725
|
+
});
|
|
1726
|
+
}); };
|
|
1727
|
+
return [4, new Promise(function (resolve, reject) {
|
|
1728
|
+
wx.login({
|
|
1729
|
+
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
1730
|
+
var error_35;
|
|
1731
|
+
return __generator(this, function (_a) {
|
|
1732
|
+
switch (_a.label) {
|
|
1733
|
+
case 0:
|
|
1734
|
+
_a.trys.push([0, 2, , 3]);
|
|
1735
|
+
return [4, mainFunc(res.code)];
|
|
1736
|
+
case 1:
|
|
1737
|
+
_a.sent();
|
|
1738
|
+
resolve(true);
|
|
1739
|
+
return [3, 3];
|
|
1740
|
+
case 2:
|
|
1741
|
+
error_35 = _a.sent();
|
|
1742
|
+
reject(error_35);
|
|
1743
|
+
return [3, 3];
|
|
1744
|
+
case 3: return [2];
|
|
1745
|
+
}
|
|
1746
|
+
});
|
|
1747
|
+
}); },
|
|
1748
|
+
fail: function (res) {
|
|
1749
|
+
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
1750
|
+
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
1751
|
+
reject(error);
|
|
1752
|
+
},
|
|
1753
|
+
});
|
|
1754
|
+
})];
|
|
1188
1755
|
case 1:
|
|
1189
1756
|
_c.sent();
|
|
1190
|
-
|
|
1191
|
-
loginState.user.setLocalUserInfo(options.userInfo);
|
|
1192
|
-
return [3, 5];
|
|
1193
|
-
case 2:
|
|
1194
|
-
if (!(options === null || options === void 0 ? void 0 : options.asyncRefreshUser)) return [3, 3];
|
|
1195
|
-
loginState.user.refresh(params);
|
|
1196
|
-
return [3, 5];
|
|
1197
|
-
case 3: return [4, loginState.user.refresh(params)];
|
|
1198
|
-
case 4:
|
|
1199
|
-
_c.sent();
|
|
1200
|
-
_c.label = 5;
|
|
1201
|
-
case 5:
|
|
1202
|
-
(_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 });
|
|
1203
|
-
(_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 });
|
|
1204
|
-
return [2, loginState];
|
|
1205
|
-
}
|
|
1206
|
-
});
|
|
1207
|
-
});
|
|
1208
|
-
};
|
|
1209
|
-
Auth.prototype.setAccessKey = function () {
|
|
1210
|
-
var _a, _b;
|
|
1211
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
1212
|
-
var accessToken, scope;
|
|
1213
|
-
return __generator(this, function (_c) {
|
|
1214
|
-
accessToken = '';
|
|
1215
|
-
scope = '';
|
|
1216
|
-
if (this.config.accessKey) {
|
|
1217
|
-
accessToken = this.config.accessKey;
|
|
1218
|
-
scope = 'accessKey';
|
|
1219
|
-
}
|
|
1220
|
-
else if (((_a = this.config.auth) === null || _a === void 0 ? void 0 : _a.secretId) && ((_b = this.config.auth) === null || _b === void 0 ? void 0 : _b.secretKey)) {
|
|
1221
|
-
accessToken = '';
|
|
1222
|
-
scope = oauth_1.DEFAULT_NODE_ACCESS_SCOPE;
|
|
1223
|
-
}
|
|
1224
|
-
if (!scope) {
|
|
1225
|
-
return [2];
|
|
1226
|
-
}
|
|
1227
|
-
try {
|
|
1228
|
-
this.oauthInstance.oauth2client.setAccessKeyCredentials({
|
|
1229
|
-
access_token: accessToken,
|
|
1230
|
-
token_type: 'Bearer',
|
|
1231
|
-
scope: scope,
|
|
1232
|
-
expires_at: new Date(+new Date() + +new Date()),
|
|
1233
|
-
expires_in: +new Date() + +new Date(),
|
|
1234
|
-
});
|
|
1235
|
-
}
|
|
1236
|
-
catch (error) {
|
|
1237
|
-
console.warn('accessKey error: ', error);
|
|
1757
|
+
return [2, this.createLoginState(undefined, { asyncRefreshUser: true })];
|
|
1238
1758
|
}
|
|
1239
|
-
return [2];
|
|
1240
1759
|
});
|
|
1241
1760
|
});
|
|
1242
1761
|
};
|
|
1243
|
-
Auth.prototype.
|
|
1762
|
+
Auth.prototype.bindOpenId = function () {
|
|
1244
1763
|
return __awaiter(this, void 0, void 0, function () {
|
|
1245
|
-
var
|
|
1246
|
-
|
|
1247
|
-
|
|
1764
|
+
var wxInfo, mainFunc;
|
|
1765
|
+
var _this = this;
|
|
1766
|
+
return __generator(this, function (_a) {
|
|
1767
|
+
switch (_a.label) {
|
|
1248
1768
|
case 0:
|
|
1249
|
-
|
|
1250
|
-
|
|
1769
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
1770
|
+
throw Error('wx api undefined');
|
|
1771
|
+
}
|
|
1772
|
+
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
1773
|
+
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
1774
|
+
var result, error_36;
|
|
1775
|
+
return __generator(this, function (_a) {
|
|
1776
|
+
switch (_a.label) {
|
|
1777
|
+
case 0:
|
|
1778
|
+
result = undefined;
|
|
1779
|
+
_a.label = 1;
|
|
1780
|
+
case 1:
|
|
1781
|
+
_a.trys.push([1, 4, , 5]);
|
|
1782
|
+
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
1783
|
+
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1784
|
+
provider_code: code,
|
|
1785
|
+
provider_params: {
|
|
1786
|
+
provider_code_type: 'open_id',
|
|
1787
|
+
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1788
|
+
},
|
|
1789
|
+
})];
|
|
1790
|
+
case 2:
|
|
1791
|
+
result = _a.sent();
|
|
1792
|
+
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
1793
|
+
throw result;
|
|
1794
|
+
}
|
|
1795
|
+
return [4, this.oauthInstance.authApi.bindWithProvider({ provider_token: result.provider_token })];
|
|
1796
|
+
case 3:
|
|
1797
|
+
_a.sent();
|
|
1798
|
+
return [3, 5];
|
|
1799
|
+
case 4:
|
|
1800
|
+
error_36 = _a.sent();
|
|
1801
|
+
throw error_36;
|
|
1802
|
+
case 5: return [2];
|
|
1803
|
+
}
|
|
1804
|
+
});
|
|
1805
|
+
}); };
|
|
1806
|
+
return [4, new Promise(function (resolve, reject) {
|
|
1807
|
+
wx.login({
|
|
1808
|
+
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
1809
|
+
var error_37;
|
|
1810
|
+
return __generator(this, function (_a) {
|
|
1811
|
+
switch (_a.label) {
|
|
1812
|
+
case 0:
|
|
1813
|
+
_a.trys.push([0, 2, , 3]);
|
|
1814
|
+
return [4, mainFunc(res.code)];
|
|
1815
|
+
case 1:
|
|
1816
|
+
_a.sent();
|
|
1817
|
+
resolve(true);
|
|
1818
|
+
return [3, 3];
|
|
1819
|
+
case 2:
|
|
1820
|
+
error_37 = _a.sent();
|
|
1821
|
+
reject(error_37);
|
|
1822
|
+
return [3, 3];
|
|
1823
|
+
case 3: return [2];
|
|
1824
|
+
}
|
|
1825
|
+
});
|
|
1826
|
+
}); },
|
|
1827
|
+
fail: function (res) {
|
|
1828
|
+
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
1829
|
+
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
1830
|
+
reject(error);
|
|
1831
|
+
},
|
|
1832
|
+
});
|
|
1833
|
+
})];
|
|
1251
1834
|
case 1:
|
|
1252
|
-
|
|
1253
|
-
return [
|
|
1254
|
-
case 2:
|
|
1255
|
-
loginState = _c.sent();
|
|
1256
|
-
return [4, this.getSession()];
|
|
1257
|
-
case 3:
|
|
1258
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1259
|
-
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
1260
|
-
case 4:
|
|
1261
|
-
error_9 = _c.sent();
|
|
1262
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_9) }];
|
|
1263
|
-
case 5: return [2];
|
|
1835
|
+
_a.sent();
|
|
1836
|
+
return [2];
|
|
1264
1837
|
}
|
|
1265
1838
|
});
|
|
1266
1839
|
});
|
|
1267
1840
|
};
|
|
1268
|
-
Auth.prototype.
|
|
1841
|
+
Auth.prototype.signInWithUnionId = function () {
|
|
1269
1842
|
return __awaiter(this, void 0, void 0, function () {
|
|
1270
|
-
var
|
|
1843
|
+
var error_38;
|
|
1271
1844
|
var _this = this;
|
|
1272
1845
|
return __generator(this, function (_a) {
|
|
1273
1846
|
switch (_a.label) {
|
|
1274
1847
|
case 0:
|
|
1275
|
-
if (!
|
|
1276
|
-
|
|
1277
|
-
|
|
1848
|
+
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
1849
|
+
throw Error('wx api undefined');
|
|
1850
|
+
}
|
|
1851
|
+
_a.label = 1;
|
|
1278
1852
|
case 1:
|
|
1279
|
-
_a.
|
|
1280
|
-
return [
|
|
1281
|
-
|
|
1282
|
-
|
|
1283
|
-
|
|
1284
|
-
|
|
1285
|
-
|
|
1286
|
-
|
|
1287
|
-
|
|
1288
|
-
|
|
1289
|
-
|
|
1290
|
-
|
|
1291
|
-
|
|
1292
|
-
|
|
1293
|
-
|
|
1294
|
-
|
|
1295
|
-
|
|
1296
|
-
|
|
1297
|
-
|
|
1298
|
-
|
|
1299
|
-
|
|
1300
|
-
|
|
1301
|
-
|
|
1302
|
-
|
|
1303
|
-
|
|
1304
|
-
|
|
1305
|
-
|
|
1306
|
-
|
|
1307
|
-
|
|
1308
|
-
|
|
1309
|
-
|
|
1310
|
-
|
|
1311
|
-
|
|
1312
|
-
|
|
1313
|
-
|
|
1314
|
-
|
|
1315
|
-
return [
|
|
1316
|
-
|
|
1317
|
-
|
|
1318
|
-
|
|
1319
|
-
|
|
1320
|
-
|
|
1321
|
-
|
|
1322
|
-
|
|
1323
|
-
|
|
1324
|
-
|
|
1325
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1326
|
-
case 8:
|
|
1327
|
-
error_11 = _e.sent();
|
|
1328
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_11) }];
|
|
1329
|
-
case 9: return [2];
|
|
1330
|
-
}
|
|
1331
|
-
});
|
|
1853
|
+
_a.trys.push([1, 3, , 4]);
|
|
1854
|
+
return [4, new Promise(function (resolve, reject) {
|
|
1855
|
+
var wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
1856
|
+
wx.login({
|
|
1857
|
+
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
1858
|
+
var providerId, result, providerToken, signInRes, error_39;
|
|
1859
|
+
return __generator(this, function (_a) {
|
|
1860
|
+
switch (_a.label) {
|
|
1861
|
+
case 0:
|
|
1862
|
+
providerId = wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId;
|
|
1863
|
+
_a.label = 1;
|
|
1864
|
+
case 1:
|
|
1865
|
+
_a.trys.push([1, 4, , 5]);
|
|
1866
|
+
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
1867
|
+
provider_code: res.code,
|
|
1868
|
+
provider_id: providerId,
|
|
1869
|
+
provider_params: {
|
|
1870
|
+
provider_code_type: 'union_id',
|
|
1871
|
+
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
1872
|
+
},
|
|
1873
|
+
})];
|
|
1874
|
+
case 2:
|
|
1875
|
+
result = _a.sent();
|
|
1876
|
+
providerToken = result.provider_token;
|
|
1877
|
+
if (!providerToken) {
|
|
1878
|
+
reject(result);
|
|
1879
|
+
return [2];
|
|
1880
|
+
}
|
|
1881
|
+
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
1882
|
+
provider_id: providerId,
|
|
1883
|
+
provider_token: providerToken,
|
|
1884
|
+
})];
|
|
1885
|
+
case 3:
|
|
1886
|
+
signInRes = _a.sent();
|
|
1887
|
+
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
1888
|
+
reject(signInRes);
|
|
1889
|
+
return [2];
|
|
1890
|
+
}
|
|
1891
|
+
resolve(true);
|
|
1892
|
+
return [3, 5];
|
|
1893
|
+
case 4:
|
|
1894
|
+
error_39 = _a.sent();
|
|
1895
|
+
reject(error_39);
|
|
1896
|
+
return [3, 5];
|
|
1897
|
+
case 5: return [2];
|
|
1898
|
+
}
|
|
1332
1899
|
});
|
|
1900
|
+
}); },
|
|
1901
|
+
fail: function (res) {
|
|
1902
|
+
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
1903
|
+
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
1904
|
+
reject(error);
|
|
1333
1905
|
},
|
|
1334
|
-
}
|
|
1335
|
-
|
|
1336
|
-
|
|
1337
|
-
|
|
1338
|
-
|
|
1339
|
-
|
|
1340
|
-
|
|
1906
|
+
});
|
|
1907
|
+
})];
|
|
1908
|
+
case 2:
|
|
1909
|
+
_a.sent();
|
|
1910
|
+
return [3, 4];
|
|
1911
|
+
case 3:
|
|
1912
|
+
error_38 = _a.sent();
|
|
1913
|
+
throw error_38;
|
|
1914
|
+
case 4: return [2, this.createLoginState()];
|
|
1341
1915
|
}
|
|
1342
1916
|
});
|
|
1343
1917
|
});
|
|
1344
1918
|
};
|
|
1345
|
-
Auth.prototype.
|
|
1346
|
-
var _a, _b;
|
|
1919
|
+
Auth.prototype.signInWithSms = function (_a) {
|
|
1920
|
+
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;
|
|
1347
1921
|
return __awaiter(this, void 0, void 0, function () {
|
|
1348
|
-
|
|
1349
|
-
|
|
1350
|
-
|
|
1351
|
-
|
|
1352
|
-
|
|
1353
|
-
|
|
1354
|
-
|
|
1355
|
-
|
|
1356
|
-
|
|
1357
|
-
|
|
1358
|
-
|
|
1359
|
-
|
|
1360
|
-
this.setAccessKey();
|
|
1361
|
-
(_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 });
|
|
1362
|
-
(_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 });
|
|
1363
|
-
return [2, __assign(__assign({}, res), { data: {}, error: null })];
|
|
1364
|
-
case 3:
|
|
1365
|
-
error_12 = _c.sent();
|
|
1366
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_12) }];
|
|
1367
|
-
case 4: return [2];
|
|
1922
|
+
return __generator(this, function (_f) {
|
|
1923
|
+
try {
|
|
1924
|
+
return [2, this.signInWithUsername({
|
|
1925
|
+
verificationInfo: verificationInfo,
|
|
1926
|
+
verificationCode: verificationCode,
|
|
1927
|
+
bindInfo: bindInfo,
|
|
1928
|
+
username: phoneNum,
|
|
1929
|
+
loginType: 'sms',
|
|
1930
|
+
})];
|
|
1931
|
+
}
|
|
1932
|
+
catch (error) {
|
|
1933
|
+
throw error;
|
|
1368
1934
|
}
|
|
1935
|
+
return [2];
|
|
1369
1936
|
});
|
|
1370
1937
|
});
|
|
1371
1938
|
};
|
|
1372
|
-
Auth.prototype.
|
|
1373
|
-
var
|
|
1374
|
-
if (!this.hasListenerSetUp) {
|
|
1375
|
-
this.setupListeners();
|
|
1376
|
-
this.hasListenerSetUp = true;
|
|
1377
|
-
}
|
|
1378
|
-
var id = Math.random().toString(36);
|
|
1379
|
-
if (!this.listeners.has(id)) {
|
|
1380
|
-
this.listeners.set(id, new Set());
|
|
1381
|
-
}
|
|
1382
|
-
this.listeners.get(id).add(callback);
|
|
1383
|
-
var subscription = {
|
|
1384
|
-
id: id,
|
|
1385
|
-
callback: callback,
|
|
1386
|
-
unsubscribe: function () {
|
|
1387
|
-
var callbacks = _this.listeners.get(id);
|
|
1388
|
-
if (callbacks) {
|
|
1389
|
-
callbacks.delete(callback);
|
|
1390
|
-
if (callbacks.size === 0) {
|
|
1391
|
-
_this.listeners.delete(id);
|
|
1392
|
-
}
|
|
1393
|
-
}
|
|
1394
|
-
},
|
|
1395
|
-
};
|
|
1396
|
-
return {
|
|
1397
|
-
data: { subscription: subscription },
|
|
1398
|
-
};
|
|
1399
|
-
};
|
|
1400
|
-
Auth.prototype.signInWithPassword = function (params) {
|
|
1401
|
-
var _a, _b;
|
|
1939
|
+
Auth.prototype.signInWithEmail = function (_a) {
|
|
1940
|
+
var _b = _a.verificationInfo, verificationInfo = _b === void 0 ? { verification_id: '', is_user: false } : _b, _c = _a.verificationCode, verificationCode = _c === void 0 ? '' : _c, _d = _a.bindInfo, bindInfo = _d === void 0 ? undefined : _d, _e = _a.email, email = _e === void 0 ? '' : _e;
|
|
1402
1941
|
return __awaiter(this, void 0, void 0, function () {
|
|
1403
|
-
|
|
1404
|
-
|
|
1405
|
-
|
|
1406
|
-
|
|
1407
|
-
|
|
1408
|
-
|
|
1409
|
-
|
|
1410
|
-
|
|
1411
|
-
});
|
|
1412
|
-
|
|
1413
|
-
|
|
1414
|
-
|
|
1415
|
-
return [4, this.getSession()];
|
|
1416
|
-
case 2:
|
|
1417
|
-
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
1418
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1419
|
-
case 3:
|
|
1420
|
-
error_13 = _e.sent();
|
|
1421
|
-
authError = new oauth_1.AuthError(error_13);
|
|
1422
|
-
if (((_a = authError.message) === null || _a === void 0 ? void 0 : _a.includes('密码不正确')) || ((_b = authError.message) === null || _b === void 0 ? void 0 : _b.includes('password'))) {
|
|
1423
|
-
console.warn('[CloudBase Auth] 登录失败提示:\n'
|
|
1424
|
-
+ ' 1. 请确认用户名/邮箱/手机号是否正确\n'
|
|
1425
|
-
+ ' 2. 请确认密码是否正确\n'
|
|
1426
|
-
+ ' 3. 如果用户不存在,请先通过 auth.signUp() 注册用户,或在云开发控制台手动创建用户\n'
|
|
1427
|
-
+ ' 4. 确认当前环境已开启对应的登录方式(控制台 → 环境 → 登录授权)');
|
|
1428
|
-
}
|
|
1429
|
-
return [2, { data: {}, error: authError }];
|
|
1430
|
-
case 4: return [2];
|
|
1942
|
+
return __generator(this, function (_f) {
|
|
1943
|
+
try {
|
|
1944
|
+
return [2, this.signInWithUsername({
|
|
1945
|
+
verificationInfo: verificationInfo,
|
|
1946
|
+
verificationCode: verificationCode,
|
|
1947
|
+
bindInfo: bindInfo,
|
|
1948
|
+
username: email,
|
|
1949
|
+
loginType: 'email',
|
|
1950
|
+
})];
|
|
1951
|
+
}
|
|
1952
|
+
catch (error) {
|
|
1953
|
+
throw error;
|
|
1431
1954
|
}
|
|
1955
|
+
return [2];
|
|
1432
1956
|
});
|
|
1433
1957
|
});
|
|
1434
1958
|
};
|
|
1435
|
-
Auth.prototype.
|
|
1959
|
+
Auth.prototype.setCustomSignFunc = function (getTickFn) {
|
|
1960
|
+
this.oauthInstance.authApi.setCustomSignFunc(getTickFn);
|
|
1961
|
+
};
|
|
1962
|
+
Auth.prototype.signIn = function (params) {
|
|
1436
1963
|
return __awaiter(this, void 0, void 0, function () {
|
|
1437
|
-
|
|
1438
|
-
|
|
1439
|
-
|
|
1440
|
-
case 0:
|
|
1441
|
-
_c.trys.push([0, 3, , 4]);
|
|
1442
|
-
this.validateParams(params, {
|
|
1443
|
-
token: { required: true, message: 'Token is required' },
|
|
1444
|
-
});
|
|
1445
|
-
return [4, this.signInWithProvider({
|
|
1446
|
-
provider_token: params.token,
|
|
1447
|
-
})];
|
|
1964
|
+
return __generator(this, function (_a) {
|
|
1965
|
+
switch (_a.label) {
|
|
1966
|
+
case 0: return [4, this.oauthInstance.authApi.signIn(params)];
|
|
1448
1967
|
case 1:
|
|
1449
|
-
|
|
1450
|
-
return [
|
|
1451
|
-
case 2:
|
|
1452
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1453
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1454
|
-
case 3:
|
|
1455
|
-
error_14 = _c.sent();
|
|
1456
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_14) }];
|
|
1457
|
-
case 4: return [2];
|
|
1968
|
+
_a.sent();
|
|
1969
|
+
return [2, this.createLoginState(params)];
|
|
1458
1970
|
}
|
|
1459
1971
|
});
|
|
1460
1972
|
});
|
|
1461
1973
|
};
|
|
1462
|
-
Auth.prototype.
|
|
1463
|
-
var _a, _b;
|
|
1974
|
+
Auth.prototype.setPassword = function (params) {
|
|
1464
1975
|
return __awaiter(this, void 0, void 0, function () {
|
|
1465
|
-
|
|
1466
|
-
|
|
1467
|
-
return __generator(this, function (_c) {
|
|
1468
|
-
switch (_c.label) {
|
|
1469
|
-
case 0:
|
|
1470
|
-
if (((_a = params.options) === null || _a === void 0 ? void 0 : _a.shouldCreateUser) === undefined || !!((_b = params.options) === null || _b === void 0 ? void 0 : _b.shouldCreateUser)) {
|
|
1471
|
-
return [2, this.signUp({
|
|
1472
|
-
email: params.email,
|
|
1473
|
-
phone: params.phone,
|
|
1474
|
-
})];
|
|
1475
|
-
}
|
|
1476
|
-
_c.label = 1;
|
|
1477
|
-
case 1:
|
|
1478
|
-
_c.trys.push([1, 3, , 4]);
|
|
1479
|
-
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
1480
|
-
return [4, this.getVerification(params.email ? { email: params.email } : { phone_number: this.formatPhone(params.phone) })];
|
|
1481
|
-
case 2:
|
|
1482
|
-
verificationInfo_2 = _c.sent();
|
|
1483
|
-
return [2, {
|
|
1484
|
-
data: {
|
|
1485
|
-
user: null,
|
|
1486
|
-
session: null,
|
|
1487
|
-
verifyOtp: function (_a) {
|
|
1488
|
-
var token = _a.token, _b = _a.messageId, messageId = _b === void 0 ? verificationInfo_2.verification_id : _b;
|
|
1489
|
-
return __awaiter(_this, void 0, void 0, function () {
|
|
1490
|
-
return __generator(this, function (_c) {
|
|
1491
|
-
return [2, this.verifyOtp({
|
|
1492
|
-
email: params.email,
|
|
1493
|
-
phone: params.phone,
|
|
1494
|
-
token: token,
|
|
1495
|
-
messageId: messageId,
|
|
1496
|
-
})];
|
|
1497
|
-
});
|
|
1498
|
-
});
|
|
1499
|
-
},
|
|
1500
|
-
},
|
|
1501
|
-
error: null,
|
|
1502
|
-
}];
|
|
1503
|
-
case 3:
|
|
1504
|
-
error_15 = _c.sent();
|
|
1505
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_15) }];
|
|
1506
|
-
case 4: return [2];
|
|
1507
|
-
}
|
|
1976
|
+
return __generator(this, function (_a) {
|
|
1977
|
+
return [2, this.oauthInstance.authApi.setPassword(params)];
|
|
1508
1978
|
});
|
|
1509
1979
|
});
|
|
1510
1980
|
};
|
|
1511
|
-
Auth.prototype.
|
|
1981
|
+
Auth.prototype.isUsernameRegistered = function (username) {
|
|
1512
1982
|
return __awaiter(this, void 0, void 0, function () {
|
|
1513
|
-
var
|
|
1983
|
+
var exist;
|
|
1514
1984
|
return __generator(this, function (_a) {
|
|
1515
1985
|
switch (_a.label) {
|
|
1516
1986
|
case 0:
|
|
1517
|
-
|
|
1518
|
-
|
|
1519
|
-
case 1:
|
|
1520
|
-
_a.trys.push([1, 7, , 8]);
|
|
1521
|
-
code = (params === null || params === void 0 ? void 0 : params.code) || utilities_2.utils.getQuery('code');
|
|
1522
|
-
state = (params === null || params === void 0 ? void 0 : params.state) || utilities_2.utils.getQuery('state');
|
|
1523
|
-
if (!code) {
|
|
1524
|
-
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'Code is required' }) }];
|
|
1525
|
-
}
|
|
1526
|
-
if (!state) {
|
|
1527
|
-
return [2, { data: {}, error: new oauth_1.AuthError({ message: 'State is required' }) }];
|
|
1528
|
-
}
|
|
1529
|
-
cacheData = (0, utils_1.getBrowserSession)(state);
|
|
1530
|
-
data.type = cacheData === null || cacheData === void 0 ? void 0 : cacheData.type;
|
|
1531
|
-
provider = (params === null || params === void 0 ? void 0 : params.provider) || (cacheData === null || cacheData === void 0 ? void 0 : cacheData.provider) || utilities_2.utils.getQuery('provider');
|
|
1532
|
-
if (!provider) {
|
|
1533
|
-
return [2, { data: data, error: new oauth_1.AuthError({ message: 'Provider is required' }) }];
|
|
1987
|
+
if (typeof username !== 'string') {
|
|
1988
|
+
(0, utilities_1.throwError)(utilities_1.ERRORS.INVALID_PARAMS, 'username must be a string');
|
|
1534
1989
|
}
|
|
1535
|
-
return [4, this.
|
|
1536
|
-
|
|
1537
|
-
|
|
1538
|
-
|
|
1539
|
-
})];
|
|
1540
|
-
case 2:
|
|
1541
|
-
token = (_a.sent()).provider_token;
|
|
1542
|
-
res = void 0;
|
|
1543
|
-
if (!(cacheData.type === oauth_1.OAUTH_TYPE.BIND_IDENTITY)) return [3, 4];
|
|
1544
|
-
return [4, this.oauthInstance.authApi.toBindIdentity({ provider_token: token, provider: provider, fireEvent: true })];
|
|
1545
|
-
case 3:
|
|
1546
|
-
res = _a.sent();
|
|
1547
|
-
return [3, 6];
|
|
1548
|
-
case 4: return [4, this.signInWithIdToken({
|
|
1549
|
-
token: token,
|
|
1550
|
-
})];
|
|
1551
|
-
case 5:
|
|
1552
|
-
res = _a.sent();
|
|
1553
|
-
res.data = __assign(__assign({}, data), res.data);
|
|
1554
|
-
_a.label = 6;
|
|
1555
|
-
case 6:
|
|
1556
|
-
localSearch = new URLSearchParams(location === null || location === void 0 ? void 0 : location.search);
|
|
1557
|
-
localSearch.delete('code');
|
|
1558
|
-
localSearch.delete('state');
|
|
1559
|
-
res.data.redirectUrl = (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);
|
|
1560
|
-
(0, utils_1.removeBrowserSession)(state);
|
|
1561
|
-
return [2, res];
|
|
1562
|
-
case 7:
|
|
1563
|
-
error_16 = _a.sent();
|
|
1564
|
-
return [2, { data: data, error: new oauth_1.AuthError(error_16) }];
|
|
1565
|
-
case 8: return [2];
|
|
1990
|
+
return [4, this.oauthInstance.authApi.checkIfUserExist({ username: username })];
|
|
1991
|
+
case 1:
|
|
1992
|
+
exist = (_a.sent()).exist;
|
|
1993
|
+
return [2, exist];
|
|
1566
1994
|
}
|
|
1567
1995
|
});
|
|
1568
1996
|
});
|
|
1569
1997
|
};
|
|
1570
|
-
Auth.prototype.
|
|
1571
|
-
var _a
|
|
1998
|
+
Auth.prototype.hasLoginState = function () {
|
|
1999
|
+
var _a;
|
|
2000
|
+
if (this.cache.mode === 'async') {
|
|
2001
|
+
(0, utilities_1.printWarn)(utilities_1.ERRORS.INVALID_OPERATION, 'current platform\'s storage is asynchronous, please use getLoginState instead');
|
|
2002
|
+
return;
|
|
2003
|
+
}
|
|
2004
|
+
var oauthLoginState = (_a = this.oauthInstance) === null || _a === void 0 ? void 0 : _a.authApi.hasLoginStateSync();
|
|
2005
|
+
if (oauthLoginState) {
|
|
2006
|
+
var loginState = new LoginState({
|
|
2007
|
+
envId: this.config.env,
|
|
2008
|
+
cache: this.cache,
|
|
2009
|
+
oauthInstance: this.oauthInstance,
|
|
2010
|
+
});
|
|
2011
|
+
return loginState;
|
|
2012
|
+
}
|
|
2013
|
+
return null;
|
|
2014
|
+
};
|
|
2015
|
+
Auth.prototype.getLoginState = function () {
|
|
1572
2016
|
return __awaiter(this, void 0, void 0, function () {
|
|
1573
|
-
var
|
|
1574
|
-
return __generator(this, function (
|
|
1575
|
-
switch (
|
|
2017
|
+
var oauthLoginState, error_40, loginState;
|
|
2018
|
+
return __generator(this, function (_a) {
|
|
2019
|
+
switch (_a.label) {
|
|
1576
2020
|
case 0:
|
|
1577
|
-
|
|
1578
|
-
|
|
1579
|
-
provider: { required: true, message: 'Provider is required' },
|
|
1580
|
-
});
|
|
1581
|
-
href = ((_a = params.options) === null || _a === void 0 ? void 0 : _a.redirectTo) || location.href;
|
|
1582
|
-
urlObject = new URL(href);
|
|
1583
|
-
provider_redirect_uri = urlObject.origin + urlObject.pathname;
|
|
1584
|
-
state = ((_b = params.options) === null || _b === void 0 ? void 0 : _b.state) || "prd-".concat(params.provider, "-").concat(Math.random().toString(36)
|
|
1585
|
-
.slice(2));
|
|
1586
|
-
return [4, this.genProviderRedirectUri({
|
|
1587
|
-
provider_id: params.provider,
|
|
1588
|
-
provider_redirect_uri: provider_redirect_uri,
|
|
1589
|
-
state: state,
|
|
1590
|
-
})];
|
|
2021
|
+
oauthLoginState = null;
|
|
2022
|
+
_a.label = 1;
|
|
1591
2023
|
case 1:
|
|
1592
|
-
|
|
1593
|
-
|
|
1594
|
-
|
|
1595
|
-
|
|
1596
|
-
|
|
1597
|
-
|
|
1598
|
-
|
|
1599
|
-
|
|
2024
|
+
_a.trys.push([1, 3, , 4]);
|
|
2025
|
+
return [4, this.oauthInstance.authApi.getLoginState()];
|
|
2026
|
+
case 2:
|
|
2027
|
+
oauthLoginState = _a.sent();
|
|
2028
|
+
return [3, 4];
|
|
2029
|
+
case 3:
|
|
2030
|
+
error_40 = _a.sent();
|
|
2031
|
+
return [2, null];
|
|
2032
|
+
case 4:
|
|
2033
|
+
if (oauthLoginState) {
|
|
2034
|
+
loginState = new LoginState({
|
|
2035
|
+
envId: this.config.env,
|
|
2036
|
+
cache: this.cache,
|
|
2037
|
+
oauthInstance: this.oauthInstance,
|
|
1600
2038
|
});
|
|
1601
|
-
|
|
1602
|
-
}
|
|
1603
|
-
(0, utils_1.saveToBrowserSession)(state, {
|
|
1604
|
-
provider: params.provider,
|
|
1605
|
-
search: urlObject.search,
|
|
1606
|
-
hash: urlObject.hash,
|
|
1607
|
-
type: ((_d = params.options) === null || _d === void 0 ? void 0 : _d.type) || oauth_1.OAUTH_TYPE.SIGN_IN,
|
|
1608
|
-
});
|
|
1609
|
-
if (isBrowser() && !((_e = params.options) === null || _e === void 0 ? void 0 : _e.skipBrowserRedirect)) {
|
|
1610
|
-
window.location.assign(finalUri);
|
|
2039
|
+
return [2, loginState];
|
|
1611
2040
|
}
|
|
1612
|
-
return [2,
|
|
1613
|
-
case 2:
|
|
1614
|
-
error_17 = _f.sent();
|
|
1615
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_17) }];
|
|
1616
|
-
case 3: return [2];
|
|
2041
|
+
return [2, null];
|
|
1617
2042
|
}
|
|
1618
2043
|
});
|
|
1619
2044
|
});
|
|
1620
2045
|
};
|
|
1621
|
-
Auth.prototype.
|
|
2046
|
+
Auth.prototype.getUserInfo = function () {
|
|
2047
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2048
|
+
return __generator(this, function (_a) {
|
|
2049
|
+
return [2, this.getCurrentUser()];
|
|
2050
|
+
});
|
|
2051
|
+
});
|
|
2052
|
+
};
|
|
2053
|
+
Auth.prototype.getWedaUserInfo = function () {
|
|
1622
2054
|
return __awaiter(this, void 0, void 0, function () {
|
|
1623
|
-
|
|
2055
|
+
return __generator(this, function (_a) {
|
|
2056
|
+
return [2, this.oauthInstance.authApi.getWedaUserInfo()];
|
|
2057
|
+
});
|
|
2058
|
+
});
|
|
2059
|
+
};
|
|
2060
|
+
Auth.prototype.updateUserBasicInfo = function (params) {
|
|
2061
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2062
|
+
var loginState;
|
|
1624
2063
|
return __generator(this, function (_a) {
|
|
1625
2064
|
switch (_a.label) {
|
|
1626
|
-
case 0:
|
|
1627
|
-
_a.trys.push([0, 2, , 3]);
|
|
1628
|
-
return [4, this.getAccessToken()];
|
|
2065
|
+
case 0: return [4, this.getLoginState()];
|
|
1629
2066
|
case 1:
|
|
1630
|
-
|
|
1631
|
-
|
|
1632
|
-
return [
|
|
2067
|
+
loginState = _a.sent();
|
|
2068
|
+
if (!loginState) return [3, 3];
|
|
2069
|
+
return [4, loginState.user.updateUserBasicInfo(params)];
|
|
1633
2070
|
case 2:
|
|
1634
|
-
|
|
1635
|
-
|
|
2071
|
+
_a.sent();
|
|
2072
|
+
_a.label = 3;
|
|
1636
2073
|
case 3: return [2];
|
|
1637
2074
|
}
|
|
1638
2075
|
});
|
|
1639
2076
|
});
|
|
1640
2077
|
};
|
|
1641
|
-
Auth.prototype.
|
|
2078
|
+
Auth.prototype.getAuthHeader = function () {
|
|
2079
|
+
console.error('Auth.getAuthHeader API 已废弃');
|
|
2080
|
+
return {};
|
|
2081
|
+
};
|
|
2082
|
+
Auth.prototype.bindWithProvider = function (params) {
|
|
1642
2083
|
return __awaiter(this, void 0, void 0, function () {
|
|
1643
|
-
|
|
1644
|
-
|
|
2084
|
+
return __generator(this, function (_a) {
|
|
2085
|
+
return [2, this.oauthInstance.authApi.bindWithProvider(params)];
|
|
2086
|
+
});
|
|
2087
|
+
});
|
|
2088
|
+
};
|
|
2089
|
+
Auth.prototype.queryUser = function (queryObj) {
|
|
2090
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2091
|
+
return __generator(this, function (_a) {
|
|
2092
|
+
return [2, this.oauthInstance.authApi.queryUserProfile(queryObj)];
|
|
2093
|
+
});
|
|
2094
|
+
});
|
|
2095
|
+
};
|
|
2096
|
+
Auth.prototype.getAccessToken = function () {
|
|
2097
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2098
|
+
var oauthAccessTokenRes;
|
|
1645
2099
|
return __generator(this, function (_a) {
|
|
1646
2100
|
switch (_a.label) {
|
|
1647
|
-
case 0:
|
|
1648
|
-
_a.trys.push([0, 2, , 3]);
|
|
1649
|
-
this.validateParams({ emailOrPhone: emailOrPhone }, {
|
|
1650
|
-
emailOrPhone: { required: true, message: 'Email or phone is required' },
|
|
1651
|
-
});
|
|
1652
|
-
redirectTo_1 = (options || {}).redirectTo;
|
|
1653
|
-
isEmail_1 = emailOrPhone.includes('@');
|
|
1654
|
-
verificationParams = void 0;
|
|
1655
|
-
if (isEmail_1) {
|
|
1656
|
-
verificationParams = { email: emailOrPhone };
|
|
1657
|
-
}
|
|
1658
|
-
else {
|
|
1659
|
-
formattedPhone = this.formatPhone(emailOrPhone);
|
|
1660
|
-
verificationParams = { phone_number: formattedPhone };
|
|
1661
|
-
}
|
|
1662
|
-
return [4, this.getVerification(verificationParams)];
|
|
2101
|
+
case 0: return [4, this.oauthInstance.oauth2client.getAccessToken()];
|
|
1663
2102
|
case 1:
|
|
1664
|
-
|
|
2103
|
+
oauthAccessTokenRes = _a.sent();
|
|
1665
2104
|
return [2, {
|
|
1666
|
-
|
|
1667
|
-
|
|
1668
|
-
var verificationTokenRes, res, error_20;
|
|
1669
|
-
var _a;
|
|
1670
|
-
return __generator(this, function (_b) {
|
|
1671
|
-
switch (_b.label) {
|
|
1672
|
-
case 0:
|
|
1673
|
-
this.validateParams(attributes, {
|
|
1674
|
-
nonce: { required: true, message: 'Nonce is required' },
|
|
1675
|
-
password: { required: true, message: 'Password is required' },
|
|
1676
|
-
});
|
|
1677
|
-
_b.label = 1;
|
|
1678
|
-
case 1:
|
|
1679
|
-
_b.trys.push([1, 5, , 6]);
|
|
1680
|
-
return [4, this.verify({
|
|
1681
|
-
verification_id: verificationInfo_3.verification_id,
|
|
1682
|
-
verification_code: attributes.nonce,
|
|
1683
|
-
})];
|
|
1684
|
-
case 2:
|
|
1685
|
-
verificationTokenRes = _b.sent();
|
|
1686
|
-
return [4, this.oauthInstance.authApi.resetPassword({
|
|
1687
|
-
email: isEmail_1 ? emailOrPhone : undefined,
|
|
1688
|
-
phone_number: !isEmail_1 ? emailOrPhone : undefined,
|
|
1689
|
-
new_password: attributes.password,
|
|
1690
|
-
verification_token: verificationTokenRes.verification_token,
|
|
1691
|
-
})];
|
|
1692
|
-
case 3:
|
|
1693
|
-
_b.sent();
|
|
1694
|
-
(_a = this.config.eventBus) === null || _a === void 0 ? void 0 : _a.fire(oauth_1.EVENTS.AUTH_STATE_CHANGED, {
|
|
1695
|
-
event: oauth_1.AUTH_STATE_CHANGED_TYPE.PASSWORD_RECOVERY,
|
|
1696
|
-
});
|
|
1697
|
-
return [4, this.signInWithPassword({
|
|
1698
|
-
email: isEmail_1 ? emailOrPhone : undefined,
|
|
1699
|
-
phone: !isEmail_1 ? emailOrPhone : undefined,
|
|
1700
|
-
password: attributes.password,
|
|
1701
|
-
})];
|
|
1702
|
-
case 4:
|
|
1703
|
-
res = _b.sent();
|
|
1704
|
-
if (redirectTo_1 && isBrowser()) {
|
|
1705
|
-
window.location.assign(redirectTo_1);
|
|
1706
|
-
}
|
|
1707
|
-
return [2, res];
|
|
1708
|
-
case 5:
|
|
1709
|
-
error_20 = _b.sent();
|
|
1710
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_20) }];
|
|
1711
|
-
case 6: return [2];
|
|
1712
|
-
}
|
|
1713
|
-
});
|
|
1714
|
-
}); },
|
|
1715
|
-
},
|
|
1716
|
-
error: null,
|
|
2105
|
+
accessToken: oauthAccessTokenRes,
|
|
2106
|
+
env: this.config.env,
|
|
1717
2107
|
}];
|
|
1718
|
-
case 2:
|
|
1719
|
-
error_19 = _a.sent();
|
|
1720
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_19) }];
|
|
1721
|
-
case 3: return [2];
|
|
1722
2108
|
}
|
|
1723
2109
|
});
|
|
1724
2110
|
});
|
|
1725
2111
|
};
|
|
1726
|
-
Auth.prototype.
|
|
2112
|
+
Auth.prototype.grantProviderToken = function (params) {
|
|
1727
2113
|
return __awaiter(this, void 0, void 0, function () {
|
|
1728
|
-
|
|
1729
|
-
|
|
1730
|
-
switch (_c.label) {
|
|
1731
|
-
case 0:
|
|
1732
|
-
_c.trys.push([0, 3, , 4]);
|
|
1733
|
-
return [4, this.oauthInstance.authApi.updatePasswordByOld({
|
|
1734
|
-
old_password: params.old_password,
|
|
1735
|
-
new_password: params.new_password,
|
|
1736
|
-
})];
|
|
1737
|
-
case 1:
|
|
1738
|
-
_c.sent();
|
|
1739
|
-
return [4, this.getSession()];
|
|
1740
|
-
case 2:
|
|
1741
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1742
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1743
|
-
case 3:
|
|
1744
|
-
error_21 = _c.sent();
|
|
1745
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_21) }];
|
|
1746
|
-
case 4: return [2];
|
|
1747
|
-
}
|
|
2114
|
+
return __generator(this, function (_a) {
|
|
2115
|
+
return [2, this.oauthInstance.authApi.grantProviderToken(params)];
|
|
1748
2116
|
});
|
|
1749
2117
|
});
|
|
1750
2118
|
};
|
|
1751
|
-
Auth.prototype.
|
|
2119
|
+
Auth.prototype.patchProviderToken = function (params) {
|
|
1752
2120
|
return __awaiter(this, void 0, void 0, function () {
|
|
1753
|
-
|
|
1754
|
-
|
|
1755
|
-
|
|
1756
|
-
|
|
1757
|
-
|
|
1758
|
-
|
|
1759
|
-
|
|
1760
|
-
|
|
1761
|
-
|
|
1762
|
-
|
|
1763
|
-
if (!['phone_change', 'email_change'].includes(type)) return [3, 2];
|
|
1764
|
-
return [4, this.verify({
|
|
1765
|
-
verification_id: params.messageId,
|
|
1766
|
-
verification_code: params.token,
|
|
1767
|
-
})];
|
|
2121
|
+
return __generator(this, function (_a) {
|
|
2122
|
+
return [2, this.oauthInstance.authApi.patchProviderToken(params)];
|
|
2123
|
+
});
|
|
2124
|
+
});
|
|
2125
|
+
};
|
|
2126
|
+
Auth.prototype.signInWithProvider = function (params) {
|
|
2127
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2128
|
+
return __generator(this, function (_a) {
|
|
2129
|
+
switch (_a.label) {
|
|
2130
|
+
case 0: return [4, this.oauthInstance.authApi.signInWithProvider(params)];
|
|
1768
2131
|
case 1:
|
|
1769
|
-
|
|
1770
|
-
return [
|
|
1771
|
-
case 2: return [4, this.signInWithUsername({
|
|
1772
|
-
verificationInfo: { verification_id: params.messageId, is_user: true },
|
|
1773
|
-
verificationCode: params.token,
|
|
1774
|
-
username: params.email || this.formatPhone(params.phone) || '',
|
|
1775
|
-
loginType: params.email ? 'email' : 'phone',
|
|
1776
|
-
})];
|
|
1777
|
-
case 3:
|
|
1778
|
-
_c.sent();
|
|
1779
|
-
_c.label = 4;
|
|
1780
|
-
case 4: return [4, this.getSession()];
|
|
1781
|
-
case 5:
|
|
1782
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1783
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1784
|
-
case 6:
|
|
1785
|
-
error_22 = _c.sent();
|
|
1786
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_22) }];
|
|
1787
|
-
case 7: return [2];
|
|
2132
|
+
_a.sent();
|
|
2133
|
+
return [2, this.createLoginState(params)];
|
|
1788
2134
|
}
|
|
1789
2135
|
});
|
|
1790
2136
|
});
|
|
1791
2137
|
};
|
|
1792
|
-
Auth.prototype.
|
|
2138
|
+
Auth.prototype.signInWithWechat = function (params) {
|
|
2139
|
+
if (params === void 0) { params = {}; }
|
|
1793
2140
|
return __awaiter(this, void 0, void 0, function () {
|
|
1794
|
-
|
|
1795
|
-
|
|
1796
|
-
|
|
1797
|
-
case 0:
|
|
1798
|
-
_c.trys.push([0, 3, , 4]);
|
|
1799
|
-
return [4, this.oauthInstance.oauth2client.getCredentials()];
|
|
2141
|
+
return __generator(this, function (_a) {
|
|
2142
|
+
switch (_a.label) {
|
|
2143
|
+
case 0: return [4, this.oauthInstance.authApi.signInWithWechat(params)];
|
|
1800
2144
|
case 1:
|
|
1801
|
-
|
|
1802
|
-
|
|
1803
|
-
return [2, { data: { session: null }, error: null }];
|
|
1804
|
-
}
|
|
1805
|
-
return [4, this.getUser()];
|
|
1806
|
-
case 2:
|
|
1807
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
1808
|
-
return [2, { data: { session: __assign(__assign({}, credentials), { user: user }), user: user }, error: null }];
|
|
1809
|
-
case 3:
|
|
1810
|
-
error_23 = _c.sent();
|
|
1811
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_23) }];
|
|
1812
|
-
case 4: return [2];
|
|
2145
|
+
_a.sent();
|
|
2146
|
+
return [2, this.createLoginState(params)];
|
|
1813
2147
|
}
|
|
1814
2148
|
});
|
|
1815
2149
|
});
|
|
1816
2150
|
};
|
|
1817
|
-
Auth.prototype.
|
|
2151
|
+
Auth.prototype.grantToken = function (params) {
|
|
1818
2152
|
return __awaiter(this, void 0, void 0, function () {
|
|
1819
|
-
|
|
1820
|
-
|
|
1821
|
-
|
|
1822
|
-
case 0:
|
|
1823
|
-
_c.trys.push([0, 4, , 5]);
|
|
1824
|
-
return [4, this.oauthInstance.oauth2client.localCredentials.getCredentials()];
|
|
2153
|
+
return __generator(this, function (_a) {
|
|
2154
|
+
switch (_a.label) {
|
|
2155
|
+
case 0: return [4, this.oauthInstance.authApi.grantToken(params)];
|
|
1825
2156
|
case 1:
|
|
1826
|
-
|
|
1827
|
-
|
|
1828
|
-
return [4, this.oauthInstance.oauth2client.refreshToken(credentials)];
|
|
1829
|
-
case 2:
|
|
1830
|
-
newTokens = _c.sent();
|
|
1831
|
-
return [4, this.getUser()];
|
|
1832
|
-
case 3:
|
|
1833
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, user = _b.user;
|
|
1834
|
-
return [2, { data: { user: user, session: __assign(__assign({}, newTokens), { user: user }) }, error: null }];
|
|
1835
|
-
case 4:
|
|
1836
|
-
error_24 = _c.sent();
|
|
1837
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_24) }];
|
|
1838
|
-
case 5: return [2];
|
|
2157
|
+
_a.sent();
|
|
2158
|
+
return [2, this.createLoginState()];
|
|
1839
2159
|
}
|
|
1840
2160
|
});
|
|
1841
2161
|
});
|
|
1842
2162
|
};
|
|
1843
|
-
Auth.prototype.
|
|
2163
|
+
Auth.prototype.genProviderRedirectUri = function (params) {
|
|
2164
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2165
|
+
return __generator(this, function (_a) {
|
|
2166
|
+
return [2, this.oauthInstance.authApi.genProviderRedirectUri(params)];
|
|
2167
|
+
});
|
|
2168
|
+
});
|
|
2169
|
+
};
|
|
2170
|
+
Auth.prototype.resetPassword = function (params) {
|
|
2171
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2172
|
+
return __generator(this, function (_a) {
|
|
2173
|
+
return [2, this.oauthInstance.authApi.resetPassword(params)];
|
|
2174
|
+
});
|
|
2175
|
+
});
|
|
2176
|
+
};
|
|
2177
|
+
Auth.prototype.deviceAuthorize = function (params) {
|
|
2178
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2179
|
+
return __generator(this, function (_a) {
|
|
2180
|
+
return [2, this.oauthInstance.authApi.deviceAuthorize(params)];
|
|
2181
|
+
});
|
|
2182
|
+
});
|
|
2183
|
+
};
|
|
2184
|
+
Auth.prototype.sudo = function (params) {
|
|
2185
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2186
|
+
return __generator(this, function (_a) {
|
|
2187
|
+
return [2, this.oauthInstance.authApi.sudo(params)];
|
|
2188
|
+
});
|
|
2189
|
+
});
|
|
2190
|
+
};
|
|
2191
|
+
Auth.prototype.deleteMe = function (params) {
|
|
2192
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2193
|
+
return __generator(this, function (_a) {
|
|
2194
|
+
return [2, this.oauthInstance.authApi.deleteMe(params)];
|
|
2195
|
+
});
|
|
2196
|
+
});
|
|
2197
|
+
};
|
|
2198
|
+
Auth.prototype.getProviders = function () {
|
|
2199
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2200
|
+
return __generator(this, function (_a) {
|
|
2201
|
+
return [2, this.oauthInstance.authApi.getProviders()];
|
|
2202
|
+
});
|
|
2203
|
+
});
|
|
2204
|
+
};
|
|
2205
|
+
Auth.prototype.loginScope = function () {
|
|
2206
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2207
|
+
return __generator(this, function (_a) {
|
|
2208
|
+
return [2, this.oauthInstance.authApi.loginScope()];
|
|
2209
|
+
});
|
|
2210
|
+
});
|
|
2211
|
+
};
|
|
2212
|
+
Auth.prototype.loginGroups = function () {
|
|
2213
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2214
|
+
return __generator(this, function (_a) {
|
|
2215
|
+
return [2, this.oauthInstance.authApi.loginGroups()];
|
|
2216
|
+
});
|
|
2217
|
+
});
|
|
2218
|
+
};
|
|
2219
|
+
Auth.prototype.onLoginStateChanged = function (callback) {
|
|
2220
|
+
var _a;
|
|
1844
2221
|
return __awaiter(this, void 0, void 0, function () {
|
|
1845
|
-
var
|
|
2222
|
+
var loginState;
|
|
2223
|
+
var _this = this;
|
|
1846
2224
|
return __generator(this, function (_b) {
|
|
1847
2225
|
switch (_b.label) {
|
|
1848
2226
|
case 0:
|
|
1849
|
-
|
|
1850
|
-
|
|
1851
|
-
|
|
2227
|
+
(_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 () {
|
|
2228
|
+
var loginState, _a;
|
|
2229
|
+
var _b;
|
|
2230
|
+
return __generator(this, function (_c) {
|
|
2231
|
+
switch (_c.label) {
|
|
2232
|
+
case 0:
|
|
2233
|
+
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];
|
|
2234
|
+
return [4, this.getLoginState()];
|
|
2235
|
+
case 1:
|
|
2236
|
+
_a = _c.sent();
|
|
2237
|
+
return [3, 3];
|
|
2238
|
+
case 2:
|
|
2239
|
+
_a = {};
|
|
2240
|
+
_c.label = 3;
|
|
2241
|
+
case 3:
|
|
2242
|
+
loginState = _a;
|
|
2243
|
+
callback.call(this, __assign(__assign({}, params), loginState));
|
|
2244
|
+
return [2];
|
|
2245
|
+
}
|
|
2246
|
+
});
|
|
2247
|
+
}); });
|
|
2248
|
+
return [4, this.getLoginState()];
|
|
1852
2249
|
case 1:
|
|
1853
|
-
|
|
1854
|
-
|
|
1855
|
-
|
|
1856
|
-
error_25 = _b.sent();
|
|
1857
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_25) }];
|
|
1858
|
-
case 3: return [2];
|
|
2250
|
+
loginState = _b.sent();
|
|
2251
|
+
callback.call(this, loginState);
|
|
2252
|
+
return [2];
|
|
1859
2253
|
}
|
|
1860
2254
|
});
|
|
1861
2255
|
});
|
|
1862
2256
|
};
|
|
1863
|
-
Auth.prototype.
|
|
2257
|
+
Auth.prototype.refreshTokenForce = function (params) {
|
|
1864
2258
|
return __awaiter(this, void 0, void 0, function () {
|
|
1865
|
-
|
|
1866
|
-
|
|
1867
|
-
|
|
1868
|
-
|
|
1869
|
-
|
|
1870
|
-
|
|
2259
|
+
return __generator(this, function (_a) {
|
|
2260
|
+
return [2, this.oauthInstance.authApi.refreshTokenForce(params)];
|
|
2261
|
+
});
|
|
2262
|
+
});
|
|
2263
|
+
};
|
|
2264
|
+
Auth.prototype.getCredentials = function () {
|
|
2265
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2266
|
+
return __generator(this, function (_a) {
|
|
2267
|
+
return [2, this.oauthInstance.authApi.getCredentials()];
|
|
2268
|
+
});
|
|
2269
|
+
});
|
|
2270
|
+
};
|
|
2271
|
+
Auth.prototype.setCredentials = function (credentials) {
|
|
2272
|
+
return __awaiter(this, void 0, void 0, function () {
|
|
2273
|
+
return __generator(this, function (_a) {
|
|
2274
|
+
switch (_a.label) {
|
|
2275
|
+
case 0: return [4, this.oauthInstance.oauth2client.setCredentials(credentials)];
|
|
1871
2276
|
case 1:
|
|
1872
|
-
|
|
1873
|
-
return [
|
|
1874
|
-
case 2:
|
|
1875
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
1876
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
1877
|
-
case 3:
|
|
1878
|
-
error_26 = _c.sent();
|
|
1879
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_26) }];
|
|
1880
|
-
case 4: return [2];
|
|
2277
|
+
_a.sent();
|
|
2278
|
+
return [2];
|
|
1881
2279
|
}
|
|
1882
2280
|
});
|
|
1883
2281
|
});
|
|
1884
2282
|
};
|
|
1885
|
-
Auth.prototype.
|
|
1886
|
-
var _a;
|
|
2283
|
+
Auth.prototype.getProviderSubType = function () {
|
|
1887
2284
|
return __awaiter(this, void 0, void 0, function () {
|
|
1888
|
-
|
|
1889
|
-
|
|
1890
|
-
return __generator(this, function (_c) {
|
|
1891
|
-
switch (_c.label) {
|
|
1892
|
-
case 0:
|
|
1893
|
-
_c.trys.push([0, 8, , 9]);
|
|
1894
|
-
hasValue = Object.keys(params).some(function (key) { return params[key] !== undefined && params[key] !== null && params[key] !== ''; });
|
|
1895
|
-
if (!hasValue) {
|
|
1896
|
-
throw new oauth_1.AuthError({ message: 'At least one field must be provided for update' });
|
|
1897
|
-
}
|
|
1898
|
-
email = params.email, phone = params.phone, restParams = __rest(params, ["email", "phone"]);
|
|
1899
|
-
needsEmailVerification_1 = email !== undefined;
|
|
1900
|
-
needsPhoneVerification = phone !== undefined;
|
|
1901
|
-
extraRes = {};
|
|
1902
|
-
if (!(needsEmailVerification_1 || needsPhoneVerification)) return [3, 4];
|
|
1903
|
-
verificationParams = void 0;
|
|
1904
|
-
if (needsEmailVerification_1) {
|
|
1905
|
-
verificationParams = { email: params.email };
|
|
1906
|
-
verificationType_1 = 'email_change';
|
|
1907
|
-
}
|
|
1908
|
-
else {
|
|
1909
|
-
formattedPhone = this.formatPhone(params.phone);
|
|
1910
|
-
verificationParams = { phone_number: formattedPhone };
|
|
1911
|
-
verificationType_1 = 'phone_change';
|
|
1912
|
-
}
|
|
1913
|
-
return [4, this.getVerification(verificationParams)];
|
|
1914
|
-
case 1:
|
|
1915
|
-
verificationInfo_4 = _c.sent();
|
|
1916
|
-
_b = Object.keys(restParams).length > 0;
|
|
1917
|
-
if (!_b) return [3, 3];
|
|
1918
|
-
return [4, this.updateUserBasicInfo(restParams)];
|
|
1919
|
-
case 2:
|
|
1920
|
-
_b = (_c.sent());
|
|
1921
|
-
_c.label = 3;
|
|
1922
|
-
case 3:
|
|
1923
|
-
_b;
|
|
1924
|
-
extraRes = {
|
|
1925
|
-
messageId: verificationInfo_4.verification_id,
|
|
1926
|
-
verifyOtp: function (verifyParams) { return __awaiter(_this, void 0, void 0, function () {
|
|
1927
|
-
var user_1, error_28;
|
|
1928
|
-
var _a;
|
|
1929
|
-
return __generator(this, function (_b) {
|
|
1930
|
-
switch (_b.label) {
|
|
1931
|
-
case 0:
|
|
1932
|
-
_b.trys.push([0, 11, , 12]);
|
|
1933
|
-
if (!(verifyParams.email && params.email === verifyParams.email)) return [3, 3];
|
|
1934
|
-
return [4, this.verifyOtp({
|
|
1935
|
-
type: 'email_change',
|
|
1936
|
-
email: params.email,
|
|
1937
|
-
token: verifyParams.token,
|
|
1938
|
-
messageId: verificationInfo_4.verification_id,
|
|
1939
|
-
})];
|
|
1940
|
-
case 1:
|
|
1941
|
-
_b.sent();
|
|
1942
|
-
return [4, this.updateUserBasicInfo({ email: params.email })];
|
|
1943
|
-
case 2:
|
|
1944
|
-
_b.sent();
|
|
1945
|
-
return [3, 9];
|
|
1946
|
-
case 3:
|
|
1947
|
-
if (!(verifyParams.phone && params.phone === verifyParams.phone)) return [3, 6];
|
|
1948
|
-
return [4, this.verifyOtp({
|
|
1949
|
-
type: 'phone_change',
|
|
1950
|
-
phone: params.phone,
|
|
1951
|
-
token: verifyParams.token,
|
|
1952
|
-
messageId: verificationInfo_4.verification_id,
|
|
1953
|
-
})];
|
|
1954
|
-
case 4:
|
|
1955
|
-
_b.sent();
|
|
1956
|
-
return [4, this.updateUserBasicInfo({ phone: this.formatPhone(params.phone) })];
|
|
1957
|
-
case 5:
|
|
1958
|
-
_b.sent();
|
|
1959
|
-
return [3, 9];
|
|
1960
|
-
case 6: return [4, this.verifyOtp({
|
|
1961
|
-
type: verificationType_1,
|
|
1962
|
-
email: needsEmailVerification_1 ? params.email : undefined,
|
|
1963
|
-
phone: !needsEmailVerification_1 ? params.phone : undefined,
|
|
1964
|
-
token: verifyParams.token,
|
|
1965
|
-
messageId: verificationInfo_4.verification_id,
|
|
1966
|
-
})];
|
|
1967
|
-
case 7:
|
|
1968
|
-
_b.sent();
|
|
1969
|
-
return [4, this.updateUserBasicInfo(params)];
|
|
1970
|
-
case 8:
|
|
1971
|
-
_b.sent();
|
|
1972
|
-
_b.label = 9;
|
|
1973
|
-
case 9: return [4, this.getUser()];
|
|
1974
|
-
case 10:
|
|
1975
|
-
user_1 = (_b.sent()).data.user;
|
|
1976
|
-
(_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 });
|
|
1977
|
-
return [2, { data: { user: user_1 }, error: null }];
|
|
1978
|
-
case 11:
|
|
1979
|
-
error_28 = _b.sent();
|
|
1980
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_28) }];
|
|
1981
|
-
case 12: return [2];
|
|
1982
|
-
}
|
|
1983
|
-
});
|
|
1984
|
-
}); },
|
|
1985
|
-
};
|
|
1986
|
-
return [3, 6];
|
|
1987
|
-
case 4: return [4, this.updateUserBasicInfo(params)];
|
|
1988
|
-
case 5:
|
|
1989
|
-
_c.sent();
|
|
1990
|
-
_c.label = 6;
|
|
1991
|
-
case 6: return [4, this.getUser()];
|
|
1992
|
-
case 7:
|
|
1993
|
-
user = (_c.sent()).data.user;
|
|
1994
|
-
(_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 });
|
|
1995
|
-
return [2, { data: __assign({ user: user }, extraRes), error: null }];
|
|
1996
|
-
case 8:
|
|
1997
|
-
error_27 = _c.sent();
|
|
1998
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_27) }];
|
|
1999
|
-
case 9: return [2];
|
|
2000
|
-
}
|
|
2285
|
+
return __generator(this, function (_a) {
|
|
2286
|
+
return [2, this.oauthInstance.authApi.getProviderSubType()];
|
|
2001
2287
|
});
|
|
2002
2288
|
});
|
|
2003
2289
|
};
|
|
2004
|
-
Auth.prototype.
|
|
2005
|
-
var _a;
|
|
2290
|
+
Auth.prototype.createCaptchaData = function (params) {
|
|
2006
2291
|
return __awaiter(this, void 0, void 0, function () {
|
|
2007
|
-
|
|
2008
|
-
|
|
2009
|
-
switch (_b.label) {
|
|
2010
|
-
case 0:
|
|
2011
|
-
_b.trys.push([0, 2, , 3]);
|
|
2012
|
-
return [4, this.oauthInstance.authApi.getProviders()];
|
|
2013
|
-
case 1:
|
|
2014
|
-
providers = _b.sent();
|
|
2015
|
-
return [2, {
|
|
2016
|
-
data: {
|
|
2017
|
-
identities: (_a = providers === null || providers === void 0 ? void 0 : providers.data) === null || _a === void 0 ? void 0 : _a.filter(function (v) { return !!v.bind; }),
|
|
2018
|
-
},
|
|
2019
|
-
error: null,
|
|
2020
|
-
}];
|
|
2021
|
-
case 2:
|
|
2022
|
-
error_29 = _b.sent();
|
|
2023
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_29) }];
|
|
2024
|
-
case 3: return [2];
|
|
2025
|
-
}
|
|
2292
|
+
return __generator(this, function (_a) {
|
|
2293
|
+
return [2, this.oauthInstance.authApi.createCaptchaData(params)];
|
|
2026
2294
|
});
|
|
2027
2295
|
});
|
|
2028
2296
|
};
|
|
2029
|
-
Auth.prototype.
|
|
2297
|
+
Auth.prototype.verifyCaptchaData = function (params) {
|
|
2030
2298
|
return __awaiter(this, void 0, void 0, function () {
|
|
2031
|
-
var error_30;
|
|
2032
2299
|
return __generator(this, function (_a) {
|
|
2033
|
-
|
|
2034
|
-
case 0:
|
|
2035
|
-
_a.trys.push([0, 2, , 3]);
|
|
2036
|
-
this.validateParams(params, {
|
|
2037
|
-
provider: { required: true, message: 'Provider is required' },
|
|
2038
|
-
});
|
|
2039
|
-
return [4, this.signInWithOAuth({
|
|
2040
|
-
provider: params.provider,
|
|
2041
|
-
options: {
|
|
2042
|
-
type: oauth_1.OAUTH_TYPE.BIND_IDENTITY,
|
|
2043
|
-
},
|
|
2044
|
-
})];
|
|
2045
|
-
case 1:
|
|
2046
|
-
_a.sent();
|
|
2047
|
-
return [2, { data: { provider: params.provider }, error: null }];
|
|
2048
|
-
case 2:
|
|
2049
|
-
error_30 = _a.sent();
|
|
2050
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_30) }];
|
|
2051
|
-
case 3: return [2];
|
|
2052
|
-
}
|
|
2300
|
+
return [2, this.oauthInstance.authApi.verifyCaptchaData(params)];
|
|
2053
2301
|
});
|
|
2054
2302
|
});
|
|
2055
2303
|
};
|
|
2056
|
-
Auth.prototype.
|
|
2304
|
+
Auth.prototype.getMiniProgramQrCode = function (params) {
|
|
2057
2305
|
return __awaiter(this, void 0, void 0, function () {
|
|
2058
|
-
var error_31;
|
|
2059
2306
|
return __generator(this, function (_a) {
|
|
2060
|
-
|
|
2061
|
-
case 0:
|
|
2062
|
-
_a.trys.push([0, 2, , 3]);
|
|
2063
|
-
this.validateParams(params, {
|
|
2064
|
-
provider: { required: true, message: 'Provider is required' },
|
|
2065
|
-
});
|
|
2066
|
-
return [4, this.oauthInstance.authApi.unbindProvider({ provider_id: params.provider })];
|
|
2067
|
-
case 1:
|
|
2068
|
-
_a.sent();
|
|
2069
|
-
return [2, { data: {}, error: null }];
|
|
2070
|
-
case 2:
|
|
2071
|
-
error_31 = _a.sent();
|
|
2072
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_31) }];
|
|
2073
|
-
case 3: return [2];
|
|
2074
|
-
}
|
|
2307
|
+
return [2, this.oauthInstance.authApi.getMiniProgramCode(params)];
|
|
2075
2308
|
});
|
|
2076
2309
|
});
|
|
2077
2310
|
};
|
|
2078
|
-
Auth.prototype.
|
|
2311
|
+
Auth.prototype.getMiniProgramQrCodeStatus = function (params) {
|
|
2079
2312
|
return __awaiter(this, void 0, void 0, function () {
|
|
2080
|
-
var user, userInfo_1, verificationInfo_5, error_32;
|
|
2081
|
-
var _this = this;
|
|
2082
2313
|
return __generator(this, function (_a) {
|
|
2083
|
-
|
|
2084
|
-
case 0:
|
|
2085
|
-
_a.trys.push([0, 3, , 4]);
|
|
2086
|
-
return [4, this.getUser()];
|
|
2087
|
-
case 1:
|
|
2088
|
-
user = (_a.sent()).data.user;
|
|
2089
|
-
this.validateAtLeastOne(user, [['email', 'phone']], 'You must provide either an email or phone number');
|
|
2090
|
-
userInfo_1 = user.email ? { email: user.email } : { phone_number: this.formatPhone(user.phone) };
|
|
2091
|
-
return [4, this.getVerification(userInfo_1)];
|
|
2092
|
-
case 2:
|
|
2093
|
-
verificationInfo_5 = _a.sent();
|
|
2094
|
-
return [2, {
|
|
2095
|
-
data: {
|
|
2096
|
-
updateUser: function (attributes) { return __awaiter(_this, void 0, void 0, function () {
|
|
2097
|
-
var verificationTokenRes, sudoRes, _a, _b, session, error_33;
|
|
2098
|
-
return __generator(this, function (_c) {
|
|
2099
|
-
switch (_c.label) {
|
|
2100
|
-
case 0:
|
|
2101
|
-
this.validateParams(attributes, {
|
|
2102
|
-
nonce: { required: true, message: 'Nonce is required' },
|
|
2103
|
-
});
|
|
2104
|
-
_c.label = 1;
|
|
2105
|
-
case 1:
|
|
2106
|
-
_c.trys.push([1, 9, , 10]);
|
|
2107
|
-
if (!attributes.password) return [3, 5];
|
|
2108
|
-
return [4, this.verify({
|
|
2109
|
-
verification_id: verificationInfo_5.verification_id,
|
|
2110
|
-
verification_code: attributes.nonce,
|
|
2111
|
-
})];
|
|
2112
|
-
case 2:
|
|
2113
|
-
verificationTokenRes = _c.sent();
|
|
2114
|
-
return [4, this.oauthInstance.authApi.sudo({
|
|
2115
|
-
verification_token: verificationTokenRes.verification_token,
|
|
2116
|
-
})];
|
|
2117
|
-
case 3:
|
|
2118
|
-
sudoRes = _c.sent();
|
|
2119
|
-
return [4, this.oauthInstance.authApi.setPassword({
|
|
2120
|
-
new_password: attributes.password,
|
|
2121
|
-
sudo_token: sudoRes.sudo_token,
|
|
2122
|
-
})];
|
|
2123
|
-
case 4:
|
|
2124
|
-
_c.sent();
|
|
2125
|
-
return [3, 7];
|
|
2126
|
-
case 5: return [4, this.signInWithUsername(__assign(__assign({ verificationInfo: verificationInfo_5, verificationCode: attributes.nonce }, userInfo_1), { loginType: userInfo_1.email ? 'email' : 'phone' }))];
|
|
2127
|
-
case 6:
|
|
2128
|
-
_c.sent();
|
|
2129
|
-
_c.label = 7;
|
|
2130
|
-
case 7: return [4, this.getSession()];
|
|
2131
|
-
case 8:
|
|
2132
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
2133
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
2134
|
-
case 9:
|
|
2135
|
-
error_33 = _c.sent();
|
|
2136
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_33) }];
|
|
2137
|
-
case 10: return [2];
|
|
2138
|
-
}
|
|
2139
|
-
});
|
|
2140
|
-
}); },
|
|
2141
|
-
},
|
|
2142
|
-
error: null,
|
|
2143
|
-
}];
|
|
2144
|
-
case 3:
|
|
2145
|
-
error_32 = _a.sent();
|
|
2146
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_32) }];
|
|
2147
|
-
case 4: return [2];
|
|
2148
|
-
}
|
|
2314
|
+
return [2, this.oauthInstance.authApi.getMiniProgramQrCodeStatus(params)];
|
|
2149
2315
|
});
|
|
2150
2316
|
});
|
|
2151
2317
|
};
|
|
2152
|
-
Auth.prototype.
|
|
2318
|
+
Auth.prototype.modifyPassword = function (params) {
|
|
2153
2319
|
return __awaiter(this, void 0, void 0, function () {
|
|
2154
|
-
var target, data, verificationId, error_34;
|
|
2155
2320
|
return __generator(this, function (_a) {
|
|
2156
|
-
|
|
2157
|
-
case 0:
|
|
2158
|
-
_a.trys.push([0, 2, , 3]);
|
|
2159
|
-
this.validateAtLeastOne(params, [['email'], ['phone']], 'You must provide either an email or phone number');
|
|
2160
|
-
target = params.type === 'signup' ? 'ANY' : 'USER';
|
|
2161
|
-
data = { target: target };
|
|
2162
|
-
if ('email' in params) {
|
|
2163
|
-
data.email = params.email;
|
|
2164
|
-
}
|
|
2165
|
-
if ('phone' in params) {
|
|
2166
|
-
data.phone_number = this.formatPhone(params.phone);
|
|
2167
|
-
}
|
|
2168
|
-
return [4, this.oauthInstance.authApi.getVerification(data)];
|
|
2169
|
-
case 1:
|
|
2170
|
-
verificationId = (_a.sent()).verification_id;
|
|
2171
|
-
return [2, {
|
|
2172
|
-
data: { messageId: verificationId },
|
|
2173
|
-
error: null,
|
|
2174
|
-
}];
|
|
2175
|
-
case 2:
|
|
2176
|
-
error_34 = _a.sent();
|
|
2177
|
-
return [2, {
|
|
2178
|
-
data: {},
|
|
2179
|
-
error: new oauth_1.AuthError(error_34),
|
|
2180
|
-
}];
|
|
2181
|
-
case 3: return [2];
|
|
2182
|
-
}
|
|
2321
|
+
return [2, this.oauthInstance.authApi.modifyPassword(params)];
|
|
2183
2322
|
});
|
|
2184
2323
|
});
|
|
2185
2324
|
};
|
|
2186
|
-
Auth.prototype.
|
|
2187
|
-
var _a;
|
|
2325
|
+
Auth.prototype.modifyPasswordWithoutLogin = function (params) {
|
|
2188
2326
|
return __awaiter(this, void 0, void 0, function () {
|
|
2189
|
-
|
|
2190
|
-
|
|
2191
|
-
switch (_d.label) {
|
|
2192
|
-
case 0:
|
|
2193
|
-
_d.trys.push([0, 3, , 4]);
|
|
2194
|
-
this.validateParams(params, {
|
|
2195
|
-
access_token: { required: true, message: 'Access token is required' },
|
|
2196
|
-
refresh_token: { required: true, message: 'Refresh token is required' },
|
|
2197
|
-
});
|
|
2198
|
-
return [4, this.oauthInstance.oauth2client.refreshToken(params, { throwError: true })];
|
|
2199
|
-
case 1:
|
|
2200
|
-
_d.sent();
|
|
2201
|
-
return [4, this.getSession()];
|
|
2202
|
-
case 2:
|
|
2203
|
-
_b = (_d.sent()).data, _c = _b === void 0 ? {} : _b, session = _c.session;
|
|
2204
|
-
(_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 });
|
|
2205
|
-
return [2, { data: { user: session.user, session: session }, error: null }];
|
|
2206
|
-
case 3:
|
|
2207
|
-
error_35 = _d.sent();
|
|
2208
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_35) }];
|
|
2209
|
-
case 4: return [2];
|
|
2210
|
-
}
|
|
2327
|
+
return __generator(this, function (_a) {
|
|
2328
|
+
return [2, this.oauthInstance.authApi.modifyPasswordWithoutLogin(params)];
|
|
2211
2329
|
});
|
|
2212
2330
|
});
|
|
2213
2331
|
};
|
|
2214
|
-
Auth.prototype.
|
|
2332
|
+
Auth.prototype.getUserBehaviorLog = function (params) {
|
|
2215
2333
|
return __awaiter(this, void 0, void 0, function () {
|
|
2216
2334
|
return __generator(this, function (_a) {
|
|
2217
|
-
return [2];
|
|
2335
|
+
return [2, this.oauthInstance.authApi.getUserBehaviorLog(params)];
|
|
2218
2336
|
});
|
|
2219
2337
|
});
|
|
2220
2338
|
};
|
|
2221
|
-
Auth.prototype.
|
|
2339
|
+
Auth.prototype.signInWithUsername = function (_a) {
|
|
2340
|
+
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;
|
|
2222
2341
|
return __awaiter(this, void 0, void 0, function () {
|
|
2223
|
-
var
|
|
2224
|
-
return __generator(this, function (
|
|
2225
|
-
switch (
|
|
2342
|
+
var verifyRes, verification_token, username, signUpParam, signInRes, bindRes, signUpRes, error_41;
|
|
2343
|
+
return __generator(this, function (_g) {
|
|
2344
|
+
switch (_g.label) {
|
|
2226
2345
|
case 0:
|
|
2227
|
-
|
|
2228
|
-
this.
|
|
2229
|
-
|
|
2230
|
-
|
|
2231
|
-
|
|
2346
|
+
_g.trys.push([0, 8, , 9]);
|
|
2347
|
+
return [4, this.oauthInstance.authApi.verify({
|
|
2348
|
+
verification_id: verificationInfo.verification_id,
|
|
2349
|
+
verification_code: verificationCode,
|
|
2350
|
+
})];
|
|
2232
2351
|
case 1:
|
|
2233
|
-
|
|
2234
|
-
|
|
2352
|
+
verifyRes = _g.sent();
|
|
2353
|
+
if (verifyRes === null || verifyRes === void 0 ? void 0 : verifyRes.error_code) {
|
|
2354
|
+
throw verifyRes;
|
|
2355
|
+
}
|
|
2356
|
+
verification_token = verifyRes.verification_token;
|
|
2357
|
+
username = this.formatPhone(rawUsername);
|
|
2358
|
+
signUpParam = { phone_number: username };
|
|
2359
|
+
if (loginType === 'email') {
|
|
2360
|
+
username = rawUsername;
|
|
2361
|
+
signUpParam = { email: username };
|
|
2362
|
+
}
|
|
2363
|
+
if (!verificationInfo.is_user) return [3, 5];
|
|
2364
|
+
return [4, this.oauthInstance.authApi.signIn({
|
|
2365
|
+
username: username,
|
|
2366
|
+
verification_token: verification_token,
|
|
2367
|
+
})];
|
|
2235
2368
|
case 2:
|
|
2236
|
-
|
|
2237
|
-
|
|
2369
|
+
signInRes = _g.sent();
|
|
2370
|
+
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
2371
|
+
throw signInRes;
|
|
2372
|
+
}
|
|
2373
|
+
if (!bindInfo) return [3, 4];
|
|
2374
|
+
return [4, this.oauthInstance.authApi.bindWithProvider({
|
|
2375
|
+
provider_token: bindInfo === null || bindInfo === void 0 ? void 0 : bindInfo.providerToken,
|
|
2376
|
+
})];
|
|
2238
2377
|
case 3:
|
|
2239
|
-
|
|
2240
|
-
|
|
2241
|
-
|
|
2242
|
-
|
|
2243
|
-
|
|
2244
|
-
|
|
2245
|
-
|
|
2246
|
-
|
|
2247
|
-
|
|
2248
|
-
|
|
2249
|
-
|
|
2250
|
-
|
|
2251
|
-
|
|
2252
|
-
|
|
2253
|
-
|
|
2254
|
-
|
|
2255
|
-
|
|
2256
|
-
|
|
2257
|
-
wx.navigateTo({ url: "/packages/$wd_system/pages/login/index".concat(query ? "?".concat(query) : '') });
|
|
2258
|
-
}
|
|
2259
|
-
else {
|
|
2260
|
-
redirectUri = params.redirect_uri || window.location.href;
|
|
2261
|
-
urlObj = new URL(redirectUri);
|
|
2262
|
-
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) : '');
|
|
2263
|
-
window.location.href = loginPage;
|
|
2264
|
-
}
|
|
2265
|
-
return [2, { data: {}, error: null }];
|
|
2266
|
-
}
|
|
2267
|
-
catch (error) {
|
|
2268
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error) }];
|
|
2378
|
+
bindRes = _g.sent();
|
|
2379
|
+
if (bindRes === null || bindRes === void 0 ? void 0 : bindRes.error_code) {
|
|
2380
|
+
throw bindRes;
|
|
2381
|
+
}
|
|
2382
|
+
_g.label = 4;
|
|
2383
|
+
case 4: return [3, 7];
|
|
2384
|
+
case 5: return [4, this.oauthInstance.authApi.signUp(__assign(__assign({}, signUpParam), { verification_token: verification_token, provider_token: bindInfo === null || bindInfo === void 0 ? void 0 : bindInfo.providerId }))];
|
|
2385
|
+
case 6:
|
|
2386
|
+
signUpRes = _g.sent();
|
|
2387
|
+
if (signUpRes === null || signUpRes === void 0 ? void 0 : signUpRes.error_code) {
|
|
2388
|
+
throw signUpRes;
|
|
2389
|
+
}
|
|
2390
|
+
_g.label = 7;
|
|
2391
|
+
case 7: return [2, this.createLoginState()];
|
|
2392
|
+
case 8:
|
|
2393
|
+
error_41 = _g.sent();
|
|
2394
|
+
throw error_41;
|
|
2395
|
+
case 9: return [2];
|
|
2269
2396
|
}
|
|
2270
|
-
return [2];
|
|
2271
2397
|
});
|
|
2272
2398
|
});
|
|
2273
2399
|
};
|
|
2274
|
-
Auth.prototype.
|
|
2400
|
+
Auth.prototype.createLoginState = function (params, options) {
|
|
2401
|
+
var _a, _b;
|
|
2275
2402
|
return __awaiter(this, void 0, void 0, function () {
|
|
2276
|
-
var loginState
|
|
2403
|
+
var loginState;
|
|
2277
2404
|
return __generator(this, function (_c) {
|
|
2278
2405
|
switch (_c.label) {
|
|
2279
2406
|
case 0:
|
|
2280
|
-
|
|
2281
|
-
this.
|
|
2282
|
-
|
|
2283
|
-
|
|
2407
|
+
loginState = new LoginState({
|
|
2408
|
+
envId: this.config.env,
|
|
2409
|
+
cache: this.cache,
|
|
2410
|
+
oauthInstance: this.oauthInstance,
|
|
2411
|
+
});
|
|
2412
|
+
return [4, loginState.checkLocalStateAsync()];
|
|
2284
2413
|
case 1:
|
|
2285
|
-
_c.trys.push([1, 5, , 6]);
|
|
2286
|
-
return [4, this.oauthInstance.authApi.signInWithCustomTicket()];
|
|
2287
|
-
case 2:
|
|
2288
2414
|
_c.sent();
|
|
2289
|
-
return [
|
|
2290
|
-
|
|
2291
|
-
|
|
2292
|
-
return [4, this.getSession()];
|
|
2293
|
-
case 4:
|
|
2294
|
-
_a = (_c.sent()).data, _b = _a === void 0 ? {} : _a, session = _b.session;
|
|
2295
|
-
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
2296
|
-
case 5:
|
|
2297
|
-
error_37 = _c.sent();
|
|
2298
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_37) }];
|
|
2299
|
-
case 6: return [2];
|
|
2300
|
-
}
|
|
2301
|
-
});
|
|
2302
|
-
});
|
|
2303
|
-
};
|
|
2304
|
-
Auth.prototype.signInWithOpenId = function (_a) {
|
|
2305
|
-
var _b = _a === void 0 ? {} : _a, _c = _b.useWxCloud, useWxCloud = _c === void 0 ? true : _c;
|
|
2306
|
-
return __awaiter(this, void 0, void 0, function () {
|
|
2307
|
-
var wxInfo, mainFunc, loginState, _d, _e, session, error_38;
|
|
2308
|
-
var _this = this;
|
|
2309
|
-
return __generator(this, function (_f) {
|
|
2310
|
-
switch (_f.label) {
|
|
2311
|
-
case 0:
|
|
2312
|
-
if (!utilities_1.adapterForWxMp.isMatch()) {
|
|
2313
|
-
throw Error('wx api undefined');
|
|
2314
|
-
}
|
|
2315
|
-
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
2316
|
-
mainFunc = function (code) { return __awaiter(_this, void 0, void 0, function () {
|
|
2317
|
-
var result, credentials, error_39;
|
|
2318
|
-
return __generator(this, function (_a) {
|
|
2319
|
-
switch (_a.label) {
|
|
2320
|
-
case 0:
|
|
2321
|
-
result = undefined;
|
|
2322
|
-
credentials = undefined;
|
|
2323
|
-
_a.label = 1;
|
|
2324
|
-
case 1:
|
|
2325
|
-
_a.trys.push([1, 4, , 5]);
|
|
2326
|
-
return [4, this.oauthInstance.authApi.grantProviderToken({
|
|
2327
|
-
provider_id: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
2328
|
-
provider_code: code,
|
|
2329
|
-
provider_params: {
|
|
2330
|
-
provider_code_type: 'open_id',
|
|
2331
|
-
appid: wxInfo === null || wxInfo === void 0 ? void 0 : wxInfo.appId,
|
|
2332
|
-
},
|
|
2333
|
-
}, useWxCloud)];
|
|
2334
|
-
case 2:
|
|
2335
|
-
result = _a.sent();
|
|
2336
|
-
if ((result === null || result === void 0 ? void 0 : result.error_code) || !result.provider_token) {
|
|
2337
|
-
throw result;
|
|
2338
|
-
}
|
|
2339
|
-
return [4, this.oauthInstance.authApi.signInWithProvider({ provider_token: result.provider_token }, useWxCloud)];
|
|
2340
|
-
case 3:
|
|
2341
|
-
credentials = _a.sent();
|
|
2342
|
-
if (credentials === null || credentials === void 0 ? void 0 : credentials.error_code) {
|
|
2343
|
-
throw credentials;
|
|
2344
|
-
}
|
|
2345
|
-
return [3, 5];
|
|
2346
|
-
case 4:
|
|
2347
|
-
error_39 = _a.sent();
|
|
2348
|
-
throw error_39;
|
|
2349
|
-
case 5: return [4, this.oauthInstance.oauth2client.setCredentials(credentials)];
|
|
2350
|
-
case 6:
|
|
2351
|
-
_a.sent();
|
|
2352
|
-
return [2];
|
|
2353
|
-
}
|
|
2354
|
-
});
|
|
2355
|
-
}); };
|
|
2356
|
-
_f.label = 1;
|
|
2357
|
-
case 1:
|
|
2358
|
-
_f.trys.push([1, 5, , 6]);
|
|
2359
|
-
return [4, new Promise(function (resolve, reject) {
|
|
2360
|
-
wx.login({
|
|
2361
|
-
success: function (res) { return __awaiter(_this, void 0, void 0, function () {
|
|
2362
|
-
var error_40;
|
|
2363
|
-
return __generator(this, function (_a) {
|
|
2364
|
-
switch (_a.label) {
|
|
2365
|
-
case 0:
|
|
2366
|
-
_a.trys.push([0, 2, , 3]);
|
|
2367
|
-
return [4, mainFunc(res.code)];
|
|
2368
|
-
case 1:
|
|
2369
|
-
_a.sent();
|
|
2370
|
-
resolve(true);
|
|
2371
|
-
return [3, 3];
|
|
2372
|
-
case 2:
|
|
2373
|
-
error_40 = _a.sent();
|
|
2374
|
-
reject(error_40);
|
|
2375
|
-
return [3, 3];
|
|
2376
|
-
case 3: return [2];
|
|
2377
|
-
}
|
|
2378
|
-
});
|
|
2379
|
-
}); },
|
|
2380
|
-
fail: function (res) {
|
|
2381
|
-
var error = new Error(res === null || res === void 0 ? void 0 : res.errMsg);
|
|
2382
|
-
error.code = res === null || res === void 0 ? void 0 : res.errno;
|
|
2383
|
-
reject(error);
|
|
2384
|
-
},
|
|
2385
|
-
});
|
|
2386
|
-
})];
|
|
2415
|
+
if (!(options === null || options === void 0 ? void 0 : options.userInfo)) return [3, 2];
|
|
2416
|
+
loginState.user.setLocalUserInfo(options.userInfo);
|
|
2417
|
+
return [3, 5];
|
|
2387
2418
|
case 2:
|
|
2388
|
-
|
|
2389
|
-
|
|
2390
|
-
|
|
2391
|
-
|
|
2392
|
-
return [4, this.getSession()];
|
|
2419
|
+
if (!(options === null || options === void 0 ? void 0 : options.asyncRefreshUser)) return [3, 3];
|
|
2420
|
+
loginState.user.refresh(params);
|
|
2421
|
+
return [3, 5];
|
|
2422
|
+
case 3: return [4, loginState.user.refresh(params)];
|
|
2393
2423
|
case 4:
|
|
2394
|
-
|
|
2395
|
-
|
|
2424
|
+
_c.sent();
|
|
2425
|
+
_c.label = 5;
|
|
2396
2426
|
case 5:
|
|
2397
|
-
|
|
2398
|
-
|
|
2399
|
-
|
|
2427
|
+
(_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 });
|
|
2428
|
+
(_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 });
|
|
2429
|
+
return [2, loginState];
|
|
2400
2430
|
}
|
|
2401
2431
|
});
|
|
2402
2432
|
});
|
|
2403
2433
|
};
|
|
2404
|
-
Auth.prototype.
|
|
2405
|
-
var
|
|
2434
|
+
Auth.prototype.setAccessKey = function () {
|
|
2435
|
+
var _a, _b;
|
|
2406
2436
|
return __awaiter(this, void 0, void 0, function () {
|
|
2407
|
-
var
|
|
2408
|
-
return __generator(this, function (
|
|
2409
|
-
|
|
2410
|
-
|
|
2411
|
-
|
|
2412
|
-
|
|
2413
|
-
|
|
2414
|
-
wxInfo = wx.getAccountInfoSync().miniProgram;
|
|
2415
|
-
providerInfo = {
|
|
2416
|
-
provider_params: { provider_code_type: 'phone' },
|
|
2417
|
-
provider_id: wxInfo.appId,
|
|
2418
|
-
};
|
|
2419
|
-
return [4, wx.login()];
|
|
2420
|
-
case 1:
|
|
2421
|
-
code = (_e.sent()).code;
|
|
2422
|
-
providerInfo.provider_code = code;
|
|
2423
|
-
_e.label = 2;
|
|
2424
|
-
case 2:
|
|
2425
|
-
_e.trys.push([2, 6, , 7]);
|
|
2426
|
-
return [4, this.oauthInstance.authApi.grantProviderToken(providerInfo)];
|
|
2427
|
-
case 3:
|
|
2428
|
-
providerToken = _e.sent();
|
|
2429
|
-
if (providerToken.error_code) {
|
|
2430
|
-
throw providerToken;
|
|
2431
|
-
}
|
|
2432
|
-
return [4, this.oauthInstance.authApi.patchProviderToken({
|
|
2433
|
-
provider_token: providerToken.provider_token,
|
|
2434
|
-
provider_id: wxInfo.appId,
|
|
2435
|
-
provider_params: {
|
|
2436
|
-
code: phoneCode,
|
|
2437
|
-
provider_code_type: 'phone',
|
|
2438
|
-
},
|
|
2439
|
-
})];
|
|
2440
|
-
case 4:
|
|
2441
|
-
providerToken = _e.sent();
|
|
2442
|
-
if (providerToken.error_code) {
|
|
2443
|
-
throw providerToken;
|
|
2444
|
-
}
|
|
2445
|
-
return [4, this.oauthInstance.authApi.signInWithProvider({
|
|
2446
|
-
provider_token: providerToken.provider_token,
|
|
2447
|
-
})];
|
|
2448
|
-
case 5:
|
|
2449
|
-
signInRes = _e.sent();
|
|
2450
|
-
if (signInRes === null || signInRes === void 0 ? void 0 : signInRes.error_code) {
|
|
2451
|
-
throw signInRes;
|
|
2452
|
-
}
|
|
2453
|
-
return [3, 7];
|
|
2454
|
-
case 6:
|
|
2455
|
-
error_41 = _e.sent();
|
|
2456
|
-
return [2, { data: {}, error: new oauth_1.AuthError(error_41) }];
|
|
2457
|
-
case 7: return [4, this.createLoginState()];
|
|
2458
|
-
case 8:
|
|
2459
|
-
loginState = _e.sent();
|
|
2460
|
-
return [4, this.getSession()];
|
|
2461
|
-
case 9:
|
|
2462
|
-
_c = (_e.sent()).data, _d = _c === void 0 ? {} : _c, session = _d.session;
|
|
2463
|
-
return [2, __assign(__assign({}, loginState), { data: { user: session.user, session: session }, error: null })];
|
|
2437
|
+
var accessToken, scope;
|
|
2438
|
+
return __generator(this, function (_c) {
|
|
2439
|
+
accessToken = '';
|
|
2440
|
+
scope = '';
|
|
2441
|
+
if (this.config.accessKey) {
|
|
2442
|
+
accessToken = this.config.accessKey;
|
|
2443
|
+
scope = 'accessKey';
|
|
2464
2444
|
}
|
|
2445
|
+
else if (((_a = this.config.auth) === null || _a === void 0 ? void 0 : _a.secretId) && ((_b = this.config.auth) === null || _b === void 0 ? void 0 : _b.secretKey)) {
|
|
2446
|
+
accessToken = '';
|
|
2447
|
+
scope = oauth_1.DEFAULT_NODE_ACCESS_SCOPE;
|
|
2448
|
+
}
|
|
2449
|
+
if (!scope) {
|
|
2450
|
+
return [2];
|
|
2451
|
+
}
|
|
2452
|
+
try {
|
|
2453
|
+
this.oauthInstance.oauth2client.setAccessKeyCredentials({
|
|
2454
|
+
access_token: accessToken,
|
|
2455
|
+
token_type: 'Bearer',
|
|
2456
|
+
scope: scope,
|
|
2457
|
+
expires_at: new Date(+new Date() + +new Date()),
|
|
2458
|
+
expires_in: +new Date() + +new Date(),
|
|
2459
|
+
});
|
|
2460
|
+
}
|
|
2461
|
+
catch (error) {
|
|
2462
|
+
console.warn('accessKey error: ', error);
|
|
2463
|
+
}
|
|
2464
|
+
return [2];
|
|
2465
2465
|
});
|
|
2466
2466
|
});
|
|
2467
2467
|
};
|
|
@@ -2902,13 +2902,12 @@ function levenshteinDistance(a, b) {
|
|
|
2902
2902
|
function findSimilarMethod(target, methods) {
|
|
2903
2903
|
var bestMatch = null;
|
|
2904
2904
|
var bestDistance = Infinity;
|
|
2905
|
-
var maxDistance = Math.max(3, Math.floor(target.length * 0.4));
|
|
2906
2905
|
for (var _i = 0, methods_1 = methods; _i < methods_1.length; _i++) {
|
|
2907
2906
|
var method = methods_1[_i];
|
|
2908
2907
|
if (method.startsWith('_') || method === 'constructor')
|
|
2909
2908
|
continue;
|
|
2910
2909
|
var distance = levenshteinDistance(target, method);
|
|
2911
|
-
if (distance < bestDistance
|
|
2910
|
+
if (distance < bestDistance) {
|
|
2912
2911
|
bestDistance = distance;
|
|
2913
2912
|
bestMatch = method;
|
|
2914
2913
|
}
|
|
@@ -2985,4 +2984,4 @@ function registerAuth(app) {
|
|
|
2985
2984
|
}
|
|
2986
2985
|
}
|
|
2987
2986
|
exports.registerAuth = registerAuth;
|
|
2988
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.js","sourceRoot":"","sources":["../../src/index.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,0CAWyB;AACzB,qCAA0C;AAC1C,yCAUoB;AACpB,iCAAqG;AACrG,yCAMoB;AAyvFK,mGA7vFvB,8BAAkB,OA6vFuB;AAAE,mGA5vF3C,8BAAkB,OA4vF2C;AAAE,sGA3vF/D,iCAAqB,OA2vF+D;AAxvFtF,kDAA4C;AAkC5C,IAAM,SAAS,GAAG,cAAM,OAAA,OAAO,MAAM,KAAK,WAAW,IAAI,OAAO,QAAQ,KAAK,WAAW,EAAhE,CAAgE,CAAA;AAmCxF,IAAM,cAAc,GAAG,MAAM,CAAA;AAkB7B,IAAM,kBAAkB,GAAG,UAAA,QAAQ,IAAI,OAAA,UAAC,MAAM;IAC5C,QAAQ,CAAC,IAAI,CAAC,cAAM,CAAC,mBAAmB,wBAAO,MAAM,KAAE,SAAS,EAAE,gCAAwB,CAAC,iBAAiB,IAAG,CAAA;AACjH,CAAC,EAFsC,CAEtC,CAAA;AAOD;IAuBE,cAAY,OAAqB;QACvB,IAAA,KAAK,GAAoB,OAAO,MAA3B,EAAE,aAAa,GAAK,OAAO,cAAZ,CAAY;QACxC,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;QAElC,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;IAIY,6BAAc,GAA3B;;;gBACE,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAW,CAAA;gBACjD,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAW,CAAA;gBACvD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAW,CAAA;gBACzD,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAW,CAAA;gBACrD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAY,CAAA;gBACvE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAW,CAAA;gBAClE,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAW,CAAA;gBAC3D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAW,CAAA;gBACnD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAW,CAAA;gBAC7D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAW,CAAA;gBAC3D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAW,CAAA;gBACvD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAW,CAAA;gBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAW,CAAA;gBAClE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAQ,CAAA;;;;KAC3D;IAIY,kCAAmB,GAAhC;;;;;;wBACE,KAAA,IAAI,CAAA;wBAAO,WAAM,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,EAAA;;wBAAlD,GAAK,GAAG,GAAG,SAAuC,CAAA;wBAClD,KAAA,IAAI,CAAA;wBAAU,WAAM,IAAI,CAAC,qBAAqB,CAAC,QAAQ,CAAC,EAAA;;wBAAxD,GAAK,MAAM,GAAG,SAA0C,CAAA;wBACxD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAW,CAAA;wBACzD,KAAA,IAAI,CAAA;wBAAS,WAAM,IAAI,CAAC,qBAAqB,CAAC,OAAO,CAAC,EAAA;;wBAAtD,GAAK,KAAK,GAAG,SAAyC,CAAA;wBACtD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC,gBAAgB,CAAC,gBAAgB,CAAY,CAAA;wBACvE,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAW,CAAA;wBAClE,KAAA,IAAI,CAAA;wBAAY,WAAM,IAAI,CAAC,qBAAqB,CAAC,UAAU,CAAC,EAAA;;wBAA5D,GAAK,QAAQ,GAAG,SAA4C,CAAA;wBAC5D,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAW,CAAA;wBACnD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAW,CAAA;wBAC7D,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,gBAAgB,CAAC,UAAU,CAAW,CAAA;wBAC3D,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,QAAQ,CAAW,CAAA;wBACvD,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,gBAAgB,CAAC,KAAK,CAAW,CAAA;wBACjD,IAAI,CAAC,WAAW,GAAG,IAAI,CAAC,gBAAgB,CAAC,cAAc,CAAW,CAAA;wBAClE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAQ,CAAA;;;;;KAC3D;IAeY,qBAAM,GAAN,UAAO,QAAgC;;;;;4BAE9B,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,cAAM,QAAQ,EAAG,EAAA;;wBAA9E,WAAW,GAAG,SAAgE;wBAEpF,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAA;;;;;KACnC;IAEY,kCAAmB,GAAhC,UAAiC,MAA6C;;;;4BAC5E,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,mBAAmB,cAAM,MAAM,EAAG,EAAA;;wBAAnE,SAAmE,CAAA;wBACnE,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;wBAApB,SAAoB,CAAA;;;;;KACrB;IAgBM,6BAAc,GAAd,UAAe,WAAmB,EAAE,WAAmB;QAC5D,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,mBAAmB,CAAC;YACpD,YAAY,EAAE,WAAW;YACzB,YAAY,EAAE,WAAW;SAC1B,CAAC,CAAA;IACJ,CAAC;IAeM,6BAAc,GAAd,UAAe,QAAgB;QACpC,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;YAChC,IAAA,sBAAU,EAAC,kBAAM,CAAC,cAAc,EAAE,2BAA2B,CAAC,CAAA;SAC/D;QAED,OAAO,IAAI,CAAC,MAAM,CAAC;YACjB,QAAQ,UAAA;SACT,CAAC,CAAA;IACJ,CAAC;IAaY,sBAAO,GAAP,UAAQ,MAA0C;;;;;4BACzC,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,EAAA;;wBAAlE,WAAW,GAAG,SAAoD;wBACxE,IAAK,WAAmB,CAAC,IAAI,KAAK,sBAAsB,EAAE;4BACxD,IAAI,CAAC,gBAAgB,CAAC,EAAE,CAAC,CAAA;4BACzB,MAAM,WAAW,CAAA;yBAClB;wBACD,IAAI,CAAC,gBAAgB,CAAC,WAAW,CAAC,CAAA;wBAClC,WAAO,WAAW,EAAA;;;;KACnB;IAEM,+BAAgB,GAAvB,UAAwB,GAAY;QAC1B,IAAA,WAAW,GAAK,IAAI,CAAC,KAAK,CAAC,IAAI,YAApB,CAAoB;QACvC,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAAA;QAEjD,IAAI,CAAC,GAAG;YAAE,OAAO,QAAQ,IAAI,EAAE,CAAA;QAE/B,OAAO,QAAQ,CAAC,GAAG,CAAC,CAAA;IACtB,CAAC;IAEM,+BAAgB,GAAvB,UAAwB,QAAa;QAC3B,IAAA,WAAW,GAAK,IAAI,CAAC,KAAK,CAAC,IAAI,YAApB,CAAoB;QACvC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,EAAE,QAAQ,CAAC,CAAA;QAC1C,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;IAEa,oCAAqB,GAAnC,UAAoC,GAAW;;;;;;wBACrC,WAAW,GAAK,IAAI,CAAC,KAAK,CAAC,IAAI,YAApB,CAAoB;wBACtB,WAAM,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,EAAA;;wBAAtD,QAAQ,GAAG,SAA2C;wBAC5D,WAAO,QAAQ,CAAC,GAAG,CAAC,EAAA;;;;KACrB;IAEO,0BAAW,GAAnB;QAAA,iBAsBC;QArBS,IAAA,WAAW,GAAK,IAAI,CAAC,KAAK,CAAC,IAAI,YAApB,CAAoB;QACvC,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,WAAW,CAAC,CAChD;QAAA;YACC,KAAK;YACL,OAAO;YACP,MAAM;YACN,QAAQ;YACR,SAAS;YACT,gBAAgB;YAChB,cAAc;YACd,WAAW;YACX,UAAU;YACV,QAAQ;YACR,KAAK;YACL,cAAc;YACd,WAAW;YACX,UAAU;YACV,YAAY;SACb,CAAC,OAAO,CAAC,UAAC,OAAO;YAChB,KAAI,CAAC,OAAO,CAAC,GAAG,QAAQ,CAAC,OAAO,CAAC,CAAA;QACnC,CAAC,CAAC,CAAA;IACJ,CAAC;IAxHY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE;gBACR,UAAU;gBACV,mCAAmC;gBACnC,oBAAoB;gBACpB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;sCAMD;IAqBM;QATN,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,QAAQ;YACf,QAAQ,EAAE;gBACR,UAAU;gBACV,2CAA2C;gBAC3C,oBAAoB;gBACpB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;8CAMD;IAeM;QATN,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,2CAA2C;gBAC3C,wBAAwB;gBACxB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;8CASD;IAaY;QARZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,YAAY;YACnB,QAAQ,EAAE;gBACR,UAAU;gBACV,oCAAoC;gBACpC,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;uCASD;IA8CH,WAAC;CAAA,AA3MD,IA2MC;AAGD,IAAA,6BAAiB,EAAC,IAAI,CAAC,CAAA;AAKvB;IAOE,oBAAY,OAA2B;QAC7B,IAAA,KAAK,GAA2B,OAAO,MAAlC,EAAE,KAAK,GAAoB,OAAO,MAA3B,EAAE,aAAa,GAAK,OAAO,cAAZ,CAAY;QAC/C,IAAI,CAAC,KAAK,EAAE;YACV,IAAA,sBAAU,EAAC,kBAAM,CAAC,cAAc,EAAE,sBAAsB,CAAC,CAAA;SAC1D;QACD,IAAI,CAAC,KAAK,GAAG,KAAK,CAAA;QAClB,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;QAElC,IAAI,CAAC,IAAI,GAAG,IAAI,IAAI,CAAC;YACnB,KAAK,EAAE,IAAI,CAAC,KAAK;YACjB,aAAa,eAAA;SACd,CAAC,CAAA;IACJ,CAAC;IAEM,oCAAe,GAAtB;;QACE,IAAI,CAAC,eAAe,GAAG,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,iBAAiB,EAAE,CAAA;QACtE,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAA;IAC5B,CAAC;IAEY,yCAAoB,GAAjC;;;;;4BACE,WAAM,CAAA,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,aAAa,EAAE,CAAA,EAAA;;wBAAjD,SAAiD,CAAA;wBACjD,WAAM,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAA;;wBAArC,SAAqC,CAAA;;;;;KACtC;IACH,iBAAC;AAAD,CAAC,AA9BD,IA8BC;AA9BY,gCAAU;AAsCvB;IAAmB,wBAAY;IAO7B,cAAY,MAAmB;QAA/B,YACE,iBAAO,SAMR;QAVO,eAAS,GAAgD,IAAI,GAAG,EAAE,CAAA;QAClE,sBAAgB,GAAG,KAAK,CAAA;QAI9B,KAAI,CAAC,MAAM,GAAG,MAAM,CAAA;QACpB,KAAI,CAAC,aAAa,GAAG,MAAM,CAAC,aAAa,CAAA;QACzC,KAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAA;QACzB,KAAI,CAAC,IAAI,EAAE,CAAA;QACX,KAAI,CAAC,YAAY,EAAE,CAAA;;IACrB,CAAC;IAgBY,8BAAe,GAAf,UAAgB,MAAmC;;;gBAC9D,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,EAAA;;;KACtD;IAeY,6BAAc,GAAd,UAAe,MAAwC;;;gBAClE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,EAAA;;;KACzD;IAiBM,wBAAS,GAAT,UAAU,MAAmC;QAClD,OAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAA;IACvD,CAAC;IAiBY,qBAAM,GAAN,UAAO,MAAgC;;;gBAClD,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAA;;;KACjD;IAiBY,8BAAe,GAAf,UACX,MAAyC,EACzC,OAAkC;;;gBAElC,IAAI,MAAM,CAAC,YAAY,EAAE;oBACvB,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;iBAC5D;gBACD,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,EAAE,OAAO,CAAC,EAAA;;;KACnE;IAKD,sBAAI,6BAAW;aAAf;YACE,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;gBAE/B,IAAA,qBAAS,EACP,kBAAM,CAAC,iBAAiB,EACxB,gFAAgF,CACjF,CAAA;gBACD,OAAM;aACP;YAED,IAAM,UAAU,GAAG,IAAI,CAAC,aAAa,EAAE,CAAA;YAEvC,IAAI,UAAU,EAAE;gBACd,OAAO,UAAU,CAAC,IAAI,IAAI,IAAI,CAAA;aAC/B;YACD,OAAO,IAAI,CAAA;QACb,CAAC;;;OAAA;IAaY,6BAAc,GAAd;;;;;4BACQ,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wBAAvC,UAAU,GAAG,SAA0B;6BACzC,UAAU,EAAV,cAAU;wBACN,QAAQ,GAAG,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAyB,CAAA;wBAC1E,WAAM,UAAU,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAA;;wBAA3C,SAA2C,CAAA;wBAC3C,WAAO,sBAAK,UAAU,CAAC,IAAI,GAAK,QAAQ,CAAoD,EAAA;4BAE9F,WAAO,IAAI,EAAA;;;;KACZ;IAqCY,oCAAqB,GAArB,UAAsB,EAI7B;YAJ6B,qBAI/B,EAAE,KAAA,EAHJ,UAAU,gBAAA;;;;;;;wBAIV,IAAI,CAAC,0BAAc,CAAC,OAAO,EAAE,EAAE;4BAC7B,MAAM,KAAK,CAAC,kBAAkB,CAAC,CAAA;yBAChC;wBACK,MAAM,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,WAAW,CAAA;wBAE5C,QAAQ,GAAG,UAAO,IAAI;;;;;wCACtB,MAAM,GAAsD,SAAS,CAAA;wCACrE,WAAW,GAA4B,SAAS,CAAA;;;;wCAGzC,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAC1D;gDACE,WAAW,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;gDAC1B,aAAa,EAAE,IAAI;gDACnB,eAAe,EAAE;oDACf,kBAAkB,EAAE,SAAS;oDAC7B,KAAK,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;iDACrB;6CACF,EACD,UAAU,CACX,EAAA;;wCAVD,MAAM,GAAG,SAUR,CAAA;wCAED,IAAI,CAAC,MAAc,aAAd,MAAM,uBAAN,MAAM,CAAU,UAAU,KAAI,CAAC,MAAM,CAAC,cAAc,EAAE;4CACzD,MAAM,MAAM,CAAA;yCACb;wCAEa,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAC9D,EAAE,cAAc,EAAE,MAAM,CAAC,cAAc,EAAE,EACzC,UAAU,CACX,EAAA;;wCAHD,WAAW,GAAG,SAGb,CAAA;wCAED,IAAK,WAAmB,aAAnB,WAAW,uBAAX,WAAW,CAAU,UAAU,EAAE;4CACpC,MAAM,WAAW,CAAA;yCAClB;;;;wCAED,MAAM,OAAK,CAAA;;;;6BAEd,CAAA;wBAED,WAAM,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;gCAChC,EAAE,CAAC,KAAK,CAAC;oCACP,OAAO,EAAE,UAAO,GAAqB;;;;;;oDAEjC,WAAM,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAA;;oDAAxB,SAAwB,CAAA;oDACxB,OAAO,CAAC,IAAI,CAAC,CAAA;;;;oDAEb,MAAM,CAAC,OAAK,CAAC,CAAA;;;;;yCAEhB;oCACD,IAAI,EAAE,UAAC,GAAQ;wCACb,IAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAC,CACnC;wCAAC,KAAa,CAAC,IAAI,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAA;wCACjC,MAAM,CAAC,KAAK,CAAC,CAAA;oCACf,CAAC;iCACF,CAAC,CAAA;4BACJ,CAAC,CAAC,EAAA;;wBAhBF,SAgBE,CAAA;wBAEF,WAAO,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,EAAE,gBAAgB,EAAE,IAAI,EAAE,CAAC,EAAA;;;;KACpE;IAgBY,yBAAU,GAAV;;;;;;;wBACX,IAAI,CAAC,0BAAc,CAAC,OAAO,EAAE,EAAE;4BAC7B,MAAM,KAAK,CAAC,kBAAkB,CAAC,CAAA;yBAChC;wBACK,MAAM,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,WAAW,CAAA;wBAE5C,QAAQ,GAAG,UAAO,IAAI;;;;;wCACtB,MAAM,GAAsD,SAAS,CAAA;;;;wCAG9D,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC;gDAC3D,WAAW,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;gDAC1B,aAAa,EAAE,IAAI;gDACnB,eAAe,EAAE;oDACf,kBAAkB,EAAE,SAAS;oDAC7B,KAAK,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;iDACrB;6CACF,CAAC,EAAA;;wCAPF,MAAM,GAAG,SAOP,CAAA;wCAEF,IAAI,CAAC,MAAc,aAAd,MAAM,uBAAN,MAAM,CAAU,UAAU,KAAI,CAAC,MAAM,CAAC,cAAc,EAAE;4CACzD,MAAM,MAAM,CAAA;yCACb;wCAED,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,cAAc,EAAE,MAAM,CAAC,cAAc,EAAE,CAAC,EAAA;;wCAA5F,SAA4F,CAAA;;;;wCAE5F,MAAM,OAAK,CAAA;;;;6BAEd,CAAA;wBAED,WAAM,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;gCAChC,EAAE,CAAC,KAAK,CAAC;oCACP,OAAO,EAAE,UAAO,GAAqB;;;;;;oDAEjC,WAAM,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAA;;oDAAxB,SAAwB,CAAA;oDACxB,OAAO,CAAC,IAAI,CAAC,CAAA;;;;oDAEb,MAAM,CAAC,OAAK,CAAC,CAAA;;;;;yCAEhB;oCACD,IAAI,EAAE,UAAC,GAAQ;wCACb,IAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAC,CACnC;wCAAC,KAAa,CAAC,IAAI,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAA;wCACjC,MAAM,CAAC,KAAK,CAAC,CAAA;oCACf,CAAC;iCACF,CAAC,CAAA;4BACJ,CAAC,CAAC,EAAA;;wBAhBF,SAgBE,CAAA;wBAEF,WAAM;;;;KACP;IAgBY,gCAAiB,GAAjB;;;;;;;wBACX,IAAI,CAAC,0BAAc,CAAC,OAAO,EAAE,EAAE;4BAC7B,MAAM,KAAK,CAAC,kBAAkB,CAAC,CAAA;yBAChC;;;;wBAEC,WAAM,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;gCAChC,IAAM,MAAM,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,WAAW,CAAA;gCAClD,EAAE,CAAC,KAAK,CAAC;oCACP,OAAO,EAAE,UAAO,GAAqB;;;;;oDAC7B,UAAU,GAAG,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,CAAA;;;;oDAEf,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC;4DACjE,aAAa,EAAE,GAAG,CAAC,IAAI;4DACvB,WAAW,EAAE,UAAU;4DACvB,eAAe,EAAE;gEACf,kBAAkB,EAAE,UAAU;gEAC9B,KAAK,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;6DACrB;yDACF,CAAC,EAAA;;oDAPI,MAAM,GAAG,SAOb;oDAEsB,aAAa,GAAK,MAAM,eAAX,CAAW;oDAEhD,IAAI,CAAC,aAAa,EAAE;wDAClB,MAAM,CAAC,MAAM,CAAC,CAAA;wDACd,WAAM;qDACP;oDAEiB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC;4DACpE,WAAW,EAAE,UAAU;4DACvB,cAAc,EAAE,aAAa;yDAC9B,CAAC,EAAA;;oDAHI,SAAS,GAAG,SAGhB;oDAEF,IAAK,SAAiB,aAAjB,SAAS,uBAAT,SAAS,CAAU,UAAU,EAAE;wDAClC,MAAM,CAAC,SAAS,CAAC,CAAA;wDACjB,WAAM;qDACP;oDACD,OAAO,CAAC,IAAI,CAAC,CAAA;;;;oDAEb,MAAM,CAAC,OAAK,CAAC,CAAA;;;;;yCAEhB;oCACD,IAAI,EAAE,UAAC,GAAQ;wCACb,IAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAC,CACnC;wCAAC,KAAa,CAAC,IAAI,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAA;wCACjC,MAAM,CAAC,KAAK,CAAC,CAAA;oCACf,CAAC;iCACF,CAAC,CAAA;4BACJ,CAAC,CAAC,EAAA;;wBA1CF,SA0CE,CAAA;;;;wBAEF,MAAM,OAAK,CAAA;4BAGb,WAAO,IAAI,CAAC,gBAAgB,EAAE,EAAA;;;;KAC/B;IAgBY,4BAAa,GAAb,UAAc,EAK1B;YAJC,wBAA0D,EAA1D,gBAAgB,mBAAG,EAAE,eAAe,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAA,EAC1D,wBAAqB,EAArB,gBAAgB,mBAAG,EAAE,KAAA,EACrB,gBAAa,EAAb,QAAQ,mBAAG,EAAE,KAAA,EACb,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA;;;gBAEpB,IAAI;oBACF,WAAO,IAAI,CAAC,kBAAkB,CAAC;4BAC7B,gBAAgB,kBAAA;4BAChB,gBAAgB,kBAAA;4BAChB,QAAQ,UAAA;4BACR,QAAQ,EAAE,QAAQ;4BAClB,SAAS,EAAE,KAAK;yBACjB,CAAC,EAAA;iBACH;gBAAC,OAAO,KAAK,EAAE;oBACd,MAAM,KAAK,CAAA;iBACZ;;;;KACF;IAgBY,8BAAe,GAAf,UAAgB,EAK5B;YAJC,wBAA0D,EAA1D,gBAAgB,mBAAG,EAAE,eAAe,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAA,EAC1D,wBAAqB,EAArB,gBAAgB,mBAAG,EAAE,KAAA,EACrB,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,aAAU,EAAV,KAAK,mBAAG,EAAE,KAAA;;;gBAEV,IAAI;oBACF,WAAO,IAAI,CAAC,kBAAkB,CAAC;4BAC7B,gBAAgB,kBAAA;4BAChB,gBAAgB,kBAAA;4BAChB,QAAQ,UAAA;4BACR,QAAQ,EAAE,KAAK;4BACf,SAAS,EAAE,OAAO;yBACnB,CAAC,EAAA;iBACH;gBAAC,OAAO,KAAK,EAAE;oBACd,MAAM,KAAK,CAAA;iBACZ;;;;KACF;IAOM,gCAAiB,GAAxB,UAAyB,SAA2C;QAClE,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;IACzD,CAAC;IA6BY,qBAAM,GAAnB,UAAoB,MAAgC;;;;4BAClD,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAA;;wBAA/C,SAA+C,CAAA;wBAC/C,WAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAA;;;;KACrC;IA4BY,0BAAW,GAAxB,UAAyB,MAAqC;;;gBAC5D,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,EAAA;;;KACtD;IAcY,mCAAoB,GAApB,UAAqB,QAAgB;;;;;;wBAChD,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;4BAChC,IAAA,sBAAU,EAAC,kBAAM,CAAC,cAAc,EAAE,2BAA2B,CAAC,CAAA;yBAC/D;wBAEiB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,EAAE,QAAQ,UAAA,EAAE,CAAC,EAAA;;wBAAzE,KAAK,GAAK,CAAA,SAA+D,CAAA,MAApE;wBACb,WAAO,KAAK,EAAA;;;;KACb;IAKM,4BAAa,GAApB;;QACE,IAAI,IAAI,CAAC,KAAK,CAAC,IAAI,KAAK,OAAO,EAAE;YAE/B,IAAA,qBAAS,EACP,kBAAM,CAAC,iBAAiB,EACxB,+EAA+E,CAChF,CAAA;YACD,OAAM;SACP;QAED,IAAM,eAAe,GAAG,MAAA,IAAI,CAAC,aAAa,0CAAE,OAAO,CAAC,iBAAiB,EAAE,CAAA;QACvE,IAAI,eAAe,EAAE;YACnB,IAAM,UAAU,GAAG,IAAI,UAAU,CAAC;gBAChC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;gBACtB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,aAAa,EAAE,IAAI,CAAC,aAAa;aAClC,CAAC,CAAA;YACF,OAAO,UAAU,CAAA;SAClB;QACD,OAAO,IAAI,CAAA;IACb,CAAC;IAcY,4BAAa,GAAb;;;;;;wBACP,eAAe,GAAG,IAAI,CAAA;;;;wBAGN,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,EAAE,EAAA;;wBAAlE,eAAe,GAAG,SAAgD,CAAA;;;;wBAElE,WAAO,IAAI,EAAA;;wBAGb,IAAI,eAAe,EAAE;4BACb,UAAU,GAAG,IAAI,UAAU,CAAC;gCAChC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;gCACtB,KAAK,EAAE,IAAI,CAAC,KAAK;gCACjB,aAAa,EAAE,IAAI,CAAC,aAAa;6BAClC,CAAC,CAAA;4BACF,WAAO,UAAU,EAAA;yBAClB;wBAED,WAAO,IAAI,EAAA;;;;KACZ;IAeY,0BAAW,GAAX;;;gBACX,WAAO,IAAI,CAAC,cAAc,EAAE,EAAA;;;KAC7B;IAWY,8BAAe,GAAf;;;gBACX,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,EAAE,EAAA;;;KACpD;IAEY,kCAAmB,GAAhC,UAAiC,MAA6C;;;;;4BACzD,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wBAAvC,UAAU,GAAG,SAA0B;6BACzC,UAAU,EAAV,cAAU;wBACZ,WAAO,UAAU,CAAC,IAAa,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAA;;wBAA3D,SAA2D,CAAA;;4BAE7D,WAAM;;;;KACP;IAMM,4BAAa,GAApB;QACE,OAAO,CAAC,KAAK,CAAC,4BAA4B,CAAC,CAAA;QAC3C,OAAO,EAAE,CAAA;IACX,CAAC;IAiBY,+BAAgB,GAAhB,UAAiB,MAA0C;;;gBACtE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAA;;;KAC3D;IAQY,wBAAS,GAAtB,UAAuB,QAA4C;;;gBACjE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,QAAQ,CAAC,EAAA;;;KAC7D;IAEY,6BAAc,GAA3B;;;;;4BAC8B,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,cAAc,EAAE,EAAA;;wBAA5E,mBAAmB,GAAG,SAAsD;wBAClF,WAAO;gCACL,WAAW,EAAE,mBAAmB;gCAChC,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;6BACrB,EAAA;;;;KACF;IAEY,iCAAkB,GAA/B,UAAgC,MAA4C;;;gBAC1E,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAA;;;KAC7D;IAEY,iCAAkB,GAA/B,UAAgC,MAA4C;;;gBAC1E,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAA;;;KAC7D;IAEY,iCAAkB,GAA/B,UAAgC,MAA4C;;;;4BAC1E,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAA;;wBAA3D,SAA2D,CAAA;wBAC3D,WAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAA;;;;KACrC;IAEY,+BAAgB,GAA7B,UAA8B,MAAgB;QAAhB,uBAAA,EAAA,WAAgB;;;;4BAC5C,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAA;;wBAAzD,SAAyD,CAAA;wBACzD,WAAO,IAAI,CAAC,gBAAgB,CAAC,MAAM,CAAC,EAAA;;;;KACrC;IAEY,yBAAU,GAAvB,UAAwB,MAAoC;;;;4BAC1D,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,CAAC,MAAM,CAAC,EAAA;;wBAAnD,SAAmD,CAAA;wBACnD,WAAO,IAAI,CAAC,gBAAgB,EAAE,EAAA;;;;KAC/B;IAEY,qCAAsB,GAAnC,UAAoC,MAAgD;;;gBAClF,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,sBAAsB,CAAC,MAAM,CAAC,EAAA;;;KACjE;IAEY,4BAAa,GAA1B,UAA2B,MAAuC;;;gBAChE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC,MAAM,CAAC,EAAA;;;KACxD;IAEY,8BAAe,GAA5B,UAA6B,MAAyC;;;gBACpE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,MAAM,CAAC,EAAA;;;KAC1D;IAEY,mBAAI,GAAjB,UAAkB,MAA8B;;;gBAC9C,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAA;;;KAC/C;IAEY,uBAAQ,GAArB,UAAsB,MAAkC;;;gBACtD,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,MAAM,CAAC,EAAA;;;KACnD;IAEY,2BAAY,GAAzB;;;gBACE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,EAAE,EAAA;;;KACjD;IAEY,yBAAU,GAAvB;;;gBACE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,UAAU,EAAE,EAAA;;;KAC/C;IAEY,0BAAW,GAAxB;;;gBACE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,EAAE,EAAA;;;KAChD;IAEY,kCAAmB,GAAhC,UAAiC,QAAkB;;;;;;;;wBACjD,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,EAAE,CAAC,cAAM,CAAC,mBAAmB,EAAE,UAAO,MAAM;;;;;;6CAE7C,CAAA,CAAA,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,0CAAE,SAAS,MAAK,gCAAwB,CAAC,iBAAiB,CAAA,EAAtE,cAAsE;wCAAG,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wCAA1B,KAAA,SAA0B,CAAA;;;wCAAG,KAAA,EAAE,CAAA;;;wCAArH,UAAU,KAA2G;wCAC3H,QAAQ,CAAC,IAAI,CAAC,IAAI,wBAAO,MAAM,GAAK,UAAU,EAAG,CAAA;;;;6BAClD,CAAC,CAAA;wBAEiB,WAAM,IAAI,CAAC,aAAa,EAAE,EAAA;;wBAAvC,UAAU,GAAG,SAA0B;wBAC7C,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE,UAAU,CAAC,CAAA;;;;;KAChC;IASY,gCAAiB,GAA9B,UAA+B,MAA4B;;;gBACzD,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAA;;;KAC5D;IAMY,6BAAc,GAA3B;;;gBACE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,EAAE,EAAA;;;KACnD;IAIY,6BAAc,GAA3B,UAA4B,WAAwB;;;;4BAClD,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,cAAc,CAAC,WAAW,CAAC,EAAA;;wBAAjE,SAAiE,CAAA;;;;;KAClE;IAUY,iCAAkB,GAAlB;;;gBACX,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,EAAE,EAAA;;;KACvD;IAEY,gCAAiB,GAA9B,UAA+B,MAAgD;;;gBAC7E,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAA;;;KAC5D;IAEY,gCAAiB,GAA9B,UAA+B,MAAsC;;;gBACnE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAA;;;KAC5D;IAEY,mCAAoB,GAAjC,UAAkC,MAA8C;;;gBAC9E,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAA;;;KAC7D;IAEY,yCAA0B,GAAvC,UAAwC,MAAoD;;;gBAC1F,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,0BAA0B,CAAC,MAAM,CAAC,EAAA;;;KACrE;IAEY,6BAAc,GAA3B,UAA4B,MAA6C;;;gBACvE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,MAAM,CAAC,EAAA;;;KACzD;IAEY,yCAA0B,GAAvC,UAAwC,MAAoD;;;gBAC1F,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,0BAA0B,CAAC,MAAM,CAAC,EAAA;;;KACrE;IAEY,iCAAkB,GAA/B,UAAgC,MAAqC;;;gBACnE,WAAO,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,MAAM,CAAC,EAAA;;;KAC7D;IAKY,iCAAkB,GAA/B,UAAgC,EAY/B;YAXC,wBAA0D,EAA1D,gBAAgB,mBAAG,EAAE,eAAe,EAAE,EAAE,EAAE,OAAO,EAAE,KAAK,EAAE,KAAA,EAC1D,wBAAqB,EAArB,gBAAgB,mBAAG,EAAE,KAAA,EACrB,gBAA0B,EAAhB,WAAW,mBAAG,EAAE,KAAA,EAC1B,gBAAoB,EAApB,QAAQ,mBAAG,SAAS,KAAA,EACpB,iBAAc,EAAd,SAAS,mBAAG,EAAE,KAAA;;;;;;;wBAUM,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC;gCACxD,eAAe,EAAE,gBAAgB,CAAC,eAAe;gCACjD,iBAAiB,EAAE,gBAAgB;6BACpC,CAAC,EAAA;;wBAHI,SAAS,GAAG,SAGhB;wBAEF,IAAK,SAAiB,aAAjB,SAAS,uBAAT,SAAS,CAAU,UAAU,EAAE;4BAClC,MAAM,SAAS,CAAA;yBAChB;wBAGO,kBAAkB,GAAK,SAAS,mBAAd,CAAc;wBAGpC,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,WAAW,CAAC,CAAA;wBACxC,WAAW,GAAQ,EAAE,YAAY,EAAE,QAAQ,EAAE,CAAA;wBAGjD,IAAI,SAAS,KAAK,OAAO,EAAE;4BACzB,QAAQ,GAAG,WAAW,CAAA;4BACtB,WAAW,GAAG,EAAE,KAAK,EAAE,QAAQ,EAAE,CAAA;yBAClC;6BAGG,gBAAgB,CAAC,OAAO,EAAxB,cAAwB;wBAER,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC;gCACxD,QAAQ,UAAA;gCACR,kBAAkB,oBAAA;6BACnB,CAAC,EAAA;;wBAHI,SAAS,GAAG,SAGhB;wBAEF,IAAK,SAAiB,aAAjB,SAAS,uBAAT,SAAS,CAAU,UAAU,EAAE;4BAClC,MAAM,SAAS,CAAA;yBAChB;6BAEG,QAAQ,EAAR,cAAQ;wBACM,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,gBAAgB,CAAC;gCAChE,cAAc,EAAG,QAAgB,aAAhB,QAAQ,uBAAR,QAAQ,CAAU,aAAa;6BACjD,CAAC,EAAA;;wBAFI,OAAO,GAAG,SAEd;wBAEF,IAAK,OAAe,aAAf,OAAO,uBAAP,OAAO,CAAU,UAAU,EAAE;4BAChC,MAAM,OAAO,CAAA;yBACd;;;4BAIe,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,uBACpD,WAAW,KACd,kBAAkB,oBAAA,EAClB,cAAc,EAAG,QAAgB,aAAhB,QAAQ,uBAAR,QAAQ,CAAU,UAAU,IAC7C,EAAA;;wBAJI,SAAS,GAAG,SAIhB;wBAEF,IAAK,SAAiB,aAAjB,SAAS,uBAAT,SAAS,CAAU,UAAU,EAAE;4BAClC,MAAM,SAAS,CAAA;yBAChB;;4BAGH,WAAO,IAAI,CAAC,gBAAgB,EAAE,EAAA;;;wBAE9B,MAAM,OAAK,CAAA;;;;;KAEd;IAEK,+BAAgB,GAAtB,UACE,MAA0C,EAC1C,OAAwD;;;;;;;wBAElD,UAAU,GAAG,IAAI,UAAU,CAAC;4BAChC,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;4BACtB,KAAK,EAAE,IAAI,CAAC,KAAK;4BACjB,aAAa,EAAE,IAAI,CAAC,aAAa;yBAClC,CAAC,CAAA;wBAEF,WAAM,UAAU,CAAC,oBAAoB,EAAE,EAAA;;wBAAvC,SAAuC,CAAA;6BAEnC,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,CAAA,EAAjB,cAAiB;wBACnB,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAA;;;6BAE9C,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,gBAAgB,CAAA,EAAzB,cAAyB;wBAC3B,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;;4BAE/B,WAAM,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,EAAA;;wBAArC,SAAqC,CAAA;;;wBAIzC,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,mBAAmB,EAAE,EAAE,SAAS,EAAE,gCAAwB,CAAC,OAAO,EAAE,CAAC,CAAA;wBAEvG,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,SAAS,EAAE,CAAC,CAAA;wBACnG,WAAO,UAAU,EAAA;;;;KAClB;IAEK,2BAAY,GAAlB;;;;;gBACM,WAAW,GAAG,EAAE,CAAA;gBAChB,KAAK,GAAG,EAAE,CAAA;gBACd,IAAI,IAAI,CAAC,MAAM,CAAC,SAAS,EAAE;oBACzB,WAAW,GAAG,IAAI,CAAC,MAAM,CAAC,SAAS,CAAA;oBACnC,KAAK,GAAG,WAAW,CAAA;iBACpB;qBAAM,IAAI,CAAA,MAAA,IAAI,CAAC,MAAM,CAAC,IAAI,0CAAE,QAAQ,MAAI,MAAA,IAAI,CAAC,MAAM,CAAC,IAAI,0CAAE,SAAS,CAAA,EAAE;oBACpE,WAAW,GAAG,EAAE,CAAA;oBAChB,KAAK,GAAG,iCAAyB,CAAA;iBAClC;gBAED,IAAI,CAAC,KAAK,EAAE;oBACV,WAAM;iBACP;gBAED,IAAI;oBACF,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,uBAAuB,CAAC;wBACtD,YAAY,EAAE,WAAW;wBACzB,UAAU,EAAE,QAAQ;wBACpB,KAAK,OAAA;wBACL,UAAU,EAAE,IAAI,IAAI,CAAC,CAAC,IAAI,IAAI,EAAE,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC;wBAC/C,UAAU,EAAE,CAAC,IAAI,IAAI,EAAE,GAAG,CAAC,IAAI,IAAI,EAAE;qBACtC,CAAC,CAAA;iBACH;gBAAC,OAAO,KAAK,EAAE;oBACd,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAA;iBACzC;;;;KACF;IAWK,gCAAiB,GAAvB,UAAwB,MAA4B;;;;;;;wBAEhD,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,iBAAiB,CAAC,MAAM,CAAC,EAAA;;wBAA1D,SAA0D,CAAA;wBACvC,WAAM,IAAI,CAAC,gBAAgB,EAAE,EAAA;;wBAA1C,UAAU,GAAG,SAA6B;wBAEb,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAGvB,iCAAa,UAAkB,KAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,KAAE;;;wBAErF,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,OAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,qBAAM,GAAZ,UAAa,MAAqD;;;;;;;6BAC5D,CAAA,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,iBAAiB,IAAI,MAAM,CAAC,kBAAkB,IAAI,MAAM,CAAC,cAAc,CAAA,EAArG,cAAqG;wBACvG,MAAM,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,YAAY,CAAC,CAAA;wBAC3D,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,CAAC,MAAM,CAAC,EAAA;;wBAA/C,SAA+C,CAAA;wBAC/C,WAAO,IAAI,CAAC,gBAAgB,EAAS,EAAA;;;wBAIrC,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,kDAAkD,CAAC,CAAA;wBAGlF,WAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAE,EAAA;;wBAAzI,qBAAmB,SAAsH;wBAE/I,WAAO;gCACL,IAAI,EAAE;oCAEJ,SAAS,EAAE,UAAO,EAAuD;4CAArD,KAAK,WAAA,EAAE,iBAA4C,EAA5C,SAAS,mBAAG,kBAAgB,CAAC,eAAe,KAAA;;;;;;;wDAGtC,WAAM,IAAI,CAAC,MAAM,CAAC;gEAC7C,eAAe,EAAE,SAAS,IAAI,kBAAgB,CAAC,eAAe;gEAC9D,iBAAiB,EAAE,KAAK;6DACzB,CAAC,EAAA;;wDAHI,oBAAoB,GAAG,SAG3B;6DAIE,kBAAgB,CAAC,OAAO,EAAxB,cAAwB;wDAC1B,WAAM,IAAI,CAAC,MAAM,CAAC;gEAChB,QAAQ,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC;gEACxD,kBAAkB,EAAE,oBAAoB,CAAC,kBAAkB;6DAC5D,CAAC,EAAA;;wDAHF,SAGE,CAAA;;;wDAGI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,MAAM,CAAC,CAAC,CAAA;wDAC/C,OAAO,IAAI,CAAC,KAAK,CAAA;wDACjB,OAAO,IAAI,CAAC,KAAK,CAAA;wDAEjB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,MAAM,gCAClC,IAAI,GACJ,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,KAC9F,kBAAkB,EAAE,oBAAoB,CAAC,kBAAkB,EAC3D,iBAAiB,EAAE,KAAK,IACxB,EAAA;;wDALF,SAKE,CAAA;wDACF,WAAM,IAAI,CAAC,gBAAgB,EAAE,EAAA;;wDAA7B,SAA6B,CAAA;;4DAGI,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wDAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wDAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wDAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;qCAEnD;iCACF;gCACD,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,sBAAO,GAAb,UAAc,MAAkC;;;;;;;;wBAEpC,WAAW,GAAK,IAAI,CAAC,KAAK,CAAC,IAAI,YAApB,CAAoB;wBAC3B,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,OAAO,CAAC,MAAM,CAAC,EAAA;;wBAAtD,GAAG,GAAG,SAAgD;wBAC5D,WAAM,IAAI,CAAC,KAAK,CAAC,gBAAgB,CAAC,WAAW,CAAC,EAAA;;wBAA9C,SAA8C,CAAA;wBAC9C,IAAI,CAAC,YAAY,EAAE,CAAA;wBAEnB,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,mBAAmB,EAAE,EAAE,SAAS,EAAE,gCAAwB,CAAC,QAAQ,EAAE,CAAC,CAAA;wBAExG,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,UAAU,EAAE,CAAC,CAAA;wBAGpG,iCAAY,GAAG,KAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,KAAE;;;wBAExC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQD,gCAAiB,GAAjB,UAAkB,QAAmC;QAArD,iBAgCC;QA/BC,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;YAC1B,IAAI,CAAC,cAAc,EAAE,CAAA;YACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAA;SAC7B;QAED,IAAM,EAAE,GAAG,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC,CAAA;QAErC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,EAAE;YAC3B,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,GAAG,EAAE,CAAC,CAAA;SAClC;QAED,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAE,CAAC,GAAG,CAAC,QAAQ,CAAC,CAAA;QAGrC,IAAM,YAAY,GAAG;YACnB,EAAE,IAAA;YACF,QAAQ,UAAA;YACR,WAAW,EAAE;gBACX,IAAM,SAAS,GAAG,KAAI,CAAC,SAAS,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;gBACxC,IAAI,SAAS,EAAE;oBACb,SAAS,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;oBAC1B,IAAI,SAAS,CAAC,IAAI,KAAK,CAAC,EAAE;wBACxB,KAAI,CAAC,SAAS,CAAC,MAAM,CAAC,EAAE,CAAC,CAAA;qBAC1B;iBACF;YACH,CAAC;SACF,CAAA;QAED,OAAO;YACL,IAAI,EAAE,EAAE,YAAY,cAAA,EAAE;SACvB,CAAA;IACH,CAAC;IAQK,iCAAkB,GAAxB,UAAyB,MAA6B;;;;;;;;wBAGlD,IAAI,CAAC,kBAAkB,CACrB,MAAM,EACN,CAAC,CAAC,UAAU,CAAC,EAAE,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,EACpC,mDAAmD,CACpD,CAAA;wBACD,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;yBAC9D,CAAC,CAAA;wBAEF,WAAM,IAAI,CAAC,MAAM,YACf,QAAQ,EAAE,MAAM,CAAC,QAAQ,IAAI,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAC3E,QAAQ,EAAE,MAAM,CAAC,QAAQ,IACtB,CAAC,MAAM,CAAC,UAAU,CAAC,CAAC,CAAC,EAAE,SAAS,EAAE,IAAI,EAAE,OAAO,EAAE,IAAI,EAAE,CAAC,CAAC,CAAC,EAAE,CAAC,EAChE,EAAA;;wBAJF,SAIE,CAAA;wBACiC,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEvD,SAAS,GAAG,IAAI,iBAAS,CAAC,QAAK,CAAC,CAAA;wBAEtC,IAAI,CAAA,MAAA,SAAS,CAAC,OAAO,0CAAE,QAAQ,CAAC,OAAO,CAAC,MAAI,MAAA,SAAS,CAAC,OAAO,0CAAE,QAAQ,CAAC,UAAU,CAAC,CAAA,EAAE;4BACnF,OAAO,CAAC,IAAI,CAAC,4BAA4B;kCACrC,0BAA0B;kCAC1B,kBAAkB;kCAClB,uDAAuD;kCACvD,wCAAwC,CAAE,CAAA;yBAC/C;wBACD,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,SAAS,EAAE,EAAA;;;;;KAExC;IAQK,gCAAiB,GAAvB,UAAwB,MAA4B;;;;;;;wBAGhD,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,mBAAmB,EAAE;yBACxD,CAAC,CAAA;wBAEF,WAAM,IAAI,CAAC,kBAAkB,CAAC;gCAC5B,cAAc,EAAE,MAAM,CAAC,KAAK;6BAC7B,CAAC,EAAA;;wBAFF,SAEE,CAAA;wBACiC,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,4BAAa,GAAnB,UAAoB,MAAwB;;;;;;;;wBAC1C,IAAI,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,gBAAgB,MAAK,SAAS,IAAI,CAAC,CAAC,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,gBAAgB,CAAA,EAAE;4BACxF,WAAO,IAAI,CAAC,MAAM,CAAC;oCACjB,KAAK,EAAE,MAAM,CAAC,KAAK;oCACnB,KAAK,EAAE,MAAM,CAAC,KAAK;iCACpB,CAAC,EAAA;yBACH;;;;wBAIC,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,kDAAkD,CAAC,CAAA;wBAGlF,WAAM,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAE,EAAA;;wBAAzI,qBAAmB,SAAsH;wBAE/I,WAAO;gCACL,IAAI,EAAE;oCACJ,IAAI,EAAE,IAAI;oCACV,OAAO,EAAE,IAAI;oCAEb,SAAS,EAAE,UAAO,EAAuD;4CAArD,KAAK,WAAA,EAAE,iBAA4C,EAA5C,SAAS,mBAAG,kBAAgB,CAAC,eAAe,KAAA;;;gDAA2B,WAAA,IAAI,CAAC,SAAS,CAAC;wDAC/G,KAAK,EAAE,MAAM,CAAC,KAAK;wDACnB,KAAK,EAAE,MAAM,CAAC,KAAK;wDACnB,KAAK,OAAA;wDACL,SAAS,WAAA;qDACV,CAAC,EAAA;;;qCAAA;iCACH;gCACD,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,0BAAW,GAAjB,UAAkB,MAAuB;;;;;;wBACjC,IAAI,GAAQ,EAAE,CAAA;;;;wBAGZ,IAAI,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,KAAI,iBAAK,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAA;wBAC7C,KAAK,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK,KAAI,iBAAK,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAA;wBAGtD,IAAI,CAAC,IAAI,EAAE;4BACT,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,EAAE,EAAA;yBAC3E;wBAED,IAAI,CAAC,KAAK,EAAE;4BACV,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,mBAAmB,EAAE,CAAC,EAAE,EAAA;yBAC5E;wBAEK,SAAS,GAAG,IAAA,yBAAiB,EAAC,KAAK,CAAC,CAAA;wBAC1C,IAAI,CAAC,IAAI,GAAG,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,IAAI,CAAA;wBAErB,QAAQ,GAAG,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,QAAQ,MAAI,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,QAAQ,CAAA,IAAI,iBAAK,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAA;wBAEtF,IAAI,CAAC,QAAQ,EAAE;4BACb,WAAO,EAAE,IAAI,MAAA,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,sBAAsB,EAAE,CAAC,EAAE,EAAA;yBAC3E;wBAGiC,WAAM,IAAI,CAAC,kBAAkB,CAAC;gCAC9D,WAAW,EAAE,QAAQ;gCACrB,qBAAqB,EAAE,QAAQ,CAAC,MAAM,GAAG,QAAQ,CAAC,QAAQ;gCAC1D,aAAa,EAAE,IAAI;6BACpB,CAAC,EAAA;;wBAJsB,KAAK,GAAK,CAAA,SAIhC,CAAA,eAJ2B;wBAMzB,GAAG,SAAgB,CAAA;6BAEnB,CAAA,SAAS,CAAC,IAAI,KAAK,kBAAU,CAAC,aAAa,CAAA,EAA3C,cAA2C;wBACvC,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,cAAc,EAAE,KAAK,EAAE,QAAQ,UAAA,EAAE,SAAS,EAAE,IAAI,EAAE,CAAC,EAAA;;wBAA3G,GAAG,GAAG,SAAqG,CAAA;;4BAGrG,WAAM,IAAI,CAAC,iBAAiB,CAAC;4BACjC,KAAK,OAAA;yBACN,CAAC,EAAA;;wBAFF,GAAG,GAAG,SAEJ,CAAA;wBACF,GAAG,CAAC,IAAI,yBAAQ,IAAI,GAAK,GAAG,CAAC,IAAI,CAAE,CAAA;;;wBAG/B,WAAW,GAAG,IAAI,eAAe,CAAC,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM,CAAC,CAAA;wBACzD,WAAW,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;wBAC1B,WAAW,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;wBAC3B,GAAG,CAAC,IAAI,CAAC,WAAW,GAAG,IAAA,oBAAY,EACjC,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,MAAK,SAAS,CAAC,CAAC,CAAC,WAAI,WAAW,CAAC,QAAQ,EAAE,CAAE,CAAC,CAAC,CAAC,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,MAAM,EAClF,CAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,IAAI,KAAI,QAAQ,CAAC,IAAI,CACjC,CAAA;wBACD,IAAA,4BAAoB,EAAC,KAAK,CAAC,CAAA;wBAE3B,WAAO,GAAG,EAAA;;;wBAEV,WAAO,EAAE,IAAI,MAAA,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAE/C;IAQK,8BAAe,GAArB,UAAsB,MAA0B;;;;;;;;wBAG5C,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;yBAC9D,CAAC,CAAA;wBAEI,IAAI,GAAG,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,UAAU,KAAI,QAAQ,CAAC,IAAI,CAAA;wBAElD,SAAS,GAAG,IAAI,GAAG,CAAC,IAAI,CAAC,CAAA;wBAEzB,qBAAqB,GAAG,SAAS,CAAC,MAAM,GAAG,SAAS,CAAC,QAAQ,CAAA;wBAE7D,KAAK,GAAG,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,KAAK,KAAI,cAAO,MAAM,CAAC,QAAQ,cAAI,IAAI,CAAC,MAAM,EAAE,CAAC,QAAQ,CAAC,EAAE,CAAC;6BACxF,KAAK,CAAC,CAAC,CAAC,CAAE,CAAA;wBAEG,WAAM,IAAI,CAAC,sBAAsB,CAAC;gCAChD,WAAW,EAAE,MAAM,CAAC,QAAQ;gCAC5B,qBAAqB,uBAAA;gCACrB,KAAK,OAAA;6BACN,CAAC,EAAA;;wBAJM,GAAG,GAAK,CAAA,SAId,CAAA,IAJS;wBAOL,UAAU,GAAG,kBAAkB,CAAC,GAAG,CAAC,CAAA;wBAGtC,QAAQ,GAAG,UAAU,CAAA;wBAEzB,IAAI,MAAA,MAAM,CAAC,OAAO,0CAAE,WAAW,EAAE;4BACzB,QAAM,IAAI,GAAG,CAAC,UAAU,CAAC,CAAA;4BAC/B,MAAM,CAAC,OAAO,CAAC,MAAM,CAAC,OAAO,CAAC,WAAW,CAAC,CAAC,OAAO,CAAC,UAAC,EAAY;oCAAX,GAAG,QAAA,EAAE,KAAK,QAAA;gCAC7D,KAAG,CAAC,YAAY,CAAC,GAAG,CAAC,GAAG,EAAE,KAAK,CAAC,CAAA;4BAClC,CAAC,CAAC,CAAA;4BACF,QAAQ,GAAG,KAAG,CAAC,QAAQ,EAAE,CAAA;yBAC1B;wBAED,IAAA,4BAAoB,EAAC,KAAK,EAAE;4BAC1B,QAAQ,EAAE,MAAM,CAAC,QAAQ;4BACzB,MAAM,EAAE,SAAS,CAAC,MAAM;4BACxB,IAAI,EAAE,SAAS,CAAC,IAAI;4BACpB,IAAI,EAAE,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,IAAI,KAAI,kBAAU,CAAC,OAAO;yBACjD,CAAC,CAAA;wBAEF,IAAI,SAAS,EAAE,IAAI,CAAC,CAAA,MAAA,MAAM,CAAC,OAAO,0CAAE,mBAAmB,CAAA,EAAE;4BACvD,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,QAAQ,CAAC,CAAA;yBACjC;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,GAAG,EAAE,QAAQ,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE1E,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAGK,wBAAS,GAAf;;;;;;;wBAE4B,WAAM,IAAI,CAAC,cAAc,EAAE,EAAA;;wBAA3C,WAAW,GAAK,CAAA,SAA2B,CAAA,YAAhC;wBACb,WAAW,GAAG,IAAA,yBAAiB,EAAC,WAAW,CAAC,CAAA;wBAClD,WAAO,EAAE,IAAI,EAAE,WAAW,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEzC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,oCAAqB,GAA3B,UACE,YAAoB,EACpB,OAAiC;;;;;;;;wBAI/B,IAAI,CAAC,cAAc,CACjB,EAAE,YAAY,cAAA,EAAE,EAChB;4BACE,YAAY,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,4BAA4B,EAAE;yBACxE,CACF,CAAA;wBAEO,eAAe,CAAA,OAAO,IAAI,EAAE,CAAA,WAAlB,CAAkB;wBAG9B,YAAU,YAAY,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAA;wBACtC,kBAAkB,SAA2C,CAAA;wBAEjE,IAAI,SAAO,EAAE;4BACX,kBAAkB,GAAG,EAAE,KAAK,EAAE,YAAY,EAAE,CAAA;yBAC7C;6BAAM;4BAEC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,YAAY,CAAC,CAAA;4BACrD,kBAAkB,GAAG,EAAE,YAAY,EAAE,cAAc,EAAE,CAAA;yBACtD;wBAGwB,WAAM,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,EAAA;;wBAAjE,qBAAmB,SAA8C;wBAEvE,WAAO;gCACL,IAAI,EAAE;oCAEJ,UAAU,EAAE,UAAO,UAAgC;;;;;;oDACjD,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE;wDAC9B,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,mBAAmB,EAAE;wDACvD,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;qDAC9D,CAAC,CAAA;;;;oDAG6B,WAAM,IAAI,CAAC,MAAM,CAAC;4DAC7C,eAAe,EAAE,kBAAgB,CAAC,eAAe;4DACjD,iBAAiB,EAAE,UAAU,CAAC,KAAK;yDACpC,CAAC,EAAA;;oDAHI,oBAAoB,GAAG,SAG3B;oDAEF,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,aAAa,CAAC;4DAC7C,KAAK,EAAE,SAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;4DACzC,YAAY,EAAE,CAAC,SAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;4DACjD,YAAY,EAAE,UAAU,CAAC,QAAQ;4DACjC,kBAAkB,EAAE,oBAAoB,CAAC,kBAAkB;yDAC5D,CAAC,EAAA;;oDALF,SAKE,CAAA;oDAEF,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE;wDACpD,KAAK,EAAE,+BAAuB,CAAC,iBAAiB;qDACjD,CAAC,CAAA;oDAEU,WAAM,IAAI,CAAC,kBAAkB,CAAC;4DACxC,KAAK,EAAE,SAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;4DACzC,KAAK,EAAE,CAAC,SAAO,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,SAAS;4DAC1C,QAAQ,EAAE,UAAU,CAAC,QAAQ;yDAC9B,CAAC,EAAA;;oDAJI,GAAG,GAAG,SAIV;oDAEF,IAAI,YAAU,IAAI,SAAS,EAAE,EAAE;wDAC7B,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,YAAU,CAAC,CAAA;qDACnC;oDAED,WAAO,GAAG,EAAA;;;oDAEV,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;yCAEnD;iCACF;gCACD,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,kCAAmB,GAAzB,UAA0B,MAA8B;;;;;;;wBAEpD,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,mBAAmB,CAAC;gCACnD,YAAY,EAAE,MAAM,CAAC,YAAY;gCACjC,YAAY,EAAE,MAAM,CAAC,YAAY;6BAClC,CAAC,EAAA;;wBAHF,SAGE,CAAA;wBAEiC,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,wBAAS,GAAf,UAAgB,MAAoB;;;;;;;wBAExB,IAAI,GAAK,MAAM,KAAX,CAAW;wBAEvB,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,mBAAmB,EAAE;4BACvD,SAAS,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,uBAAuB,EAAE;yBAChE,CAAC,CAAA;6BAEE,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,EAA/C,cAA+C;wBACjD,WAAM,IAAI,CAAC,MAAM,CAAC;gCAChB,eAAe,EAAE,MAAM,CAAC,SAAS;gCACjC,iBAAiB,EAAE,MAAM,CAAC,KAAK;6BAChC,CAAC,EAAA;;wBAHF,SAGE,CAAA;;4BAEF,WAAM,IAAI,CAAC,kBAAkB,CAAC;4BAC5B,gBAAgB,EAAE,EAAE,eAAe,EAAE,MAAM,CAAC,SAAS,EAAE,OAAO,EAAE,IAAI,EAAE;4BACtE,gBAAgB,EAAE,MAAM,CAAC,KAAK;4BAC9B,QAAQ,EAAE,MAAM,CAAC,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,EAAE;4BAC9D,SAAS,EAAE,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO;yBAC5C,CAAC,EAAA;;wBALF,SAKE,CAAA;;4BAG+B,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,yBAAU,GAAhB;;;;;;;wBAEqC,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,cAAc,EAAE,EAAA;;wBAAjF,WAAW,GAAgB,SAAsD;wBAEvF,IAAI,CAAC,WAAW,IAAI,WAAW,CAAC,KAAK,KAAK,WAAW,EAAE;4BACrD,WAAO,EAAE,IAAI,EAAE,EAAE,OAAO,EAAE,IAAI,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;yBAChD;wBAE+B,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;wBAA5C,KAAwB,CAAA,SAAoB,CAAA,KAAzB,EAAnB,qBAAiB,EAAE,KAAA,EAAX,IAAI,UAAA;wBAEpB,WAAO,EAAE,IAAI,EAAE,EAAE,OAAO,wBAAO,WAAW,KAAE,IAAI,MAAA,GAAE,EAAE,IAAI,MAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEzE,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,6BAAc,GAApB,UAAqB,aAAsB;;;;;;;wBAEN,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,gBAAgB,CAAC,cAAc,EAAE,EAAA;;wBAAlG,WAAW,GAAgB,SAAuE;wBACxG,WAAW,CAAC,aAAa,GAAG,aAAa,IAAI,WAAW,CAAC,aAAa,CAAA;wBACpD,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,YAAY,CAAC,WAAW,CAAC,EAAA;;wBAA3E,SAAS,GAAG,SAA+D;wBACjD,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;wBAA5C,KAAwB,CAAA,SAAoB,CAAA,KAAzB,EAAnB,qBAAiB,EAAE,KAAA,EAAX,IAAI,UAAA;wBAEpB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,MAAA,EAAE,OAAO,wBAAO,SAAS,KAAE,IAAI,MAAA,GAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEvE,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,sBAAO,GAAb;;;;;;;wBAEiB,KAAA,IAAI,CAAC,aAAa,CAAA;wBAAC,WAAM,IAAI,CAAC,cAAc,EAAE,EAAA;;wBAArD,IAAI,GAAG,SAAA,IAAI,GAAe,SAA2B,EAAC;wBAC5D,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,MAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEtC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAMK,0BAAW,GAAjB;;;;;;;wBAEI,WAAM,IAAI,CAAC,WAAW,CAAC,OAAO,EAAE,EAAA;;wBAAhC,SAAgC,CAAA;wBAEG,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBACvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,yBAAU,GAAhB,UAAiB,MAAqB;;;;;;;;;wBAG5B,QAAQ,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,IAAI,CAAC,UAAA,GAAG,IAAI,OAAA,MAAM,CAAC,GAAG,CAAC,KAAK,SAAS,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,IAAI,IAAI,MAAM,CAAC,GAAG,CAAC,KAAK,EAAE,EAAvE,CAAuE,CAAE,CAAA;wBAC1H,IAAI,CAAC,QAAQ,EAAE;4BACb,MAAM,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,gDAAgD,EAAE,CAAC,CAAA;yBACnF;wBAEO,KAAK,GAA2B,MAAM,MAAjC,EAAE,KAAK,GAAoB,MAAM,MAA1B,EAAK,UAAU,UAAK,MAAM,EAAxC,kBAA+B,CAAF,CAAW;wBAGxC,2BAAyB,KAAK,KAAK,SAAS,CAAA;wBAC5C,sBAAsB,GAAG,KAAK,KAAK,SAAS,CAAA;wBAE9C,QAAQ,GAAG,EAAE,CAAA;6BAEb,CAAA,wBAAsB,IAAI,sBAAsB,CAAA,EAAhD,cAAgD;wBAE9C,kBAAkB,SAA2C,CAAA;wBAGjE,IAAI,wBAAsB,EAAE;4BAC1B,kBAAkB,GAAG,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAA;4BAC5C,kBAAgB,GAAG,cAAc,CAAA;yBAClC;6BAAM;4BAEC,cAAc,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;4BACrD,kBAAkB,GAAG,EAAE,YAAY,EAAE,cAAc,EAAE,CAAA;4BACrD,kBAAgB,GAAG,cAAc,CAAA;yBAClC;wBAGwB,WAAM,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,EAAA;;wBAAjE,qBAAmB,SAA8C;wBAEvE,KAAA,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,GAAG,CAAC,CAAA;iCAAlC,cAAkC;wBAAK,WAAM,IAAI,CAAC,mBAAmB,CAAC,UAAU,CAAC,EAAA;;wBAA3C,KAAA,CAAC,SAA0C,CAAC,CAAA;;;wBAAlF,GAAkF;wBAElF,QAAQ,GAAG;4BACT,SAAS,EAAE,kBAAgB,CAAC,eAAe;4BAC3C,SAAS,EAAE,UAAO,YAA+D;;;;;;;iDAEzE,CAAA,YAAY,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,CAAA,EAAzD,cAAyD;4CAE3D,WAAM,IAAI,CAAC,SAAS,CAAC;oDACnB,IAAI,EAAE,cAAc;oDACpB,KAAK,EAAE,MAAM,CAAC,KAAK;oDACnB,KAAK,EAAE,YAAY,CAAC,KAAK;oDACzB,SAAS,EAAE,kBAAgB,CAAC,eAAe;iDAC5C,CAAC,EAAA;;4CALF,SAKE,CAAA;4CACF,WAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,MAAM,CAAC,KAAK,EAAE,CAAC,EAAA;;4CAAvD,SAAuD,CAAA;;;iDAC9C,CAAA,YAAY,CAAC,KAAK,IAAI,MAAM,CAAC,KAAK,KAAK,YAAY,CAAC,KAAK,CAAA,EAAzD,cAAyD;4CAElE,WAAM,IAAI,CAAC,SAAS,CAAC;oDACnB,IAAI,EAAE,cAAc;oDACpB,KAAK,EAAE,MAAM,CAAC,KAAK;oDACnB,KAAK,EAAE,YAAY,CAAC,KAAK;oDACzB,SAAS,EAAE,kBAAgB,CAAC,eAAe;iDAC5C,CAAC,EAAA;;4CALF,SAKE,CAAA;4CACF,WAAM,IAAI,CAAC,mBAAmB,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,EAAE,CAAC,EAAA;;4CAAzE,SAAyE,CAAA;;gDAEzE,WAAM,IAAI,CAAC,SAAS,CAAC;gDACnB,IAAI,EAAE,kBAAgB;gDACtB,KAAK,EAAE,wBAAsB,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;gDACxD,KAAK,EAAE,CAAC,wBAAsB,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;gDACzD,KAAK,EAAE,YAAY,CAAC,KAAK;gDACzB,SAAS,EAAE,kBAAgB,CAAC,eAAe;6CAC5C,CAAC,EAAA;;4CANF,SAME,CAAA;4CAEF,WAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAA;;4CAAtC,SAAsC,CAAA;;gDAKpC,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;4CADd,SACN,CAAA,SAAoB,CAAA,UADV;4CAEd,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,YAAY,EAAE,CAAC,CAAA;4CAEtG,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,QAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;4CAEtC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;iCAEnD;yBACF,CAAA;;4BAGD,WAAM,IAAI,CAAC,mBAAmB,CAAC,MAAM,CAAC,EAAA;;wBAAtC,SAAsC,CAAA;;4BAIpC,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;wBADd,IAAI,GACV,CAAA,SAAoB,CAAA,UADV;wBAEd,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,YAAY,EAAE,CAAC,CAAA;wBAEtG,WAAO,EAAE,IAAI,aAAI,IAAI,MAAA,IAAK,QAAQ,CAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEnD,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,gCAAiB,GAAvB;;;;;;;;wBAEsB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,YAAY,EAAE,EAAA;;wBAA3D,SAAS,GAAG,SAA+C;wBAEjE,WAAO;gCACL,IAAI,EAAE;oCACJ,UAAU,EAAE,MAAA,SAAS,aAAT,SAAS,uBAAT,SAAS,CAAE,IAAI,0CAAE,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC,CAAC,CAAC,CAAC,IAAI,EAAR,CAAQ,CAA0D;iCAC5G;gCACD,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,2BAAY,GAAlB,UAAmB,MAAuB;;;;;;;wBAGtC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;yBAC9D,CAAC,CAAA;wBAEF,WAAM,IAAI,CAAC,eAAe,CAAC;gCACzB,QAAQ,EAAE,MAAM,CAAC,QAAQ;gCACzB,OAAO,EAAE;oCACP,IAAI,EAAE,kBAAU,CAAC,aAAa;iCAC/B;6BACF,CAAC,EAAA;;wBALF,SAKE,CAAA;wBAEF,WAAO,EAAE,IAAI,EAAE,EAAE,QAAQ,EAAE,MAAM,CAAC,QAAQ,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE3D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,6BAAc,GAApB,UAAqB,MAAyB;;;;;;;wBAG1C,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;yBAC9D,CAAC,CAAA;wBAEF,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,WAAW,EAAE,MAAM,CAAC,QAAQ,EAAE,CAAC,EAAA;;wBAAjF,SAAiF,CAAA;wBAEjF,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEhC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,6BAAc,GAApB;;;;;;;;wBAIQ,WAAM,IAAI,CAAC,OAAO,EAAE,EAAA;;wBADd,IAAI,GACV,CAAA,SAAoB,CAAA,UADV;wBAGd,IAAI,CAAC,kBAAkB,CAAC,IAAI,EAAE,CAAC,CAAC,OAAO,EAAE,OAAO,CAAC,CAAC,EAAE,kDAAkD,CAAC,CAAA;wBACjG,aAAW,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,KAAK,EAAE,CAAC,CAAC,CAAC,EAAE,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE,CAAA;wBAG3E,WAAM,IAAI,CAAC,eAAe,CAAC,UAAQ,CAAC,EAAA;;wBAAvD,qBAAmB,SAAoC;wBAE7D,WAAO;gCACL,IAAI,EAAE;oCAEJ,UAAU,EAAE,UAAO,UAAgC;;;;;oDACjD,IAAI,CAAC,cAAc,CAAC,UAAU,EAAE;wDAC9B,KAAK,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,mBAAmB,EAAE;qDACxD,CAAC,CAAA;;;;yDAEI,UAAU,CAAC,QAAQ,EAAnB,cAAmB;oDAEQ,WAAM,IAAI,CAAC,MAAM,CAAC;4DAC7C,eAAe,EAAE,kBAAgB,CAAC,eAAe;4DACjD,iBAAiB,EAAE,UAAU,CAAC,KAAK;yDACpC,CAAC,EAAA;;oDAHI,oBAAoB,GAAG,SAG3B;oDAGc,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC;4DACpD,kBAAkB,EAAE,oBAAoB,CAAC,kBAAkB;yDAC5D,CAAC,EAAA;;oDAFI,OAAO,GAAG,SAEd;oDAEF,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,WAAW,CAAC;4DAC3C,YAAY,EAAE,UAAU,CAAC,QAAQ;4DACjC,UAAU,EAAE,OAAO,CAAC,UAAU;yDAC/B,CAAC,EAAA;;oDAHF,SAGE,CAAA;;wDAEF,WAAM,IAAI,CAAC,kBAAkB,qBAC3B,gBAAgB,oBAAA,EAChB,gBAAgB,EAAE,UAAU,CAAC,KAAK,IAC/B,UAAQ,KACX,SAAS,EAAE,UAAQ,CAAC,KAAK,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,OAAO,IAC7C,EAAA;;oDALF,SAKE,CAAA;;wDAG+B,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;oDAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;oDAEvB,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;oDAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;yCAEnD;iCACF;gCACD,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,qBAAM,GAAZ,UAAa,MAAiB;;;;;;;wBAG1B,IAAI,CAAC,kBAAkB,CAAC,MAAM,EAAE,CAAC,CAAC,OAAO,CAAC,EAAE,CAAC,OAAO,CAAC,CAAC,EAAE,kDAAkD,CAAC,CAAA;wBAErG,MAAM,GAAG,MAAM,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM,CAAA;wBAClD,IAAI,GAAsE,EAAE,MAAM,QAAA,EAAE,CAAA;wBAC1F,IAAI,OAAO,IAAI,MAAM,EAAE;4BACrB,IAAI,CAAC,KAAK,GAAG,MAAM,CAAC,KAAK,CAAA;yBAC1B;wBAED,IAAI,OAAO,IAAI,MAAM,EAAE;4BACrB,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,WAAW,CAAC,MAAM,CAAC,KAAK,CAAC,CAAA;yBACnD;wBAG2C,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,EAAA;;wBAAzE,cAAc,GAAK,CAAA,SAAsD,CAAA,gBAA3D;wBAEvC,WAAO;gCACL,IAAI,EAAE,EAAE,SAAS,EAAE,cAAc,EAAE;gCACnC,KAAK,EAAE,IAAI;6BACZ,EAAA;;;wBAED,WAAO;gCACL,IAAI,EAAE,EAAE;gCACR,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC;6BAC5B,EAAA;;;;;KAEJ;IAQK,yBAAU,GAAhB,UAAiB,MAAqB;;;;;;;;wBAElC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,YAAY,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,0BAA0B,EAAE;4BACrE,aAAa,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,2BAA2B,EAAE;yBACxE,CAAC,CAAA;wBAEF,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,YAAY,CAAC,MAAM,EAAE,EAAE,UAAU,EAAE,IAAI,EAAE,CAAC,EAAA;;wBAAhF,SAAgF,CAAA;wBAE7C,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAEvB,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,SAAS,EAAE,CAAC,CAAA;wBAEnG,WAAO,EAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAE7D,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAGK,qCAAsB,GAA5B;;;;;;KAEC;IAOK,yBAAU,GAAhB,UAAiB,MAAmB;;;;;;;wBAEhC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE;4BAC1B,QAAQ,EAAE,EAAE,QAAQ,EAAE,IAAI,EAAE,OAAO,EAAE,sBAAsB,EAAE;yBAC9D,CAAC,CAAA;wBAEqB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,MAAM,CAAC,EAAA;;wBAA5D,UAAU,GAAK,CAAA,SAA6C,CAAA,WAAlD;wBAElB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,QAAQ,CAAC,EAAE,UAAU,YAAA,EAAE,CAAC,EAAA;;wBAAzD,SAAyD,CAAA;wBAEzD,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;wBAEhC,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,iCAAkB,GAAxB,UAAyB,MAA0C;QAA1C,uBAAA,EAAA,WAA0C;;;;gBACjE,IAAI;oBACI,aAAa,GAAG,MAAM,CAAC,cAAc,IAAI,KAAK,CAAA;oBAC9C,KAAK,GAAG,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,IAAI,EAAE,CAAC;yBAC1C,GAAG,CAAC,UAAA,GAAG,IAAI,OAAA,UAAG,GAAG,cAAI,MAAM,CAAC,KAAK,CAAC,GAAG,CAAC,CAAE,EAA7B,CAA6B,CAAC;yBACzC,IAAI,CAAC,GAAG,CAAC,CAAA;oBAEZ,IAAI,0BAAc,CAAC,OAAO,EAAE,EAAE;wBAC5B,EAAE,CAAC,UAAU,CAAC,EAAE,GAAG,EAAE,gDAAyC,KAAK,CAAC,CAAC,CAAC,WAAI,KAAK,CAAE,CAAC,CAAC,CAAC,EAAE,CAAE,EAAE,CAAC,CAAA;qBAC5F;yBAAM;wBACC,WAAW,GAAG,MAAM,CAAC,YAAY,IAAI,MAAM,CAAC,QAAQ,CAAC,IAAI,CAAA;wBACzD,MAAM,GAAG,IAAI,GAAG,CAAC,WAAW,CAAC,CAAA;wBAC7B,SAAS,GAAG,UAAG,MAAM,CAAC,MAAM,6BAAmB,MAAM,CAAC,MAAM,IAAI,EAAE,qBAAW,IAAI,CAAC,MAAM,CAAC,GAAG,wBAChG,IAAI,CAAC,MAAM,CAAC,QAAQ,IAAI,IAAI,CAAC,MAAM,CAAC,GAAG,6BACtB,aAAa,2BAAiB,kBAAkB,CAAC,WAAW,CAAC,SAAG,KAAK,CAAC,CAAC,CAAC,WAAI,KAAK,CAAE,CAAC,CAAC,CAAC,EAAE,CAAE,CAAA;wBAC7G,MAAM,CAAC,QAAQ,CAAC,IAAI,GAAG,SAAS,CAAA;qBACjC;oBACD,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;iBACjC;gBAAC,OAAO,KAAK,EAAE;oBACd,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,KAAK,CAAC,EAAE,EAAA;iBACjD;;;;KACF;IAOK,qCAAsB,GAA5B,UAA6B,SAA4C;;;;;;wBACvE,IAAI,SAAS,EAAE;4BACb,IAAI,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;yBAClC;;;;wBAGC,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,sBAAsB,EAAE,EAAA;;wBAAzD,SAAyD,CAAA;wBACtC,WAAM,IAAI,CAAC,gBAAgB,EAAE,EAAA;;wBAA1C,UAAU,GAAG,SAA6B;wBAEb,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAGvB,iCAAa,UAAkB,KAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,KAAE;;;wBAErF,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAOK,+BAAgB,GAAtB,UAAuB,EAA0B;YAA1B,qBAAwB,EAAE,KAAA,EAAxB,kBAAiB,EAAjB,UAAU,mBAAG,IAAI,KAAA;;;;;;;wBACxC,IAAI,CAAC,0BAAc,CAAC,OAAO,EAAE,EAAE;4BAC7B,MAAM,KAAK,CAAC,kBAAkB,CAAC,CAAA;yBAChC;wBACK,MAAM,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,WAAW,CAAA;wBAE5C,QAAQ,GAAG,UAAO,IAAI;;;;;wCACtB,MAAM,GAAsD,SAAS,CAAA;wCACrE,WAAW,GAA4B,SAAS,CAAA;;;;wCAGzC,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAC1D;gDACE,WAAW,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;gDAC1B,aAAa,EAAE,IAAI;gDACnB,eAAe,EAAE;oDACf,kBAAkB,EAAE,SAAS;oDAC7B,KAAK,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,KAAK;iDACrB;6CACF,EACD,UAAU,CACX,EAAA;;wCAVD,MAAM,GAAG,SAUR,CAAA;wCAED,IAAI,CAAC,MAAc,aAAd,MAAM,uBAAN,MAAM,CAAU,UAAU,KAAI,CAAC,MAAM,CAAC,cAAc,EAAE;4CACzD,MAAM,MAAM,CAAA;yCACb;wCAEa,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAC/D,EAAE,cAAc,EAAE,MAAM,CAAC,cAAc,EAAE,EACzC,UAAU,CACX,EAAA;;wCAHD,WAAW,GAAG,SAGb,CAAA;wCAED,IAAK,WAAmB,aAAnB,WAAW,uBAAX,WAAW,CAAU,UAAU,EAAE;4CACpC,MAAM,WAAW,CAAA;yCAClB;;;;wCAED,MAAM,QAAK,CAAA;4CAEb,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,cAAc,CAAC,WAA0B,CAAC,EAAA;;wCAAhF,SAAgF,CAAA;;;;6BACjF,CAAA;;;;wBAGC,WAAM,IAAI,OAAO,CAAC,UAAC,OAAO,EAAE,MAAM;gCAChC,EAAE,CAAC,KAAK,CAAC;oCACP,OAAO,EAAE,UAAO,GAAqB;;;;;;oDAEjC,WAAM,QAAQ,CAAC,GAAG,CAAC,IAAI,CAAC,EAAA;;oDAAxB,SAAwB,CAAA;oDACxB,OAAO,CAAC,IAAI,CAAC,CAAA;;;;oDAEb,MAAM,CAAC,QAAK,CAAC,CAAA;;;;;yCAEhB;oCACD,IAAI,EAAE,UAAC,GAAQ;wCACb,IAAM,KAAK,GAAG,IAAI,KAAK,CAAC,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,MAAM,CAAC,CACnC;wCAAC,KAAa,CAAC,IAAI,GAAG,GAAG,aAAH,GAAG,uBAAH,GAAG,CAAE,KAAK,CAAA;wCACjC,MAAM,CAAC,KAAK,CAAC,CAAA;oCACf,CAAC;iCACF,CAAC,CAAA;4BACJ,CAAC,CAAC,EAAA;;wBAhBF,SAgBE,CAAA;wBAEiB,WAAM,IAAI,CAAC,gBAAgB,EAAE,EAAA;;wBAA1C,UAAU,GAAG,SAA6B;wBAEb,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAGvB,iCAAa,UAAkB,KAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,KAAE;;;wBAErF,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;;;;;KAEnD;IAQK,kCAAmB,GAAzB,UAA0B,EAAkB;YAAhB,iBAAc,EAAd,SAAS,mBAAG,EAAE,KAAA;;;;;;wBAoCxC,IAAI,CAAC,0BAAc,CAAC,OAAO,EAAE,EAAE;4BAC7B,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,kBAAkB,EAAE,CAAC,EAAE,EAAA;yBAC3E;wBACK,MAAM,GAAG,EAAE,CAAC,kBAAkB,EAAE,CAAC,WAAW,CAAA;wBAC5C,YAAY,GAAG;4BACnB,eAAe,EAAE,EAAE,kBAAkB,EAAE,OAAO,EAAE;4BAChD,WAAW,EAAE,MAAM,CAAC,KAAK;yBAC1B,CAAA;wBAEgB,WAAM,EAAE,CAAC,KAAK,EAAE,EAAA;;wBAAzB,IAAI,GAAK,CAAA,SAAgB,CAAA,KAArB;wBACV,YAAoB,CAAC,aAAa,GAAG,IAAI,CAAA;;;;wBAGrB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC,YAAY,CAAC,EAAA;;wBAAjF,aAAa,GAAG,SAAiE;wBACrF,IAAI,aAAa,CAAC,UAAU,EAAE;4BAC5B,MAAM,aAAa,CAAA;yBACpB;wBAEe,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC;gCAClE,cAAc,EAAE,aAAa,CAAC,cAAc;gCAC5C,WAAW,EAAE,MAAM,CAAC,KAAK;gCACzB,eAAe,EAAE;oCACf,IAAI,EAAE,SAAS;oCACf,kBAAkB,EAAE,OAAO;iCAC5B;6BACF,CAAC,EAAA;;wBAPF,aAAa,GAAG,SAOd,CAAA;wBACF,IAAI,aAAa,CAAC,UAAU,EAAE;4BAC5B,MAAM,aAAa,CAAA;yBACpB;wBAEiB,WAAM,IAAI,CAAC,aAAa,CAAC,OAAO,CAAC,kBAAkB,CAAC;gCACpE,cAAc,EAAE,aAAa,CAAC,cAAc;6BAC7C,CAAC,EAAA;;wBAFI,SAAS,GAAG,SAEhB;wBAEF,IAAK,SAAiB,aAAjB,SAAS,uBAAT,SAAS,CAAU,UAAU,EAAE;4BAClC,MAAM,SAAS,CAAA;yBAChB;;;;wBAED,WAAO,EAAE,IAAI,EAAE,EAAE,EAAE,KAAK,EAAE,IAAI,iBAAS,CAAC,QAAK,CAAC,EAAE,EAAA;4BAG/B,WAAM,IAAI,CAAC,gBAAgB,EAAE,EAAA;;wBAA1C,UAAU,GAAG,SAA6B;wBAEb,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBAAlD,KAA2B,CAAA,SAAuB,CAAA,KAA5B,EAAtB,qBAAoB,EAAE,KAAA,EAAd,OAAO,aAAA;wBAGvB,iCAAa,UAAkB,KAAE,IAAI,EAAE,EAAE,IAAI,EAAE,OAAO,CAAC,IAAI,EAAE,OAAO,SAAA,EAAE,EAAE,KAAK,EAAE,IAAI,KAAE;;;;KACtF;IAES,0BAAW,GAArB,UAAsB,KAAa;QACjC,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YACrD,OAAO,KAAK,CAAC,OAAO,CAAC,oBAAoB,EAAE,OAAO,CAAC,CAAA;SACpD;QACD,OAAO,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,cAAO,KAAK,CAAE,CAAA;IAC7D,CAAC;IAEO,8BAAe,GAAvB,UAAwB,KAAK,EAAE,OAAO,EAAE,IAAI;QAC1C,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,UAAC,SAAS;YAC/B,SAAS,CAAC,OAAO,CAAC,UAAC,QAAQ;gBACzB,IAAI;oBACF,QAAQ,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;iBAC/B;gBAAC,OAAO,KAAK,EAAE;oBACd,OAAO,CAAC,KAAK,CAAC,sCAAsC,EAAE,KAAK,CAAC,CAAA;iBAC7D;YACH,CAAC,CAAC,CAAA;QACJ,CAAC,CAAC,CAAA;QACF,OAAM;IACR,CAAC;IAEO,6BAAc,GAAtB;QAAA,iBAUC;;QATC,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,EAAE,CAAC,cAAM,CAAC,kBAAkB,EAAE,UAAO,MAAM;;;;;;wBACzD,KAAK,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,0CAAE,KAAK,CAAA;wBAC3B,IAAI,GAAG,MAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,IAAI,0CAAE,IAAI,CAAA;wBAG3B,WAAM,IAAI,CAAC,UAAU,EAAE,EAAA;;wBADjB,OAAO,GACb,CAAA,SAAuB,CAAA,aADV;wBAGjB,IAAI,CAAC,eAAe,CAAC,KAAK,EAAE,OAAO,EAAE,IAAI,CAAC,CAAA;;;;aAC3C,CAAC,CAAA;IACJ,CAAC;IAEO,4BAAa,GAArB,UAAsB,QAA6C;;QACjE,IAAI,CAAC,QAAQ;YAAE,OAAO,IAAI,CAAA;QAG1B,IAAM,KAAK,GAAG,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,KAAK,KAAI,EAAE,CAAA;QACnC,IAAM,KAAK,GAAG,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,YAAY,KAAI,EAAE,CAAA;QAC1C,IAAM,MAAM,GAAG,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,MAAI,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,GAAG,CAAA,IAAI,EAAE,CAAA;QAEnD,OAAO;YACL,EAAE,EAAE,MAAM;YACV,GAAG,EAAE,eAAe;YACpB,IAAI,EAAE,MAAA,MAAA,QAAQ,CAAC,MAAM,0CAAE,GAAG,mDAAG,UAAA,KAAK,IAAI,OAAA,CAAC,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC,EAA9C,CAA8C,CAAC;YACrF,KAAK,EAAE,KAAK,IAAI,EAAE;YAClB,kBAAkB,EAAE,CAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,cAAc,EAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU;YACxF,KAAK,OAAA;YACL,kBAAkB,EAAE,KAAK,CAAC,CAAC,CAAC,QAAQ,CAAC,UAAU,CAAC,CAAC,CAAC,SAAS;YAC3D,YAAY,EAAE,QAAQ,CAAC,UAAU;YACjC,eAAe,EAAG,QAAgB,CAAC,eAAe;YAClD,YAAY,EAAE;gBACZ,QAAQ,EAAE,CAAA,MAAA,QAAQ,CAAC,SAAS,0CAAE,WAAW,EAAE,KAAI,WAAW;gBAC1D,SAAS,EAAE,CAAC,CAAA,MAAA,QAAQ,CAAC,SAAS,0CAAE,WAAW,EAAE,KAAI,WAAW,CAAC;aAC9D;YACD,aAAa,EAAE;gBAEb,IAAI,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI;gBACpB,OAAO,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,OAAO;gBAC1B,QAAQ,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,QAAQ;gBAC5B,MAAM,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM;gBACxB,MAAM,EAAE,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,MAAM;gBAExB,GAAG,EAAE,QAAQ,CAAC,GAAG;gBACjB,QAAQ,EAAE,QAAQ,CAAC,QAAQ,KAAI,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,IAAI,CAAA;gBAC7C,SAAS,EAAE,QAAQ,CAAC,SAAS,IAAI,QAAQ,CAAC,OAAO;gBACjD,QAAQ,EAAE,QAAQ,CAAC,QAAQ;gBAC3B,WAAW,EAAE,QAAQ,CAAC,WAAW;aAClC;YACD,UAAU,EACR,CAAA,MAAA,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAE,SAAS,0CAAE,GAAG,CAAC,UAAA,CAAC,IAAI,OAAA,CAAC;gBAC7B,EAAE,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE;gBACd,WAAW,EAAE,CAAC,CAAC,EAAE,IAAI,EAAE;gBACvB,OAAO,EAAE,MAAM;gBACf,aAAa,EAAE;oBACb,WAAW,EAAE,CAAC,CAAC,EAAE;oBACjB,gBAAgB,EAAE,CAAC,CAAC,gBAAgB;oBACpC,IAAI,EAAE,CAAC,CAAC,IAAI;iBACb;gBACD,QAAQ,EAAE,CAAC,CAAC,EAAE,IAAI,WAAW;gBAC7B,UAAU,EAAE,QAAQ,CAAC,UAAU;gBAC/B,UAAU,EAAE,QAAQ,CAAC,UAAU;gBAC/B,eAAe,EAAG,QAAgB,CAAC,eAAe;aACnD,CAAC,EAb4B,CAa5B,CAAC,KAAI,EAAE;YACX,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,UAAU,EAAE,QAAQ,CAAC,UAAU;YAC/B,YAAY,EAAE,QAAQ,CAAC,IAAI,KAAK,WAAW;SAC5C,CAAA;IACH,CAAC;IAKO,6BAAc,GAAtB,UAAuB,MAAW,EAAE,KAAiE;QACnG,KAA0B,UAAqB,EAArB,KAAA,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAArB,cAAqB,EAArB,IAAqB,EAAE;YAAtC,IAAA,WAAW,EAAV,GAAG,QAAA,EAAE,IAAI,QAAA;YACnB,IAAI,IAAI,CAAC,QAAQ,IAAI,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,GAAG,CAAC,MAAK,SAAS,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,GAAG,CAAC,MAAK,IAAI,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,GAAG,CAAC,MAAK,EAAE,CAAC,EAAE;gBACpG,MAAM,IAAI,iBAAS,CAAC,EAAE,OAAO,EAAE,IAAI,CAAC,OAAO,EAAE,CAAC,CAAA;aAC/C;SACF;IACH,CAAC;IAKO,iCAAkB,GAA1B,UAA2B,MAAW,EAAE,WAAuB,EAAE,OAAe;QAC9E,IAAM,QAAQ,GAAG,WAAW,CAAC,IAAI,CAAC,UAAA,KAAK,IAAI,OAAA,KAAK,CAAC,IAAI,CAAC,UAAA,KAAK,IAAI,OAAA,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,KAAK,CAAC,MAAK,SAAS,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,KAAK,CAAC,MAAK,IAAI,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAG,KAAK,CAAC,MAAK,EAAE,EAAnF,CAAmF,CAAC,EAAxG,CAAwG,CAAE,CAAA;QAErJ,IAAI,CAAC,QAAQ,EAAE;YACb,MAAM,IAAI,iBAAS,CAAC,EAAE,OAAO,SAAA,EAAE,CAAC,CAAA;SACjC;IACH,CAAC;IAEa,mBAAI,GAAlB;;;;;;;;wBAEqC,WAAM,IAAI,CAAC,aAAa,CAAC,YAAY,CAAC,gBAAgB,CAAC,cAAc,EAAE,EAAA;;wBAAlG,WAAW,GAAgB,SAAuE;wBACxG,IAAI,WAAW,EAAE;4BACf,MAAA,IAAI,CAAC,MAAM,CAAC,QAAQ,0CAAE,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE,EAAE,KAAK,EAAE,+BAAuB,CAAC,eAAe,EAAE,CAAC,CAAA;yBAC1G;;;;;4BAKH,WAAO,EAAE,KAAK,EAAE,IAAI,EAAE,EAAA;;;;KACvB;IA/oEY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,8CAA8C;gBAC9C,wBAAwB;gBACxB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;+CAGD;IAeY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE;gBACR,UAAU;gBACV,6CAA6C;gBAC7C,wBAAwB;gBACxB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;8CAGD;IAiBM;QATN,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE;gBACR,UAAU;gBACV,wCAAwC;gBACxC,uBAAuB;gBACvB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;yCAGD;IAiBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,qCAAqC;gBACrC,2BAA2B;gBAC3B,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;sCAGD;IAiBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,8CAA8C;gBAC9C,2BAA2B;gBAC3B,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;+CASD;IAkCY;QARZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE;gBACR,UAAU;gBACV,6CAA6C;gBAC7C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;8CASD;IAqCY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE;gBACR,UAAU;gBACV,qBAAqB;gBACrB,oDAAoD;gBACpD,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;qDAgED;IAgBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,eAAe;YACtB,QAAQ,EAAE;gBACR,UAAU;gBACV,8BAA8B;gBAC9B,yCAAyC;gBACzC,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;0CAiDD;IAgBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,kBAAkB;YACzB,QAAQ,EAAE;gBACR,UAAU;gBACV,+BAA+B;gBAC/B,gDAAgD;gBAChD,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;iDAsDD;IAgBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,2BAA2B;gBAC3B,4CAA4C;gBAC5C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;6CAkBD;IAgBY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,qBAAqB;gBACrB,8CAA8C;gBAC9C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;+CAkBD;IAqFY;QARZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,aAAa;YACpB,QAAQ,EAAE;gBACR,UAAU;gBACV,mDAAmD;gBACnD,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;oDAQD;IAuCY;QARZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,WAAW;YAClB,QAAQ,EAAE;gBACR,UAAU;gBACV,4CAA4C;gBAC5C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;6CAoBD;IAeY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,UAAU;YACjB,QAAQ,EAAE;gBACR,UAAU;gBACV,aAAa;gBACb,0CAA0C;gBAC1C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;2CAGD;IAWY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,cAAc;YACrB,QAAQ,EAAE;gBACR,UAAU;gBACV,aAAa;gBACb,8CAA8C;gBAC9C,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;+CAGD;IAkCY;QATZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,aAAa;YACpB,QAAQ,EAAE;gBACR,UAAU;gBACV,+CAA+C;gBAC/C,qBAAqB;gBACrB,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;gDAGD;IAuHY;QARZ,IAAA,gCAAoB,EAAC;YACpB,KAAK,EAAE,SAAS;YAChB,QAAQ,EAAE;gBACR,UAAU;gBACV,iDAAiD;gBACjD,sKAA6B,8BAAkB,CAAE;aAClD;SACF,CAAC;;;;kDAGD;IAw5CH,WAAC;CAAA,AA9qED,CAAmB,wBAAY,GA8qE9B;AAiPkB,oBAAI;AAvOvB,SAAgB,oBAAoB,CAClC,MAAkD,EAClD,OASC;IAXH,iBA6FC;;IAhFS,IAAA,KAAwD,MAAM,OAAxC,EAAtB,MAAM,mBAAG,aAAa,KAAA,EAAE,IAAI,GAA4B,MAAM,KAAlC,EAAE,SAAS,GAAiB,MAAM,UAAvB,EAAE,UAAU,GAAK,MAAM,WAAX,CAAW;IACtE,IAAM,QAAQ,GAAG,CAAA,OAAO,aAAP,OAAO,uBAAP,OAAO,CAAE,QAAQ,KAAK,6BAAiB,CAAC,IAAI,CAAC,OAAO,CAAC,EAA6B,CAAA;IAC3F,IAAA,OAAO,GAAc,QAAQ,QAAtB,EAAE,OAAO,GAAK,QAAQ,QAAb,CAAa;IAE/B,IAAA,KAAkD,OAAO,IAAI,EAAE,EAA7D,GAAG,SAAA,EAAE,QAAQ,cAAA,EAAE,KAAK,WAAA,EAAE,KAAK,WAAA,EAAO,SAAS,SAAkB,CAAA;IAC/D,IAAA,SAAS,GAAK,CAAA,OAAO,IAAI,EAAE,CAAA,UAAlB,CAAkB;IACjC,IAAI,CAAC,SAAS,EAAE;QACd,SAAS,GAAG,kBAAW,GAAG,cAAI,MAAM,iCAA8B,CAAA;KACnE;IAED,IAAM,UAAU,GAAG;QACjB,GAAG,KAAA;QACH,QAAQ,UAAA;QACR,IAAI,MAAA;QACJ,SAAS,WAAA;QACT,UAAU,YAAA;QACV,QAAQ,EAAE,IAAI,iCAAqB,EAAE;KACtC,CAAA;IAED,IAAM,aAAa,GAAG,IAAI,sBAAc,CAAC,IAAA,wBAAc,wBAClD,UAAU,KACb,SAAS,WAAA,EACT,OAAO,EAAE,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,KAAI,uBAAe,EAE3C,OAAO,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,EACxB,WAAW,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,WAAW,EAChC,OAAO,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,EACxB,mBAAmB,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,mBAAmB,EAChD,cAAc,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,EACtC,OAAO,EAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,OAAO,EACxB,OAAO,SAAA,EACP,kBAAkB,EAAE,kBAAkB,CAAC,UAAU,CAAC,QAAQ,CAAC,EAC3D,OAAO,aAAI,eAAe,EAAE,4BAAqB,MAAM,CAAC,UAAU,CAAE,IAAK,CAAC,MAAM,CAAC,OAAO,IAAI,EAAE,CAAC,GAC/F,kBAAkB,EAAE,MAAM,CAAC,kBAAkB,EAC7C,KAAK,OAAA,EACL,IAAI,EAAE,MAAA,MAAA,OAAO,CAAC,GAAG,0CAAE,MAAM,0CAAE,IAAI,IAC/B,CAAE,CAAA;IAEJ,IAAM,YAAY,GAAG,IAAI,IAAI,uBACxB,UAAU,KACb,MAAM,QAAA,EACN,WAAW,EAAE,MAAM,CAAC,WAAW,EAC/B,KAAK,OAAA,EACL,KAAK,EACH,KAAK,IAAI,IAAI,0BAAc,CAAC;YAC1B,WAAW,EAAE,MAAM,CAAC,WAAW;YAC/B,IAAI,EAAE,EAAE,WAAW,EAAE,oBAAa,GAAG,CAAE,EAAE;YACzC,YAAY,EAAE,QAAQ;SACvB,CAAC,EACJ,OAAO,EAAE,OAAO,IAAI,KAAK,EACzB,QAAQ,EAAE,SAAS,EACnB,aAAa,eAAA,EACb,IAAI,EAAE,MAAA,MAAA,OAAO,CAAC,GAAG,0CAAE,MAAM,0CAAE,IAAI,IAC/B,CAAA;IAIF,aAAa,CAAC,iBAAiB,CAAC,UAAO,IAAI,EAAE,KAAK;;YAChD,IAAI,CAAC,IAAI;gBAAE,WAAM;YAEjB,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAU,CAAC,OAAO,EAAE;gBACpC,IAAI,KAAK,EAAE;oBACT,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE;wBAClD,KAAK,EAAE,+BAAuB,CAAC,SAAS;wBACxC,IAAI,wBAAO,IAAI,KAAE,KAAK,OAAA,GAAE;qBACzB,CAAC,CAAA;iBACH;qBAAM,IAAI,IAAI,CAAC,IAAI,EAAE;oBAGpB,YAAY,CAAC,gBAAgB,CAAC,EAAE,EAAE,EAAE,QAAQ,EAAE,IAAI,CAAC,IAAI,EAAE,CAAC,CAAA;iBAC3D;aACF;iBAAM,IAAI,IAAI,CAAC,IAAI,KAAK,kBAAU,CAAC,aAAa,EAAE;gBACjD,UAAU,CAAC,QAAQ,CAAC,IAAI,CAAC,cAAM,CAAC,kBAAkB,EAAE;oBAClD,KAAK,EAAE,+BAAuB,CAAC,aAAa;oBAC5C,IAAI,wBAAO,IAAI,KAAE,KAAK,OAAA,GAAE;iBACzB,CAAC,CAAA;aACH;;;SACF,CAAC,CAAA;IAEF,OAAO,EAAE,YAAY,cAAA,EAAE,aAAa,eAAA,EAAE,CAAA;AACxC,CAAC;AA7FD,oDA6FC;AAED,IAAM,SAAS,GAAG,MAAM,CAAA;AAMxB,SAAS,mBAAmB,CAAC,CAAS,EAAE,CAAS;IAC/C,IAAM,MAAM,GAAe,EAAE,CAAA;IAC7B,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAClC,MAAM,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAA;KAChB;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAClC,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAA;KACjB;IACD,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;QAClC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,CAAC,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAClC,IAAM,IAAI,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,KAAK,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;YACtE,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,CAAC,GAAG,CACrB,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,EACpB,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,CAAC,EACpB,MAAM,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC,GAAG,IAAI,CAC5B,CAAA;SACF;KACF;IACD,OAAO,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,CAAA;AACnC,CAAC;AAMD,SAAS,iBAAiB,CAAC,MAAc,EAAE,OAAiB;IAC1D,IAAI,SAAS,GAAkB,IAAI,CAAA;IACnC,IAAI,YAAY,GAAG,QAAQ,CAAA;IAC3B,IAAM,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,CAAC,EAAE,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,MAAM,GAAG,GAAG,CAAC,CAAC,CAAA;IAEhE,KAAqB,UAAO,EAAP,mBAAO,EAAP,qBAAO,EAAP,IAAO,EAAE;QAAzB,IAAM,MAAM,gBAAA;QAEf,IAAI,MAAM,CAAC,UAAU,CAAC,GAAG,CAAC,IAAI,MAAM,KAAK,aAAa;YAAE,SAAQ;QAChE,IAAM,QAAQ,GAAG,mBAAmB,CAAC,MAAM,EAAE,MAAM,CAAC,CAAA;QACpD,IAAI,QAAQ,GAAG,YAAY,IAAI,QAAQ,IAAI,WAAW,EAAE;YACtD,YAAY,GAAG,QAAQ,CAAA;YACvB,SAAS,GAAG,MAAM,CAAA;SACnB;KACF;IACD,OAAO,SAAS,CAAA;AAClB,CAAC;AAED,IAAM,SAAS,GAAwB;IACrC,IAAI,EAAE,cAAc;IACpB,SAAS,EAAE,SAAS;IACpB,MAAM,YAAC,MAAyB;QAC9B,IAAM,IAAI,GAAG,UAAU,MAAyB;;YAC9C,IAAI,IAAI,CAAC,YAAY,IAAI,CAAC,MAAM,EAAE;gBAEhC,OAAO,IAAI,CAAC,YAAY,CAAA;aACzB;YAED,MAAM,GAAG,MAAM,IAAI;gBACjB,MAAM,EAAE,EAAE;gBACV,WAAW,EAAE,OAAO;gBACpB,OAAO,EAAE,uBAAe;aACzB,CAAA;YACO,IAAA,OAAO,GAAK,IAAI,CAAC,QAAQ,QAAlB,CAAkB;YAEjC,IAAM,cAAc,GAAG,MAAM,CAAC,WAAW,IAAI,OAAO,CAAC,cAAc,CAAA;YACnE,IAAI,cAAc,IAAI,cAAc,KAAK,IAAI,CAAC,MAAM,CAAC,WAAW,EAAE;gBAChE,IAAI,CAAC,YAAY,CAAC,EAAE,WAAW,EAAE,cAAc,EAAE,CAAC,CAAA;aACnD;YAEK,IAAA,KAAkC,oBAAoB,qBAExD,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,EAC5B,OAAO,EAAE,IAAI,CAAC,MAAM,CAAC,OAAO,IACzB,MAAM,KACT,WAAW,EAAE,IAAI,CAAC,MAAM,CAAC,WAAW,EACpC,IAAI,EAAE,IAAI,CAAC,MAAM,CAAC,IAAI,EACtB,SAAS,EAAE,IAAI,CAAC,MAAM,CAAC,SAAS,EAChC,UAAU,EAAE,IAAI,CAAC,MAAM,CAAC,UAAU,EAClC,UAAU,EAAE,IAAI,CAAC,OAAO,EACxB,kBAAkB,EAAE,MAAA,IAAI,CAAC,MAAM,CAAC,IAAI,0CAAE,kBAAkB,KAE1D;gBACE,GAAG,EAAE,IAAI,CAAC,MAAM,CAAC,GAAG;gBACpB,QAAQ,EAAE,IAAI,CAAC,MAAM,CAAC,QAAQ;gBAC9B,SAAS,EAAE,IAAI,CAAC,OAAO,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,YAAY,IAAI,WAAW,CAAC;gBAChF,QAAQ,EAAE,IAAI,CAAC,QAAQ;gBACvB,KAAK,EAAE,IAAI,CAAC,KAAK;gBACjB,GAAG,EAAE,IAAI;gBACT,KAAK,EAAE,IAAI,CAAC,MAAM,CAAC,KAAK;aACzB,CACF,EArBO,YAAY,kBAAA,EAAE,aAAa,mBAqBlC,CAAA;YAED,IAAI,CAAC,aAAa,GAAG,aAAa,CAAA;YAElC,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;YAEhC,OAAO,IAAI,CAAC,YAAY,CAAA;QAC1B,CAAC,CAAA;QAED,IAAM,SAAS,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,EAAE,MAAM,CAAC,CAAA;QACzC,MAAM,CAAC,MAAM,CAAC,IAAI,EAAE,SAAS,CAAC,CAAA;QAC9B,MAAM,CAAC,cAAc,CAAC,IAAI,EAAE,MAAM,CAAC,cAAc,CAAC,SAAS,CAAC,CAAC,CAAA;QAG7D,IAAM,YAAY,GAAG,OAAO,KAAK,KAAK,WAAW;YAC/C,CAAC,CAAC,IAAI,KAAK,CAAC,IAAI,EAAE;gBAChB,GAAG,YAAC,MAAM,EAAE,IAAI,EAAE,QAAQ;oBACxB,IAAM,KAAK,GAAG,OAAO,CAAC,GAAG,CAAC,MAAM,EAAE,IAAI,EAAE,QAAQ,CAAC,CAAA;oBACjD,IAAI,KAAK,KAAK,SAAS,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;wBACnD,OAAO,KAAK,CAAA;qBACb;oBAED,IAAM,OAAO,GAAG,MAAM,CAAC,mBAAmB,CAAC,MAAM,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC;yBACtE,MAAM,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;yBAC3B,MAAM,CAAC,UAAA,CAAC,IAAI,OAAA,OAAO,MAAM,CAAC,CAAC,CAAC,KAAK,UAAU,EAA/B,CAA+B,CAAC,CAAA;oBAC/C,IAAM,UAAU,GAAG,iBAAiB,CAAC,IAAI,EAAE,OAAO,CAAC,CAAA;oBACnD,IAAI,UAAU,EAAE;wBACd,OAAO,CAAC,IAAI,CAAC,gCAAyB,IAAI,oDAA0C,UAAU,SAAM,CAAC,CAAA;qBACtG;oBACD,OAAO,KAAK,CAAA;gBACd,CAAC;aACF,CAAC;YACF,CAAC,CAAC,IAAI,CAAA;QAER,IAAI,CAAC,SAAS,CAAC,GAAG,YAAY,CAAA;QAC9B,OAAO,YAAY,CAAA;IACrB,CAAC;CACF,CAAA;AAED,IAAI;IAGF,SAAS,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;CACvC;AAAC,OAAO,CAAC,EAAE,GAAE;AAMd,SAAgB,YAAY,CAAC,GAA0C;IACrE,IAAI;QACF,GAAG,CAAC,iBAAiB,CAAC,SAAS,CAAC,CAAA;KACjC;IAAC,OAAO,CAAC,EAAE;QACV,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC,CAAA;KAChB;AACH,CAAC;AAND,oCAMC","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  DEFAULT_NODE_ACCESS_SCOPE,\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 {\n  AuthV1Compat,\n  WeixinAuthProvider,\n  CustomAuthProvider,\n  AnonymousAuthProvider,\n  applyUserV1Compat,\n} from './v1-compat'\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  VerifyOAuthRes,\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}\n\n// 应用 v1 兼容方法到 User 类\napplyUserV1Compat(User)\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\ninterface IAuthConfig extends ICloudbaseAuthConfig {\n  cache: ICloudbaseCache\n  request?: ICloudbaseRequest\n  runtime?: string\n}\n\nclass Auth extends AuthV1Compat {\n  readonly config: IAuthConfig\n  oauthInstance: CloudbaseOAuth\n  readonly cache: ICloudbaseCache\n  private listeners: Map<string, Set<OnAuthStateChangeCallback>> = new Map()\n  private hasListenerSetUp = false\n\n  constructor(config: IAuthConfig) {\n    super()\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    if (params.phone_number) {\n      params.phone_number = this.formatPhone(params.phone_number)\n    }\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().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  /**\n   * @deprecated 使用 getCurrentUser 代替，因为与node-sdk方法名冲突\n   * @returns\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  // v1 兼容 API 方法已移至 AuthV1Compat 基类 (v1-compat.ts)\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 = this.formatPhone(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    let accessToken = ''\n    let scope = ''\n    if (this.config.accessKey) {\n      accessToken = this.config.accessKey\n      scope = 'accessKey'\n    } else if (this.config.auth?.secretId && this.config.auth?.secretKey) {\n      accessToken = ''\n      scope = DEFAULT_NODE_ACCESS_SCOPE\n    }\n\n    if (!scope) {\n      return\n    }\n\n    try {\n      this.oauthInstance.oauth2client.setAccessKeyCredentials({\n        access_token: accessToken,\n        token_type: 'Bearer',\n        scope,\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  // ========== 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      params.phone_number = this.formatPhone(params.phone_number)\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      const authError = new AuthError(error)\n      // 优化错误提示：登录失败时提供更友好的排查指引\n      if (authError.message?.includes('密码不正确') || authError.message?.includes('password')) {\n        console.warn('[CloudBase Auth] 登录失败提示：\\n'\n          + '  1. 请确认用户名/邮箱/手机号是否正确\\n'\n          + '  2. 请确认密码是否正确\\n'\n          + '  3. 如果用户不存在，请先通过 auth.signUp() 注册用户，或在云开发控制台手动创建用户\\n'\n          + '  4. 确认当前环境已开启对应的登录方式（控制台 → 环境 → 登录授权）',)\n      }\n      return { data: {}, error: authError }\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    if (params.options?.shouldCreateUser === undefined || !!params.options?.shouldCreateUser) {\n      return this.signUp({\n        email: params.email,\n        phone: params.phone,\n      })\n    }\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          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<VerifyOAuthRes> {\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: VerifyOAuthRes\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      res.data.redirectUrl = 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.getCurrentUser())\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 {\n        data: {\n          identities: providers?.data?.filter(v => !!v.bind) as unknown as GetUserIdentitiesRes['data']['identities'],\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-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 = '', useWxCloud = false }): Promise<SignInRes> {\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', code: phoneCode, appid: wxInfo.appId },\n    //   provider_id: wxInfo.appId,\n    // }\n\n    // const { code } = await wx.login()\n    // ;(providerInfo as any).provider_code = code\n\n    // try {\n    //   const providerToken = await this.oauthInstance.authApi.grantProviderToken(providerInfo, useWxCloud)\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    //   }, useWxCloud)\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    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  protected 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 || userInfo?.name,\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<\nICloudbaseAuthConfig,\n'region' | 'persistence' | 'i18n' | 'accessKey' | 'useWxCloud' | 'auth'\n> &\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    auth: options.app?.config?.auth,\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    auth: options.app?.config?.auth,\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\n/**\n * 计算两个字符串之间的编辑距离（Levenshtein distance）\n * 用于在用户调用不存在的 Auth 方法时，推荐最相似的方法名\n */\nfunction levenshteinDistance(a: string, b: string): number {\n  const matrix: number[][] = []\n  for (let i = 0; i <= a.length; i++) {\n    matrix[i] = [i]\n  }\n  for (let j = 0; j <= b.length; j++) {\n    matrix[0][j] = j\n  }\n  for (let i = 1; i <= a.length; i++) {\n    for (let j = 1; j <= b.length; j++) {\n      const cost = a[i - 1].toLowerCase() === b[j - 1].toLowerCase() ? 0 : 1\n      matrix[i][j] = Math.min(\n        matrix[i - 1][j] + 1,\n        matrix[i][j - 1] + 1,\n        matrix[i - 1][j - 1] + cost,\n      )\n    }\n  }\n  return matrix[a.length][b.length]\n}\n\n/**\n * 在方法列表中查找与目标名称最相似的方法\n * @returns 最相似的方法名，如果没有足够相似的则返回 null\n */\nfunction findSimilarMethod(target: string, methods: string[]): string | null {\n  let bestMatch: string | null = null\n  let bestDistance = Infinity\n  const maxDistance = Math.max(3, Math.floor(target.length * 0.4)) // 允许 40% 的编辑距离\n\n  for (const method of methods) {\n    // 跳过私有方法和构造函数\n    if (method.startsWith('_') || method === 'constructor') continue\n    const distance = levenshteinDistance(target, method)\n    if (distance < bestDistance && distance <= maxDistance) {\n      bestDistance = distance\n      bestMatch = method\n    }\n  }\n  return bestMatch\n}\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\n    // 包装 Proxy，当用户调用不存在的方法时提供 \"Did you mean?\" 提示\n    const authWithHint = typeof Proxy !== 'undefined'\n      ? new Proxy(auth, {\n        get(target, prop, receiver) {\n          const value = Reflect.get(target, prop, receiver)\n          if (value !== undefined || typeof prop !== 'string') {\n            return value\n          }\n          // 查找最相似的方法名\n          const allKeys = Object.getOwnPropertyNames(Object.getPrototypeOf(target))\n            .concat(Object.keys(target))\n            .filter(k => typeof target[k] === 'function')\n          const suggestion = findSimilarMethod(prop, allKeys)\n          if (suggestion) {\n            console.warn(`[CloudBase Auth] auth.${prop} is not a function. Did you mean: auth.${suggestion}() ?`)\n          }\n          return value\n        },\n      })\n      : auth\n\n    this[NAMESPACE] = authWithHint\n    return authWithHint\n  },\n}\n\ntry {\n  // 尝试自动注册至全局变量cloudbase\n  // 此行为只在浏览器环境下有效\n  cloudbase.registerComponent(component)\n} catch (e) {}\n\nexport { UserInfo, Auth, WeixinAuthProvider, CustomAuthProvider, AnonymousAuthProvider }\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"]}
|
|
2987
|
+
//# 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  DEFAULT_NODE_ACCESS_SCOPE,\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 {\n  AuthV1Compat,\n  WeixinAuthProvider,\n  CustomAuthProvider,\n  AnonymousAuthProvider,\n  applyUserV1Compat,\n} from './v1-compat'\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  VerifyOAuthRes,\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}\n\n// 应用 v1 兼容方法到 User 类\napplyUserV1Compat(User)\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\ninterface IAuthConfig extends ICloudbaseAuthConfig {\n  cache: ICloudbaseCache\n  request?: ICloudbaseRequest\n  runtime?: string\n}\n\nclass Auth extends AuthV1Compat {\n  readonly config: IAuthConfig\n  oauthInstance: CloudbaseOAuth\n  readonly cache: ICloudbaseCache\n  private listeners: Map<string, Set<OnAuthStateChangeCallback>> = new Map()\n  private hasListenerSetUp = false\n\n  constructor(config: IAuthConfig) {\n    super()\n    this.config = config\n    this.oauthInstance = config.oauthInstance\n    this.cache = config.cache\n    this.init()\n    this.setAccessKey()\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      params.phone_number = this.formatPhone(params.phone_number)\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      const authError = new AuthError(error)\n      // 优化错误提示：登录失败时提供更友好的排查指引\n      if (authError.message?.includes('密码不正确') || authError.message?.includes('password')) {\n        console.warn('[CloudBase Auth] 登录失败提示：\\n'\n          + '  1. 请确认用户名/邮箱/手机号是否正确\\n'\n          + '  2. 请确认密码是否正确\\n'\n          + '  3. 如果用户不存在，请先通过 auth.signUp() 注册用户，或在云开发控制台手动创建用户\\n'\n          + '  4. 确认当前环境已开启对应的登录方式（控制台 → 环境 → 登录授权）',)\n      }\n      return { data: {}, error: authError }\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    if (params.options?.shouldCreateUser === undefined || !!params.options?.shouldCreateUser) {\n      return this.signUp({\n        email: params.email,\n        phone: params.phone,\n      })\n    }\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          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<VerifyOAuthRes> {\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: VerifyOAuthRes\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      res.data.redirectUrl = 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.getCurrentUser())\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 {\n        data: {\n          identities: providers?.data?.filter(v => !!v.bind) as unknown as GetUserIdentitiesRes['data']['identities'],\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-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 = '', useWxCloud = false }): Promise<SignInRes> {\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', code: phoneCode, appid: wxInfo.appId },\n    //   provider_id: wxInfo.appId,\n    // }\n\n    // const { code } = await wx.login()\n    // ;(providerInfo as any).provider_code = code\n\n    // try {\n    //   const providerToken = await this.oauthInstance.authApi.grantProviderToken(providerInfo, useWxCloud)\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    //   }, useWxCloud)\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    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  /**\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    if (params.phone_number) {\n      params.phone_number = this.formatPhone(params.phone_number)\n    }\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().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().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  /**\n   * @deprecated 使用 getCurrentUser 代替，因为与node-sdk方法名冲突\n   * @returns\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 = this.formatPhone(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    let accessToken = ''\n    let scope = ''\n    if (this.config.accessKey) {\n      accessToken = this.config.accessKey\n      scope = 'accessKey'\n    } else if (this.config.auth?.secretId && this.config.auth?.secretKey) {\n      accessToken = ''\n      scope = DEFAULT_NODE_ACCESS_SCOPE\n    }\n\n    if (!scope) {\n      return\n    }\n\n    try {\n      this.oauthInstance.oauth2client.setAccessKeyCredentials({\n        access_token: accessToken,\n        token_type: 'Bearer',\n        scope,\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  protected 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 || userInfo?.name,\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<\nICloudbaseAuthConfig,\n'region' | 'persistence' | 'i18n' | 'accessKey' | 'useWxCloud' | 'auth'\n> &\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    auth: options.app?.config?.auth,\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    auth: options.app?.config?.auth,\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\n/**\n * 计算两个字符串之间的编辑距离（Levenshtein distance）\n * 用于在用户调用不存在的 Auth 方法时，推荐最相似的方法名\n */\nfunction levenshteinDistance(a: string, b: string): number {\n  const matrix: number[][] = []\n  for (let i = 0; i <= a.length; i++) {\n    matrix[i] = [i]\n  }\n  for (let j = 0; j <= b.length; j++) {\n    matrix[0][j] = j\n  }\n  for (let i = 1; i <= a.length; i++) {\n    for (let j = 1; j <= b.length; j++) {\n      const cost = a[i - 1].toLowerCase() === b[j - 1].toLowerCase() ? 0 : 1\n      matrix[i][j] = Math.min(\n        matrix[i - 1][j] + 1,\n        matrix[i][j - 1] + 1,\n        matrix[i - 1][j - 1] + cost,\n      )\n    }\n  }\n  return matrix[a.length][b.length]\n}\n\n/**\n * 在方法列表中查找与目标名称最相似的方法\n * @returns 最相似的方法名，如果没有足够相似的则返回 null\n */\nfunction findSimilarMethod(target: string, methods: string[]): string | null {\n  let bestMatch: string | null = null\n  let bestDistance = Infinity\n\n  for (const method of methods) {\n    // 跳过私有方法和构造函数\n    if (method.startsWith('_') || method === 'constructor') continue\n    const distance = levenshteinDistance(target, method)\n    if (distance < bestDistance) {\n      bestDistance = distance\n      bestMatch = method\n    }\n  }\n  return bestMatch\n}\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\n    // 包装 Proxy，当用户调用不存在的方法时提供 \"Did you mean?\" 提示\n    const authWithHint = typeof Proxy !== 'undefined'\n      ? new Proxy(auth, {\n        get(target, prop, receiver) {\n          const value = Reflect.get(target, prop, receiver)\n          if (value !== undefined || typeof prop !== 'string') {\n            return value\n          }\n          // 查找最相似的方法名\n          const allKeys = Object.getOwnPropertyNames(Object.getPrototypeOf(target))\n            .concat(Object.keys(target))\n            .filter(k => typeof target[k] === 'function')\n          const suggestion = findSimilarMethod(prop, allKeys)\n          if (suggestion) {\n            console.warn(`[CloudBase Auth] auth.${prop} is not a function. Did you mean: auth.${suggestion}() ?`)\n          }\n          return value\n        },\n      })\n      : auth\n\n    this[NAMESPACE] = authWithHint\n    return authWithHint\n  },\n}\n\ntry {\n  // 尝试自动注册至全局变量cloudbase\n  // 此行为只在浏览器环境下有效\n  cloudbase.registerComponent(component)\n} catch (e) {}\n\nexport { UserInfo, Auth, WeixinAuthProvider, CustomAuthProvider, AnonymousAuthProvider }\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"]}
|