@mittwald/ext-bridge 0.2.0-alpha.781 → 0.2.0-alpha.782
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/js/config/getConfig.mjs +7 -7
- package/dist/js/config/getConfig.mjs.map +1 -1
- package/dist/js/config/parse.mjs +10 -11
- package/dist/js/config/parse.mjs.map +1 -1
- package/dist/js/config/schemas.mjs +16 -15
- package/dist/js/config/schemas.mjs.map +1 -1
- package/dist/js/environment.mjs +7 -5
- package/dist/js/environment.mjs.map +1 -1
- package/dist/js/error.mjs +10 -8
- package/dist/js/error.mjs.map +1 -1
- package/dist/js/getExtBridge.mjs +7 -5
- package/dist/js/getExtBridge.mjs.map +1 -1
- package/dist/js/global-browser.mjs +6 -14
- package/dist/js/global-browser.mjs.map +1 -1
- package/dist/js/index-browser.mjs +4 -4
- package/dist/js/index-node.mjs +4 -6
- package/dist/js/index.mjs +0 -2
- package/dist/js/lib/assertBrowserEnv.mjs +8 -11
- package/dist/js/lib/assertBrowserEnv.mjs.map +1 -1
- package/dist/js/lib/controllablePromise.mjs +20 -16
- package/dist/js/lib/controllablePromise.mjs.map +1 -1
- package/dist/js/react/hooks/index.mjs +1 -0
- package/dist/js/react/hooks/useConfig.mjs +7 -6
- package/dist/js/react/hooks/useConfig.mjs.map +1 -1
- package/dist/js/react/hooks/useExtBridge.mjs +8 -7
- package/dist/js/react/hooks/useExtBridge.mjs.map +1 -1
- package/dist/js/react.mjs +4 -3
- package/dist/js/readiness.mjs +26 -27
- package/dist/js/readiness.mjs.map +1 -1
- package/dist/js/sessionToken/decode.mjs +15 -27
- package/dist/js/sessionToken/decode.mjs.map +1 -1
- package/dist/js/sessionToken/getAccessToken.mjs +16 -13
- package/dist/js/sessionToken/getAccessToken.mjs.map +1 -1
- package/dist/js/sessionToken/getSessionToken.mjs +7 -7
- package/dist/js/sessionToken/getSessionToken.mjs.map +1 -1
- package/dist/js/sessionToken/index.mjs +2 -0
- package/dist/js/sessionToken/publicKeys/fetchPublicKey.mjs +15 -15
- package/dist/js/sessionToken/publicKeys/fetchPublicKey.mjs.map +1 -1
- package/dist/js/sessionToken/publicKeys/index.mjs +1 -0
- package/dist/js/sessionToken/publicKeys/publicKeys.mjs +13 -15
- package/dist/js/sessionToken/publicKeys/publicKeys.mjs.map +1 -1
- package/dist/js/sessionToken/schemas.mjs +18 -17
- package/dist/js/sessionToken/schemas.mjs.map +1 -1
- package/dist/js/sessionToken/verify.mjs +12 -11
- package/dist/js/sessionToken/verify.mjs.map +1 -1
- package/package.json +4 -4
- package/dist/js/index-browser.mjs.map +0 -1
- package/dist/js/index-node.mjs.map +0 -1
- package/dist/js/index.mjs.map +0 -1
- package/dist/js/react.mjs.map +0 -1
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { getExtBridge } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
return extBridge.config;
|
|
1
|
+
import { getExtBridge } from "../getExtBridge.mjs";
|
|
2
|
+
//#region src/config/getConfig.ts
|
|
3
|
+
var getConfig = async () => {
|
|
4
|
+
return (await getExtBridge()).config;
|
|
6
5
|
};
|
|
7
|
-
|
|
6
|
+
//#endregion
|
|
8
7
|
export { getConfig };
|
|
9
|
-
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=getConfig.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getConfig.mjs","sources":["../../../src/config/getConfig.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\n\nexport const getConfig = async () => {\n const extBridge = await getExtBridge();\n return extBridge.config;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"getConfig.mjs","names":[],"sources":["../../../src/config/getConfig.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\n\nexport const getConfig = async () => {\n const extBridge = await getExtBridge();\n return extBridge.config;\n};\n"],"mappings":";;AAEA,IAAa,YAAY,YAAY;AAEnC,SADkB,MAAM,cAAc,EACrB"}
|
package/dist/js/config/parse.mjs
CHANGED
|
@@ -1,13 +1,12 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
}
|
|
9
|
-
return parsed.data;
|
|
1
|
+
import { ExtBridgeError } from "../error.mjs";
|
|
2
|
+
import { config } from "./schemas.mjs";
|
|
3
|
+
//#region src/config/parse.ts
|
|
4
|
+
var parseConfig = (something) => {
|
|
5
|
+
const parsed = config.safeParse(something);
|
|
6
|
+
if (parsed.error) throw new ExtBridgeError("Invalid config: " + parsed.error.message);
|
|
7
|
+
return parsed.data;
|
|
10
8
|
};
|
|
11
|
-
|
|
9
|
+
//#endregion
|
|
12
10
|
export { parseConfig };
|
|
13
|
-
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=parse.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"parse.mjs","sources":["../../../src/config/parse.ts"],"sourcesContent":["import { config } from \"@/config/schemas\";\nimport { ExtBridgeError } from \"@/error\";\n\nexport const parseConfig = (something: unknown) => {\n const parsed = config.safeParse(something);\n if (parsed.error) {\n throw new ExtBridgeError(\"Invalid config: \" + parsed.error.message);\n }\n return parsed.data;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"parse.mjs","names":[],"sources":["../../../src/config/parse.ts"],"sourcesContent":["import { config } from \"@/config/schemas\";\nimport { ExtBridgeError } from \"@/error\";\n\nexport const parseConfig = (something: unknown) => {\n const parsed = config.safeParse(something);\n if (parsed.error) {\n throw new ExtBridgeError(\"Invalid config: \" + parsed.error.message);\n }\n return parsed.data;\n};\n"],"mappings":";;;AAGA,IAAa,eAAe,cAAuB;CACjD,MAAM,SAAS,OAAO,UAAU,UAAU;AAC1C,KAAI,OAAO,MACT,OAAM,IAAI,eAAe,qBAAqB,OAAO,MAAM,QAAQ;AAErE,QAAO,OAAO"}
|
|
@@ -1,18 +1,19 @@
|
|
|
1
|
-
import { z } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
//#region src/config/schemas.ts
|
|
3
|
+
var baseConfig = z.object({
|
|
4
|
+
sessionId: z.string(),
|
|
5
|
+
userId: z.string(),
|
|
6
|
+
extensionId: z.string(),
|
|
7
|
+
extensionInstanceId: z.string(),
|
|
8
|
+
variantKey: z.string().optional().nullable()
|
|
9
9
|
});
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
10
|
+
var contextParameters = z.object({
|
|
11
|
+
appInstallationId: z.string().optional(),
|
|
12
|
+
projectId: z.string().optional(),
|
|
13
|
+
customerId: z.string().optional()
|
|
14
14
|
});
|
|
15
|
-
|
|
16
|
-
|
|
15
|
+
var config = baseConfig.extend(contextParameters.shape).catchall(z.string().optional().nullable());
|
|
16
|
+
//#endregion
|
|
17
17
|
export { config };
|
|
18
|
-
|
|
18
|
+
|
|
19
|
+
//# sourceMappingURL=schemas.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schemas.mjs","sources":["../../../src/config/schemas.ts"],"sourcesContent":["import { z } from \"zod\";\n\nconst baseConfig = z.object({\n sessionId: z.string(),\n userId: z.string(),\n extensionId: z.string(),\n extensionInstanceId: z.string(),\n variantKey: z.string().optional().nullable(),\n});\n\nconst contextParameters = z.object({\n appInstallationId: z.string().optional(),\n projectId: z.string().optional(),\n customerId: z.string().optional(),\n});\n\nexport const config = baseConfig\n .extend(contextParameters.shape)\n .catchall(z.string().optional().nullable());\n"],"
|
|
1
|
+
{"version":3,"file":"schemas.mjs","names":[],"sources":["../../../src/config/schemas.ts"],"sourcesContent":["import { z } from \"zod\";\n\nconst baseConfig = z.object({\n sessionId: z.string(),\n userId: z.string(),\n extensionId: z.string(),\n extensionInstanceId: z.string(),\n variantKey: z.string().optional().nullable(),\n});\n\nconst contextParameters = z.object({\n appInstallationId: z.string().optional(),\n projectId: z.string().optional(),\n customerId: z.string().optional(),\n});\n\nexport const config = baseConfig\n .extend(contextParameters.shape)\n .catchall(z.string().optional().nullable());\n"],"mappings":";;AAEA,IAAM,aAAa,EAAE,OAAO;CAC1B,WAAW,EAAE,QAAQ;CACrB,QAAQ,EAAE,QAAQ;CAClB,aAAa,EAAE,QAAQ;CACvB,qBAAqB,EAAE,QAAQ;CAC/B,YAAY,EAAE,QAAQ,CAAC,UAAU,CAAC,UAAU;CAC7C,CAAC;AAEF,IAAM,oBAAoB,EAAE,OAAO;CACjC,mBAAmB,EAAE,QAAQ,CAAC,UAAU;CACxC,WAAW,EAAE,QAAQ,CAAC,UAAU;CAChC,YAAY,EAAE,QAAQ,CAAC,UAAU;CAClC,CAAC;AAEF,IAAa,SAAS,WACnB,OAAO,kBAAkB,MAAM,CAC/B,SAAS,EAAE,QAAQ,CAAC,UAAU,CAAC,UAAU,CAAC"}
|
package/dist/js/environment.mjs
CHANGED
|
@@ -1,6 +1,8 @@
|
|
|
1
|
-
import { env } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { env } from "std-env";
|
|
2
|
+
//#region src/environment.ts
|
|
3
|
+
/** @internal */
|
|
4
|
+
var MW_EXT_API_URL = env["MW_EXT_API_URL"] ?? "https://api.mittwald.de";
|
|
5
|
+
//#endregion
|
|
5
6
|
export { MW_EXT_API_URL };
|
|
6
|
-
|
|
7
|
+
|
|
8
|
+
//# sourceMappingURL=environment.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"environment.mjs","sources":["../../src/environment.ts"],"sourcesContent":["import { env } from \"std-env\";\n\n/** @internal */\nexport const MW_EXT_API_URL =\n env[\"MW_EXT_API_URL\"] ?? \"https://api.mittwald.de\";\n"],"
|
|
1
|
+
{"version":3,"file":"environment.mjs","names":[],"sources":["../../src/environment.ts"],"sourcesContent":["import { env } from \"std-env\";\n\n/** @internal */\nexport const MW_EXT_API_URL =\n env[\"MW_EXT_API_URL\"] ?? \"https://api.mittwald.de\";\n"],"mappings":";;;AAGA,IAAa,iBACX,IAAI,qBAAqB"}
|
package/dist/js/error.mjs
CHANGED
|
@@ -1,10 +1,12 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
}
|
|
1
|
+
//#region src/error.ts
|
|
2
|
+
var ExtBridgeError = class extends Error {
|
|
3
|
+
constructor(message) {
|
|
4
|
+
super(message);
|
|
5
|
+
this.message = message;
|
|
6
|
+
}
|
|
7
|
+
};
|
|
7
8
|
ExtBridgeError.prototype.name = "ExtBridgeError";
|
|
8
|
-
|
|
9
|
+
//#endregion
|
|
9
10
|
export { ExtBridgeError };
|
|
10
|
-
|
|
11
|
+
|
|
12
|
+
//# sourceMappingURL=error.mjs.map
|
package/dist/js/error.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"error.mjs","sources":["../../src/error.ts"],"sourcesContent":["export class ExtBridgeError extends Error {\n constructor(message: string) {\n super(message);\n this.message = message;\n }\n}\n\nExtBridgeError.prototype.name = \"ExtBridgeError\";\n"],"
|
|
1
|
+
{"version":3,"file":"error.mjs","names":[],"sources":["../../src/error.ts"],"sourcesContent":["export class ExtBridgeError extends Error {\n constructor(message: string) {\n super(message);\n this.message = message;\n }\n}\n\nExtBridgeError.prototype.name = \"ExtBridgeError\";\n"],"mappings":";AAAA,IAAa,iBAAb,cAAoC,MAAM;CACxC,YAAY,SAAiB;AAC3B,QAAM,QAAQ;AACd,OAAK,UAAU;;;AAInB,eAAe,UAAU,OAAO"}
|
package/dist/js/getExtBridge.mjs
CHANGED
|
@@ -1,7 +1,9 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
//#region src/getExtBridge.ts
|
|
2
|
+
var getExtBridge = async () => {
|
|
3
|
+
await globalThis.mwExtBridge.readiness.isReady();
|
|
4
|
+
return globalThis.mwExtBridge;
|
|
4
5
|
};
|
|
5
|
-
|
|
6
|
+
//#endregion
|
|
6
7
|
export { getExtBridge };
|
|
7
|
-
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=getExtBridge.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getExtBridge.mjs","sources":["../../src/getExtBridge.ts"],"sourcesContent":["export const getExtBridge = async () => {\n await globalThis.mwExtBridge.readiness.isReady();\n return globalThis.mwExtBridge;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"getExtBridge.mjs","names":[],"sources":["../../src/getExtBridge.ts"],"sourcesContent":["export const getExtBridge = async () => {\n await globalThis.mwExtBridge.readiness.isReady();\n return globalThis.mwExtBridge;\n};\n"],"mappings":";AAAA,IAAa,eAAe,YAAY;AACtC,OAAM,WAAW,YAAY,UAAU,SAAS;AAChD,QAAO,WAAW"}
|
|
@@ -1,15 +1,7 @@
|
|
|
1
|
-
import { readinessApi } from
|
|
1
|
+
import { readinessApi } from "./readiness.mjs";
|
|
2
|
+
//#region src/global-browser.ts
|
|
3
|
+
if (typeof globalThis.mwExtBridge !== "undefined") console.warn("mwExtBridge is already defined. The @mittwald/ext-bridge package is probably installed multiple times.");
|
|
4
|
+
globalThis.mwExtBridge = { readiness: readinessApi };
|
|
5
|
+
//#endregion
|
|
2
6
|
|
|
3
|
-
|
|
4
|
-
if (isAlreadyDefined) {
|
|
5
|
-
console.warn(
|
|
6
|
-
"mwExtBridge is already defined. The @mittwald/ext-bridge package is probably installed multiple times."
|
|
7
|
-
);
|
|
8
|
-
}
|
|
9
|
-
const mwExtBridge = {
|
|
10
|
-
readiness: readinessApi
|
|
11
|
-
};
|
|
12
|
-
globalThis.mwExtBridge = mwExtBridge;
|
|
13
|
-
|
|
14
|
-
export { mwExtBridge };
|
|
15
|
-
//# sourceMappingURL=global-browser.mjs.map
|
|
7
|
+
//# sourceMappingURL=global-browser.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"global-browser.mjs","sources":["../../src/global-browser.ts"],"sourcesContent":["import { readinessApi } from \"@/readiness\";\nimport type { ExtBridge } from \"@/types\";\n\nconst isAlreadyDefined = typeof globalThis.mwExtBridge !== \"undefined\";\n\nif (isAlreadyDefined) {\n console.warn(\n \"mwExtBridge is already defined. The @mittwald/ext-bridge package is probably installed multiple times.\",\n );\n}\n\nexport const mwExtBridge = {\n readiness: readinessApi,\n} as ExtBridge;\n\nglobalThis.mwExtBridge = mwExtBridge;\n"],"
|
|
1
|
+
{"version":3,"file":"global-browser.mjs","names":[],"sources":["../../src/global-browser.ts"],"sourcesContent":["import { readinessApi } from \"@/readiness\";\nimport type { ExtBridge } from \"@/types\";\n\nconst isAlreadyDefined = typeof globalThis.mwExtBridge !== \"undefined\";\n\nif (isAlreadyDefined) {\n console.warn(\n \"mwExtBridge is already defined. The @mittwald/ext-bridge package is probably installed multiple times.\",\n );\n}\n\nexport const mwExtBridge = {\n readiness: readinessApi,\n} as ExtBridge;\n\nglobalThis.mwExtBridge = mwExtBridge;\n"],"mappings":";;AAKA,IAFyB,OAAO,WAAW,gBAAgB,YAGzD,SAAQ,KACN,yGACD;AAOH,WAAW,cAJgB,EACzB,WAAW,cACZ"}
|
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import "./global-browser.mjs";
|
|
2
|
+
import { getConfig } from "./config/getConfig.mjs";
|
|
3
|
+
import { getSessionToken } from "./sessionToken/getSessionToken.mjs";
|
|
4
|
+
export { getConfig, getSessionToken };
|
package/dist/js/index-node.mjs
CHANGED
|
@@ -1,6 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
import
|
|
3
|
-
import
|
|
4
|
-
export { verify }
|
|
5
|
-
export { getAccessToken } from './sessionToken/getAccessToken.mjs';
|
|
6
|
-
//# sourceMappingURL=index-node.mjs.map
|
|
1
|
+
import { verify } from "./sessionToken/verify.mjs";
|
|
2
|
+
import "./sessionToken/index.mjs";
|
|
3
|
+
import { getAccessToken } from "./sessionToken/getAccessToken.mjs";
|
|
4
|
+
export { getAccessToken, verify };
|
package/dist/js/index.mjs
CHANGED
|
@@ -1,13 +1,10 @@
|
|
|
1
|
-
import { ExtBridgeError } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
throw new ExtBridgeError(
|
|
7
|
-
"Ext Bridge can only be used in a browser environment. To opt-out from SSR you can use <BrowserOnly> from '@mittwald/flow-remote-react-components'."
|
|
8
|
-
);
|
|
9
|
-
}
|
|
1
|
+
import { ExtBridgeError } from "../error.mjs";
|
|
2
|
+
//#region src/lib/assertBrowserEnv.ts
|
|
3
|
+
var isBrowser = typeof window !== "undefined" && typeof window.document !== "undefined";
|
|
4
|
+
var assertBrowserEnv = () => {
|
|
5
|
+
if (!isBrowser) throw new ExtBridgeError("Ext Bridge can only be used in a browser environment. To opt-out from SSR you can use <BrowserOnly> from '@mittwald/flow-remote-react-components'.");
|
|
10
6
|
};
|
|
11
|
-
|
|
7
|
+
//#endregion
|
|
12
8
|
export { assertBrowserEnv };
|
|
13
|
-
|
|
9
|
+
|
|
10
|
+
//# sourceMappingURL=assertBrowserEnv.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"assertBrowserEnv.mjs","sources":["../../../src/lib/assertBrowserEnv.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\n\nconst isBrowser: boolean =\n typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\n\nexport const assertBrowserEnv = () => {\n if (!isBrowser) {\n throw new ExtBridgeError(\n \"Ext Bridge can only be used in a browser environment. To opt-out from SSR you can use <BrowserOnly> from '@mittwald/flow-remote-react-components'.\",\n );\n }\n};\n"],"
|
|
1
|
+
{"version":3,"file":"assertBrowserEnv.mjs","names":[],"sources":["../../../src/lib/assertBrowserEnv.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\n\nconst isBrowser: boolean =\n typeof window !== \"undefined\" && typeof window.document !== \"undefined\";\n\nexport const assertBrowserEnv = () => {\n if (!isBrowser) {\n throw new ExtBridgeError(\n \"Ext Bridge can only be used in a browser environment. To opt-out from SSR you can use <BrowserOnly> from '@mittwald/flow-remote-react-components'.\",\n );\n }\n};\n"],"mappings":";;AAEA,IAAM,YACJ,OAAO,WAAW,eAAe,OAAO,OAAO,aAAa;AAE9D,IAAa,yBAAyB;AACpC,KAAI,CAAC,UACH,OAAM,IAAI,eACR,qJACD"}
|
|
@@ -1,18 +1,22 @@
|
|
|
1
|
-
import { ExtBridgeError } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
1
|
+
import { ExtBridgeError } from "../error.mjs";
|
|
2
|
+
//#region src/lib/controllablePromise.ts
|
|
3
|
+
var controllablePromise = () => {
|
|
4
|
+
let resolve = () => {
|
|
5
|
+
throw new ExtBridgeError("Unexpected call of resolve()");
|
|
6
|
+
};
|
|
7
|
+
let reject = () => {
|
|
8
|
+
throw new ExtBridgeError("Unexpected call of reject()");
|
|
9
|
+
};
|
|
10
|
+
return [
|
|
11
|
+
new Promise((res, rej) => {
|
|
12
|
+
resolve = res;
|
|
13
|
+
reject = rej;
|
|
14
|
+
}),
|
|
15
|
+
resolve,
|
|
16
|
+
reject
|
|
17
|
+
];
|
|
15
18
|
};
|
|
16
|
-
|
|
19
|
+
//#endregion
|
|
17
20
|
export { controllablePromise };
|
|
18
|
-
|
|
21
|
+
|
|
22
|
+
//# sourceMappingURL=controllablePromise.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"controllablePromise.mjs","sources":["../../../src/lib/controllablePromise.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\n\nexport const controllablePromise = () => {\n let resolve = (): void => {\n throw new ExtBridgeError(\"Unexpected call of resolve()\");\n };\n\n let reject: (error: unknown) => void = () => {\n throw new ExtBridgeError(\"Unexpected call of reject()\");\n };\n\n const promise = new Promise<void>((res, rej) => {\n resolve = res;\n reject = rej;\n });\n\n return [promise, resolve, reject] as const;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"controllablePromise.mjs","names":[],"sources":["../../../src/lib/controllablePromise.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\n\nexport const controllablePromise = () => {\n let resolve = (): void => {\n throw new ExtBridgeError(\"Unexpected call of resolve()\");\n };\n\n let reject: (error: unknown) => void = () => {\n throw new ExtBridgeError(\"Unexpected call of reject()\");\n };\n\n const promise = new Promise<void>((res, rej) => {\n resolve = res;\n reject = rej;\n });\n\n return [promise, resolve, reject] as const;\n};\n"],"mappings":";;AAEA,IAAa,4BAA4B;CACvC,IAAI,gBAAsB;AACxB,QAAM,IAAI,eAAe,+BAA+B;;CAG1D,IAAI,eAAyC;AAC3C,QAAM,IAAI,eAAe,8BAA8B;;AAQzD,QAAO;EALS,IAAI,SAAe,KAAK,QAAQ;AAC9C,aAAU;AACV,YAAS;IACT;EAEe;EAAS;EAAO"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "./useConfig.mjs";
|
|
@@ -1,8 +1,9 @@
|
|
|
1
|
-
import { useExtBridge } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
1
|
+
import { useExtBridge } from "./useExtBridge.mjs";
|
|
2
|
+
//#region src/react/hooks/useConfig.ts
|
|
3
|
+
var useConfig = () => {
|
|
4
|
+
return useExtBridge().config;
|
|
5
5
|
};
|
|
6
|
-
|
|
6
|
+
//#endregion
|
|
7
7
|
export { useConfig };
|
|
8
|
-
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=useConfig.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useConfig.mjs","sources":["../../../../src/react/hooks/useConfig.ts"],"sourcesContent":["import { useExtBridge } from \"@/react/hooks/useExtBridge\";\n\nexport const useConfig = () => {\n return useExtBridge().config;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"useConfig.mjs","names":[],"sources":["../../../../src/react/hooks/useConfig.ts"],"sourcesContent":["import { useExtBridge } from \"@/react/hooks/useExtBridge\";\n\nexport const useConfig = () => {\n return useExtBridge().config;\n};\n"],"mappings":";;AAEA,IAAa,kBAAkB;AAC7B,QAAO,cAAc,CAAC"}
|
|
@@ -1,9 +1,10 @@
|
|
|
1
|
-
import { getExtBridge } from
|
|
2
|
-
import { usePromise } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
1
|
+
import { getExtBridge } from "../../getExtBridge.mjs";
|
|
2
|
+
import { usePromise } from "@mittwald/react-use-promise";
|
|
3
|
+
//#region src/react/hooks/useExtBridge.ts
|
|
4
|
+
var useExtBridge = () => {
|
|
5
|
+
return usePromise(getExtBridge, []);
|
|
6
6
|
};
|
|
7
|
-
|
|
7
|
+
//#endregion
|
|
8
8
|
export { useExtBridge };
|
|
9
|
-
|
|
9
|
+
|
|
10
|
+
//# sourceMappingURL=useExtBridge.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"useExtBridge.mjs","sources":["../../../../src/react/hooks/useExtBridge.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\nimport { usePromise } from \"@mittwald/react-use-promise\";\n\nexport const useExtBridge = () => {\n return usePromise(getExtBridge, []);\n};\n"],"
|
|
1
|
+
{"version":3,"file":"useExtBridge.mjs","names":[],"sources":["../../../../src/react/hooks/useExtBridge.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\nimport { usePromise } from \"@mittwald/react-use-promise\";\n\nexport const useExtBridge = () => {\n return usePromise(getExtBridge, []);\n};\n"],"mappings":";;;AAGA,IAAa,qBAAqB;AAChC,QAAO,WAAW,cAAc,EAAE,CAAC"}
|
package/dist/js/react.mjs
CHANGED
|
@@ -1,3 +1,4 @@
|
|
|
1
|
-
import
|
|
2
|
-
|
|
3
|
-
|
|
1
|
+
import "./global-browser.mjs";
|
|
2
|
+
import { useConfig } from "./react/hooks/useConfig.mjs";
|
|
3
|
+
import "./react/hooks/index.mjs";
|
|
4
|
+
export { useConfig };
|
package/dist/js/readiness.mjs
CHANGED
|
@@ -1,30 +1,29 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import {
|
|
3
|
-
import { assertBrowserEnv } from
|
|
4
|
-
import { controllablePromise } from
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
}, timeoutMs);
|
|
15
|
-
return timoutPromise;
|
|
1
|
+
import { ExtBridgeError } from "./error.mjs";
|
|
2
|
+
import { parseConfig } from "./config/parse.mjs";
|
|
3
|
+
import { assertBrowserEnv } from "./lib/assertBrowserEnv.mjs";
|
|
4
|
+
import { controllablePromise } from "./lib/controllablePromise.mjs";
|
|
5
|
+
//#region src/readiness.ts
|
|
6
|
+
var timeoutMs = 7500;
|
|
7
|
+
var [readiness, resolveReadiness] = controllablePromise();
|
|
8
|
+
var [timoutPromise, , rejectOnTimeout] = controllablePromise();
|
|
9
|
+
var startTimeout = () => {
|
|
10
|
+
setTimeout(() => {
|
|
11
|
+
rejectOnTimeout(new ExtBridgeError(`Ext Bridge not ready after ${timeoutMs}ms`));
|
|
12
|
+
}, timeoutMs);
|
|
13
|
+
return timoutPromise;
|
|
16
14
|
};
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
15
|
+
var readinessApi = {
|
|
16
|
+
isReady: async () => {
|
|
17
|
+
assertBrowserEnv();
|
|
18
|
+
await Promise.race([readiness, startTimeout()]);
|
|
19
|
+
},
|
|
20
|
+
setIsReady: async () => {
|
|
21
|
+
const config = await mwExtBridge.connection.getConfig();
|
|
22
|
+
mwExtBridge.config = parseConfig(config);
|
|
23
|
+
resolveReadiness();
|
|
24
|
+
}
|
|
27
25
|
};
|
|
28
|
-
|
|
26
|
+
//#endregion
|
|
29
27
|
export { readinessApi };
|
|
30
|
-
|
|
28
|
+
|
|
29
|
+
//# sourceMappingURL=readiness.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"readiness.mjs","sources":["../../src/readiness.ts"],"sourcesContent":["import { parseConfig } from \"@/config/parse\";\nimport { ExtBridgeError } from \"@/error\";\nimport { assertBrowserEnv } from \"@/lib/assertBrowserEnv\";\nimport { controllablePromise } from \"@/lib/controllablePromise\";\n\nconst timeoutMs = 7500;\n\nconst [readiness, resolveReadiness] = controllablePromise();\nconst [timoutPromise, , rejectOnTimeout] = controllablePromise();\n\nconst startTimeout = () => {\n setTimeout(() => {\n rejectOnTimeout(\n new ExtBridgeError(`Ext Bridge not ready after ${timeoutMs}ms`),\n );\n }, timeoutMs);\n return timoutPromise;\n};\n\nexport const readinessApi = {\n isReady: async () => {\n assertBrowserEnv();\n await Promise.race([readiness, startTimeout()]);\n },\n setIsReady: async () => {\n const config = await mwExtBridge.connection.getConfig();\n mwExtBridge.config = parseConfig(config);\n resolveReadiness();\n },\n} as const;\n"],"
|
|
1
|
+
{"version":3,"file":"readiness.mjs","names":[],"sources":["../../src/readiness.ts"],"sourcesContent":["import { parseConfig } from \"@/config/parse\";\nimport { ExtBridgeError } from \"@/error\";\nimport { assertBrowserEnv } from \"@/lib/assertBrowserEnv\";\nimport { controllablePromise } from \"@/lib/controllablePromise\";\n\nconst timeoutMs = 7500;\n\nconst [readiness, resolveReadiness] = controllablePromise();\nconst [timoutPromise, , rejectOnTimeout] = controllablePromise();\n\nconst startTimeout = () => {\n setTimeout(() => {\n rejectOnTimeout(\n new ExtBridgeError(`Ext Bridge not ready after ${timeoutMs}ms`),\n );\n }, timeoutMs);\n return timoutPromise;\n};\n\nexport const readinessApi = {\n isReady: async () => {\n assertBrowserEnv();\n await Promise.race([readiness, startTimeout()]);\n },\n setIsReady: async () => {\n const config = await mwExtBridge.connection.getConfig();\n mwExtBridge.config = parseConfig(config);\n resolveReadiness();\n },\n} as const;\n"],"mappings":";;;;;AAKA,IAAM,YAAY;AAElB,IAAM,CAAC,WAAW,oBAAoB,qBAAqB;AAC3D,IAAM,CAAC,iBAAiB,mBAAmB,qBAAqB;AAEhE,IAAM,qBAAqB;AACzB,kBAAiB;AACf,kBACE,IAAI,eAAe,8BAA8B,UAAU,IAAI,CAChE;IACA,UAAU;AACb,QAAO;;AAGT,IAAa,eAAe;CAC1B,SAAS,YAAY;AACnB,oBAAkB;AAClB,QAAM,QAAQ,KAAK,CAAC,WAAW,cAAc,CAAC,CAAC;;CAEjD,YAAY,YAAY;EACtB,MAAM,SAAS,MAAM,YAAY,WAAW,WAAW;AACvD,cAAY,SAAS,YAAY,OAAO;AACxC,oBAAkB;;CAErB"}
|
|
@@ -1,29 +1,17 @@
|
|
|
1
|
-
import { ExtBridgeError } from
|
|
2
|
-
import { sessionTokenPayload } from
|
|
3
|
-
import { decodeJwt } from
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
nbf: ignoredNbf,
|
|
14
|
-
...rest
|
|
15
|
-
} = decodeJwt(jwt);
|
|
16
|
-
const parsed = sessionTokenPayload.safeParse({
|
|
17
|
-
userId: sub,
|
|
18
|
-
...rest
|
|
19
|
-
});
|
|
20
|
-
if (parsed.error) {
|
|
21
|
-
throw new ExtBridgeError(
|
|
22
|
-
"Session token payload invalid: " + parsed.error.message
|
|
23
|
-
);
|
|
24
|
-
}
|
|
25
|
-
return parsed.data;
|
|
1
|
+
import { ExtBridgeError } from "../error.mjs";
|
|
2
|
+
import { sessionTokenPayload } from "./schemas.mjs";
|
|
3
|
+
import { decodeJwt } from "jose";
|
|
4
|
+
//#region src/sessionToken/decode.ts
|
|
5
|
+
var decode = (jwt) => {
|
|
6
|
+
const { sub, aud: ignoredAud, exp: ignoredExp, iat: ignoredIat, iss: ignoredIss, jti: ignoredJti, nbf: ignoredNbf, ...rest } = decodeJwt(jwt);
|
|
7
|
+
const parsed = sessionTokenPayload.safeParse({
|
|
8
|
+
userId: sub,
|
|
9
|
+
...rest
|
|
10
|
+
});
|
|
11
|
+
if (parsed.error) throw new ExtBridgeError("Session token payload invalid: " + parsed.error.message);
|
|
12
|
+
return parsed.data;
|
|
26
13
|
};
|
|
27
|
-
|
|
14
|
+
//#endregion
|
|
28
15
|
export { decode };
|
|
29
|
-
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=decode.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"decode.mjs","sources":["../../../src/sessionToken/decode.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\nimport { sessionTokenPayload } from \"@/sessionToken/schemas\";\nimport type { SessionTokenPayload } from \"@/sessionToken/types\";\nimport { decodeJwt } from \"jose\";\n\ntype JwtPayloadType = Omit<SessionTokenPayload, \"userId\">;\n\nexport const decode = (jwt: string) => {\n const {\n sub,\n aud: ignoredAud,\n exp: ignoredExp,\n iat: ignoredIat,\n iss: ignoredIss,\n jti: ignoredJti,\n nbf: ignoredNbf,\n ...rest\n } = decodeJwt<JwtPayloadType>(jwt);\n\n const parsed = sessionTokenPayload.safeParse({\n userId: sub,\n ...rest,\n });\n\n if (parsed.error) {\n throw new ExtBridgeError(\n \"Session token payload invalid: \" + parsed.error.message,\n );\n }\n\n return parsed.data;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"decode.mjs","names":[],"sources":["../../../src/sessionToken/decode.ts"],"sourcesContent":["import { ExtBridgeError } from \"@/error\";\nimport { sessionTokenPayload } from \"@/sessionToken/schemas\";\nimport type { SessionTokenPayload } from \"@/sessionToken/types\";\nimport { decodeJwt } from \"jose\";\n\ntype JwtPayloadType = Omit<SessionTokenPayload, \"userId\">;\n\nexport const decode = (jwt: string) => {\n const {\n sub,\n aud: ignoredAud,\n exp: ignoredExp,\n iat: ignoredIat,\n iss: ignoredIss,\n jti: ignoredJti,\n nbf: ignoredNbf,\n ...rest\n } = decodeJwt<JwtPayloadType>(jwt);\n\n const parsed = sessionTokenPayload.safeParse({\n userId: sub,\n ...rest,\n });\n\n if (parsed.error) {\n throw new ExtBridgeError(\n \"Session token payload invalid: \" + parsed.error.message,\n );\n }\n\n return parsed.data;\n};\n"],"mappings":";;;;AAOA,IAAa,UAAU,QAAgB;CACrC,MAAM,EACJ,KACA,KAAK,YACL,KAAK,YACL,KAAK,YACL,KAAK,YACL,KAAK,YACL,KAAK,YACL,GAAG,SACD,UAA0B,IAAI;CAElC,MAAM,SAAS,oBAAoB,UAAU;EAC3C,QAAQ;EACR,GAAG;EACJ,CAAC;AAEF,KAAI,OAAO,MACT,OAAM,IAAI,eACR,oCAAoC,OAAO,MAAM,QAClD;AAGH,QAAO,OAAO"}
|
|
@@ -1,15 +1,18 @@
|
|
|
1
|
-
import { MW_EXT_API_URL } from
|
|
2
|
-
import axios from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
1
|
+
import { MW_EXT_API_URL } from "../environment.mjs";
|
|
2
|
+
import axios from "axios";
|
|
3
|
+
//#region src/sessionToken/getAccessToken.ts
|
|
4
|
+
var getAccessToken = async (sessionToken, extensionSecret) => {
|
|
5
|
+
return (await axios({
|
|
6
|
+
url: `${MW_EXT_API_URL}/v2/authenticate-session-token`,
|
|
7
|
+
data: {
|
|
8
|
+
sessionToken,
|
|
9
|
+
extensionSecret
|
|
10
|
+
},
|
|
11
|
+
validateStatus: (status) => status === 201,
|
|
12
|
+
method: "POST"
|
|
13
|
+
})).data;
|
|
12
14
|
};
|
|
13
|
-
|
|
15
|
+
//#endregion
|
|
14
16
|
export { getAccessToken };
|
|
15
|
-
|
|
17
|
+
|
|
18
|
+
//# sourceMappingURL=getAccessToken.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getAccessToken.mjs","sources":["../../../src/sessionToken/getAccessToken.ts"],"sourcesContent":["import { MW_EXT_API_URL } from \"@/environment\";\nimport axios from \"axios\";\n\ninterface ApiResponse {\n expiry: string;\n publicToken: string;\n}\n\nexport const getAccessToken = async (\n sessionToken: string,\n extensionSecret: string,\n) => {\n const response = await axios<ApiResponse>({\n url: `${MW_EXT_API_URL}/v2/authenticate-session-token`,\n data: { sessionToken, extensionSecret },\n validateStatus: (status) => status === 201,\n method: \"POST\",\n });\n return response.data;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"getAccessToken.mjs","names":[],"sources":["../../../src/sessionToken/getAccessToken.ts"],"sourcesContent":["import { MW_EXT_API_URL } from \"@/environment\";\nimport axios from \"axios\";\n\ninterface ApiResponse {\n expiry: string;\n publicToken: string;\n}\n\nexport const getAccessToken = async (\n sessionToken: string,\n extensionSecret: string,\n) => {\n const response = await axios<ApiResponse>({\n url: `${MW_EXT_API_URL}/v2/authenticate-session-token`,\n data: { sessionToken, extensionSecret },\n validateStatus: (status) => status === 201,\n method: \"POST\",\n });\n return response.data;\n};\n"],"mappings":";;;AAQA,IAAa,iBAAiB,OAC5B,cACA,oBACG;AAOH,SANiB,MAAM,MAAmB;EACxC,KAAK,GAAG,eAAe;EACvB,MAAM;GAAE;GAAc;GAAiB;EACvC,iBAAiB,WAAW,WAAW;EACvC,QAAQ;EACT,CAAC,EACc"}
|
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { getExtBridge } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
return bridge.connection.getSessionToken();
|
|
1
|
+
import { getExtBridge } from "../getExtBridge.mjs";
|
|
2
|
+
//#region src/sessionToken/getSessionToken.ts
|
|
3
|
+
var getSessionToken = async () => {
|
|
4
|
+
return (await getExtBridge()).connection.getSessionToken();
|
|
6
5
|
};
|
|
7
|
-
|
|
6
|
+
//#endregion
|
|
8
7
|
export { getSessionToken };
|
|
9
|
-
|
|
8
|
+
|
|
9
|
+
//# sourceMappingURL=getSessionToken.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"getSessionToken.mjs","sources":["../../../src/sessionToken/getSessionToken.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\n\nexport const getSessionToken = async () => {\n const bridge = await getExtBridge();\n return bridge.connection.getSessionToken();\n};\n"],"
|
|
1
|
+
{"version":3,"file":"getSessionToken.mjs","names":[],"sources":["../../../src/sessionToken/getSessionToken.ts"],"sourcesContent":["import { getExtBridge } from \"@/getExtBridge\";\n\nexport const getSessionToken = async () => {\n const bridge = await getExtBridge();\n return bridge.connection.getSessionToken();\n};\n"],"mappings":";;AAEA,IAAa,kBAAkB,YAAY;AAEzC,SADe,MAAM,cAAc,EACrB,WAAW,iBAAiB"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
|
-
import { MW_EXT_API_URL } from
|
|
2
|
-
import axios from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
return response.data.key;
|
|
1
|
+
import { MW_EXT_API_URL } from "../../environment.mjs";
|
|
2
|
+
import axios from "axios";
|
|
3
|
+
//#region src/sessionToken/publicKeys/fetchPublicKey.ts
|
|
4
|
+
var fetchPublicKey = async (serial) => {
|
|
5
|
+
return (await axios({
|
|
6
|
+
url: `${MW_EXT_API_URL}/v2/public-keys/${serial}`,
|
|
7
|
+
validateStatus: (status) => status === 200,
|
|
8
|
+
params: {
|
|
9
|
+
format: "spki",
|
|
10
|
+
purpose: "session_token"
|
|
11
|
+
}
|
|
12
|
+
})).data.key;
|
|
14
13
|
};
|
|
15
|
-
|
|
14
|
+
//#endregion
|
|
16
15
|
export { fetchPublicKey };
|
|
17
|
-
|
|
16
|
+
|
|
17
|
+
//# sourceMappingURL=fetchPublicKey.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"fetchPublicKey.mjs","sources":["../../../../src/sessionToken/publicKeys/fetchPublicKey.ts"],"sourcesContent":["import { MW_EXT_API_URL } from \"@/environment\";\nimport axios from \"axios\";\n\ninterface ApiResponse {\n algorithm: string;\n key: string;\n serial: string;\n}\n\nexport const fetchPublicKey = async (serial: string) => {\n const response = await axios<ApiResponse>({\n url: `${MW_EXT_API_URL}/v2/public-keys/${serial}`,\n validateStatus: (status) => status === 200,\n params: {\n format: \"spki\",\n purpose: \"session_token\",\n },\n });\n return response.data.key;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"fetchPublicKey.mjs","names":[],"sources":["../../../../src/sessionToken/publicKeys/fetchPublicKey.ts"],"sourcesContent":["import { MW_EXT_API_URL } from \"@/environment\";\nimport axios from \"axios\";\n\ninterface ApiResponse {\n algorithm: string;\n key: string;\n serial: string;\n}\n\nexport const fetchPublicKey = async (serial: string) => {\n const response = await axios<ApiResponse>({\n url: `${MW_EXT_API_URL}/v2/public-keys/${serial}`,\n validateStatus: (status) => status === 200,\n params: {\n format: \"spki\",\n purpose: \"session_token\",\n },\n });\n return response.data.key;\n};\n"],"mappings":";;;AASA,IAAa,iBAAiB,OAAO,WAAmB;AAStD,SARiB,MAAM,MAAmB;EACxC,KAAK,GAAG,eAAe,kBAAkB;EACzC,iBAAiB,WAAW,WAAW;EACvC,QAAQ;GACN,QAAQ;GACR,SAAS;GACV;EACF,CAAC,EACc,KAAK"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
import "./publicKeys.mjs";
|
|
@@ -1,17 +1,15 @@
|
|
|
1
|
-
import { fetchPublicKey } from
|
|
2
|
-
import { importSPKI } from
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
const cryptoKey = await importSPKI(publicKeyFromApi, "Ed25519");
|
|
12
|
-
cache.set(serial, cryptoKey);
|
|
13
|
-
return cryptoKey;
|
|
1
|
+
import { fetchPublicKey } from "./fetchPublicKey.mjs";
|
|
2
|
+
import { importSPKI } from "jose";
|
|
3
|
+
//#region src/sessionToken/publicKeys/publicKeys.ts
|
|
4
|
+
var cache = /* @__PURE__ */ new Map();
|
|
5
|
+
var getPublicKey = async (serial) => {
|
|
6
|
+
const cached = cache.get(serial);
|
|
7
|
+
if (cached) return cached;
|
|
8
|
+
const cryptoKey = await importSPKI(await fetchPublicKey(serial), "Ed25519");
|
|
9
|
+
cache.set(serial, cryptoKey);
|
|
10
|
+
return cryptoKey;
|
|
14
11
|
};
|
|
15
|
-
|
|
12
|
+
//#endregion
|
|
16
13
|
export { getPublicKey };
|
|
17
|
-
|
|
14
|
+
|
|
15
|
+
//# sourceMappingURL=publicKeys.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"publicKeys.mjs","sources":["../../../../src/sessionToken/publicKeys/publicKeys.ts"],"sourcesContent":["import { fetchPublicKey } from \"@/sessionToken/publicKeys/fetchPublicKey\";\nimport { importSPKI } from \"jose\";\n\nconst cache = new Map<string, CryptoKey>();\n\nexport const getPublicKey = async (serial: string): Promise<CryptoKey> => {\n const cached = cache.get(serial);\n if (cached) {\n return cached;\n }\n\n const publicKeyFromApi = await fetchPublicKey(serial);\n const cryptoKey = await importSPKI(publicKeyFromApi, \"Ed25519\");\n\n cache.set(serial, cryptoKey);\n return cryptoKey;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"publicKeys.mjs","names":[],"sources":["../../../../src/sessionToken/publicKeys/publicKeys.ts"],"sourcesContent":["import { fetchPublicKey } from \"@/sessionToken/publicKeys/fetchPublicKey\";\nimport { importSPKI } from \"jose\";\n\nconst cache = new Map<string, CryptoKey>();\n\nexport const getPublicKey = async (serial: string): Promise<CryptoKey> => {\n const cached = cache.get(serial);\n if (cached) {\n return cached;\n }\n\n const publicKeyFromApi = await fetchPublicKey(serial);\n const cryptoKey = await importSPKI(publicKeyFromApi, \"Ed25519\");\n\n cache.set(serial, cryptoKey);\n return cryptoKey;\n};\n"],"mappings":";;;AAGA,IAAM,wBAAQ,IAAI,KAAwB;AAE1C,IAAa,eAAe,OAAO,WAAuC;CACxE,MAAM,SAAS,MAAM,IAAI,OAAO;AAChC,KAAI,OACF,QAAO;CAIT,MAAM,YAAY,MAAM,WADC,MAAM,eAAe,OAAO,EACA,UAAU;AAE/D,OAAM,IAAI,QAAQ,UAAU;AAC5B,QAAO"}
|
|
@@ -1,19 +1,20 @@
|
|
|
1
|
-
import { z } from
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
1
|
+
import { z } from "zod";
|
|
2
|
+
//#region src/sessionToken/schemas.ts
|
|
3
|
+
var extensionScopes = z.string().array();
|
|
4
|
+
var extensionContext = z.enum(["project", "customer"]);
|
|
5
|
+
var sessionTokenPayload = z.object({
|
|
6
|
+
sessionId: z.string(),
|
|
7
|
+
userId: z.string(),
|
|
8
|
+
extensionId: z.string(),
|
|
9
|
+
extensionInstanceId: z.string(),
|
|
10
|
+
contextId: z.string(),
|
|
11
|
+
context: extensionContext,
|
|
12
|
+
scopes: extensionScopes,
|
|
13
|
+
authenticatableWithoutSecret: z.boolean(),
|
|
14
|
+
publicKeySerial: z.string(),
|
|
15
|
+
variantKey: z.string().optional().nullable()
|
|
16
16
|
});
|
|
17
|
+
//#endregion
|
|
18
|
+
export { sessionTokenPayload };
|
|
17
19
|
|
|
18
|
-
|
|
19
|
-
//# sourceMappingURL=schemas.mjs.map
|
|
20
|
+
//# sourceMappingURL=schemas.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"schemas.mjs","sources":["../../../src/sessionToken/schemas.ts"],"sourcesContent":["import { z } from \"zod\";\n\nexport const extensionScopes = z.string().array();\nexport const extensionContext = z.enum([\"project\", \"customer\"]);\n\nexport const sessionTokenPayload = z.object({\n sessionId: z.string(),\n userId: z.string(),\n extensionId: z.string(),\n extensionInstanceId: z.string(),\n contextId: z.string(),\n context: extensionContext,\n scopes: extensionScopes,\n authenticatableWithoutSecret: z.boolean(),\n publicKeySerial: z.string(),\n variantKey: z.string().optional().nullable(),\n});\n"],"
|
|
1
|
+
{"version":3,"file":"schemas.mjs","names":[],"sources":["../../../src/sessionToken/schemas.ts"],"sourcesContent":["import { z } from \"zod\";\n\nexport const extensionScopes = z.string().array();\nexport const extensionContext = z.enum([\"project\", \"customer\"]);\n\nexport const sessionTokenPayload = z.object({\n sessionId: z.string(),\n userId: z.string(),\n extensionId: z.string(),\n extensionInstanceId: z.string(),\n contextId: z.string(),\n context: extensionContext,\n scopes: extensionScopes,\n authenticatableWithoutSecret: z.boolean(),\n publicKeySerial: z.string(),\n variantKey: z.string().optional().nullable(),\n});\n"],"mappings":";;AAEA,IAAa,kBAAkB,EAAE,QAAQ,CAAC,OAAO;AACjD,IAAa,mBAAmB,EAAE,KAAK,CAAC,WAAW,WAAW,CAAC;AAE/D,IAAa,sBAAsB,EAAE,OAAO;CAC1C,WAAW,EAAE,QAAQ;CACrB,QAAQ,EAAE,QAAQ;CAClB,aAAa,EAAE,QAAQ;CACvB,qBAAqB,EAAE,QAAQ;CAC/B,WAAW,EAAE,QAAQ;CACrB,SAAS;CACT,QAAQ;CACR,8BAA8B,EAAE,SAAS;CACzC,iBAAiB,EAAE,QAAQ;CAC3B,YAAY,EAAE,QAAQ,CAAC,UAAU,CAAC,UAAU;CAC7C,CAAC"}
|
|
@@ -1,13 +1,14 @@
|
|
|
1
|
-
import { decode } from
|
|
2
|
-
import { getPublicKey } from
|
|
3
|
-
import
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
1
|
+
import { decode } from "./decode.mjs";
|
|
2
|
+
import { getPublicKey } from "./publicKeys/publicKeys.mjs";
|
|
3
|
+
import "./publicKeys/index.mjs";
|
|
4
|
+
import { jwtVerify } from "jose";
|
|
5
|
+
//#region src/sessionToken/verify.ts
|
|
6
|
+
var verify = async (sessionToken) => {
|
|
7
|
+
const decoded = decode(sessionToken);
|
|
8
|
+
await jwtVerify(sessionToken, await getPublicKey(decoded.publicKeySerial));
|
|
9
|
+
return decoded;
|
|
10
10
|
};
|
|
11
|
-
|
|
11
|
+
//#endregion
|
|
12
12
|
export { verify };
|
|
13
|
-
|
|
13
|
+
|
|
14
|
+
//# sourceMappingURL=verify.mjs.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"verify.mjs","sources":["../../../src/sessionToken/verify.ts"],"sourcesContent":["import { decode } from \"@/sessionToken/decode\";\nimport { getPublicKey } from \"@/sessionToken/publicKeys\";\nimport { jwtVerify } from \"jose\";\n\nexport const verify = async (sessionToken: string) => {\n const decoded = decode(sessionToken);\n const publicKey = await getPublicKey(decoded.publicKeySerial);\n await jwtVerify(sessionToken, publicKey);\n return decoded;\n};\n"],"
|
|
1
|
+
{"version":3,"file":"verify.mjs","names":[],"sources":["../../../src/sessionToken/verify.ts"],"sourcesContent":["import { decode } from \"@/sessionToken/decode\";\nimport { getPublicKey } from \"@/sessionToken/publicKeys\";\nimport { jwtVerify } from \"jose\";\n\nexport const verify = async (sessionToken: string) => {\n const decoded = decode(sessionToken);\n const publicKey = await getPublicKey(decoded.publicKeySerial);\n await jwtVerify(sessionToken, publicKey);\n return decoded;\n};\n"],"mappings":";;;;;AAIA,IAAa,SAAS,OAAO,iBAAyB;CACpD,MAAM,UAAU,OAAO,aAAa;AAEpC,OAAM,UAAU,cADE,MAAM,aAAa,QAAQ,gBAAgB,CACrB;AACxC,QAAO"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@mittwald/ext-bridge",
|
|
3
|
-
"version": "0.2.0-alpha.
|
|
3
|
+
"version": "0.2.0-alpha.782",
|
|
4
4
|
"type": "module",
|
|
5
5
|
"description": "Bridge for mStudio embedded frontend extensions",
|
|
6
6
|
"homepage": "https://mittwald.github.io/flow",
|
|
@@ -52,11 +52,11 @@
|
|
|
52
52
|
"rimraf": "^6.1.2",
|
|
53
53
|
"rollup-preserve-directives": "^1.1.3",
|
|
54
54
|
"typescript": "^5.9.3",
|
|
55
|
-
"vite": "^
|
|
55
|
+
"vite": "^8.0.8",
|
|
56
56
|
"vite-plugin-checker": "^0.12.0",
|
|
57
57
|
"vite-plugin-dts": "^4.5.4",
|
|
58
58
|
"vite-plugin-externalize-deps": "^0.10.0",
|
|
59
|
-
"vitest": "^4.
|
|
59
|
+
"vitest": "^4.1.3"
|
|
60
60
|
},
|
|
61
61
|
"peerDependencies": {
|
|
62
62
|
"react": "^19.2.0",
|
|
@@ -70,5 +70,5 @@
|
|
|
70
70
|
"optional": true
|
|
71
71
|
}
|
|
72
72
|
},
|
|
73
|
-
"gitHead": "
|
|
73
|
+
"gitHead": "064502040a73940325804ff924f88c5f618fb15b"
|
|
74
74
|
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-browser.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;"}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index-node.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
package/dist/js/index.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":""}
|
package/dist/js/react.mjs.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"react.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|