@cloudbase/oauth 2.23.3 → 2.24.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (43) hide show
  1. package/dist/cjs/auth/apis.js +170 -14
  2. package/dist/cjs/auth/auth-error.js +32 -0
  3. package/dist/cjs/auth/consts.js +24 -2
  4. package/dist/cjs/auth/models.js +1 -1
  5. package/dist/cjs/captcha/captcha-dom.js +223 -0
  6. package/dist/cjs/captcha/captcha.js +11 -102
  7. package/dist/cjs/index.js +25 -3
  8. package/dist/cjs/oauth2client/interface.js +1 -1
  9. package/dist/cjs/oauth2client/models.js +1 -1
  10. package/dist/cjs/oauth2client/oauth2client.js +384 -110
  11. package/dist/cjs/utils/base64.js +15 -2
  12. package/dist/esm/auth/apis.js +113 -2
  13. package/dist/esm/auth/auth-error.js +9 -0
  14. package/dist/esm/auth/consts.js +22 -0
  15. package/dist/esm/captcha/captcha-dom.js +129 -0
  16. package/dist/esm/captcha/captcha.js +14 -97
  17. package/dist/esm/index.js +18 -2
  18. package/dist/esm/oauth2client/oauth2client.js +162 -36
  19. package/dist/esm/utils/base64.js +12 -0
  20. package/dist/miniprogram/index.js +1 -1
  21. package/dist/types/auth/apis.d.ts +19 -1
  22. package/dist/types/auth/auth-error.d.ts +6 -0
  23. package/dist/types/auth/consts.d.ts +22 -0
  24. package/dist/types/auth/models.d.ts +2 -0
  25. package/dist/types/captcha/captcha-dom.d.ts +3 -0
  26. package/dist/types/captcha/captcha.d.ts +3 -1
  27. package/dist/types/index.d.ts +11 -2
  28. package/dist/types/oauth2client/interface.d.ts +1 -1
  29. package/dist/types/oauth2client/models.d.ts +14 -0
  30. package/dist/types/oauth2client/oauth2client.d.ts +58 -2
  31. package/dist/types/utils/base64.d.ts +5 -0
  32. package/package.json +4 -4
  33. package/src/auth/apis.ts +189 -4
  34. package/src/auth/auth-error.ts +21 -0
  35. package/src/auth/consts.ts +28 -0
  36. package/src/auth/models.ts +2 -0
  37. package/src/captcha/captcha-dom.ts +178 -0
  38. package/src/captcha/captcha.ts +25 -115
  39. package/src/index.ts +51 -3
  40. package/src/oauth2client/interface.ts +1 -1
  41. package/src/oauth2client/models.ts +28 -0
  42. package/src/oauth2client/oauth2client.ts +254 -34
  43. package/src/utils/base64.ts +12 -0
@@ -1,6 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.weappJwtDecode = exports.base64_url_decode = exports.weAtob = exports.weBtoa = void 0;
3
+ exports.weappJwtDecodeAll = exports.weappJwtDecode = exports.base64_url_decode = exports.weAtob = exports.weBtoa = void 0;
4
4
  var b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/=';
5
5
  var b64re = /^(?:[A-Za-z\d+/]{4})*?(?:[A-Za-z\d+/]{2}(?:==)?|[A-Za-z\d+/]{3}=?)?$/;
6
6
  function weBtoa(string) {
@@ -96,4 +96,17 @@ function weappJwtDecode(token, options) {
96
96
  }
97
97
  }
98
98
  exports.weappJwtDecode = weappJwtDecode;
