@cloudbase/oauth 3.0.0 → 3.0.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (70) hide show
  1. package/dist/cjs/auth/apis.d.ts +22 -4
  2. package/dist/cjs/auth/apis.js +255 -66
  3. package/dist/cjs/auth/auth-error.d.ts +6 -0
  4. package/dist/cjs/auth/auth-error.js +32 -0
  5. package/dist/cjs/auth/consts.d.ts +22 -0
  6. package/dist/cjs/auth/consts.js +24 -2
  7. package/dist/cjs/auth/models.d.ts +13 -4
  8. package/dist/cjs/auth/models.js +1 -1
  9. package/dist/cjs/captcha/captcha-dom.d.ts +3 -0
  10. package/dist/cjs/captcha/captcha-dom.js +223 -0
  11. package/dist/cjs/captcha/captcha.d.ts +3 -1
  12. package/dist/cjs/captcha/captcha.js +11 -102
  13. package/dist/cjs/index.d.ts +12 -2
  14. package/dist/cjs/index.js +27 -4
  15. package/dist/cjs/oauth2client/interface.d.ts +1 -1
  16. package/dist/cjs/oauth2client/interface.js +1 -1
  17. package/dist/cjs/oauth2client/models.d.ts +15 -1
  18. package/dist/cjs/oauth2client/models.js +1 -1
  19. package/dist/cjs/oauth2client/oauth2client.d.ts +62 -3
  20. package/dist/cjs/oauth2client/oauth2client.js +426 -131
  21. package/dist/cjs/utils/base64.d.ts +5 -0
  22. package/dist/cjs/utils/base64.js +15 -2
  23. package/dist/cjs/utils/encryptlong/index.js +22 -16
  24. package/dist/cjs/utils/index.js +1 -1
  25. package/dist/cjs/utils/mp.js +4 -4
  26. package/dist/cjs/utils/urlSearchParams.js +1 -1
  27. package/dist/esm/auth/apis.d.ts +22 -4
  28. package/dist/esm/auth/apis.js +130 -10
  29. package/dist/esm/auth/auth-error.d.ts +6 -0
  30. package/dist/esm/auth/auth-error.js +9 -0
  31. package/dist/esm/auth/consts.d.ts +22 -0
  32. package/dist/esm/auth/consts.js +22 -0
  33. package/dist/esm/auth/models.d.ts +13 -4
  34. package/dist/esm/captcha/captcha-dom.d.ts +3 -0
  35. package/dist/esm/captcha/captcha-dom.js +129 -0
  36. package/dist/esm/captcha/captcha.d.ts +3 -1
  37. package/dist/esm/captcha/captcha.js +14 -97
  38. package/dist/esm/index.d.ts +12 -2
  39. package/dist/esm/index.js +20 -3
  40. package/dist/esm/oauth2client/interface.d.ts +1 -1
  41. package/dist/esm/oauth2client/models.d.ts +15 -1
  42. package/dist/esm/oauth2client/oauth2client.d.ts +62 -3
  43. package/dist/esm/oauth2client/oauth2client.js +200 -55
  44. package/dist/esm/utils/base64.d.ts +5 -0
  45. package/dist/esm/utils/base64.js +12 -0
  46. package/dist/esm/utils/encryptlong/index.js +21 -15
  47. package/dist/esm/utils/mp.js +3 -3
  48. package/dist/miniprogram/index.js +1 -1
  49. package/package.json +10 -4
  50. package/src/auth/apis.ts +222 -17
  51. package/src/auth/auth-error.ts +21 -0
  52. package/src/auth/consts.ts +28 -0
  53. package/src/auth/models.ts +13 -4
  54. package/src/captcha/captcha-dom.ts +178 -0
  55. package/src/captcha/captcha.ts +25 -114
  56. package/src/index.ts +54 -4
  57. package/src/oauth2client/interface.ts +1 -1
  58. package/src/oauth2client/models.ts +29 -1
  59. package/src/oauth2client/oauth2client.ts +308 -55
  60. package/src/utils/base64.ts +12 -0
  61. package/src/utils/encryptlong/index.js +20 -14
  62. package/src/utils/index.ts +1 -0
  63. package/src/utils/mp.ts +3 -3
  64. package/src/utils/urlSearchParams.ts +2 -0
  65. package/tsconfig.json +1 -0
  66. package/dist/cjs/utils/cloudbase-adapter-wx_mp.d.ts +0 -1
  67. package/dist/cjs/utils/cloudbase-adapter-wx_mp.js +0 -40
  68. package/dist/esm/utils/cloudbase-adapter-wx_mp.d.ts +0 -1
  69. package/dist/esm/utils/cloudbase-adapter-wx_mp.js +0 -35
  70. package/src/utils/cloudbase-adapter-wx_mp.ts +0 -42
@@ -0,0 +1,6 @@
1
+ export declare class AuthError extends Error {
2
+ code: (string & {}) | undefined;
3
+ status: number | undefined;
4
+ protected __isAuthError: boolean;
5
+ constructor(error: any);
6
+ }
@@ -0,0 +1,32 @@
1
+ "use strict";
2
+ var __extends = (this && this.__extends) || (function () {
3
+ var extendStatics = function (d, b) {
4
+ extendStatics = Object.setPrototypeOf ||
5
+ ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
6
+ function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };
7
+ return extendStatics(d, b);
8
+ };
9
+ return function (d, b) {
10
+ if (typeof b !== "function" && b !== null)
11
+ throw new TypeError("Class extends value " + String(b) + " is not a constructor or null");
12
+ extendStatics(d, b);
13
+ function __() { this.constructor = d; }
14
+ d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
15
+ };
16
+ })();
17
+ Object.defineProperty(exports, "__esModule", { value: true });
18
+ exports.AuthError = void 0;
19
+ var AuthError = (function (_super) {
20
+ __extends(AuthError, _super);
21
+ function AuthError(error) {
22
+ var _this = _super.call(this, error.error_description || error.message) || this;
23
+ _this.__isAuthError = true;
24
+ _this.name = 'AuthError';
25
+ _this.status = error.error;
26
+ _this.code = error.error_code;
27
+ return _this;
28
+ }
29
+ return AuthError;
30
+ }(Error));
31
+ exports.AuthError = AuthError;
32
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXV0aC1lcnJvci5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9hdXRoL2F1dGgtZXJyb3IudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7O0FBQUE7SUFBK0IsNkJBQUs7SUFjbEMsbUJBQVksS0FBSztRQUFqQixZQUNFLGtCQUFNLEtBQUssQ0FBQyxpQkFBaUIsSUFBSSxLQUFLLENBQUMsT0FBTyxDQUFDLFNBSWhEO1FBUFMsbUJBQWEsR0FBRyxJQUFJLENBQUE7UUFJNUIsS0FBSSxDQUFDLElBQUksR0FBRyxXQUFXLENBQUE7UUFDdkIsS0FBSSxDQUFDLE1BQU0sR0FBRyxLQUFLLENBQUMsS0FBSyxDQUFBO1FBQ3pCLEtBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDLFVBQVUsQ0FBQTs7SUFDOUIsQ0FBQztJQUNILGdCQUFDO0FBQUQsQ0FBQyxBQXBCRCxDQUErQixLQUFLLEdBb0JuQztBQXBCWSw4QkFBUyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBBdXRoRXJyb3IgZXh0ZW5kcyBFcnJvciB7XG4gIC8qKlxuICAgKiBFcnJvciBjb2RlIGFzc29jaWF0ZWQgd2l0aCB0aGUgZXJyb3IuIE1vc3QgZXJyb3JzIGNvbWluZyBmcm9tXG4gICAqIEhUVFAgcmVzcG9uc2VzIHdpbGwgaGF2ZSBhIGNvZGUsIHRob3VnaCBzb21lIGVycm9ycyB0aGF0IG9jY3VyXG4gICAqIGJlZm9yZSBhIHJlc3BvbnNlIGlzIHJlY2VpdmVkIHdpbGwgbm90IGhhdmUgb25lIHByZXNlbnQuIEluIHRoYXRcbiAgICogY2FzZSB7QGxpbmsgI3N0YXR1c30gd2lsbCBhbHNvIGJlIHVuZGVmaW5lZC5cbiAgICovXG4gIGNvZGU6IChzdHJpbmcgJiB7fSkgfCB1bmRlZmluZWRcblxuICAvKiogSFRUUCBzdGF0dXMgY29kZSB0aGF0IGNhdXNlZCB0aGUgZXJyb3IuICovXG4gIHN0YXR1czogbnVtYmVyIHwgdW5kZWZpbmVkXG5cbiAgcHJvdGVjdGVkIF9faXNBdXRoRXJyb3IgPSB0cnVlXG5cbiAgY29uc3RydWN0b3IoZXJyb3IpIHtcbiAgICBzdXBlcihlcnJvci5lcnJvcl9kZXNjcmlwdGlvbiB8fCBlcnJvci5tZXNzYWdlKVxuICAgIHRoaXMubmFtZSA9ICdBdXRoRXJyb3InXG4gICAgdGhpcy5zdGF0dXMgPSBlcnJvci5lcnJvclxuICAgIHRoaXMuY29kZSA9IGVycm9yLmVycm9yX2NvZGVcbiAgfVxufVxuIl19
@@ -108,3 +108,25 @@ export declare enum ErrorType {
108
108
  CAPTCHA_REQUIRED = "captcha_required",
109
109
  CAPTCHA_INVALID = "captcha_invalid"
110
110
  }
111
+ export declare const LOGIN_STATE_CHANGED_TYPE: {
112
+ SIGN_OUT: string;
113
+ SIGN_IN: string;
114
+ CREDENTIALS_ERROR: string;
115
+ };
116
+ export declare const AUTH_STATE_CHANGED_TYPE: {
117
+ SIGNED_OUT: string;
118
+ SIGNED_IN: string;
119
+ INITIAL_SESSION: string;
120
+ PASSWORD_RECOVERY: string;
121
+ TOKEN_REFRESHED: string;
122
+ USER_UPDATED: string;
123
+ BIND_IDENTITY: string;
124
+ };
125
+ export declare const EVENTS: {
126
+ LOGIN_STATE_CHANGED: string;
127
+ AUTH_STATE_CHANGED: string;
128
+ };
129
+ export declare const OAUTH_TYPE: {
130
+ SIGN_IN: string;
131
+ BIND_IDENTITY: string;
132
+ };
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.ErrorType = exports.VerificationUsages = exports.ApiUrlsV2 = exports.ApiUrls = exports.AUTH_API_PREFIX = void 0;
3
+ exports.OAUTH_TYPE = exports.EVENTS = exports.AUTH_STATE_CHANGED_TYPE = exports.LOGIN_STATE_CHANGED_TYPE = exports.ErrorType = exports.VerificationUsages = exports.ApiUrlsV2 = exports.ApiUrls = exports.AUTH_API_PREFIX = void 0;
4
4
  exports.AUTH_API_PREFIX = '/auth';
