@logto/browser 1.1.2 → 2.1.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/lib/cache.cjs ADDED
@@ -0,0 +1,25 @@
1
+ 'use strict';
2
+
3
+ const keyPrefix = `logto_cache`;
4
+ class CacheStorage {
5
+ constructor(appId) {
6
+ this.appId = appId;
7
+ }
8
+ getKey(item) {
9
+ if (item === undefined) {
10
+ return `${keyPrefix}:${this.appId}`;
11
+ }
12
+ return `${keyPrefix}:${this.appId}:${item}`;
13
+ }
14
+ async getItem(key) {
15
+ return sessionStorage.getItem(this.getKey(key));
16
+ }
17
+ async setItem(key, value) {
18
+ sessionStorage.setItem(this.getKey(key), value);
19
+ }
20
+ async removeItem(key) {
21
+ sessionStorage.removeItem(`${this.getKey(key)}`);
22
+ }
23
+ }
24
+
25
+ exports.CacheStorage = CacheStorage;
package/lib/cache.d.ts ADDED
@@ -0,0 +1,10 @@
1
+ import type { Storage, CacheKey } from '@logto/client';
2
+ import type { Nullable } from '@silverhand/essentials';
3
+ export declare class CacheStorage implements Storage<CacheKey> {
4
+ readonly appId: string;
5
+ constructor(appId: string);
6
+ getKey(item?: string): string;
7
+ getItem(key: CacheKey): Promise<Nullable<string>>;
8
+ setItem(key: CacheKey, value: string): Promise<void>;
9
+ removeItem(key: CacheKey): Promise<void>;
10
+ }
package/lib/cache.js ADDED
@@ -0,0 +1,23 @@
1
+ const keyPrefix = `logto_cache`;
2
+ class CacheStorage {
3
+ constructor(appId) {
4
+ this.appId = appId;
5
+ }
6
+ getKey(item) {
7
+ if (item === undefined) {
8
+ return `${keyPrefix}:${this.appId}`;
9
+ }
10
+ return `${keyPrefix}:${this.appId}:${item}`;
11
+ }
12
+ async getItem(key) {
13
+ return sessionStorage.getItem(this.getKey(key));
14
+ }
15
+ async setItem(key, value) {
16
+ sessionStorage.setItem(this.getKey(key), value);
17
+ }
18
+ async removeItem(key) {
19
+ sessionStorage.removeItem(`${this.getKey(key)}`);
20
+ }
21
+ }
22
+
23
+ export { CacheStorage };
@@ -0,0 +1 @@
1
+ export {};
package/lib/index.cjs ADDED
@@ -0,0 +1,66 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var BaseClient = require('@logto/client');
6
+ var essentials = require('@silverhand/essentials');
7
+ var cache = require('./cache.cjs');
8
+ var storage = require('./storage.cjs');
9
+ var generators = require('./utils/generators.cjs');
10
+
11
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
+
13
+ var BaseClient__default = /*#__PURE__*/_interopDefault(BaseClient);
14
+
15
+ const navigate = (url) => {
16
+ window.location.assign(url);
17
+ };
18
+ class LogtoClient extends BaseClient__default.default {
19
+ /**
20
+ * @param config The configuration object for the client.
21
+ * @param [unstable_enableCache=false] Whether to enable cache for well-known data.
22
+ * Use sessionStorage by default.
23
+ */
24
+ constructor(config, unstable_enableCache = false) {
25
+ const requester = BaseClient.createRequester(fetch);
26
+ super(config, {
27
+ requester,
28
+ navigate,
29
+ storage: new storage.BrowserStorage(config.appId),
30
+ unstable_cache: essentials.conditional(unstable_enableCache && new cache.CacheStorage(config.appId)),
31
+ generateCodeChallenge: generators.generateCodeChallenge,
32
+ generateCodeVerifier: generators.generateCodeVerifier,
33
+ generateState: generators.generateState,
34
+ });
35
+ }
36
+ }
37
+
38
+ Object.defineProperty(exports, 'LogtoClientError', {
39
+ enumerable: true,
40
+ get: function () { return BaseClient.LogtoClientError; }
41
+ });
42
+ Object.defineProperty(exports, 'LogtoError', {
43
+ enumerable: true,
44
+ get: function () { return BaseClient.LogtoError; }
45
+ });
46
+ Object.defineProperty(exports, 'LogtoRequestError', {
47
+ enumerable: true,
48
+ get: function () { return BaseClient.LogtoRequestError; }
49
+ });
50
+ Object.defineProperty(exports, 'OidcError', {
51
+ enumerable: true,
52
+ get: function () { return BaseClient.OidcError; }
53
+ });
54
+ Object.defineProperty(exports, 'Prompt', {
55
+ enumerable: true,
56
+ get: function () { return BaseClient.Prompt; }
57
+ });
58
+ Object.defineProperty(exports, 'ReservedScope', {
59
+ enumerable: true,
60
+ get: function () { return BaseClient.ReservedScope; }
61
+ });
62
+ Object.defineProperty(exports, 'UserScope', {
63
+ enumerable: true,
64
+ get: function () { return BaseClient.UserScope; }
65
+ });
66
+ exports.default = LogtoClient;
package/lib/index.d.ts CHANGED
@@ -3,5 +3,10 @@ import BaseClient from '@logto/client';
3
3
  export type { IdTokenClaims, LogtoErrorCode, LogtoConfig, LogtoClientErrorCode, UserInfoResponse, InteractionMode, } from '@logto/client';