99
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base64.js","sourceRoot":"","sources":["../../../src/utils/base64.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\n// weapp jwt-decode\nconst b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\nconst b64re = /^(?:[A-Za-z\\d+/]{4})*?(?:[A-Za-z\\d+/]{2}(?:==)?|[A-Za-z\\d+/]{3}=?)?$/\n\n// btoa\nexport function weBtoa(string: string) {\n  string = String(string)\n  let bitmap\n  let a\n  let b\n  let c\n  let result = ''\n  let i = 0\n  const rest = string.length % 3\n\n  for (; i < string.length;) {\n    if ((a = string.charCodeAt(i++)) > 255 || (b = string.charCodeAt(i++)) > 255 || (c = string.charCodeAt(i++)) > 255) throw new TypeError('Failed to execute \\'btoa\\' on \\'Window\\': The string to be encoded contains characters outside of the Latin1 range.',)\n\n    bitmap = (a << 16) | (b << 8) | c\n    result\n      += b64.charAt((bitmap >> 18) & 63)\n      + b64.charAt((bitmap >> 12) & 63)\n      + b64.charAt((bitmap >> 6) & 63)\n      + b64.charAt(bitmap & 63)\n  }\n\n  return rest ? result.slice(0, rest - 3) + '==='.substring(rest) : result\n}\n// atob\nexport const weAtob = function (string: string) {\n  string = String(string).replace(/[\\t\\n\\f\\r ]+/g, '')\n  if (!b64re.test(string)) throw new TypeError('Failed to execute \\'atob\\' on \\'Window\\': The string to be decoded is not correctly encoded.')\n  string += '=='.slice(2 - (string.length & 3))\n  let bitmap\n  let result = ''\n  let r1\n  let r2\n  let i = 0\n  for (; i < string.length;) {\n    bitmap =      (b64.indexOf(string.charAt(i++)) << 18)\n      | (b64.indexOf(string.charAt(i++)) << 12)\n      | ((r1 = b64.indexOf(string.charAt(i++))) << 6)\n      | (r2 = b64.indexOf(string.charAt(i++)))\n\n    result\n      += r1 === 64\n        ? String.fromCharCode((bitmap >> 16) & 255)\n        : r2 === 64\n          ? String.fromCharCode((bitmap >> 16) & 255, (bitmap >> 8) & 255)\n          : String.fromCharCode((bitmap >> 16) & 255, (bitmap >> 8) & 255, bitmap & 255)\n  }\n  return result\n}\n\nfunction b64DecodeUnicode(str: string) {\n  return decodeURIComponent(weAtob(str).replace(/(.)/g, (p) => {\n    let code = p.charCodeAt(0).toString(16)\n      .toUpperCase()\n    if (code.length < 2) {\n      code = `0${code}`\n    }\n    return `%${code}`\n  }),)\n}\n\nexport function base64_url_decode(str: string) {\n  let output = str.replace(/-/g, '+').replace(/_/g, '/')\n  switch (output.length % 4) {\n    case 0:\n      break\n    case 2:\n      output += '=='\n      break\n    case 3:\n      output += '='\n      break\n    default:\n      throw new Error('Illegal base64url string!')\n  }\n\n  try {\n    return b64DecodeUnicode(output)\n  } catch (err) {\n    return weAtob(output)\n  }\n}\n\nexport function weappJwtDecode(token: string, options?: any) {\n  if (typeof token !== 'string') {\n    throw new Error('Invalid token specified')\n  }\n  options = options || {}\n  const pos = options.header === true ? 0 : 1\n  try {\n    return JSON.parse(base64_url_decode(token.split('.')[pos]))\n  } catch (e) {\n    throw new Error(`Invalid token specified: ${e}` ? (e as any).message : '')\n  }\n}\n"]}
99
+ function weappJwtDecodeAll(token) {
100
+ if (typeof token !== 'string') {
101
+ throw new Error('Invalid token specified');
102
+ }
103
+ try {
104
+ var parts = token.split('.').map(function (segment, i) { return i === 2 ? segment : JSON.parse(base64_url_decode(segment)); });
105
+ return { claims: parts[1], header: parts[0], signature: parts[2] };
106
+ }
107
+ catch (e) {
108
+ throw new Error("Invalid token specified: ".concat(e) ? e.message : '');
109
+ }
110
+ }
111
+ exports.weappJwtDecodeAll = weappJwtDecodeAll;
112
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"base64.js","sourceRoot":"","sources":["../../../src/utils/base64.ts"],"names":[],"mappings":"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","sourcesContent":["/* eslint-disable */\n// weapp jwt-decode\nconst b64 = 'ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/='\nconst b64re = /^(?:[A-Za-z\\d+/]{4})*?(?:[A-Za-z\\d+/]{2}(?:==)?|[A-Za-z\\d+/]{3}=?)?$/\n\n// btoa\nexport function weBtoa(string: string) {\n  string = String(string)\n  let bitmap\n  let a\n  let b\n  let c\n  let result = ''\n  let i = 0\n  const rest = string.length % 3\n\n  for (; i < string.length;) {\n    if ((a = string.charCodeAt(i++)) > 255 || (b = string.charCodeAt(i++)) > 255 || (c = string.charCodeAt(i++)) > 255) throw new TypeError('Failed to execute \\'btoa\\' on \\'Window\\': The string to be encoded contains characters outside of the Latin1 range.',)\n\n    bitmap = (a << 16) | (b << 8) | c\n    result\n      += b64.charAt((bitmap >> 18) & 63)\n      + b64.charAt((bitmap >> 12) & 63)\n      + b64.charAt((bitmap >> 6) & 63)\n      + b64.charAt(bitmap & 63)\n  }\n\n  return rest ? result.slice(0, rest - 3) + '==='.substring(rest) : result\n}\n// atob\nexport const weAtob = function (string: string) {\n  string = String(string).replace(/[\\t\\n\\f\\r ]+/g, '')\n  if (!b64re.test(string)) throw new TypeError('Failed to execute \\'atob\\' on \\'Window\\': The string to be decoded is not correctly encoded.')\n  string += '=='.slice(2 - (string.length & 3))\n  let bitmap\n  let result = ''\n  let r1\n  let r2\n  let i = 0\n  for (; i < string.length;) {\n    bitmap =      (b64.indexOf(string.charAt(i++)) << 18)\n      | (b64.indexOf(string.charAt(i++)) << 12)\n      | ((r1 = b64.indexOf(string.charAt(i++))) << 6)\n      | (r2 = b64.indexOf(string.charAt(i++)))\n\n    result\n      += r1 === 64\n        ? String.fromCharCode((bitmap >> 16) & 255)\n        : r2 === 64\n          ? String.fromCharCode((bitmap >> 16) & 255, (bitmap >> 8) & 255)\n          : String.fromCharCode((bitmap >> 16) & 255, (bitmap >> 8) & 255, bitmap & 255)\n  }\n  return result\n}\n\nfunction b64DecodeUnicode(str: string) {\n  return decodeURIComponent(weAtob(str).replace(/(.)/g, (p) => {\n    let code = p.charCodeAt(0).toString(16)\n      .toUpperCase()\n    if (code.length < 2) {\n      code = `0${code}`\n    }\n    return `%${code}`\n  }),)\n}\n\nexport function base64_url_decode(str: string) {\n  let output = str.replace(/-/g, '+').replace(/_/g, '/')\n  switch (output.length % 4) {\n    case 0:\n      break\n    case 2:\n      output += '=='\n      break\n    case 3:\n      output += '='\n      break\n    default:\n      throw new Error('Illegal base64url string!')\n  }\n\n  try {\n    return b64DecodeUnicode(output)\n  } catch (err) {\n    return weAtob(output)\n  }\n}\n\nexport function weappJwtDecode(token: string, options?: any) {\n  if (typeof token !== 'string') {\n    throw new Error('Invalid token specified')\n  }\n  options = options || {}\n  const pos = options.header === true ? 0 : 1\n  try {\n    return JSON.parse(base64_url_decode(token.split('.')[pos]))\n  } catch (e) {\n    throw new Error(`Invalid token specified: ${e}` ? (e as any).message : '')\n  }\n}\n\nexport function weappJwtDecodeAll(token: string) {\n  if (typeof token !== 'string') {\n    throw new Error('Invalid token specified')\n  }\n  try {\n    const parts = token.split('.').map((segment, i) => i === 2 ? segment : JSON.parse(base64_url_decode(segment)))\n    return { claims: parts[1], header: parts[0], signature: parts[2]}\n  } catch (e) {\n    throw new Error(`Invalid token specified: ${e}` ? (e as any).message : '')\n  }\n}\n"]}
@@ -1,9 +1,10 @@
1
1
  'use strict';