5
5
  var ApiUrls;
6
6
  (function (ApiUrls) {
@@ -115,4 +115,26 @@ var ErrorType;
115
115
  ErrorType["CAPTCHA_REQUIRED"] = "captcha_required";
116
116
  ErrorType["CAPTCHA_INVALID"] = "captcha_invalid";
117
117
  })(ErrorType = exports.ErrorType || (exports.ErrorType = {}));
118
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../src/auth/consts.ts"],"names":[],"mappings":";;;AAAa,QAAA,eAAe,GAAG,OAAO,CAAA;AAEtC,IAAY,OAiDX;AAjDD,WAAY,OAAO;IACjB,0CAA+B,CAAA;IAC/B,uCAA4B,CAAA;IAC5B,yCAA8B,CAAA;IAC9B,qDAA0C,CAAA;IAC1C,4CAAiC,CAAA;IACjC,mDAAwC,CAAA;IACxC,+CAAoC,CAAA;IACpC,uDAA4C,CAAA;IAC5C,iEAAsD,CAAA;IAEtD,0CAA+B,CAAA;IAC/B,kEAAuD,CAAA;IACvD,sEAA2D,CAAA;IAC3D,oEAAyD,CAAA;IACzD,oDAAyC,CAAA;IAEzC,oDAAyC,CAAA;IACzC,gDAAqC,CAAA;IAErC,sCAA2B,CAAA;IAC3B,gDAAqC,CAAA;IACrC,4CAAiC,CAAA;IACjC,gDAAqC,CAAA;IACrC,sDAA2C,CAAA;IAC3C,oEAAyD,CAAA;IACzD,8CAAmC,CAAA;IACnC,uDAA4C,CAAA;IAC5C,oDAAyC,CAAA;IACzC,0CAA+B,CAAA;IAC/B,qCAA0B,CAAA;IAC1B,gDAAqC,CAAA;IACrC,kDAAuC,CAAA;IACvC,6DAAkD,CAAA;IAClD,+CAAoC,CAAA;IACpC,yDAA8C,CAAA;IAC9C,yEAA8D,CAAA;IAC9D,sDAA2C,CAAA;IAC3C,8DAAmD,CAAA;IAEnD,gDAAqC,CAAA;IACrC,iDAAsC,CAAA;IAEtC,gDAAqC,CAAA;IACrC,8DAAmD,CAAA;IACnD,+CAAoC,CAAA;IAEpC,yDAA8C,CAAA;IAC9C,kEAAuD,CAAA;AACzD,CAAC,EAjDW,OAAO,GAAP,eAAO,KAAP,eAAO,QAiDlB;AAED,IAAY,SAQX;AARD,WAAY,SAAS;IACnB,qDAAwC,CAAA;IACxC,yCAA4B,CAAA;IAC5B,wCAA2B,CAAA;IAC3B,uDAA0C,CAAA;IAC1C,wEAA2D,CAAA;IAC3D,sDAAyC,CAAA;IACzC,+DAAkD,CAAA;AACpD,CAAC,EARW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAQpB;AAED,IAAY,kBAMX;AAND,WAAY,kBAAkB;IAC5B,2CAAqB,CAAA;IACrB,yCAAmB,CAAA;IACnB,uDAAiC,CAAA;IACjC,mEAA6C,CAAA;IAC7C,iEAA2C,CAAA;AAC7C,CAAC,EANW,kBAAkB,GAAlB,0BAAkB,KAAlB,0BAAkB,QAM7B;AAED,IAAY,SAiDX;AAjDD,WAAY,SAAS;IACnB,wCAA2B,CAAA;IAC3B,4BAAe,CAAA;IACf,oCAAuB,CAAA;IACvB,gCAAmB,CAAA;IACnB,gDAAmC,CAAA;IACnC,sDAAyC,CAAA;IACzC,wDAA2C,CAAA;IAC3C,kDAAqC,CAAA;IACrC,oDAAuC,CAAA;IACvC,oCAAuB,CAAA;IACvB,8CAAiC,CAAA;IACjC,oDAAuC,CAAA;IACvC,gCAAmB,CAAA;IACnB,0CAA6B,CAAA;IAC7B,4CAA+B,CAAA;IAC/B,kCAAqB,CAAA;IACrB,wCAA2B,CAAA;IAC3B,oCAAuB,CAAA;IAEvB,kDAAqC,CAAA;IACrC,kDAAqC,CAAA;IACrC,8CAAiC,CAAA;IACjC,0CAA6B,CAAA;IAC7B,0CAA6B,CAAA;IAC7B,oEAAuD,CAAA;IACvD,wDAA2C,CAAA;IAC3C,sDAAyC,CAAA;IACzC,wEAA2D,CAAA;IAC3D,0CAA6B,CAAA;IAC7B,gDAAmC,CAAA;IACnC,wDAA2C,CAAA;IAC3C,4CAA+B,CAAA;IAC/B,oEAAuD,CAAA;IACvD,4CAA+B,CAAA;IAC/B,4CAA+B,CAAA;IAC/B,0CAA6B,CAAA;IAC7B,gEAAmD,CAAA;IACnD,0DAA6C,CAAA;IAC7C,8CAAiC,CAAA;IACjC,sEAAyD,CAAA;IACzD,kDAAqC,CAAA;IACrC,wDAA2C,CAAA;IAC3C,8DAAiD,CAAA;IACjD,4DAA+C,CAAA;IAC/C,oEAAuD,CAAA;IACvD,sEAAyD,CAAA;IACzD,kDAAqC,CAAA;IACrC,gDAAmC,CAAA;AACrC,CAAC,EAjDW,SAAS,GAAT,iBAAS,KAAT,iBAAS,QAiDpB","sourcesContent":["export const AUTH_API_PREFIX = '/auth'\n\nexport enum ApiUrls {\n  AUTH_SIGN_UP_URL = '/v1/signup',\n  AUTH_TOKEN_URL = '/v1/token',\n  AUTH_REVOKE_URL = '/v1/revoke',\n  WEDA_USER_URL = '/v1/plugin/weda/userinfo',\n  AUTH_RESET_PASSWORD = '/v1/reset',\n  AUTH_GET_DEVICE_CODE = '/v1/device/code',\n  CHECK_USERNAME = '/v1/checkUsername',\n  CHECK_IF_USER_EXIST = '/v1/checkIfUserExist',\n  GET_PROVIDER_TYPE = '/v1/mgr/provider/providerSubType',\n\n  AUTH_SIGN_IN_URL = '/v1/signin',\n  AUTH_SIGN_IN_ANONYMOUSLY_URL = '/v1/signin/anonymously',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v1/signin/with/provider',\n  AUTH_SIGN_IN_WITH_WECHAT_URL = '/v1/signin/wechat/noauth',\n  AUTH_SIGN_IN_CUSTOM = '/v1/signin/custom',\n\n  PROVIDER_TOKEN_URL = '/v1/provider/token',\n  PROVIDER_URI_URL = '/v1/provider/uri',\n\n  USER_ME_URL = '/v1/user/me',\n  AUTH_SIGNOUT_URL = '/v1/user/signout',\n  USER_QUERY_URL = '/v1/user/query',\n  USER_PRIFILE_URL = '/v1/user/profile',\n  USER_BASIC_EDIT_URL = '/v1/user/basic/edit',\n  USER_TRANS_BY_PROVIDER_URL = '/v1/user/trans/by/provider',\n  PROVIDER_LIST = '/v1/user/provider',\n  PROVIDER_BIND_URL = '/v1/user/provider/bind',\n  PROVIDER_UNBIND_URL = '/v1/user/provider',\n  CHECK_PWD_URL = '/v1/user/sudo',\n  SUDO_URL = '/v1/user/sudo',\n  BIND_CONTACT_URL = '/v1/user/contact',\n  AUTH_SET_PASSWORD = '/v1/user/password',\n  AUTHORIZE_DEVICE_URL = '/v1/user/device/authorize',\n  AUTHORIZE_URL = '/v1/user/authorize',\n  AUTHORIZE_INFO_URL = '/v1/user/authorize/info',\n  AUTHORIZED_DEVICES_DELETE_URL = '/v1/user/authorized/devices/',\n  AUTH_REVOKE_ALL_URL = '/v1/user/revoke/all',\n  GET_USER_BEHAVIOR_LOG = '/v1/user/security/history',\n\n  VERIFICATION_URL = '/v1/verification',\n  VERIFY_URL = '/v1/verification/verify',\n\n  CAPTCHA_DATA_URL = '/v1/captcha/data',\n  VERIFY_CAPTCHA_DATA_URL = '/v1/captcha/data/verify',\n  GET_CAPTCHA_URL = '/v1/captcha/init',\n\n  GET_MINIPROGRAM_QRCODE = '/v1/qrcode/generate',\n  GET_MINIPROGRAM_QRCODE_STATUS = '/v1/qrcode/get/status',\n}\n\nexport enum ApiUrlsV2 {\n  AUTH_SIGN_IN_URL = '/v2/signin/username',\n  AUTH_TOKEN_URL = '/v2/token',\n  USER_ME_URL = '/v2/user/me',\n  VERIFY_URL = '/v2/signin/verificationcode',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v2/signin/with/provider',\n  AUTH_PUBLIC_KEY = '/v2/signin/publichkey',\n  AUTH_RESET_PASSWORD = '/v2/signin/password/update'\n}\n\nexport enum VerificationUsages {\n  REGISTER = 'REGISTER',\n  SIGN_IN = 'SIGN_IN',\n  PASSWORD_RESET = 'PASSWORD_RESET',\n  EMAIL_ADDRESS_CHANGE = 'EMAIL_ADDRESS_CHANGE',\n  PHONE_NUMBER_CHANGE = 'PHONE_NUMBER_CHANGE',\n}\n\nexport enum ErrorType {\n  UNREACHABLE = 'unreachable',\n  LOCAL = 'local',\n  CANCELLED = 'cancelled',\n  UNKNOWN = 'unknown',\n  UNAUTHENTICATED = 'unauthenticated',\n  RESOURCE_EXHAUSTED = 'resource_exhausted',\n  FAILED_PRECONDITION = 'failed_precondition',\n  INVALID_ARGUMENT = 'invalid_argument',\n  DEADLINE_EXCEEDED = 'deadline_exceeded',\n  NOT_FOUND = 'not_found',\n  ALREADY_EXISTS = 'already_exists',\n  PERMISSION_DENIED = 'permission_denied',\n  ABORTED = 'aborted',\n  OUT_OF_RANGE = 'out_of_range',\n  UNIMPLEMENTED = 'unimplemented',\n  INTERNAL = 'internal',\n  UNAVAILABLE = 'unavailable',\n  DATA_LOSS = 'data_loss',\n  // CommonError\n  INVALID_PASSWORD = 'invalid_password',\n  PASSWORD_NOT_SET = 'password_not_set',\n  INVALID_STATUS = 'invalid_status',\n  USER_PENDING = 'user_pending',\n  USER_BLOCKED = 'user_blocked',\n  INVALID_VERIFICATION_CODE = 'invalid_verification_code',\n  TWO_FACTOR_REQUIRED = 'two_factor_required',\n  INVALID_TWO_FACTOR = 'invalid_two_factor',\n  INVALID_TWO_FACTOR_RECOVERY = 'invalid_two_factor_recovery',\n  UNDER_REVIEW = 'under_review',\n  INVALID_REQUEST = 'invalid_request',\n  UNAUTHORIZED_CLIENT = 'unauthorized_client',\n  ACCESS_DENIED = 'access_denied',\n  UNSUPPORTED_RESPONSE_TYPE = 'unsupported_response_type',\n  INVALID_SCOPE = 'invalid_scope',\n  INVALID_GRANT = 'invalid_grant',\n  SERVER_ERROR = 'server_error',\n  TEMPORARILY_UNAVAILABLE = 'temporarily_unavailable',\n  INTERACTION_REQUIRED = 'interaction_required',\n  LOGIN_REQUIRED = 'login_required',\n  ACCOUNT_SELECTION_REQUIRED = 'account_selection_required',\n  CONSENT_REQUIRED = 'consent_required',\n  INVALID_REQUEST_URI = 'invalid_request_uri',\n  INVALID_REQUEST_OBJECT = 'invalid_request_object',\n  REQUEST_NOT_SUPPORTED = 'request_not_supported',\n  REQUEST_URI_NOT_SUPPORTED = 'request_uri_not_supported',\n  REGISTRATION_NOT_SUPPORTED = 'registration_not_supported',\n  CAPTCHA_REQUIRED = 'captcha_required',\n  CAPTCHA_INVALID = 'captcha_invalid',\n}\n"]}
118
+ exports.LOGIN_STATE_CHANGED_TYPE = {
119
+ SIGN_OUT: 'sign_out',
120
+ SIGN_IN: 'sign_in',
121
+ CREDENTIALS_ERROR: 'credentials_error',
122
+ };
123
+ exports.AUTH_STATE_CHANGED_TYPE = {
124
+ SIGNED_OUT: 'SIGNED_OUT',
125
+ SIGNED_IN: 'SIGNED_IN',
126
+ INITIAL_SESSION: 'INITIAL_SESSION',
127
+ PASSWORD_RECOVERY: 'PASSWORD_RECOVERY',
128
+ TOKEN_REFRESHED: 'TOKEN_REFRESHED',
129
+ USER_UPDATED: 'USER_UPDATED',
130
+ BIND_IDENTITY: 'BIND_IDENTITY',
131
+ };
132
+ exports.EVENTS = {
133
+ LOGIN_STATE_CHANGED: 'loginStateChanged',
134
+ AUTH_STATE_CHANGED: 'authStateChanged',
135
+ };
136
+ exports.OAUTH_TYPE = {
137
+ SIGN_IN: 'sign_in',
138
+ BIND_IDENTITY: 'bind_identity',
139
+ };
140
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"consts.js","sourceRoot":"","sources":["../../../src/auth/consts.ts"],"names":[],"mappings":"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","sourcesContent":["export const AUTH_API_PREFIX = '/auth'\n\nexport enum ApiUrls {\n  AUTH_SIGN_UP_URL = '/v1/signup',\n  AUTH_TOKEN_URL = '/v1/token',\n  AUTH_REVOKE_URL = '/v1/revoke',\n  WEDA_USER_URL = '/v1/plugin/weda/userinfo',\n  AUTH_RESET_PASSWORD = '/v1/reset',\n  AUTH_GET_DEVICE_CODE = '/v1/device/code',\n  CHECK_USERNAME = '/v1/checkUsername',\n  CHECK_IF_USER_EXIST = '/v1/checkIfUserExist',\n  GET_PROVIDER_TYPE = '/v1/mgr/provider/providerSubType',\n\n  AUTH_SIGN_IN_URL = '/v1/signin',\n  AUTH_SIGN_IN_ANONYMOUSLY_URL = '/v1/signin/anonymously',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v1/signin/with/provider',\n  AUTH_SIGN_IN_WITH_WECHAT_URL = '/v1/signin/wechat/noauth',\n  AUTH_SIGN_IN_CUSTOM = '/v1/signin/custom',\n\n  PROVIDER_TOKEN_URL = '/v1/provider/token',\n  PROVIDER_URI_URL = '/v1/provider/uri',\n\n  USER_ME_URL = '/v1/user/me',\n  AUTH_SIGNOUT_URL = '/v1/user/signout',\n  USER_QUERY_URL = '/v1/user/query',\n  USER_PRIFILE_URL = '/v1/user/profile',\n  USER_BASIC_EDIT_URL = '/v1/user/basic/edit',\n  USER_TRANS_BY_PROVIDER_URL = '/v1/user/trans/by/provider',\n  PROVIDER_LIST = '/v1/user/provider',\n  PROVIDER_BIND_URL = '/v1/user/provider/bind',\n  PROVIDER_UNBIND_URL = '/v1/user/provider',\n  CHECK_PWD_URL = '/v1/user/sudo',\n  SUDO_URL = '/v1/user/sudo',\n  BIND_CONTACT_URL = '/v1/user/contact',\n  AUTH_SET_PASSWORD = '/v1/user/password',\n  AUTHORIZE_DEVICE_URL = '/v1/user/device/authorize',\n  AUTHORIZE_URL = '/v1/user/authorize',\n  AUTHORIZE_INFO_URL = '/v1/user/authorize/info',\n  AUTHORIZED_DEVICES_DELETE_URL = '/v1/user/authorized/devices/',\n  AUTH_REVOKE_ALL_URL = '/v1/user/revoke/all',\n  GET_USER_BEHAVIOR_LOG = '/v1/user/security/history',\n\n  VERIFICATION_URL = '/v1/verification',\n  VERIFY_URL = '/v1/verification/verify',\n\n  CAPTCHA_DATA_URL = '/v1/captcha/data',\n  VERIFY_CAPTCHA_DATA_URL = '/v1/captcha/data/verify',\n  GET_CAPTCHA_URL = '/v1/captcha/init',\n\n  GET_MINIPROGRAM_QRCODE = '/v1/qrcode/generate',\n  GET_MINIPROGRAM_QRCODE_STATUS = '/v1/qrcode/get/status',\n}\n\nexport enum ApiUrlsV2 {\n  AUTH_SIGN_IN_URL = '/v2/signin/username',\n  AUTH_TOKEN_URL = '/v2/token',\n  USER_ME_URL = '/v2/user/me',\n  VERIFY_URL = '/v2/signin/verificationcode',\n  AUTH_SIGN_IN_WITH_PROVIDER_URL = '/v2/signin/with/provider',\n  AUTH_PUBLIC_KEY = '/v2/signin/publichkey',\n  AUTH_RESET_PASSWORD = '/v2/signin/password/update'\n}\n\nexport enum VerificationUsages {\n  REGISTER = 'REGISTER',\n  SIGN_IN = 'SIGN_IN',\n  PASSWORD_RESET = 'PASSWORD_RESET',\n  EMAIL_ADDRESS_CHANGE = 'EMAIL_ADDRESS_CHANGE',\n  PHONE_NUMBER_CHANGE = 'PHONE_NUMBER_CHANGE',\n}\n\nexport enum ErrorType {\n  UNREACHABLE = 'unreachable',\n  LOCAL = 'local',\n  CANCELLED = 'cancelled',\n  UNKNOWN = 'unknown',\n  UNAUTHENTICATED = 'unauthenticated',\n  RESOURCE_EXHAUSTED = 'resource_exhausted',\n  FAILED_PRECONDITION = 'failed_precondition',\n  INVALID_ARGUMENT = 'invalid_argument',\n  DEADLINE_EXCEEDED = 'deadline_exceeded',\n  NOT_FOUND = 'not_found',\n  ALREADY_EXISTS = 'already_exists',\n  PERMISSION_DENIED = 'permission_denied',\n  ABORTED = 'aborted',\n  OUT_OF_RANGE = 'out_of_range',\n  UNIMPLEMENTED = 'unimplemented',\n  INTERNAL = 'internal',\n  UNAVAILABLE = 'unavailable',\n  DATA_LOSS = 'data_loss',\n  // CommonError\n  INVALID_PASSWORD = 'invalid_password',\n  PASSWORD_NOT_SET = 'password_not_set',\n  INVALID_STATUS = 'invalid_status',\n  USER_PENDING = 'user_pending',\n  USER_BLOCKED = 'user_blocked',\n  INVALID_VERIFICATION_CODE = 'invalid_verification_code',\n  TWO_FACTOR_REQUIRED = 'two_factor_required',\n  INVALID_TWO_FACTOR = 'invalid_two_factor',\n  INVALID_TWO_FACTOR_RECOVERY = 'invalid_two_factor_recovery',\n  UNDER_REVIEW = 'under_review',\n  INVALID_REQUEST = 'invalid_request',\n  UNAUTHORIZED_CLIENT = 'unauthorized_client',\n  ACCESS_DENIED = 'access_denied',\n  UNSUPPORTED_RESPONSE_TYPE = 'unsupported_response_type',\n  INVALID_SCOPE = 'invalid_scope',\n  INVALID_GRANT = 'invalid_grant',\n  SERVER_ERROR = 'server_error',\n  TEMPORARILY_UNAVAILABLE = 'temporarily_unavailable',\n  INTERACTION_REQUIRED = 'interaction_required',\n  LOGIN_REQUIRED = 'login_required',\n  ACCOUNT_SELECTION_REQUIRED = 'account_selection_required',\n  CONSENT_REQUIRED = 'consent_required',\n  INVALID_REQUEST_URI = 'invalid_request_uri',\n  INVALID_REQUEST_OBJECT = 'invalid_request_object',\n  REQUEST_NOT_SUPPORTED = 'request_not_supported',\n  REQUEST_URI_NOT_SUPPORTED = 'request_uri_not_supported',\n  REGISTRATION_NOT_SUPPORTED = 'registration_not_supported',\n  CAPTCHA_REQUIRED = 'captcha_required',\n  CAPTCHA_INVALID = 'captcha_invalid',\n}\n\nexport const LOGIN_STATE_CHANGED_TYPE = {\n  SIGN_OUT: 'sign_out',\n  SIGN_IN: 'sign_in',\n  CREDENTIALS_ERROR: 'credentials_error',\n}\n\nexport const AUTH_STATE_CHANGED_TYPE = {\n  SIGNED_OUT: 'SIGNED_OUT',\n  SIGNED_IN: 'SIGNED_IN',\n  INITIAL_SESSION: 'INITIAL_SESSION',\n  PASSWORD_RECOVERY: 'PASSWORD_RECOVERY',\n  TOKEN_REFRESHED: 'TOKEN_REFRESHED',\n  USER_UPDATED: 'USER_UPDATED',\n  BIND_IDENTITY: 'BIND_IDENTITY',\n}\n\nexport const EVENTS = {\n  // 登录态改变后触发\n  LOGIN_STATE_CHANGED: 'loginStateChanged',\n  // 授权态改变后触发\n  AUTH_STATE_CHANGED: 'authStateChanged',\n}\n\nexport const OAUTH_TYPE = {\n  SIGN_IN: 'sign_in',\n  BIND_IDENTITY: 'bind_identity',\n}\n"]}
@@ -235,7 +235,7 @@ export interface PatchProviderTokenResponse {
235
235
  }