4
4
  export { LogtoError, OidcError, Prompt, LogtoRequestError, LogtoClientError, ReservedScope, UserScope, } from '@logto/client';
5
5
  export default class LogtoClient extends BaseClient {
6
- constructor(config: LogtoConfig);
6
+ /**
7
+ * @param config The configuration object for the client.
8
+ * @param [unstable_enableCache=false] Whether to enable cache for well-known data.
9
+ * Use sessionStorage by default.
10
+ */
11
+ constructor(config: LogtoConfig, unstable_enableCache?: boolean);
7
12
  }
package/lib/index.js CHANGED
@@ -1,58 +1,31 @@
1
- 'use strict';
2
-
3
- Object.defineProperty(exports, '__esModule', { value: true });
4
-
5
- var BaseClient = require('@logto/client');
6
- var storage = require('./storage.js');
7
- var generators = require('./utils/generators.js');
8
-
9
- function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
10
-
11
- var BaseClient__default = /*#__PURE__*/_interopDefault(BaseClient);
1
+ import BaseClient, { createRequester } from '@logto/client';
2
+ export { LogtoClientError, LogtoError, LogtoRequestError, OidcError, Prompt, ReservedScope, UserScope } from '@logto/client';
3
+ import { conditional } from '@silverhand/essentials';
4
+ import { CacheStorage } from './cache.js';
5
+ import { BrowserStorage } from './storage.js';
6
+ import { generateCodeChallenge, generateCodeVerifier, generateState } from './utils/generators.js';
12
7
 
13
8
  const navigate = (url) => {
14
9
  window.location.assign(url);
15
10
  };