2
- import { ApiUrls, ApiUrlsV2, ErrorType } from './consts';
2
+ import { ApiUrls, ApiUrlsV2, AUTH_STATE_CHANGED_TYPE, ErrorType, EVENTS, OAUTH_TYPE } from './consts';
3
3
  import { OAuth2Client, defaultStorage } from '../oauth2client/oauth2client';
4
4
  import { Captcha } from '../captcha/captcha';
5
5
  import { deepClone } from '../utils';
6
6
  import MyURLSearchParams from '../utils/urlSearchParams';
7
+ import { AuthError } from '..';
7
8
  function getEncryptUtils(isEncrypt, adapter) {
8
9
  const getUtils = () => {
9
10
  try {
@@ -54,16 +55,19 @@ export class Auth {
54
55
  onCredentialsError: opts.onCredentialsError,
55
56
  headers: opts.headers || {},
56
57
  i18n: opts.i18n,
58
+ debug: opts.debug,
57
59
  };
58
60
  oAuth2Client = new OAuth2Client(initOptions);
59
61
  }
60
62
  if (!request) {
61
63
  const baseRequest = oAuth2Client.request.bind(oAuth2Client);
62
64
  const captcha = new Captcha({
65
+ env: opts.env,
63
66
  clientId: opts.clientId,
64
67
  request: baseRequest,
65
68
  storage: opts.storage,
66
69
  adapter: opts.adapter,
70
+ oauthInstance: this,
67
71
  ...opts.captchaOptions,
68
72
  });
69
73
  request = captcha.request.bind(captcha);
@@ -240,6 +244,99 @@ export class Auth {
240
244
  });
241
245
  return Promise.resolve(credentials);
242
246
  }
247
+ async toBindIdentity(params) {
248
+ const credentials = params.credentials || (await this.config.credentialsClient.localCredentials.getCredentials());
249
+ let res;
250
+ try {
251
+ await this.bindWithProvider({
252
+ provider_token: params.provider_token,
253
+ }, credentials);
254
+ res = { data: { type: OAUTH_TYPE.BIND_IDENTITY, provider: params.provider }, error: null };
255
+ }
256
+ catch (error) {
257
+ res = { data: { type: OAUTH_TYPE.BIND_IDENTITY }, error: new AuthError(error) };
258
+ }
259
+ if (params.fireEvent) {
260
+ this.config.eventBus?.fire?.(EVENTS.AUTH_STATE_CHANGED, {
261
+ event: AUTH_STATE_CHANGED_TYPE.BIND_IDENTITY,
262
+ info: res,
263
+ });
264
+ }
265
+ return res;
266
+ }
267
+ async getInitialSession() {
268
+ let data = {};
269
+ try {
270
+ if (typeof window === 'undefined' || typeof document === 'undefined') {
271
+ return { data: null, error: null };
272
+ }
273
+ const localSearch = new URLSearchParams(location?.search);
274
+ const code = localSearch.get('code');
275
+ const state = localSearch.get('state');
276
+ if (!code || !state) {
277
+ return { data: null, error: null };
278
+ }
279
+ let cacheData = null;
280
+ try {
281
+ cacheData = JSON.parse(sessionStorage.getItem(state) || 'null');
282
+ }
283
+ catch {
284
+ }
285
+ data = { type: cacheData?.type };
286
+ const errorParam = localSearch.get('error');
287
+ const errorDescription = localSearch.get('error_description');
288
+ if (errorParam || errorDescription) {
289
+ return {
290
+ data,
291
+ error: new AuthError({ message: errorDescription || errorParam || 'Unknown error from OAuth provider' }),
292
+ };
293
+ }
294
+ const provider = cacheData?.provider || localSearch.get('provider');
295
+ if (!provider) {
296
+ return { data, error: new AuthError({ message: 'Provider is required for OAuth verification' }) };
297
+ }
298
+ const redirectUri = location.origin + location.pathname;
299
+ const { provider_token: providerToken } = await this.grantProviderToken({
300
+ provider_id: provider,
301
+ provider_redirect_uri: redirectUri,
302
+ provider_code: code,
303
+ });
304
+ let credentials;
305
+ let user = null;
306
+ let res;
307
+ if (cacheData.type === OAUTH_TYPE.BIND_IDENTITY) {
308
+ credentials = await this.config.credentialsClient.localCredentials.getCredentials();
309
+ res = await this.toBindIdentity({ provider, provider_token: providerToken, credentials });
310
+ }
311
+ else if (cacheData.type === OAUTH_TYPE.SIGN_IN) {
312
+ res = this.getParamsByVersion({ provider }, 'AUTH_SIGN_IN_WITH_PROVIDER_URL');
313
+ credentials = await this.config.request(res.url, {
314
+ method: 'POST',
315
+ body: { provider_token: providerToken },
316
+ });
317
+ try {
318
+ user = await this.getUserInfo({ credentials });
319
+ }
320
+ catch (e) {
321
+ console.error('get user info error', e);
322
+ }
323
+ res = { data: { ...data, session: credentials, user }, error: null };
324
+ }
325
+ localSearch.delete('code');
326
+ localSearch.delete('state');
327
+ localSearch.delete('provider');
328
+ this.restoreUrlState(cacheData?.search === undefined ? `?${localSearch.toString()}` : cacheData.search, cacheData?.hash || location.hash);
329
+ try {
330
+ sessionStorage.removeItem(state);
331
+ }
332
+ catch {
333
+ }
334
+ return res;
335
+ }
336
+ catch (error) {
337
+ return { data, error: new AuthError(error) };
338
+ }
339
+ }
243
340
  async signInCustom(params) {
244
341
  const credentials = await this.config.request(ApiUrls.AUTH_SIGN_IN_CUSTOM, {
245
342
  method: 'POST',
@@ -256,11 +353,12 @@ export class Auth {
256
353
  await this.config.credentialsClient.setCredentials(credentials);
257
354
  return Promise.resolve(credentials);
258
355
  }
259
- async bindWithProvider(params) {
356
+ async bindWithProvider(params, credentials) {
260
357
  return this.config.request(ApiUrls.PROVIDER_BIND_URL, {
261
358
  method: 'POST',
262
359
  body: params,
263
360
  withCredentials: true,
361
+ getCredentials: credentials ? () => credentials : undefined,
264
362
  });
265
363
  }
266
364
  async getUserProfile(params) {
@@ -275,6 +373,7 @@ export class Auth {
275
373
  const userInfo = await this.config.request(res.url, {
276
374
  method: 'GET',
277
375
  withCredentials: true,
376
+ getCredentials: params.credentials ? () => params.credentials : undefined,
278
377
  });
279
378
  if (userInfo.sub) {
280
379
  userInfo.uid = userInfo.sub;
@@ -635,4 +734,16 @@ export class Auth {
635
734
  },
636
735
  });
637
736
  }
737
+ restoreUrlState(search, hash) {
738
+ if (search === undefined)
739
+ return;
740
+ try {
741
+ const url = new URL(window.location.href);
742
+ url.search = search;
743
+ url.hash = hash || '';
744
+ window.history.replaceState(null, '', url.toString());
745
+ }
746
+ catch {
747
+ }
748
+ }
638
749
  }
@@ -0,0 +1,9 @@
1
+ export class AuthError extends Error {
2
+ constructor(error) {
3
+ super(error.error_description || error.message);
4
+ this.__isAuthError = true;
5
+ this.name = 'AuthError';
6
+ this.status = error.error;
7
+ this.code = error.error_code;
8
+ }
9
+ }
@@ -112,3 +112,25 @@ export var ErrorType;
112
112
  ErrorType["CAPTCHA_REQUIRED"] = "captcha_required";
113
113
  ErrorType["CAPTCHA_INVALID"] = "captcha_invalid";
114
114
  })(ErrorType || (ErrorType = {}));
115
+ export const LOGIN_STATE_CHANGED_TYPE = {
116
+ SIGN_OUT: 'sign_out',
117
+ SIGN_IN: 'sign_in',
118
+ CREDENTIALS_ERROR: 'credentials_error',
119
+ };
120
+ export const AUTH_STATE_CHANGED_TYPE = {
121
+ SIGNED_OUT: 'SIGNED_OUT',
122
+ SIGNED_IN: 'SIGNED_IN',
123
+ INITIAL_SESSION: 'INITIAL_SESSION',
124
+ PASSWORD_RECOVERY: 'PASSWORD_RECOVERY',
125
+ TOKEN_REFRESHED: 'TOKEN_REFRESHED',
126
+ USER_UPDATED: 'USER_UPDATED',
127
+ BIND_IDENTITY: 'BIND_IDENTITY',
128
+ };
129
+ export const EVENTS = {
130
+ LOGIN_STATE_CHANGED: 'loginStateChanged',
131
+ AUTH_STATE_CHANGED: 'authStateChanged',
132
+ };
133
+ export const OAUTH_TYPE = {
134
+ SIGN_IN: 'sign_in',
135
+ BIND_IDENTITY: 'bind_identity',
136
+ };
@@ -0,0 +1,129 @@
1
+ import { CloudbaseEventEmitter } from '@cloudbase/utilities/dist/cjs/libs/events';
2
+ import { parseCaptcha } from '@cloudbase/utilities/dist/cjs/libs/util';
3
+ const debounce = (func, delay) => {
4
+ let timeoutId;
5
+ return (...args) => {
6
+ clearTimeout(timeoutId);
7
+ timeoutId = setTimeout(() => func.apply(null, args), delay);
8
+ };
9
+ };
10
+ const eventBus = new CloudbaseEventEmitter();
11
+ const CAPTCHA_EVENT = {
12
+ CAPTCHA_DATA_CHANGE: 'captchaDataChange',
13
+ RESOLVE_CAPTCHA_DATA: 'resolveCaptchaData',
14
+ };
15
+ const CAPTCHA_STYLES = {
16
+ overlay: 'position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);z-index:999',
17
+ 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',
18
+ prompt: 'margin-bottom:15px',
19
+ captchaWrap: 'display:flex;align-items:center;justify-content:space-between;margin-bottom:15px',
20
+ captchaImg: 'width:100%;height:auto;border:1px solid #eee',
21
+ refreshBtn: 'padding:10px 8px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;flex:1;white-space:nowrap;margin-left:10px',
22
+ input: 'width:100%;padding:14px 16px;margin-bottom:15px;box-sizing:border-box;border:2px solid #e8ecf4;border-radius:10px;font-size:15px',
23
+ confirmBtn: 'width:100%;padding:10px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer',
24
+ loading: 'background:#6c757d;cursor:not-allowed',
25
+ };
26
+ const genCaptchaDom = ({ oauthInstance, captchaState }) => {
27
+ const CAPTCHA_IMG_ID = 'captcha-image';
28
+ const refreshCaptcha = async () => {
29
+ try {
30
+ const result = await oauthInstance.createCaptchaData({ state: captchaState.state });
31
+ captchaState = { ...captchaState, captchaData: result.data, token: result.token };
32
+ document.getElementById(CAPTCHA_IMG_ID).src = result.data;
33
+ }
34
+ catch (error) {
35
+ console.error('刷新图形验证码失败', error);
36
+ }
37
+ };
38
+ const createElement = (tag, styles, text) => {
39
+ const el = document.createElement(tag);
40
+ if (styles)
41
+ el.style.cssText = styles;
42
+ if (text)
43
+ el.textContent = text;
44
+ return el;
45
+ };
46
+ const overlay = createElement('div', CAPTCHA_STYLES.overlay);
47
+ const modal = createElement('div', CAPTCHA_STYLES.modal);
48
+ modal.appendChild(createElement('p', CAPTCHA_STYLES.prompt, '请输入你看到的字符:'));
49
+ const captchaWrap = createElement('div', CAPTCHA_STYLES.captchaWrap);
50
+ const captchaImg = createElement('img', CAPTCHA_STYLES.captchaImg);
51
+ captchaImg.id = CAPTCHA_IMG_ID;
52
+ captchaImg.src = captchaState.captchaData;
53
+ captchaWrap.appendChild(captchaImg);
54
+ const refreshBtn = createElement('button', CAPTCHA_STYLES.refreshBtn, '刷新');
55
+ refreshBtn.onclick = debounce(async () => {
56
+ refreshBtn.textContent = '加载中...';
57
+ refreshBtn.disabled = true;
58
+ refreshBtn.style.cssText = `${CAPTCHA_STYLES.refreshBtn};${CAPTCHA_STYLES.loading}`;
59
+ try {
60
+ await refreshCaptcha();
61
+ }
62
+ finally {
63
+ refreshBtn.textContent = '刷新';
64
+ refreshBtn.disabled = false;
65
+ refreshBtn.style.cssText = CAPTCHA_STYLES.refreshBtn;
66
+ }
67
+ }, 500);
68
+ captchaWrap.appendChild(refreshBtn);
69
+ modal.appendChild(captchaWrap);
70
+ const input = createElement('input', CAPTCHA_STYLES.input);
71
+ input.type = 'text';
72
+ input.placeholder = '输入字符';
73
+ input.maxLength = 4;
74
+ modal.appendChild(input);
75
+ const errorMsg = createElement('div', 'color:#dc3545;font-size:12px;margin-bottom:10px;display:none;padding:8px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:4px');
76
+ modal.appendChild(errorMsg);
77
+ const showError = (message) => {
78
+ errorMsg.textContent = message;
79
+ errorMsg.style.display = 'block';
80
+ };
81
+ const confirmBtn = createElement('button', CAPTCHA_STYLES.confirmBtn, '确定');
82
+ confirmBtn.onclick = debounce(async () => {
83
+ const inputValue = input.value.trim();
84
+ if (!inputValue) {
85
+ showError('请输入字符');
86
+ return;
87
+ }
88
+ errorMsg.style.display = 'none';
89
+ confirmBtn.textContent = '验证中...';
90
+ confirmBtn.disabled = true;
91
+ confirmBtn.style.cssText = `${CAPTCHA_STYLES.confirmBtn};${CAPTCHA_STYLES.loading}`;
92
+ try {
93
+ const verifyResult = await oauthInstance.verifyCaptchaData({
94
+ token: captchaState.token,
95
+ key: inputValue,
96
+ });
97
+ eventBus.fire(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, verifyResult);
98
+ console.log('图形验证码校验成功');
99
+ document.body.removeChild(overlay);
100
+ document.body.removeChild(modal);
101
+ }
102
+ catch (error) {
103
+ console.error('图形验证码校验失败', error);
104
+ const errorMessage = error.error_description || '图形验证码校验失败';
105
+ showError(errorMessage);
106
+ input.value = '';
107
+ input.focus();
108
+ await refreshCaptcha();
109
+ }
110
+ finally {
111
+ confirmBtn.textContent = '确定';
112
+ confirmBtn.disabled = false;
113
+ confirmBtn.style.cssText = CAPTCHA_STYLES.confirmBtn;
114
+ }
115
+ }, 500);
116
+ modal.appendChild(confirmBtn);
117
+ document.body.appendChild(overlay);
118
+ document.body.appendChild(modal);
119
+ };
120
+ export const openURIWithCallback = async (url, oauthInstance) => {
121
+ const { captchaData, state, token } = parseCaptcha(url);
122
+ genCaptchaDom({ oauthInstance, captchaState: { captchaData, state, token } });
123
+ return new Promise((resolve) => {
124
+ console.log('等待图形验证码校验结果...');
125
+ eventBus.on(CAPTCHA_EVENT.RESOLVE_CAPTCHA_DATA, (res) => {
126
+ resolve(res?.data);
127
+ });
128
+ });
129
+ };
@@ -1,7 +1,7 @@
1
1
  import { ApiUrls, ErrorType } from '../auth/consts';
2
2
  import { defaultStorage } from '../oauth2client/oauth2client';
3
- import { isInMpWebView, isMp } from '../utils/mp';
4
- import MyURLSearchParams from '../utils/urlSearchParams';
3
+ import { isMp } from '../utils/mp';
4
+ import { openURIWithCallback } from './captcha-dom';
5
5
  export class Captcha {
6
6
  constructor(opts) {
7
7
  if (!opts.openURIWithCallback) {
@@ -11,7 +11,7 @@ export class Captcha {
11
11
  opts.storage = defaultStorage;
12
12
  }
13
13
  this.config = opts;
14
- this.tokenSectionName = `captcha_${opts.clientId}`;
14
+ this.tokenSectionName = `captcha_${opts.clientId || opts.env}`;
15
15
  }
16
16
  isMatch() {
17
17
  return this.config?.adapter?.isMatch?.() || isMp();
@@ -42,65 +42,7 @@ export class Captcha {
42
42
  return resp;
43
43
  }
44
44
  getDefaultOpenURIWithCallback() {
45
- if (!this.isMatch() && !isInMpWebView()) {
46
- if (window.location.search.indexOf('__captcha') > 0) {
47
- document.body.style.display = 'none';
48
- }
49
- if (document.getElementById('captcha_panel_wrap') === null) {
50
- const elementDiv = document.createElement('div');
51
- elementDiv.style.cssText = 'background-color: rgba(0, 0, 0, 0.7);position: fixed;left: 0px;right: 0px;top: 0px;bottom: 0px;padding: 9vw 0 0 0;display: none;z-index:100;';
52
- elementDiv.setAttribute('id', 'captcha_panel_wrap');
53
- setTimeout(() => {
54
- document.body.appendChild(elementDiv);
55
- }, 0);
56
- }
57
- }
58
- return this.defaultOpenURIWithCallback;
59
- }
60
- async defaultOpenURIWithCallback(url, opts) {
61
- const { width = '355px', height = '355px' } = opts || {};
62
- const matched = url.match(/^(data:.*)$/);
63
- if (matched) {
64
- return Promise.reject({
65
- error: ErrorType.UNIMPLEMENTED,
66
- error_description: 'need to impl captcha data',
67
- });
68
- }
69
- const target = document.getElementById('captcha_panel_wrap');
70
- const iframe = document.createElement('iframe');
71
- target.innerHTML = '';
72
- iframe.setAttribute('src', url);
73
- iframe.setAttribute('id', 'review-panel-iframe');
74
- iframe.style.cssText = `min-width:${width};display:block;height:${height};margin:0 auto;background-color: rgb(255, 255, 255);border: none;`;
75
- target.appendChild(iframe);
76
- target.style.display = 'block';
77
- return new Promise((resolve, reject) => {
78
- iframe.onload = function () {
79
- try {
80
- const windowLocation = window.location;
81
- const iframeLocation = iframe.contentWindow.location;
82
- if (iframeLocation.host + iframeLocation.pathname === windowLocation.host + windowLocation.pathname) {
83
- target.style.display = 'none';
84
- const iframeUrlParams = new MyURLSearchParams(iframeLocation.search);
85
- const captchToken = iframeUrlParams.get('captcha_token');
86
- if (captchToken) {
87
- return resolve({
88
- captcha_token: captchToken,
89
- expires_in: Number(iframeUrlParams.get('expires_in')),
90
- });
91
- }
92
- return reject({
93
- error: iframeUrlParams.get('error'),
94
- error_description: iframeUrlParams.get('error_description'),
95
- });
96
- }
97
- target.style.display = 'block';
98
- }
99
- catch (error) {
100
- target.style.display = 'block';
101
- }
102
- };
103
- });
45
+ return (url) => openURIWithCallback(url, this.config.oauthInstance);
104
46
  }
105
47
  async getCaptchaToken(forceNewToken, state) {
106
48
  if (!forceNewToken) {
@@ -109,41 +51,16 @@ export class Captcha {
109
51
  return captchaToken;
110
52
  }
111
53
  }
112
- let captchaTokenResp;
113
- if (!this.isMatch() && !isInMpWebView()) {
114
- const redirect_uri = `${window.location.origin + window.location.pathname}?__captcha=on`;
115
- captchaTokenResp = await this.config.request(ApiUrls.GET_CAPTCHA_URL, {
116
- method: 'POST',
117
- body: {
118
- client_id: this.config.clientId,
119
- redirect_uri,
120
- state,
121
- },
122
- withCredentials: false,
123
- });
124
- if (captchaTokenResp.captcha_token) {
125
- const captchaToken = {
126
- captcha_token: captchaTokenResp.captcha_token,
127
- expires_in: captchaTokenResp.expires_in,
128
- };
129
- this.saveCaptchaToken(captchaToken);
130
- return captchaTokenResp.captcha_token;
131
- }
132
- }
133
- else {
134
- const captchaDataResp = await this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
135
- method: 'POST',
136
- body: {
137
- state,
138
- redirect_uri: '',
139
- },
140
- withCredentials: false,
141
- });
142
- captchaTokenResp = {
143
- url: `${captchaDataResp.data}?state=${encodeURIComponent(state)}&token=${encodeURIComponent(captchaDataResp.token)}`,
144
- };
145
- }
146
- const captchaToken = await this.config.openURIWithCallback(captchaTokenResp.url);
54
+ const captchaDataResp = await this.config.request(ApiUrls.CAPTCHA_DATA_URL, {
55
+ method: 'POST',
56
+ body: {
57
+ state,
58
+ redirect_uri: '',
59
+ },
60
+ withCredentials: false,
61
+ });
62
+ const captchaTokenUrl = `${captchaDataResp.data}?state=${encodeURIComponent(state)}&token=${encodeURIComponent(captchaDataResp.token)}`;
63
+ const captchaToken = await this.config.openURIWithCallback(captchaTokenUrl);
147
64
  this.saveCaptchaToken(captchaToken);
148
65
  return captchaToken.captcha_token;
149
66
  }
package/dist/esm/index.js CHANGED
@@ -2,12 +2,16 @@ import { OAuth2Client } from './oauth2client/oauth2client';
2
2
  import { Auth } from './auth/apis';
3
3
  import { AUTH_API_PREFIX } from './auth/consts';
4
4
  export { Auth } from './auth/apis';
5
- export { AUTH_API_PREFIX } from './auth/consts';
5
+ export { AUTH_API_PREFIX, OAUTH_TYPE } from './auth/consts';
6
+ export { AuthError } from './auth/auth-error';
6
7
  import * as authModels_1 from './auth/models';
7
8
  export { authModels_1 as authModels };
9
+ export { weappJwtDecodeAll } from './utils/base64';
10
+ export { LOGIN_STATE_CHANGED_TYPE, EVENTS, AUTH_STATE_CHANGED_TYPE } from './auth/consts';
8
11
  export class CloudbaseOAuth {
9
12
  constructor(authOptions) {
10
- const { apiOrigin, apiPath = AUTH_API_PREFIX, clientId, env, storage, request, baseRequest, anonymousSignInFunc, wxCloud, adapter, onCredentialsError, headers, i18n, useWxCloud } = authOptions;
13
+ const { apiOrigin, apiPath = AUTH_API_PREFIX, clientId, env, storage, request, baseRequest, anonymousSignInFunc, wxCloud, adapter, onCredentialsError, headers, i18n, useWxCloud, eventBus, detectSessionInUrl, debug, } = authOptions;
14
+ this.detectSessionInUrl = detectSessionInUrl ?? false;
11
15
  this.oauth2client = new OAuth2Client({
12
16
  apiOrigin,
13
17
  apiPath,
@@ -21,6 +25,8 @@ export class CloudbaseOAuth {
21
25
  headers: headers || {},
22
26
  i18n,
23
27
  useWxCloud,
28
+ eventBus,
29
+ debug,
24
30
  });
25
31
  this.authApi = new Auth({
26
32
  credentialsClient: this.oauth2client,
@@ -28,5 +34,15 @@ export class CloudbaseOAuth {
28
34
  request: request ? this.oauth2client.request.bind(this.oauth2client) : undefined,
29
35
  adapter,
30
36
  });
37
+ if (detectSessionInUrl) {
38
+ this.oauth2client.setGetInitialSession(this.authApi.getInitialSession.bind(this.authApi));
39
+ }
40
+ }
41
+ initializeSession(onUserObtained) {
42
+ if (!this.detectSessionInUrl) {
43
+ return;
44
+ }
45
+ this.oauth2client.setOnInitialSessionObtained(onUserObtained);
46
+ this.oauth2client.initialize();
31
47
  }
32
48
  }