236
236
  export interface GenProviderRedirectUriRequest {
237
237
  provider_id: string;
238
- redirect_uri: string;
238
+ redirect_uri?: string;
239
239
  provider_redirect_uri?: string;
240
240
  state: string;
241
241
  scope?: string;
@@ -278,6 +278,12 @@ export interface UserProfile {
278
278
  zoneinfo?: string;
279
279
  locale?: string;
280
280
  created_from?: string;
281
+ created_at?: string;
282
+ updated_at?: string;
283
+ loginType?: string;
284
+ avatarUrl?: string;
285
+ location?: any;
286
+ hasPassword?: boolean;
281
287
  }
282
288
  interface UserProvider {
283
289
  id: string;
@@ -377,8 +383,8 @@ export interface QueryUserProfileResponse {
377
383
  data?: [SimpleUserProfile];
378
384
  }
379
385
  export interface ResetPasswordRequest extends BaseRequest {
380
- email: string;
381
- phone_number: string;
386
+ email?: string;
387
+ phone_number?: string;
382
388
  new_password: string;
383
389
  verification_token: string;
384
390
  }
@@ -436,7 +442,7 @@ export interface SignoutRequest {
436
442
  redirect_uri?: string;
437
443
  state?: string;
438
444
  }
439
- export interface SignoutReponse {
445
+ export interface SignoutResponse {
440
446
  redirect_uri?: string;
441
447
  }
442
448
  export interface AuthorizeDeviceRequest extends BaseRequest {
@@ -511,6 +517,8 @@ export interface ModifyUserBasicInfoRequest {
511
517
  gender?: 'MALE' | 'FEMALE';
512
518
  password?: string;
513
519
  new_password?: string;
520
+ email?: string;
521
+ phone?: string;
514
522
  }
515
523
  export interface GetUserBehaviorLog {
516
524
  type: 'LOGIN' | 'MODIFY';
@@ -537,5 +545,6 @@ export interface ToDefaultLoginPage {
537
545
  config_version?: 'env' | string;
538
546
  redirect_uri?: string;
539
547
  app_id?: string;
548
+ query?: Record<string, any>;
540
549
  }
541
550
  export {};
@@ -1,3 +1,3 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../src/auth/models.ts"],"names":[],"mappings":"","sourcesContent":["interface BaseRequest {\n  client_id?: string\n}\n\nexport type GetCustomSignTicketFn = () => Promise<string>\n\nexport interface SignInRequest extends BaseRequest, EncryptParams {\n  username?: string\n  password?: string\n  verification_token?: string\n  version?: string\n  query?: { with_department?: boolean; with_role?: boolean }\n}\n\nexport interface SignInWithProviderRequest extends BaseRequest {\n  provider_token: string\n  version?: string\n}\n\nexport interface SignUpRequest extends BaseRequest {\n  phone_number?: string\n  email?: string\n\n  verification_code?: string\n  verification_token?: string\n  provider_token?: string\n\n  password?: string\n  name?: string\n  gender?: string\n  picture?: string\n  locale?: string\n}\n\nexport interface GetVerificationRequest extends BaseRequest {\n  phone_number?: string\n  email?: string\n  target?: string | 'ANY'\n  usage?: string\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string\n  is_user?: boolean | false\n}\n\nexport interface VerifyResponse {\n  verification_token?: string\n}\n\nexport interface VerifyRequest extends BaseRequest {\n  verification_code: string\n  verification_id?: string\n  verification_token?: string\n  version?: string\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string\n}\n\nexport interface GrantProviderTokenRequest extends BaseRequest {\n  provider_id: string\n  provider_redirect_uri?: string\n  provider_code?: string\n  provider_access_token?: string\n  provider_id_token?: string\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  code?: string\n  error_code?: string\n  provider_profile?: ProviderProfile\n}\n\nexport interface PatchProviderTokenRequest extends BaseRequest {\n  provider_id?: string\n  provider_token: string\n  provider_params: {\n    encryptedData?: string\n    iv?: string\n    code?: string\n    provider_code_type?: string\n  }\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  provider_profile: ProviderProfile\n}\n\n// export interface GenProviderRedirectUriRequest {\n//   provider_id: string;\n//   provider_redirect_uri: string;\n//   state: string;\n//   other_params?: {\n//     sign_out_uri?: string;\n//   };\n// }\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string\n  signout_uri?: string\n}\n\nexport interface BindWithProviderRequest extends BaseRequest {\n  provider_token: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface UserProfileProvider {\n  id?: string\n  provider_user_id?: string\n  name?: string\n}\n\nexport interface UserProfile {\n  name?: string\n  picture?: string\n  username?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  providers?: [UserProfileProvider]\n  gender?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  created_from?: string\n  sub?: string\n  uid?: string\n  address?: {\n    formatted?: string\n    street_address?: string\n    locality?: string\n    region?: string\n    postal_code?: string\n    country?: string\n  }\n  nickName?: string // TODO:\n  province?: string // TODO:\n  country?: string // TODO:\n  city?: string // TODO:\n}\n\nexport type UserInfo = UserProfile\n\nexport interface ProviderProfile {\n  provider_id: string\n  phone_number?: string\n  name?: string\n  picture?: string\n  email?: string\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string\n}\n\nexport interface GrantTokenRequest extends BaseRequest {\n  client_secret?: string\n  code?: string\n  grant_type?: string\n  redirect_uri?: string\n  nonce?: string\n  refresh_token?: string\n  scope?: string\n}\n\nexport interface UnbindProviderRequest extends BaseRequest {\n  provider_id: string\n}\n\nexport interface BindPhoneRequest extends BaseRequest {\n  phone_number: string\n  sudo_token: string\n  verification_token: string\n}\n\nexport interface SetPasswordRequest extends BaseRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface ChangeBindedProviderRequest extends BaseRequest {\n  trans_token: string\n  provider_id: string\n}\n\nexport interface QueryUserProfileReq extends BaseRequest {\n  appended_params: string\n}\n\nexport interface SignInWithProviderRequest {\n  provider_token: string\n  provider_id?: string\n}\n\nexport interface SignInCustomRequest {\n  provider_id?: string\n  ticket: string\n}\n\nexport interface SignUpRequest {\n  phone_number?: string\n  email?: string\n\n  verification_code?: string\n  verification_token?: string\n  provider_token?: string\n\n  username?: string\n  password?: string\n  name?: string\n  gender?: string\n  picture?: string\n  locale?: string\n\n  anonymous_token?: string\n}\n\nexport interface GetVerificationRequest {\n  phone_number?: string\n  email?: string\n  // 可选 ANY，USER，NOT_USER, CUR_USER;\n  target?: string | 'ANY'\n  usage?: string\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string\n  is_user?: boolean | false\n}\n\nexport interface VerifyResponse {\n  verification_token?: string\n  expires_in: number\n}\n\nexport interface VerifyRequest {\n  verification_code: string\n  verification_id?: string\n  verification_token?: string\n  version?: string\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string\n  expires_in: number\n}\n\nexport interface GrantProviderTokenRequest {\n  provider_id: string\n  provider_redirect_uri?: string\n  provider_code?: string\n  provider_access_token?: string\n  provider_id_token?: string\n  provider_params?: {\n    provider_code_type?: string\n    appid?: string\n  }\n}\n\nexport interface PatchProviderTokenRequest {\n  provider_token: string\n  provider_id?: string\n  provider_params: {\n    encryptedData?: string\n    iv?: string\n    code?: string\n    provider_code_type?: string\n  }\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  provider_profile: ProviderProfile\n}\n\nexport interface GenProviderRedirectUriRequest {\n  provider_id: string\n  redirect_uri: string\n  /**\n   * @deprecated\n   */\n  provider_redirect_uri?: string\n  state: string\n  scope?: string\n  response_type?: string\n  other_params?: {\n    [key: string]: string\n  }\n}\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string\n  signout_uri?: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface UserProfileProvider {\n  id?: string\n  provider_user_id?: string\n  name?: string\n}\n\ninterface ProfileGroup {\n  id: string\n  expires_at?: string\n}\n\nexport interface UserProfile {\n  sub?: string\n  name?: string\n  picture?: string\n  username?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  groups?: [ProfileGroup]\n  providers?: [UserProfileProvider]\n  gender?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  created_from?: string\n}\n\ninterface UserProvider {\n  id: string\n  name: string\n  provider_user_name?: string\n  bind: boolean\n}\nexport interface ProvidersResponse {\n  total: number\n  data: [UserProvider]\n}\n\nexport interface ProviderProfile {\n  provider_id: string\n  name?: string\n  picture?: string\n  phone_number?: string\n  email?: string\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string\n}\n\nexport interface GrantTokenRequest {\n  client_secret?: string\n  code?: string\n  grant_type?: string\n  redirect_uri?: string\n  nonce?: string\n  refresh_token?: string\n  username?: string\n  password?: string\n  scope?: string\n  code_verifier?: string\n  device_code?: string\n}\n\nexport interface UnbindProviderRequest {\n  provider_id: string\n}\n\nexport interface CheckPasswordRequest extends BaseRequest {\n  password: string\n}\n\nexport interface EditContactRequest {\n  phone_number?: string\n  email?: string\n  sudo_token: string\n  verification_token: string\n  // 冲突解决方案\n  // 可选：DEFAULT， 默认解决方案：提示用户该手机号已被其他人绑定\n  //      DELETE_ACCOUNT_TRANSFER，标记原来的账号为已注销，并将手机换绑给自己\n  //     TRANSFER 仅换绑手机号，不注销原有账号。（原有账号无法登录情况下，则自动标记为注销）\n  conflict_resolution?: string\n}\n\nexport interface BindPhoneRequest {\n  phone_number: string\n  sudo_token: string\n  verification_token: string\n  conflict_resolution: string\n  // 1. DEFAULT 0, 默认提示用户手机号已被绑定\n  // 2. DELETE_ACCOUNT_TRANSFER 1, 标记原账号已被注销，并将手机换绑给自己\n  // 3. TRANSFER 2, 仅换绑手机号，不注销原有账号（换绑后原账号无法登录时，则自动注销原账号）\n}\n\nexport interface BindEmailRequest {\n  email: string\n  sudo_token: string\n  verification_token: string\n}\n\nexport interface SetPasswordRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface SetPasswordRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface UpdatePasswordRequest {\n  old_password: string\n  new_password: string\n}\n\n// password 和 verification_token 而选一，如果绑定了手机号，则必须使用verification_token 进行sudo\nexport interface SudoRequest {\n  password?: string\n  verification_token?: string\n}\n\nexport interface SudoResponse {\n  sudo_token?: string\n}\n\nexport interface WithSudoRequest {\n  sudo_token: string\n  version?: string\n}\n\nexport interface ChangeBoundProviderRequest {\n  trans_token: string\n  provider_id: string\n}\n\nexport interface ChangeBoundProviderResponse {\n  client_id: string\n}\n\nexport interface QueryUserProfileRequest {\n  id?: [string]\n  username?: string\n  email?: string\n  phone_number?: string\n}\n\nexport interface QueryUserProfileResponse {\n  total: number\n  data?: [SimpleUserProfile]\n}\n\nexport interface ResetPasswordRequest extends BaseRequest {\n  email: string\n  phone_number: string\n  new_password: string\n  verification_token: string\n}\n\nexport interface DeviceAuthorizeRequest extends BaseRequest {\n  scope?: string\n}\n\nexport interface AuthorizeRequest extends BaseRequest {\n  response_type?: string\n  redirect_uri?: string\n  state?: string\n  scope?: string\n  code_challenge?: string\n  code_challenge_method?: string\n  sign_out_uri?: string\n}\n\nexport interface AuthorizeResponse {\n  code?: string\n  access_token?: string\n  id_token?: string\n  token_type?: string\n  scope?: string\n  state?: string\n  expires_in?: number\n}\n\nexport interface AuthorizeInfoRequest extends BaseRequest {\n  response_type?: string\n  redirect_uri?: string\n  state?: string\n  scope?: string\n  sign_out_uri?: string\n  locale?: string\n}\n\nexport interface Scope {\n  id: string\n  name: string\n  description?: string\n  picture?: string\n  url?: string\n  children?: Scope[]\n}\nexport interface AuthorizeInfoResponse {\n  client: {\n    id: string\n    name: string\n    description?: string\n    picture?: string\n    url?: string\n  }\n  scopes?: Scope[]\n}\n\nexport interface RevokeDeviceRequest {\n  device_id: string\n}\n\nexport interface SignoutRequest {\n  redirect_uri?: string\n  state?: string\n}\n\nexport interface SignoutReponse {\n  redirect_uri?: string\n}\n\nexport interface AuthorizeDeviceRequest extends BaseRequest {\n  user_code: string\n  scope?: string\n  state?: string\n}\n\nexport interface DeviceAuthorizeResponse {\n  device_code: string\n  user_code?: string\n  expires_in: number\n  interval: number\n  verification_uri?: string\n  verification_uri_complete?: string\n}\n\n// 简化版用户信息\nexport interface SimpleUserProfile {\n  sub: string\n  name: string\n  picture?: string\n  gender?: string\n  locale?: string\n  email?: string\n  phone_number?: string\n}\n\nexport interface CheckUsernameRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistResponse {\n  exist: boolean\n}\n\nexport interface PublicKey {\n  public_key: string // 加密的公钥\n  public_key_thumbprint: string // 加密的公钥指纹\n}\n\nexport interface EncryptParams {\n  isEncrypt?: boolean // 是否需要加密\n  public_key_thumbprint?: string // 加密的公钥指纹\n  params?: string // 加密的数据\n}\n\nexport interface ProviderSubType {\n  id: string\n  provider_sub_type: 'NO_AUTH_LOGIN' | '' // NO_AUTH_LOGIN-免密登录\n}\n\nexport interface GetMiniProgramQrCodeRequest {\n  envId: string\n  wxAppId: string\n}\n\nexport interface GetMiniProgramQrCodeResponse {\n  qr_code: string\n  qr_code_id: string\n  expires_in: number\n}\n\nexport interface GetMiniProgramQrCodeStatusRequest {\n  qrCodeId: string\n  envId: string\n  wxAppId: string\n}\n\nexport interface GetMiniProgramQrCodeStatusResponse {\n  status: string\n  provider_token: string\n  expires_in: number\n}\n\nexport interface ModifyUserBasicInfoRequest {\n  user_id?: string\n  nickname?: string\n  username?: string\n  description?: string\n  avatar_url?: string\n  gender?: 'MALE' | 'FEMALE'\n  password?: string // 旧密码\n  new_password?: string // 新密码\n}\n\nexport interface GetUserBehaviorLog {\n  type: 'LOGIN' | 'MODIFY' // LOGIN-登录日志，MODIFY-修改登录方式日志\n  limit: number // 每页查询数量\n  page_token?: string\n}\n\nexport interface GetUserBehaviorLogRes {\n  id: string\n  ip: string\n  user_agent: string\n  client_id: string\n  device_id: string\n  created_at: string\n  meta: { from: string }\n}\n\n\nexport interface ModifyPasswordWithoutLoginRequest {\n  username?: string\n  password?: string // 旧密码\n  new_password?: string // 新密码\n}\n\nexport interface ToDefaultLoginPage {\n  config_version?: 'env' | string; // 登录配置，默认env（托管登录页）\n  redirect_uri?: string; // 登录后回调地址，默认当前地址\n  app_id?: string; // 应用id，托管登录页不需要传\n}\n"]}
3
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"models.js","sourceRoot":"","sources":["../../../src/auth/models.ts"],"names":[],"mappings":"","sourcesContent":["interface BaseRequest {\n  client_id?: string\n}\n\nexport type GetCustomSignTicketFn = () => Promise<string>\n\nexport interface SignInRequest extends BaseRequest, EncryptParams {\n  username?: string\n  password?: string\n  verification_token?: string\n  version?: string\n  query?: { with_department?: boolean; with_role?: boolean }\n}\n\nexport interface SignInWithProviderRequest extends BaseRequest {\n  provider_token: string\n  version?: string\n}\n\nexport interface SignUpRequest extends BaseRequest {\n  phone_number?: string\n  email?: string\n\n  verification_code?: string\n  verification_token?: string\n  provider_token?: string\n\n  password?: string\n  name?: string\n  gender?: string\n  picture?: string\n  locale?: string\n}\n\nexport interface GetVerificationRequest extends BaseRequest {\n  phone_number?: string\n  email?: string\n  target?: string | 'ANY'\n  usage?: string\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string\n  is_user?: boolean | false\n}\n\nexport interface VerifyResponse {\n  verification_token?: string\n}\n\nexport interface VerifyRequest extends BaseRequest {\n  verification_code: string\n  verification_id?: string\n  verification_token?: string\n  version?: string\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string\n}\n\nexport interface GrantProviderTokenRequest extends BaseRequest {\n  provider_id: string\n  provider_redirect_uri?: string\n  provider_code?: string\n  provider_access_token?: string\n  provider_id_token?: string\n}\n\nexport interface GrantProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  code?: string\n  error_code?: string\n  provider_profile?: ProviderProfile\n}\n\nexport interface PatchProviderTokenRequest extends BaseRequest {\n  provider_id?: string\n  provider_token: string\n  provider_params: {\n    encryptedData?: string\n    iv?: string\n    code?: string\n    provider_code_type?: string\n  }\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  provider_profile: ProviderProfile\n}\n\n// export interface GenProviderRedirectUriRequest {\n//   provider_id: string;\n//   provider_redirect_uri: string;\n//   state: string;\n//   other_params?: {\n//     sign_out_uri?: string;\n//   };\n// }\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string\n  signout_uri?: string\n}\n\nexport interface BindWithProviderRequest extends BaseRequest {\n  provider_token: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface UserProfileProvider {\n  id?: string\n  provider_user_id?: string\n  name?: string\n}\n\nexport interface UserProfile {\n  name?: string\n  picture?: string\n  username?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  providers?: [UserProfileProvider]\n  gender?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  created_from?: string\n  sub?: string\n  uid?: string\n  address?: {\n    formatted?: string\n    street_address?: string\n    locality?: string\n    region?: string\n    postal_code?: string\n    country?: string\n  }\n  nickName?: string // TODO:\n  province?: string // TODO:\n  country?: string // TODO:\n  city?: string // TODO:\n}\n\nexport type UserInfo = UserProfile\n\nexport interface ProviderProfile {\n  provider_id: string\n  phone_number?: string\n  name?: string\n  picture?: string\n  email?: string\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string\n}\n\nexport interface GrantTokenRequest extends BaseRequest {\n  client_secret?: string\n  code?: string\n  grant_type?: string\n  redirect_uri?: string\n  nonce?: string\n  refresh_token?: string\n  scope?: string\n}\n\nexport interface UnbindProviderRequest extends BaseRequest {\n  provider_id: string\n}\n\nexport interface BindPhoneRequest extends BaseRequest {\n  phone_number: string\n  sudo_token: string\n  verification_token: string\n}\n\nexport interface SetPasswordRequest extends BaseRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface ChangeBindedProviderRequest extends BaseRequest {\n  trans_token: string\n  provider_id: string\n}\n\nexport interface QueryUserProfileReq extends BaseRequest {\n  appended_params: string\n}\n\nexport interface SignInWithProviderRequest {\n  provider_token: string\n  provider_id?: string\n}\n\nexport interface SignInCustomRequest {\n  provider_id?: string\n  ticket: string\n}\n\nexport interface SignUpRequest {\n  phone_number?: string\n  email?: string\n\n  verification_code?: string\n  verification_token?: string\n  provider_token?: string\n\n  username?: string\n  password?: string\n  name?: string\n  gender?: string\n  picture?: string\n  locale?: string\n\n  anonymous_token?: string\n}\n\nexport interface GetVerificationRequest {\n  phone_number?: string\n  email?: string\n  // 可选 ANY，USER，NOT_USER, CUR_USER;\n  target?: string | 'ANY'\n  usage?: string\n}\n\nexport interface GetVerificationResponse {\n  verification_id?: string\n  is_user?: boolean | false\n}\n\nexport interface VerifyResponse {\n  verification_token?: string\n  expires_in: number\n}\n\nexport interface VerifyRequest {\n  verification_code: string\n  verification_id?: string\n  verification_token?: string\n  version?: string\n}\n\nexport interface ProviderBindRequest {\n  provider_token: string\n  expires_in: number\n}\n\nexport interface GrantProviderTokenRequest {\n  provider_id: string\n  provider_redirect_uri?: string\n  provider_code?: string\n  provider_access_token?: string\n  provider_id_token?: string\n  provider_params?: {\n    provider_code_type?: string\n    appid?: string\n  }\n}\n\nexport interface PatchProviderTokenRequest {\n  provider_token: string\n  provider_id?: string\n  provider_params: {\n    encryptedData?: string\n    iv?: string\n    code?: string\n    provider_code_type?: string\n  }\n}\n\nexport interface PatchProviderTokenResponse {\n  provider_token: string\n  expires_in: number\n  provider_profile: ProviderProfile\n}\n\nexport interface GenProviderRedirectUriRequest {\n  provider_id: string\n  redirect_uri?: string\n  /**\n   * @deprecated\n   */\n  provider_redirect_uri?: string\n  state: string\n  scope?: string\n  response_type?: string\n  other_params?: {\n    [key: string]: string\n  }\n}\n\nexport interface GenProviderRedirectUriResponse {\n  uri: string\n  signout_uri?: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface BindWithProviderRequest {\n  provider_token: string\n}\n\nexport interface UserProfileProvider {\n  id?: string\n  provider_user_id?: string\n  name?: string\n}\n\ninterface ProfileGroup {\n  id: string\n  expires_at?: string\n}\n\nexport interface UserProfile {\n  sub?: string\n  name?: string\n  picture?: string\n  username?: string\n  email?: string\n  email_verified?: boolean\n  phone_number?: string\n  groups?: [ProfileGroup]\n  providers?: [UserProfileProvider]\n  gender?: string\n  birthdate?: string\n  zoneinfo?: string\n  locale?: string\n  created_from?: string\n  created_at?: string\n  updated_at?: string\n  loginType?: string\n  avatarUrl?: string\n  location?: any\n  hasPassword?: boolean\n}\n\ninterface UserProvider {\n  id: string\n  name: string\n  provider_user_name?: string\n  bind: boolean\n}\nexport interface ProvidersResponse {\n  total: number\n  data: [UserProvider]\n}\n\nexport interface ProviderProfile {\n  provider_id: string\n  name?: string\n  picture?: string\n  phone_number?: string\n  email?: string\n}\n\nexport interface TransByProviderRequest {\n  provider_token: string\n}\n\nexport interface GrantTokenRequest {\n  client_secret?: string\n  code?: string\n  grant_type?: string\n  redirect_uri?: string\n  nonce?: string\n  refresh_token?: string\n  username?: string\n  password?: string\n  scope?: string\n  code_verifier?: string\n  device_code?: string\n}\n\nexport interface UnbindProviderRequest {\n  provider_id: string\n}\n\nexport interface CheckPasswordRequest extends BaseRequest {\n  password: string\n}\n\nexport interface EditContactRequest {\n  phone_number?: string\n  email?: string\n  sudo_token: string\n  verification_token: string\n  // 冲突解决方案\n  // 可选：DEFAULT， 默认解决方案：提示用户该手机号已被其他人绑定\n  //      DELETE_ACCOUNT_TRANSFER，标记原来的账号为已注销，并将手机换绑给自己\n  //     TRANSFER 仅换绑手机号，不注销原有账号。（原有账号无法登录情况下，则自动标记为注销）\n  conflict_resolution?: string\n}\n\nexport interface BindPhoneRequest {\n  phone_number: string\n  sudo_token: string\n  verification_token: string\n  conflict_resolution: string\n  // 1. DEFAULT 0, 默认提示用户手机号已被绑定\n  // 2. DELETE_ACCOUNT_TRANSFER 1, 标记原账号已被注销，并将手机换绑给自己\n  // 3. TRANSFER 2, 仅换绑手机号，不注销原有账号（换绑后原账号无法登录时，则自动注销原账号）\n}\n\nexport interface BindEmailRequest {\n  email: string\n  sudo_token: string\n  verification_token: string\n}\n\nexport interface SetPasswordRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface SetPasswordRequest {\n  new_password: string\n  sudo_token: string\n}\n\nexport interface UpdatePasswordRequest {\n  old_password: string\n  new_password: string\n}\n\n// password 和 verification_token 而选一，如果绑定了手机号，则必须使用verification_token 进行sudo\nexport interface SudoRequest {\n  password?: string\n  verification_token?: string\n}\n\nexport interface SudoResponse {\n  sudo_token?: string\n}\n\nexport interface WithSudoRequest {\n  sudo_token: string\n  version?: string\n}\n\nexport interface ChangeBoundProviderRequest {\n  trans_token: string\n  provider_id: string\n}\n\nexport interface ChangeBoundProviderResponse {\n  client_id: string\n}\n\nexport interface QueryUserProfileRequest {\n  id?: [string]\n  username?: string\n  email?: string\n  phone_number?: string\n}\n\nexport interface QueryUserProfileResponse {\n  total: number\n  data?: [SimpleUserProfile]\n}\n\nexport interface ResetPasswordRequest extends BaseRequest {\n  email?: string\n  phone_number?: string\n  new_password: string\n  verification_token: string\n}\n\nexport interface DeviceAuthorizeRequest extends BaseRequest {\n  scope?: string\n}\n\nexport interface AuthorizeRequest extends BaseRequest {\n  response_type?: string\n  redirect_uri?: string\n  state?: string\n  scope?: string\n  code_challenge?: string\n  code_challenge_method?: string\n  sign_out_uri?: string\n}\n\nexport interface AuthorizeResponse {\n  code?: string\n  access_token?: string\n  id_token?: string\n  token_type?: string\n  scope?: string\n  state?: string\n  expires_in?: number\n}\n\nexport interface AuthorizeInfoRequest extends BaseRequest {\n  response_type?: string\n  redirect_uri?: string\n  state?: string\n  scope?: string\n  sign_out_uri?: string\n  locale?: string\n}\n\nexport interface Scope {\n  id: string\n  name: string\n  description?: string\n  picture?: string\n  url?: string\n  children?: Scope[]\n}\nexport interface AuthorizeInfoResponse {\n  client: {\n    id: string\n    name: string\n    description?: string\n    picture?: string\n    url?: string\n  }\n  scopes?: Scope[]\n}\n\nexport interface RevokeDeviceRequest {\n  device_id: string\n}\n\nexport interface SignoutRequest {\n  redirect_uri?: string\n  state?: string\n}\n\nexport interface SignoutResponse {\n  redirect_uri?: string\n}\n\nexport interface AuthorizeDeviceRequest extends BaseRequest {\n  user_code: string\n  scope?: string\n  state?: string\n}\n\nexport interface DeviceAuthorizeResponse {\n  device_code: string\n  user_code?: string\n  expires_in: number\n  interval: number\n  verification_uri?: string\n  verification_uri_complete?: string\n}\n\n// 简化版用户信息\nexport interface SimpleUserProfile {\n  sub: string\n  name: string\n  picture?: string\n  gender?: string\n  locale?: string\n  email?: string\n  phone_number?: string\n}\n\nexport interface CheckUsernameRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistRequest {\n  username: string\n}\n\nexport interface CheckIfUserExistResponse {\n  exist: boolean\n}\n\nexport interface PublicKey {\n  public_key: string // 加密的公钥\n  public_key_thumbprint: string // 加密的公钥指纹\n}\n\nexport interface EncryptParams {\n  isEncrypt?: boolean // 是否需要加密\n  public_key_thumbprint?: string // 加密的公钥指纹\n  params?: string // 加密的数据\n}\n\nexport interface ProviderSubType {\n  id: string\n  provider_sub_type: 'NO_AUTH_LOGIN' | '' // NO_AUTH_LOGIN-免密登录\n}\n\nexport interface GetMiniProgramQrCodeRequest {\n  envId: string\n  wxAppId: string\n}\n\nexport interface GetMiniProgramQrCodeResponse {\n  qr_code: string\n  qr_code_id: string\n  expires_in: number\n}\n\nexport interface GetMiniProgramQrCodeStatusRequest {\n  qrCodeId: string\n  envId: string\n  wxAppId: string\n}\n\nexport interface GetMiniProgramQrCodeStatusResponse {\n  status: string\n  provider_token: string\n  expires_in: number\n}\n\nexport interface ModifyUserBasicInfoRequest {\n  user_id?: string\n  nickname?: string\n  username?: string\n  description?: string\n  avatar_url?: string\n  gender?: 'MALE' | 'FEMALE'\n  password?: string // 旧密码\n  new_password?: string // 新密码\n  email?: string\n  phone?: string\n}\n\nexport interface GetUserBehaviorLog {\n  type: 'LOGIN' | 'MODIFY' // LOGIN-登录日志，MODIFY-修改登录方式日志\n  limit: number // 每页查询数量\n  page_token?: string\n}\n\nexport interface GetUserBehaviorLogRes {\n  id: string\n  ip: string\n  user_agent: string\n  client_id: string\n  device_id: string\n  created_at: string\n  meta: { from: string }\n}\n\n\nexport interface ModifyPasswordWithoutLoginRequest {\n  username?: string\n  password?: string // 旧密码\n  new_password?: string // 新密码\n}\n\nexport interface ToDefaultLoginPage {\n  config_version?: 'env' | string; // 登录配置，默认env（托管登录页）\n  redirect_uri?: string; // 登录后回调地址，默认当前地址\n  app_id?: string; // 应用id，托管登录页不需要传\n  query?: Record<string, any> // 跳转登录链接携带的自定义参数，会拼接在链接后面\n}\n"]}
@@ -0,0 +1,3 @@
1
+ import { CaptchaToken } from '@cloudbase/adapter-interface';
2
+ import { Auth } from '../auth/apis';
3
+ export declare const openURIWithCallback: (url: string, oauthInstance?: Auth) => Promise<CaptchaToken>;
@@ -0,0 +1,223 @@
1
+ "use strict";
2
+ var __assign = (this && this.__assign) || function () {
3
+ __assign = Object.assign || function(t) {
4
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
5
+ s = arguments[i];
6
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
7
+ t[p] = s[p];
8
+ }
9
+ return t;
10
+ };
11
+ return __assign.apply(this, arguments);
12
+ };
13
+ var __awaiter = (this && this.__awaiter) || function (thisArg, _arguments, P, generator) {
14
+ function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }
15
+ return new (P || (P = Promise))(function (resolve, reject) {
16
+ function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }
17
+ function rejected(value) { try { step(generator["throw"](value)); } catch (e) { reject(e); } }
18
+ function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }
19
+ step((generator = generator.apply(thisArg, _arguments || [])).next());
20
+ });
21
+ };
22
+ var __generator = (this && this.__generator) || function (thisArg, body) {
23
+ var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;
24
+ return g = { next: verb(0), "throw": verb(1), "return": verb(2) }, typeof Symbol === "function" && (g[Symbol.iterator] = function() { return this; }), g;
25
+ function verb(n) { return function (v) { return step([n, v]); }; }
26
+ function step(op) {
27
+ if (f) throw new TypeError("Generator is already executing.");
28
+ while (g && (g = 0, op[0] && (_ = 0)), _) try {
29
+ if (f = 1, y && (t = op[0] & 2 ? y["return"] : op[0] ? y["throw"] || ((t = y["return"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;
30
+ if (y = 0, t) op = [op[0] & 2, t.value];
31
+ switch (op[0]) {
32
+ case 0: case 1: t = op; break;
33
+ case 4: _.label++; return { value: op[1], done: false };
34
+ case 5: _.label++; y = op[1]; op = [0]; continue;
35
+ case 7: op = _.ops.pop(); _.trys.pop(); continue;
36
+ default:
37
+ if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }
38
+ if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }
39
+ if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }
40
+ if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }
41
+ if (t[2]) _.ops.pop();
42
+ _.trys.pop(); continue;
43
+ }
44
+ op = body.call(thisArg, _);
45
+ } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }
46
+ if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };
47
+ }
48
+ };
49
+ Object.defineProperty(exports, "__esModule", { value: true });
50
+ exports.openURIWithCallback = void 0;
51
+ var events_1 = require("@cloudbase/utilities/dist/cjs/libs/events");
52
+ var util_1 = require("@cloudbase/utilities/dist/cjs/libs/util");
53
+ var debounce = function (func, delay) {
54
+ var timeoutId;
55
+ return function () {
56
+ var args = [];
57
+ for (var _i = 0; _i < arguments.length; _i++) {
58
+ args[_i] = arguments[_i];
59
+ }
60
+ clearTimeout(timeoutId);
61
+ timeoutId = setTimeout(function () { return func.apply(null, args); }, delay);
62
+ };
63
+ };
64
+ var eventBus = new events_1.CloudbaseEventEmitter();
65
+ var CAPTCHA_EVENT = {
66
+ CAPTCHA_DATA_CHANGE: 'captchaDataChange',
67
+ RESOLVE_CAPTCHA_DATA: 'resolveCaptchaData',
68
+ };
69
+ var CAPTCHA_STYLES = {
70
+ overlay: 'position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:999',
71
+ modal: 'position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 0 10px rgba(0,0,0,0.2);z-index:1000',
72
+ prompt: 'margin-bottom:15px',
73
+ captchaWrap: 'display:flex;align-items:center;justify-content:space-between;margin-bottom:15px',
74
+ captchaImg: 'width:100%;height:auto;border:1px solid #eee',
75
+ refreshBtn: 'padding:10px 8px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;flex:1;white-space:nowrap;margin-left:10px',
76
+ input: 'width:100%;padding:14px 16px;margin-bottom:15px;box-sizing:border-box;border:2px solid #e8ecf4;border-radius:10px;font-size:15px',
77
+ confirmBtn: 'width:100%;padding:10px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer',
78
+ loading: 'background:#6c757d;cursor:not-allowed',
79
+ };
80
+ var genCaptchaDom = function (_a) {
81
+ var oauthInstance = _a.oauthInstance, captchaState = _a.captchaState;
82
+ var CAPTCHA_IMG_ID = 'captcha-image';
83
+ var refreshCaptcha = function () { return __awaiter(void 0, void 0, void 0, function () {
84
+ var result, error_1;
85
+ return __generator(this, function (_a) {
86
+ switch (_a.label) {
87
+ case 0:
88
+ _a.trys.push([0, 2, , 3]);
89
+ return [4, oauthInstance.createCaptchaData({ state: captchaState.state })];
90
+ case 1:
91
+ result = _a.sent();
92
+ captchaState = __assign(__assign({}, captchaState), { captchaData: result.data, token: result.token });
93
+ document.getElementById(CAPTCHA_IMG_ID).src = result.data;
94
+ return [3, 3];
95
+ case 2:
96
+ error_1 = _a.sent();
97
+ console.error('刷新图形验证码失败', error_1);
98
+ return [3, 3];
99
+ case 3: return [2];
100
+ }
101
+ });
102
+ }); };
103
+ var createElement = function (tag, styles, text) {
104
+ var el = document.createElement(tag);
105
+ if (styles)
106
+ el.style.cssText = styles;
107
+ if (text)
108
+ el.textContent = text;
109
+ return el;
110
+ };
111
+ var overlay = createElement('div', CAPTCHA_STYLES.overlay);
112
+ var modal = createElement('div', CAPTCHA_STYLES.modal);
113
+ modal.appendChild(createElement('p', CAPTCHA_STYLES.prompt, '请输入你看到的字符:'));
114
+ var captchaWrap = createElement('div', CAPTCHA_STYLES.captchaWrap);
115
+ var captchaImg = createElement('img', CAPTCHA_STYLES.captchaImg);
116
+ captchaImg.id = CAPTCHA_IMG_ID;
117
+ captchaImg.src = captchaState.captchaData;
118
+ captchaWrap.appendChild(captchaImg);
119
+ var refreshBtn = createElement('button', CAPTCHA_STYLES.refreshBtn, '刷新');
120
+ refreshBtn.onclick = debounce(function () { return __awaiter(void 0, void 0, void 0, function () {
121
+ return __generator(this, function (_a) {
122
+ switch (_a.label) {
123
+ case 0:
124
+ refreshBtn.textContent = '加载中...';
125
+ refreshBtn.disabled = true;
126
+ refreshBtn.style.cssText = "".concat(CAPTCHA_STYLES.refreshBtn, ";").concat(CAPTCHA_STYLES.loading);
127
+ _a.label = 1;
128
+ case 1:
129
+ _a.trys.push([1, , 3, 4]);
130
+ return [4, refreshCaptcha()];
131
+ case 2:
132
+ _a.sent();
133
+ return [3, 4];
134
+ case 3:
135
+ refreshBtn.textContent = '刷新';
136
+ refreshBtn.disabled = false;
137
+ refreshBtn.style.cssText = CAPTCHA_STYLES.refreshBtn;
138
+ return [7];
139
+ case 4: return [2];
140
+ }
141
+ });
142
+ }); }, 500);
143
+ captchaWrap.appendChild(refreshBtn);
144
+ modal.appendChild(captchaWrap);
145
+ var input = createElement('input', CAPTCHA_STYLES.input);
146
+ input.type = 'text';
147
+ input.placeholder = '输入字符';
148
+ input.maxLength = 4;
149
+ modal.appendChild(input);
150
+ var errorMsg = createElement('div', 'color:#dc3545;font-size:12px;margin-bottom:10px;display:none;padding:8px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px');
151
+ modal.appendChild(errorMsg);
152
+ var showError = function (message) {
153
+ errorMsg.textContent = message;
154
+ errorMsg.style.display = 'block';
155
+ };
156
+ var confirmBtn = createElement('button', CAPTCHA_STYLES.confirmBtn, '确定');
157
+ confirmBtn.onclick = debounce(function () { return __awaiter(void 0, void 0, void 0, function () {
158
+ var inputValue, verifyResult, error_2, errorMessage;
159
+ return __generator(this, function (_a) {
160
+ switch (_a.label) {
161
+ case 0:
162
+ inputValue = input.value.trim();
163
+ if (!inputValue) {
164
+ showError('请输入字符');
165
+ return [2];
166
+ }
167
+ errorMsg.style.display = 'none';
168
+ confirmBtn.textContent = '验证中...';
169
+ confirmBtn.disabled = true;
170
+ confirmBtn.style.cssText = "".concat(CAPTCHA_STYLES.confirmBtn, ";").concat(CAPTCHA_STYLES.loading);
171
+ _a.label = 1;
172
+ case 1:
173
+ _a.trys.push([1, 3, 5, 6]);
174
+ return [4, oauthInstance.verifyCaptchaData({
175
+ token: captchaState.token,
176
+ key: inputValue,
177
+ })];
178
+ case 2:
179
+ verifyResult = _a.sent();
180
+ eventBus.fire(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, verifyResult);
181
+ console.log('图形验证码校验成功');
182
+ document.body.removeChild(overlay);
183
+ document.body.removeChild(modal);
184
+ return [3, 6];
185
+ case 3:
186
+ error_2 = _a.sent();
187
+ console.error('图形验证码校验失败', error_2);
188
+ errorMessage = error_2.error_description || '图形验证码校验失败';
189
+ showError(errorMessage);
190
+ input.value = '';
191
+ input.focus();
192
+ return [4, refreshCaptcha()];
193
+ case 4:
194
+ _a.sent();
195
+ return [3, 6];
196
+ case 5:
197
+ confirmBtn.textContent = '确定';
198
+ confirmBtn.disabled = false;
199
+ confirmBtn.style.cssText = CAPTCHA_STYLES.confirmBtn;
200
+ return [7];
201
+ case 6: return [2];
202
+ }
203
+ });
204
+ }); }, 500);
205
+ modal.appendChild(confirmBtn);
206
+ document.body.appendChild(overlay);
207
+ document.body.appendChild(modal);
208
+ };
209
+ var openURIWithCallback = function (url, oauthInstance) { return __awaiter(void 0, void 0, void 0, function () {
210
+ var _a, captchaData, state, token;
211
+ return __generator(this, function (_b) {
212
+ _a = (0, util_1.parseCaptcha)(url), captchaData = _a.captchaData, state = _a.state, token = _a.token;
213
+ genCaptchaDom({ oauthInstance: oauthInstance, captchaState: { captchaData: captchaData, state: state, token: token } });
214
+ return [2, new Promise(function (resolve) {
215
+ console.log('等待图形验证码校验结果...');
216
+ eventBus.on(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, function (res) {
217
+ resolve(res === null || res === void 0 ? void 0 : res.data);
218
+ });
219
+ })];
220
+ });
221
+ }); };
222
+ exports.openURIWithCallback = openURIWithCallback;
223
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"captcha-dom.js","sourceRoot":"","sources":["../../../src/captcha/captcha-dom.ts"],"names":[],"mappings":"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","sourcesContent":["import { CaptchaToken } from '@cloudbase/adapter-interface'\nimport { CloudbaseEventEmitter } from '@cloudbase/utilities/dist/cjs/libs/events'\nimport { parseCaptcha } from '@cloudbase/utilities/dist/cjs/libs/util'\nimport { Auth } from '../auth/apis'\n\n// 防抖函数实现\nconst debounce = (func: Function, delay: number) => {\n  let timeoutId: NodeJS.Timeout\n  return (...args: any[]) => {\n    clearTimeout(timeoutId)\n    timeoutId = setTimeout(() => func.apply(null, args), delay)\n  }\n}\n\nconst eventBus = new CloudbaseEventEmitter()\n\nconst CAPTCHA_EVENT = {\n  CAPTCHA_DATA_CHANGE: 'captchaDataChange',\n  RESOLVE_CAPTCHA_DATA: 'resolveCaptchaData',\n}\n\n// 图形验证码弹窗样式类\nconst CAPTCHA_STYLES = {\n  overlay: 'position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:999',\n  modal:\n    'position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:320px;padding:20px;background:#fff;border-radius:8px;box-shadow:0 0 10px rgba(0,0,0,0.2);z-index:1000',\n  prompt: 'margin-bottom:15px',\n  captchaWrap: 'display:flex;align-items:center;justify-content:space-between;margin-bottom:15px',\n  captchaImg: 'width:100%;height:auto;border:1px solid #eee',\n  refreshBtn:\n    'padding:10px 8px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;flex:1;white-space:nowrap;margin-left:10px',\n  input:\n    'width:100%;padding:14px 16px;margin-bottom:15px;box-sizing:border-box;border:2px solid #e8ecf4;border-radius:10px;font-size:15px',\n  confirmBtn: 'width:100%;padding:10px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer',\n  loading: 'background:#6c757d;cursor:not-allowed',\n}\n\n/**\n * 显示图形图形验证码\n * @param param0\n */\nconst genCaptchaDom = ({ oauthInstance, captchaState }) => {\n  const CAPTCHA_IMG_ID = 'captcha-image'\n\n  // 刷新图形验证码函数\n  const refreshCaptcha = async () => {\n    try {\n      const result = await oauthInstance.createCaptchaData({ state: captchaState.state })\n      captchaState = { ...captchaState, captchaData: result.data, token: result.token }\n      ;(document.getElementById(CAPTCHA_IMG_ID) as HTMLImageElement).src = result.data\n    } catch (error) {\n      console.error('刷新图形验证码失败', error)\n    }\n  }\n\n  // 创建元素并设置样式\n  const createElement = (tag: string, styles?: string, text?: string) => {\n    const el = document.createElement(tag)\n    if (styles) el.style.cssText = styles\n    if (text) el.textContent = text\n    return el\n  }\n\n  // 创建遮罩层和弹窗\n  const overlay = createElement('div', CAPTCHA_STYLES.overlay)\n  const modal = createElement('div', CAPTCHA_STYLES.modal)\n\n  // 添加提示文字\n  modal.appendChild(createElement('p', CAPTCHA_STYLES.prompt, '请输入你看到的字符：'))\n\n  // 图形验证码区域\n  const captchaWrap = createElement('div', CAPTCHA_STYLES.captchaWrap)\n  const captchaImg = createElement('img', CAPTCHA_STYLES.captchaImg) as HTMLImageElement\n  captchaImg.id = CAPTCHA_IMG_ID\n  captchaImg.src = captchaState.captchaData\n  captchaWrap.appendChild(captchaImg)\n\n  // 刷新按钮\n  const refreshBtn = createElement('button', CAPTCHA_STYLES.refreshBtn, '刷新') as HTMLButtonElement\n  refreshBtn.onclick = debounce(async () => {\n    refreshBtn.textContent = '加载中...'\n    refreshBtn.disabled = true\n    refreshBtn.style.cssText = `${CAPTCHA_STYLES.refreshBtn};${CAPTCHA_STYLES.loading}`\n\n    try {\n      await refreshCaptcha()\n    } finally {\n      refreshBtn.textContent = '刷新'\n      refreshBtn.disabled = false\n      refreshBtn.style.cssText = CAPTCHA_STYLES.refreshBtn\n    }\n  }, 500)\n  captchaWrap.appendChild(refreshBtn)\n  modal.appendChild(captchaWrap)\n\n  // 输入框\n  const input = createElement('input', CAPTCHA_STYLES.input) as HTMLInputElement\n  input.type = 'text'\n  input.placeholder = '输入字符'\n  input.maxLength = 4\n  modal.appendChild(input)\n\n  // 错误提示元素\n  const errorMsg = createElement(\n    'div',\n    'color:#dc3545;font-size:12px;margin-bottom:10px;display:none;padding:8px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px',\n  )\n  modal.appendChild(errorMsg)\n\n  // 显示错误提示\n  const showError = (message: string) => {\n    errorMsg.textContent = message\n    errorMsg.style.display = 'block'\n  }\n\n  // 确定按钮\n  const confirmBtn = createElement('button', CAPTCHA_STYLES.confirmBtn, '确定') as HTMLButtonElement\n  confirmBtn.onclick = debounce(async () => {\n    const inputValue = input.value.trim()\n    if (!inputValue) {\n      showError('请输入字符')\n      return\n    }\n\n    // 隐藏之前的错误提示\n    errorMsg.style.display = 'none'\n\n    confirmBtn.textContent = '验证中...'\n    confirmBtn.disabled = true\n    confirmBtn.style.cssText = `${CAPTCHA_STYLES.confirmBtn};${CAPTCHA_STYLES.loading}`\n\n    try {\n      const verifyResult = await oauthInstance.verifyCaptchaData({\n        token: captchaState.token,\n        key: inputValue,\n      })\n      eventBus.fire(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, verifyResult)\n      console.log('图形验证码校验成功')\n      document.body.removeChild(overlay)\n      document.body.removeChild(modal)\n    } catch (error) {\n      console.error('图形验证码校验失败', error)\n      // 根据错误类型显示不同的错误提示\n      const errorMessage = error.error_description || '图形验证码校验失败'\n      showError(errorMessage)\n\n      // 清空输入框并刷新图形验证码\n      input.value = ''\n      input.focus()\n      await refreshCaptcha()\n    } finally {\n      confirmBtn.textContent = '确定'\n      confirmBtn.disabled = false\n      confirmBtn.style.cssText = CAPTCHA_STYLES.confirmBtn\n    }\n  }, 500)\n  modal.appendChild(confirmBtn)\n\n  // 插入页面\n  document.body.appendChild(overlay)\n  document.body.appendChild(modal)\n}\n\nexport const openURIWithCallback = async (url: string, oauthInstance?: Auth): Promise<CaptchaToken> => {\n  // 解析URL中的图形验证码参数\n  const { captchaData, state, token } = parseCaptcha(url)\n\n  genCaptchaDom({ oauthInstance, captchaState: { captchaData, state, token } })\n\n  // 监听图形验证码校验结果\n  return new Promise((resolve) => {\n    console.log('等待图形验证码校验结果...')\n    eventBus.on(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, (res) => {\n      // auth.verifyCaptchaData的校验结果\n      resolve(res?.data)\n    })\n  })\n}\n"]}
@@ -1,7 +1,9 @@
1
1
  import { SimpleStorage, RequestFunction } from '../oauth2client/interface';
2
2
  import { AuthClientRequestOptions } from '../oauth2client/models';
3
3
  import { SDKAdapterInterface } from '@cloudbase/adapter-interface';
4
+ import { Auth } from '../auth/apis';
4
5
  export interface CaptchaOptions {
6
+ env: string;
5
7
  clientId: string;
6
8
  request: RequestFunction;
7
9
  storage: SimpleStorage;
@@ -9,6 +11,7 @@ export interface CaptchaOptions {
9
11
  adapter?: SDKAdapterInterface & {
10
12
  isMatch?: () => boolean;
11
13
  };
14
+ oauthInstance?: Auth;
12
15
  }
13
16
  type OpenURIWithCallbackFuction = (url: string) => Promise<CaptchaToken>;
14
17
  export interface CaptchaToken {
@@ -31,7 +34,6 @@ export declare class Captcha {
31
34
  isMatch(): boolean;
32
35
  request<T>(url: string, options?: CaptchaRequestOptions): Promise<T>;
33
36
  private getDefaultOpenURIWithCallback;
34
- private defaultOpenURIWithCallback;
35
37
  private getCaptchaToken;
36
38
  private appendCaptchaTokenToURL;
37
39
  private saveCaptchaToken;