16
- class LogtoClient extends BaseClient__default.default {
17
- constructor(config) {
18
- const requester = BaseClient.createRequester(fetch);
11
+ class LogtoClient extends BaseClient {
12
+ /**
13
+ * @param config The configuration object for the client.
14
+ * @param [unstable_enableCache=false] Whether to enable cache for well-known data.
15
+ * Use sessionStorage by default.
16
+ */
17
+ constructor(config, unstable_enableCache = false) {
18
+ const requester = createRequester(fetch);
19
19
  super(config, {
20
20
  requester,
21
21
  navigate,
22
- storage: new storage.BrowserStorage(config.appId),
23
- generateCodeChallenge: generators.generateCodeChallenge,
24
- generateCodeVerifier: generators.generateCodeVerifier,
25
- generateState: generators.generateState,
22
+ storage: new BrowserStorage(config.appId),
23
+ unstable_cache: conditional(unstable_enableCache && new CacheStorage(config.appId)),
24
+ generateCodeChallenge,
25
+ generateCodeVerifier,
26
+ generateState,
26
27
  });
27
28
  }
28
29
  }
29
30
 
30
- Object.defineProperty(exports, 'LogtoClientError', {
31
- enumerable: true,
32
- get: function () { return BaseClient.LogtoClientError; }
33
- });
34
- Object.defineProperty(exports, 'LogtoError', {
35
- enumerable: true,
36
- get: function () { return BaseClient.LogtoError; }
37
- });
38
- Object.defineProperty(exports, 'LogtoRequestError', {
39
- enumerable: true,
40
- get: function () { return BaseClient.LogtoRequestError; }
41
- });
42
- Object.defineProperty(exports, 'OidcError', {
43
- enumerable: true,
44
- get: function () { return BaseClient.OidcError; }
45
- });
46
- Object.defineProperty(exports, 'Prompt', {
47
- enumerable: true,
48
- get: function () { return BaseClient.Prompt; }
49
- });
50
- Object.defineProperty(exports, 'ReservedScope', {
51
- enumerable: true,
52
- get: function () { return BaseClient.ReservedScope; }
53
- });
54
- Object.defineProperty(exports, 'UserScope', {
55
- enumerable: true,
56
- get: function () { return BaseClient.UserScope; }
57
- });
58
- exports.default = LogtoClient;
31
+ export { LogtoClient as default };
@@ -0,0 +1,37 @@
1
+ 'use strict';
2
+
3
+ const keyPrefix = `logto`;
4
+ class BrowserStorage {
5
+ constructor(appId) {
6
+ this.appId = appId;
7
+ }
8
+ getKey(item) {
9
+ if (item === undefined) {
10
+ return `${keyPrefix}:${this.appId}`;
11
+ }
12
+ return `${keyPrefix}:${this.appId}:${item}`;
13
+ }
14
+ async getItem(key) {
15
+ if (key === 'signInSession') {
16
+ // The latter `getItem()` is for backward compatibility. Can be removed when major bump.
17
+ return sessionStorage.getItem(this.getKey(key)) ?? sessionStorage.getItem(this.getKey());
18
+ }
19
+ return localStorage.getItem(this.getKey(key));
20
+ }
21
+ async setItem(key, value) {
22
+ if (key === 'signInSession') {
23
+ sessionStorage.setItem(this.getKey(key), value);
24
+ return;
25
+ }
26
+ localStorage.setItem(this.getKey(key), value);
27
+ }
28
+ async removeItem(key) {
29
+ if (key === 'signInSession') {
30
+ sessionStorage.removeItem(this.getKey(key));
31
+ return;
32
+ }
33
+ localStorage.removeItem(this.getKey(key));
34
+ }
35
+ }
36
+
37
+ exports.BrowserStorage = BrowserStorage;
package/lib/storage.d.ts CHANGED
@@ -1,9 +1,9 @@
1
1
  import type { Storage, StorageKey } from '@logto/client';
2
2
  import type { Nullable } from '@silverhand/essentials';
3
- export declare const logtoStorageItemKeyPrefix = "logto";
4
- export declare class BrowserStorage implements Storage {
5
- private readonly storageKey;
3
+ export declare class BrowserStorage implements Storage<StorageKey> {
4
+ readonly appId: string;
6
5
  constructor(appId: string);
6
+ getKey(item?: string): string;
7
7
  getItem(key: StorageKey): Promise<Nullable<string>>;
8
8
  setItem(key: StorageKey, value: string): Promise<void>;
9
9
  removeItem(key: StorageKey): Promise<void>;
package/lib/storage.js CHANGED
@@ -1,31 +1,35 @@
1
- 'use strict';
2
-
3
- const logtoStorageItemKeyPrefix = `logto`;
1
+ const keyPrefix = `logto`;
4
2
  class BrowserStorage {
5
3
  constructor(appId) {
6
- this.storageKey = `${logtoStorageItemKeyPrefix}:${appId}`;
4
+ this.appId = appId;
5
+ }
6
+ getKey(item) {
7
+ if (item === undefined) {
8
+ return `${keyPrefix}:${this.appId}`;
9
+ }
10
+ return `${keyPrefix}:${this.appId}:${item}`;
7
11
  }
8
12
  async getItem(key) {
9
13
  if (key === 'signInSession') {
10
- return sessionStorage.getItem(this.storageKey);
14
+ // The latter `getItem()` is for backward compatibility. Can be removed when major bump.
15
+ return sessionStorage.getItem(this.getKey(key)) ?? sessionStorage.getItem(this.getKey());
11
16
  }
12
- return localStorage.getItem(`${this.storageKey}:${key}`);
17
+ return localStorage.getItem(this.getKey(key));
13
18
  }
14
19
  async setItem(key, value) {
15
20
  if (key === 'signInSession') {
16
- sessionStorage.setItem(this.storageKey, value);
21
+ sessionStorage.setItem(this.getKey(key), value);
17
22
  return;
18
23
  }
19
- localStorage.setItem(`${this.storageKey}:${key}`, value);
24
+ localStorage.setItem(this.getKey(key), value);
20
25
  }
21
26
  async removeItem(key) {
22
27
  if (key === 'signInSession') {
23
- sessionStorage.removeItem(this.storageKey);
28
+ sessionStorage.removeItem(this.getKey(key));
24
29
  return;
25
30
  }
26
- localStorage.removeItem(`${this.storageKey}:${key}`);
31
+ localStorage.removeItem(this.getKey(key));
27
32
  }
28
33
  }
29
34
 
30
- exports.BrowserStorage = BrowserStorage;
31
- exports.logtoStorageItemKeyPrefix = logtoStorageItemKeyPrefix;
35
+ export { BrowserStorage };
@@ -1,11 +1,13 @@
1
- import { LogtoError } from '@logto/client';
2
- import { fromUint8Array } from 'js-base64';
1
+ 'use strict';
2
+
3
+ var BaseClient = require('@logto/client');
4
+ var jsBase64 = require('js-base64');
3
5
 
4
6
  /** @link [Proof Key for Code Exchange by OAuth Public Clients](https://datatracker.ietf.org/doc/html/rfc7636) */
5
7
  /**
6
8
  * @param length The length of the raw random data.
7
9
  */
8
- const generateRandomString = (length = 64) => fromUint8Array(crypto.getRandomValues(new Uint8Array(length)), true);
10
+ const generateRandomString = (length = 64) => jsBase64.fromUint8Array(crypto.getRandomValues(new Uint8Array(length)), true);
9
11
  /**
10
12
  * Generates random string for state and encodes them in url safe base64
11
13
  */
@@ -30,11 +32,13 @@ const generateCodeChallenge = async (codeVerifier) => {
30
32
  * https://developer.mozilla.org/en-US/docs/Web/API/Crypto/subtle
31
33
  * https://www.chromium.org/blink/webcrypto/#accessing-it
32
34
  */
33
- throw new LogtoError('crypto_subtle_unavailable');
35
+ throw new BaseClient.LogtoError('crypto_subtle_unavailable');
34
36
  }
35
37
  const encodedCodeVerifier = new TextEncoder().encode(codeVerifier);
36
38
  const codeChallenge = new Uint8Array(await crypto.subtle.digest('SHA-256', encodedCodeVerifier));
37
- return fromUint8Array(codeChallenge, true);
39
+ return jsBase64.fromUint8Array(codeChallenge, true);
38
40
  };
39
41
 
40
- export { generateCodeChallenge, generateCodeVerifier, generateState };
42
+ exports.generateCodeChallenge = generateCodeChallenge;
43
+ exports.generateCodeVerifier = generateCodeVerifier;
44
+ exports.generateState = generateState;
@@ -1,13 +1,11 @@
1
- 'use strict';
2
-
3
- var BaseClient = require('@logto/client');
4
- var jsBase64 = require('js-base64');
1
+ import { LogtoError } from '@logto/client';
2
+ import { fromUint8Array } from 'js-base64';
5
3
 
6
4
  /** @link [Proof Key for Code Exchange by OAuth Public Clients](https://datatracker.ietf.org/doc/html/rfc7636) */
7
5
  /**
8
6
  * @param length The length of the raw random data.
9
7
  */
10
- const generateRandomString = (length = 64) => jsBase64.fromUint8Array(crypto.getRandomValues(new Uint8Array(length)), true);
8
+ const generateRandomString = (length = 64) => fromUint8Array(crypto.getRandomValues(new Uint8Array(length)), true);
11
9
  /**
12
10
  * Generates random string for state and encodes them in url safe base64
13
11
  */
@@ -32,13 +30,11 @@ const generateCodeChallenge = async (codeVerifier) => {
32
30
  * https://developer.mozilla.org/en-US/docs/Web/API/Crypto/subtle
33
31
  * https://www.chromium.org/blink/webcrypto/#accessing-it
34
32
  */
35
- throw new BaseClient.LogtoError('crypto_subtle_unavailable');
33
+ throw new LogtoError('crypto_subtle_unavailable');
36
34
  }
37
35
  const encodedCodeVerifier = new TextEncoder().encode(codeVerifier);
38
36
  const codeChallenge = new Uint8Array(await crypto.subtle.digest('SHA-256', encodedCodeVerifier));
39
- return jsBase64.fromUint8Array(codeChallenge, true);
37
+ return fromUint8Array(codeChallenge, true);
40
38
  };
41
39
 
42
- exports.generateCodeChallenge = generateCodeChallenge;
43
- exports.generateCodeVerifier = generateCodeVerifier;
44
- exports.generateState = generateState;
40
+ export { generateCodeChallenge, generateCodeVerifier, generateState };
package/package.json CHANGED
@@ -1,14 +1,16 @@
1
1
  {
2
2
  "name": "@logto/browser",
3
- "version": "1.1.2",
4
- "source": "./src/index.ts",
5
- "main": "./lib/index.js",
3
+ "version": "2.1.0",
4
+ "type": "module",
5
+ "main": "./lib/index.cjs",
6
+ "module": "./lib/index.js",
7
+ "types": "./lib/index.d.ts",
6
8
  "exports": {
7
- "require": "./lib/index.js",
8
- "import": "./lib/index.mjs"
9
+ "types": "./lib/index.d.ts",
10
+ "require": "./lib/index.cjs",
11
+ "import": "./lib/index.js",
12
+ "default": "./lib/index.js"
9
13
  },
10
- "module": "./lib/index.mjs",
11
- "types": "./lib/index.d.ts",
12
14
  "files": [
13
15
  "lib"
14
16
  ],
@@ -18,32 +20,20 @@
18
20
  "url": "https://github.com/logto-io/js.git",
19
21
  "directory": "packages/browser"
20
22
  },
21
- "scripts": {
22
- "dev:tsc": "tsc -p tsconfig.build.json -w --preserveWatchOutput",
23
- "precommit": "lint-staged",
24
- "check": "tsc --noEmit",
25
- "build": "rm -rf lib/ && tsc -p tsconfig.build.json --noEmit && rollup -c",
26
- "lint": "eslint --ext .ts src",
27
- "test": "jest",
28
- "test:coverage": "jest --silent --coverage",
29
- "prepack": "pnpm test"
30
- },
31
23
  "dependencies": {
32
- "@logto/client": "^1.1.2",
33
- "@silverhand/essentials": "^2.6.1",
24
+ "@logto/client": "^2.2.0",
25
+ "@silverhand/essentials": "^2.6.2",
34
26
  "js-base64": "^3.7.4"
35
27
  },
36
28
  "devDependencies": {
37
- "@jest/types": "^29.5.0",
38
- "@silverhand/eslint-config": "^2.0.0",
39
- "@silverhand/ts-config": "^1.0.0",
29
+ "@silverhand/eslint-config": "^3.0.1",
30
+ "@silverhand/ts-config": "^3.0.0",
40
31
  "@swc/core": "^1.3.50",
41
32
  "@swc/jest": "^0.2.24",
42
33
  "@types/jest": "^29.5.0",
43
34
  "eslint": "^8.38.0",
44
35
  "jest": "^29.5.0",
45
36
  "jest-environment-jsdom": "^29.5.0",
46
- "jest-location-mock": "^1.0.9",
47
37
  "jest-matcher-specific-error": "^1.0.0",
48
38
  "lint-staged": "^13.0.0",
49
39
  "prettier": "^2.8.7",
@@ -57,5 +47,13 @@
57
47
  "publishConfig": {
58
48
  "access": "public"
59
49
  },
60
- "gitHead": "9e9a8b0887ef67baa7c3c564590bb06e7801d03e"
61
- }
50
+ "scripts": {
51
+ "dev:tsc": "tsc -p tsconfig.build.json -w --preserveWatchOutput",
52
+ "precommit": "lint-staged",
53
+ "check": "tsc --noEmit",
54
+ "build": "rm -rf lib/ && tsc -p tsconfig.build.json --noEmit && rollup -c",
55
+ "lint": "eslint --ext .ts src",
56
+ "test": "jest",
57
+ "test:coverage": "jest --silent --coverage"
58
+ }
59
+ }
package/lib/index.mjs DELETED
@@ -1,23 +0,0 @@
1
- import BaseClient, { createRequester } from '@logto/client';
2
- export { LogtoClientError, LogtoError, LogtoRequestError, OidcError, Prompt, ReservedScope, UserScope } from '@logto/client';
3
- import { BrowserStorage } from './storage.mjs';
4
- import { generateCodeChallenge, generateCodeVerifier, generateState } from './utils/generators.mjs';
5
-
6
- const navigate = (url) => {
7
- window.location.assign(url);
8
- };
9
- class LogtoClient extends BaseClient {
10
- constructor(config) {
11
- const requester = createRequester(fetch);
12
- super(config, {
13
- requester,
14
- navigate,
15
- storage: new BrowserStorage(config.appId),
16
- generateCodeChallenge,
17
- generateCodeVerifier,
18
- generateState,
19
- });
20
- }
21
- }
22
-
23
- export { LogtoClient as default };
package/lib/storage.mjs DELETED
@@ -1,28 +0,0 @@
1
- const logtoStorageItemKeyPrefix = `logto`;
2
- class BrowserStorage {
3
- constructor(appId) {
4
- this.storageKey = `${logtoStorageItemKeyPrefix}:${appId}`;
5
- }
6
- async getItem(key) {
7
- if (key === 'signInSession') {
8
- return sessionStorage.getItem(this.storageKey);
9
- }
10
- return localStorage.getItem(`${this.storageKey}:${key}`);
11
- }
12
- async setItem(key, value) {
13
- if (key === 'signInSession') {
14
- sessionStorage.setItem(this.storageKey, value);
15
- return;
16
- }
17
- localStorage.setItem(`${this.storageKey}:${key}`, value);
18
- }
19
- async removeItem(key) {
20
- if (key === 'signInSession') {
21
- sessionStorage.removeItem(this.storageKey);
22
- return;
23
- }
24
- localStorage.removeItem(`${this.storageKey}:${key}`);
25
- }
26
- }
27
-
28
- export { BrowserStorage, logtoStorageItemKeyPrefix };