@dxos/rpc-tunnel 0.8.4-main.a4bbb77 → 0.8.4-main.ae835ea
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/lib/browser/index.mjs +13 -28
- package/dist/lib/browser/index.mjs.map +3 -3
- package/dist/lib/browser/meta.json +1 -1
- package/dist/lib/node-esm/index.mjs +13 -28
- package/dist/lib/node-esm/index.mjs.map +3 -3
- package/dist/lib/node-esm/meta.json +1 -1
- package/dist/types/tsconfig.tsbuildinfo +1 -1
- package/package.json +3 -3
- package/src/ports/iframe.ts +1 -1
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
// src/ports/iframe.ts
|
|
2
|
-
import
|
|
2
|
+
import UAParser from "ua-parser-js";
|
|
3
3
|
import { log } from "@dxos/log";
|
|
4
4
|
var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/rpc-tunnel/src/ports/iframe.ts";
|
|
5
5
|
var browser;
|
|
@@ -152,21 +152,20 @@ var createWorkerPort = ({ port, channel, subscribe }) => ({
|
|
|
152
152
|
|
|
153
153
|
// src/port-muxer.ts
|
|
154
154
|
import { log as log3 } from "@dxos/log";
|
|
155
|
-
function _define_property(obj, key, value) {
|
|
156
|
-
if (key in obj) {
|
|
157
|
-
Object.defineProperty(obj, key, {
|
|
158
|
-
value,
|
|
159
|
-
enumerable: true,
|
|
160
|
-
configurable: true,
|
|
161
|
-
writable: true
|
|
162
|
-
});
|
|
163
|
-
} else {
|
|
164
|
-
obj[key] = value;
|
|
165
|
-
}
|
|
166
|
-
return obj;
|
|
167
|
-
}
|
|
168
155
|
var __dxlog_file3 = "/__w/dxos/dxos/packages/core/mesh/rpc-tunnel/src/port-muxer.ts";
|
|
169
156
|
var PortMuxer = class {
|
|
157
|
+
_messagePort;
|
|
158
|
+
_activeChannels = /* @__PURE__ */ new Map();
|
|
159
|
+
_rpcPorts = /* @__PURE__ */ new Map();
|
|
160
|
+
constructor(_messagePort) {
|
|
161
|
+
this._messagePort = _messagePort;
|
|
162
|
+
if (this._messagePort) {
|
|
163
|
+
this._messagePort.onmessage = (event) => this.onWorkerMessage(event);
|
|
164
|
+
}
|
|
165
|
+
if (typeof window !== "undefined") {
|
|
166
|
+
window.addEventListener("message", (event) => this.onWindowMessage(event));
|
|
167
|
+
}
|
|
168
|
+
}
|
|
170
169
|
createWorkerPort(options) {
|
|
171
170
|
if (!this._messagePort) {
|
|
172
171
|
throw new Error("Message port is required to create worker ports");
|
|
@@ -213,20 +212,6 @@ var PortMuxer = class {
|
|
|
213
212
|
C: (f, a) => f(...a)
|
|
214
213
|
});
|
|
215
214
|
}
|
|
216
|
-
constructor(_messagePort) {
|
|
217
|
-
_define_property(this, "_messagePort", void 0);
|
|
218
|
-
_define_property(this, "_activeChannels", void 0);
|
|
219
|
-
_define_property(this, "_rpcPorts", void 0);
|
|
220
|
-
this._messagePort = _messagePort;
|
|
221
|
-
this._activeChannels = /* @__PURE__ */ new Map();
|
|
222
|
-
this._rpcPorts = /* @__PURE__ */ new Map();
|
|
223
|
-
if (this._messagePort) {
|
|
224
|
-
this._messagePort.onmessage = (event) => this.onWorkerMessage(event);
|
|
225
|
-
}
|
|
226
|
-
if (typeof window !== "undefined") {
|
|
227
|
-
window.addEventListener("message", (event) => this.onWindowMessage(event));
|
|
228
|
-
}
|
|
229
|
-
}
|
|
230
215
|
};
|
|
231
216
|
export {
|
|
232
217
|
PortMuxer,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/ports/iframe.ts", "../../../src/ports/worker.ts", "../../../src/port-muxer.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport
|
|
5
|
-
"mappings": ";AAIA,
|
|
6
|
-
"names": ["UAParser", "log", "browser", "os", "navigator", "parser", "userAgent", "getBrowser", "name", "getOS", "sendToIFrame", "iframe", "origin", "message", "contentWindow", "postMessage", "payload", "sendToParentWindow", "window", "parent", "createIFramePort", "channel", "onOrigin", "send", "data", "length", "buffer", "slice", "byteOffset", "byteLength", "subscribe", "callback", "handler", "event", "source", "isMessageData", "undefined", "Uint8Array", "addEventListener", "removeEventListener", "createIFrame", "id", "hidden", "allow", "create", "document", "createElement", "src", "setAttribute", "body", "appendChild", "getElementById", "log", "createWorkerPort", "port", "channel", "subscribe", "send", "message", "payload", "buffer", "slice", "byteOffset", "byteLength", "postMessage", "callback", "handler", "event", "data", "debug", "Uint8Array", "onmessage", "log", "PortMuxer", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport UAParser from 'ua-parser-js';\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from '../message';\n\nlet browser: string | undefined;\nlet os: string | undefined;\n\nif (typeof navigator !== 'undefined') {\n // TODO(wittjosiah): Stop user agent parsing.\n const parser = new UAParser(navigator.userAgent);\n browser = parser.getBrowser().name;\n os = parser.getOS().name;\n}\n\nconst sendToIFrame = (iframe: HTMLIFrameElement, origin: string, message: MessageData) => {\n if (!iframe.contentWindow) {\n log('IFrame content window missing', { origin });\n return;\n }\n\n if (browser === 'Chrome' && os === 'iOS') {\n iframe.contentWindow.postMessage(message, origin);\n } else {\n iframe.contentWindow.postMessage(message, origin, [message.payload]);\n }\n};\n\nconst sendToParentWindow = (origin: string, message: MessageData) => {\n if (browser === 'Chrome' && os === 'iOS') {\n window.parent.postMessage(message, origin);\n } else {\n window.parent.postMessage(message, origin, [message.payload]);\n }\n};\n\nexport type IFramePortOptions = {\n channel: string;\n iframe?: HTMLIFrameElement;\n origin?: string;\n onOrigin?: (origin: string) => void;\n};\n\n/**\n * Create a RPC port with an iframe over window messaging.\n * @param options.channel Identifier for sent/recieved messages.\n * @param options.iframe Instance of the iframe if sending to child.\n * @param options.origin Origin of the destination window.\n * @param options.onOrigin Callback triggered when origin of destination window is verified.\n * @returns RPC port for messaging.\n */\nexport const createIFramePort = ({ channel, iframe, origin, onOrigin }: IFramePortOptions): RpcPort => {\n return {\n send: async (data) => {\n if (!origin) {\n log('no origin set', { channel });\n return;\n }\n\n log('sending', { channel, data: data.length });\n const payload = data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);\n const message = { channel, payload };\n if (iframe) {\n sendToIFrame(iframe, origin, message);\n } else {\n sendToParentWindow(origin, message);\n }\n },\n\n subscribe: (callback) => {\n const handler = (event: MessageEvent<unknown>) => {\n if (!iframe && event.source !== window.parent) {\n // Not from parent window.\n return;\n } else if (iframe && event.source !== iframe.contentWindow) {\n // Not from child window.\n return;\n }\n\n const isMessageData =\n event.data && typeof event.data === 'object' && 'channel' in event.data && 'payload' in event.data;\n const message = isMessageData ? (event.data as MessageData) : undefined;\n if (message?.channel !== channel) {\n return;\n }\n\n if (!origin) {\n origin = event.origin;\n onOrigin?.(origin);\n }\n\n log('received', message);\n callback(new Uint8Array(message.payload));\n };\n\n window.addEventListener('message', handler);\n return () => window.removeEventListener('message', handler);\n },\n };\n};\n\nexport type CreateIFrameOptions = {\n hidden?: boolean;\n allow?: string;\n};\n\n/**\n * Create a hidden iframe and insert it into the DOM.\n * If an element with the same id already exists it will be returned instead.\n * @param source Source of the iframe.\n * @param id DOM id of the iframe.\n * @returns The created iframe.\n */\nexport const createIFrame = (source: string, id: string, { hidden = true, allow }: CreateIFrameOptions = {}) => {\n const create = () => {\n const iframe = document.createElement('iframe') as HTMLIFrameElement;\n iframe.id = id;\n iframe.src = source;\n hidden && iframe.setAttribute('style', 'display: none;');\n allow && iframe.setAttribute('allow', allow);\n document.body.appendChild(iframe);\n return iframe;\n };\n\n return (document.getElementById(id) as HTMLIFrameElement) ?? create();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from '../message';\n\nexport type WorkerPortOptions = {\n port: MessagePort;\n channel?: string;\n subscribe?: RpcPort['subscribe'];\n};\n\n/**\n * Create a RPC port for a worker.\n * @param options.port Message port to send message on.\n * @param options.channel Identifier for sent/recieved messages.\n * @param options.subscribe\n * @returns RPC port for messaging.\n */\n// TODO(wittjosiah): Rename for more general purpose MessagePort.\nexport const createWorkerPort = ({ port, channel, subscribe }: WorkerPortOptions): RpcPort => ({\n send: async (message) => {\n // Based on https://stackoverflow.com/a/54646864/2804332.\n const payload = message.buffer.slice(message.byteOffset, message.byteOffset + message.byteLength);\n port.postMessage(\n {\n channel,\n payload,\n },\n [payload],\n );\n },\n\n subscribe:\n subscribe ??\n ((callback) => {\n const handler = (event: MessageEvent<MessageData>) => {\n const message = event.data;\n if (channel && message.channel !== channel) {\n return;\n }\n\n log.debug('received', { message });\n callback(new Uint8Array(message.payload));\n };\n\n port.onmessage = handler;\n return () => {\n port.onmessage = null;\n };\n }),\n});\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from './message';\nimport { type IFramePortOptions, type WorkerPortOptions, createIFramePort, createWorkerPort } from './ports';\n\n/**\n * Facilitates the multiplexing of multiple RpcPorts over a single MessagePort.\n */\nexport class PortMuxer {\n private readonly _activeChannels = new Map<string, (msg: Uint8Array) => void>();\n\n private readonly _rpcPorts = new Map<string, RpcPort>();\n\n constructor(private readonly _messagePort?: MessagePort) {\n if (this._messagePort) {\n this._messagePort.onmessage = (event) => this.onWorkerMessage(event);\n }\n\n if (typeof window !== 'undefined') {\n window.addEventListener('message', (event) => this.onWindowMessage(event));\n }\n }\n\n createWorkerPort(options: Omit<WorkerPortOptions, 'port' | 'subscribe' | 'channel'> & { channel: string }): RpcPort {\n if (!this._messagePort) {\n throw new Error('Message port is required to create worker ports');\n }\n\n const port = createWorkerPort({\n ...options,\n port: this._messagePort,\n subscribe: (callback) => {\n this._activeChannels.set(options.channel, callback);\n return () => this._activeChannels.delete(options.channel);\n },\n });\n this._rpcPorts.set(options.channel, port);\n\n return port;\n }\n\n createIFramePort(options: IFramePortOptions): RpcPort {\n const port = createIFramePort(options);\n this._rpcPorts.set(options.channel, port);\n\n return port;\n }\n\n private onWorkerMessage(event: MessageEvent<MessageData>): void {\n const message = event.data;\n log.debug('Recieved message from worker port', {\n channel: message.channel,\n payload: message.payload,\n });\n\n const callback = this._activeChannels.get(message.channel);\n callback?.(new Uint8Array(message.payload));\n }\n\n private onWindowMessage(event: MessageEvent<MessageData>): void {\n const message = event.data;\n log.debug('Recieved message from window', {\n channel: message.channel,\n payload: message.payload,\n });\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["UAParser", "log", "browser", "os", "navigator", "parser", "userAgent", "getBrowser", "name", "getOS", "sendToIFrame", "iframe", "origin", "message", "contentWindow", "postMessage", "payload", "sendToParentWindow", "window", "parent", "createIFramePort", "channel", "onOrigin", "send", "data", "length", "buffer", "slice", "byteOffset", "byteLength", "subscribe", "callback", "handler", "event", "source", "isMessageData", "undefined", "Uint8Array", "addEventListener", "removeEventListener", "createIFrame", "id", "hidden", "allow", "create", "document", "createElement", "src", "setAttribute", "body", "appendChild", "getElementById", "log", "createWorkerPort", "port", "channel", "subscribe", "send", "message", "payload", "buffer", "slice", "byteOffset", "byteLength", "postMessage", "callback", "handler", "event", "data", "debug", "Uint8Array", "onmessage", "log", "PortMuxer", "_activeChannels", "Map", "_rpcPorts", "_messagePort", "onmessage", "event", "onWorkerMessage", "window", "addEventListener", "onWindowMessage", "createWorkerPort", "options", "Error", "port", "subscribe", "callback", "set", "channel", "delete", "createIFramePort", "message", "data", "log", "debug", "payload", "get", "Uint8Array"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/ports/iframe.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/ports/iframe.ts":{"bytes":13967,"imports":[{"path":"ua-parser-js","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"src/ports/worker.ts":{"bytes":4832,"imports":[{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"src/ports/index.ts":{"bytes":542,"imports":[{"path":"src/ports/iframe.ts","kind":"import-statement","original":"./iframe"},{"path":"src/ports/worker.ts","kind":"import-statement","original":"./worker"}],"format":"esm"},"src/port-muxer.ts":{"bytes":7534,"imports":[{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"src/ports/index.ts","kind":"import-statement","original":"./ports"}],"format":"esm"},"src/index.ts":{"bytes":587,"imports":[{"path":"src/ports/index.ts","kind":"import-statement","original":"./ports"},{"path":"src/port-muxer.ts","kind":"import-statement","original":"./port-muxer"}],"format":"esm"}},"outputs":{"dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":12793},"dist/lib/browser/index.mjs":{"imports":[{"path":"ua-parser-js","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"exports":["PortMuxer","createIFrame","createIFramePort","createWorkerPort"],"entryPoint":"src/index.ts","inputs":{"src/ports/iframe.ts":{"bytesInOutput":3182},"src/ports/index.ts":{"bytesInOutput":0},"src/ports/worker.ts":{"bytesInOutput":902},"src/index.ts":{"bytesInOutput":0},"src/port-muxer.ts":{"bytesInOutput":1842}},"bytes":6110}}}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import { createRequire } from 'node:module';const require = createRequire(import.meta.url);
|
|
2
2
|
|
|
3
3
|
// src/ports/iframe.ts
|
|
4
|
-
import
|
|
4
|
+
import UAParser from "ua-parser-js";
|
|
5
5
|
import { log } from "@dxos/log";
|
|
6
6
|
var __dxlog_file = "/__w/dxos/dxos/packages/core/mesh/rpc-tunnel/src/ports/iframe.ts";
|
|
7
7
|
var browser;
|
|
@@ -154,21 +154,20 @@ var createWorkerPort = ({ port, channel, subscribe }) => ({
|
|
|
154
154
|
|
|
155
155
|
// src/port-muxer.ts
|
|
156
156
|
import { log as log3 } from "@dxos/log";
|
|
157
|
-
function _define_property(obj, key, value) {
|
|
158
|
-
if (key in obj) {
|
|
159
|
-
Object.defineProperty(obj, key, {
|
|
160
|
-
value,
|
|
161
|
-
enumerable: true,
|
|
162
|
-
configurable: true,
|
|
163
|
-
writable: true
|
|
164
|
-
});
|
|
165
|
-
} else {
|
|
166
|
-
obj[key] = value;
|
|
167
|
-
}
|
|
168
|
-
return obj;
|
|
169
|
-
}
|
|
170
157
|
var __dxlog_file3 = "/__w/dxos/dxos/packages/core/mesh/rpc-tunnel/src/port-muxer.ts";
|
|
171
158
|
var PortMuxer = class {
|
|
159
|
+
_messagePort;
|
|
160
|
+
_activeChannels = /* @__PURE__ */ new Map();
|
|
161
|
+
_rpcPorts = /* @__PURE__ */ new Map();
|
|
162
|
+
constructor(_messagePort) {
|
|
163
|
+
this._messagePort = _messagePort;
|
|
164
|
+
if (this._messagePort) {
|
|
165
|
+
this._messagePort.onmessage = (event) => this.onWorkerMessage(event);
|
|
166
|
+
}
|
|
167
|
+
if (typeof window !== "undefined") {
|
|
168
|
+
window.addEventListener("message", (event) => this.onWindowMessage(event));
|
|
169
|
+
}
|
|
170
|
+
}
|
|
172
171
|
createWorkerPort(options) {
|
|
173
172
|
if (!this._messagePort) {
|
|
174
173
|
throw new Error("Message port is required to create worker ports");
|
|
@@ -215,20 +214,6 @@ var PortMuxer = class {
|
|
|
215
214
|
C: (f, a) => f(...a)
|
|
216
215
|
});
|
|
217
216
|
}
|
|
218
|
-
constructor(_messagePort) {
|
|
219
|
-
_define_property(this, "_messagePort", void 0);
|
|
220
|
-
_define_property(this, "_activeChannels", void 0);
|
|
221
|
-
_define_property(this, "_rpcPorts", void 0);
|
|
222
|
-
this._messagePort = _messagePort;
|
|
223
|
-
this._activeChannels = /* @__PURE__ */ new Map();
|
|
224
|
-
this._rpcPorts = /* @__PURE__ */ new Map();
|
|
225
|
-
if (this._messagePort) {
|
|
226
|
-
this._messagePort.onmessage = (event) => this.onWorkerMessage(event);
|
|
227
|
-
}
|
|
228
|
-
if (typeof window !== "undefined") {
|
|
229
|
-
window.addEventListener("message", (event) => this.onWindowMessage(event));
|
|
230
|
-
}
|
|
231
|
-
}
|
|
232
217
|
};
|
|
233
218
|
export {
|
|
234
219
|
PortMuxer,
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"version": 3,
|
|
3
3
|
"sources": ["../../../src/ports/iframe.ts", "../../../src/ports/worker.ts", "../../../src/port-muxer.ts"],
|
|
4
|
-
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport
|
|
5
|
-
"mappings": ";;;AAIA,
|
|
6
|
-
"names": ["UAParser", "log", "browser", "os", "navigator", "parser", "userAgent", "getBrowser", "name", "getOS", "sendToIFrame", "iframe", "origin", "message", "contentWindow", "postMessage", "payload", "sendToParentWindow", "window", "parent", "createIFramePort", "channel", "onOrigin", "send", "data", "length", "buffer", "slice", "byteOffset", "byteLength", "subscribe", "callback", "handler", "event", "source", "isMessageData", "undefined", "Uint8Array", "addEventListener", "removeEventListener", "createIFrame", "id", "hidden", "allow", "create", "document", "createElement", "src", "setAttribute", "body", "appendChild", "getElementById", "log", "createWorkerPort", "port", "channel", "subscribe", "send", "message", "payload", "buffer", "slice", "byteOffset", "byteLength", "postMessage", "callback", "handler", "event", "data", "debug", "Uint8Array", "onmessage", "log", "PortMuxer", "
|
|
4
|
+
"sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport UAParser from 'ua-parser-js';\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from '../message';\n\nlet browser: string | undefined;\nlet os: string | undefined;\n\nif (typeof navigator !== 'undefined') {\n // TODO(wittjosiah): Stop user agent parsing.\n const parser = new UAParser(navigator.userAgent);\n browser = parser.getBrowser().name;\n os = parser.getOS().name;\n}\n\nconst sendToIFrame = (iframe: HTMLIFrameElement, origin: string, message: MessageData) => {\n if (!iframe.contentWindow) {\n log('IFrame content window missing', { origin });\n return;\n }\n\n if (browser === 'Chrome' && os === 'iOS') {\n iframe.contentWindow.postMessage(message, origin);\n } else {\n iframe.contentWindow.postMessage(message, origin, [message.payload]);\n }\n};\n\nconst sendToParentWindow = (origin: string, message: MessageData) => {\n if (browser === 'Chrome' && os === 'iOS') {\n window.parent.postMessage(message, origin);\n } else {\n window.parent.postMessage(message, origin, [message.payload]);\n }\n};\n\nexport type IFramePortOptions = {\n channel: string;\n iframe?: HTMLIFrameElement;\n origin?: string;\n onOrigin?: (origin: string) => void;\n};\n\n/**\n * Create a RPC port with an iframe over window messaging.\n * @param options.channel Identifier for sent/recieved messages.\n * @param options.iframe Instance of the iframe if sending to child.\n * @param options.origin Origin of the destination window.\n * @param options.onOrigin Callback triggered when origin of destination window is verified.\n * @returns RPC port for messaging.\n */\nexport const createIFramePort = ({ channel, iframe, origin, onOrigin }: IFramePortOptions): RpcPort => {\n return {\n send: async (data) => {\n if (!origin) {\n log('no origin set', { channel });\n return;\n }\n\n log('sending', { channel, data: data.length });\n const payload = data.buffer.slice(data.byteOffset, data.byteOffset + data.byteLength);\n const message = { channel, payload };\n if (iframe) {\n sendToIFrame(iframe, origin, message);\n } else {\n sendToParentWindow(origin, message);\n }\n },\n\n subscribe: (callback) => {\n const handler = (event: MessageEvent<unknown>) => {\n if (!iframe && event.source !== window.parent) {\n // Not from parent window.\n return;\n } else if (iframe && event.source !== iframe.contentWindow) {\n // Not from child window.\n return;\n }\n\n const isMessageData =\n event.data && typeof event.data === 'object' && 'channel' in event.data && 'payload' in event.data;\n const message = isMessageData ? (event.data as MessageData) : undefined;\n if (message?.channel !== channel) {\n return;\n }\n\n if (!origin) {\n origin = event.origin;\n onOrigin?.(origin);\n }\n\n log('received', message);\n callback(new Uint8Array(message.payload));\n };\n\n window.addEventListener('message', handler);\n return () => window.removeEventListener('message', handler);\n },\n };\n};\n\nexport type CreateIFrameOptions = {\n hidden?: boolean;\n allow?: string;\n};\n\n/**\n * Create a hidden iframe and insert it into the DOM.\n * If an element with the same id already exists it will be returned instead.\n * @param source Source of the iframe.\n * @param id DOM id of the iframe.\n * @returns The created iframe.\n */\nexport const createIFrame = (source: string, id: string, { hidden = true, allow }: CreateIFrameOptions = {}) => {\n const create = () => {\n const iframe = document.createElement('iframe') as HTMLIFrameElement;\n iframe.id = id;\n iframe.src = source;\n hidden && iframe.setAttribute('style', 'display: none;');\n allow && iframe.setAttribute('allow', allow);\n document.body.appendChild(iframe);\n return iframe;\n };\n\n return (document.getElementById(id) as HTMLIFrameElement) ?? create();\n};\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from '../message';\n\nexport type WorkerPortOptions = {\n port: MessagePort;\n channel?: string;\n subscribe?: RpcPort['subscribe'];\n};\n\n/**\n * Create a RPC port for a worker.\n * @param options.port Message port to send message on.\n * @param options.channel Identifier for sent/recieved messages.\n * @param options.subscribe\n * @returns RPC port for messaging.\n */\n// TODO(wittjosiah): Rename for more general purpose MessagePort.\nexport const createWorkerPort = ({ port, channel, subscribe }: WorkerPortOptions): RpcPort => ({\n send: async (message) => {\n // Based on https://stackoverflow.com/a/54646864/2804332.\n const payload = message.buffer.slice(message.byteOffset, message.byteOffset + message.byteLength);\n port.postMessage(\n {\n channel,\n payload,\n },\n [payload],\n );\n },\n\n subscribe:\n subscribe ??\n ((callback) => {\n const handler = (event: MessageEvent<MessageData>) => {\n const message = event.data;\n if (channel && message.channel !== channel) {\n return;\n }\n\n log.debug('received', { message });\n callback(new Uint8Array(message.payload));\n };\n\n port.onmessage = handler;\n return () => {\n port.onmessage = null;\n };\n }),\n});\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { log } from '@dxos/log';\nimport { type RpcPort } from '@dxos/rpc';\n\nimport { type MessageData } from './message';\nimport { type IFramePortOptions, type WorkerPortOptions, createIFramePort, createWorkerPort } from './ports';\n\n/**\n * Facilitates the multiplexing of multiple RpcPorts over a single MessagePort.\n */\nexport class PortMuxer {\n private readonly _activeChannels = new Map<string, (msg: Uint8Array) => void>();\n\n private readonly _rpcPorts = new Map<string, RpcPort>();\n\n constructor(private readonly _messagePort?: MessagePort) {\n if (this._messagePort) {\n this._messagePort.onmessage = (event) => this.onWorkerMessage(event);\n }\n\n if (typeof window !== 'undefined') {\n window.addEventListener('message', (event) => this.onWindowMessage(event));\n }\n }\n\n createWorkerPort(options: Omit<WorkerPortOptions, 'port' | 'subscribe' | 'channel'> & { channel: string }): RpcPort {\n if (!this._messagePort) {\n throw new Error('Message port is required to create worker ports');\n }\n\n const port = createWorkerPort({\n ...options,\n port: this._messagePort,\n subscribe: (callback) => {\n this._activeChannels.set(options.channel, callback);\n return () => this._activeChannels.delete(options.channel);\n },\n });\n this._rpcPorts.set(options.channel, port);\n\n return port;\n }\n\n createIFramePort(options: IFramePortOptions): RpcPort {\n const port = createIFramePort(options);\n this._rpcPorts.set(options.channel, port);\n\n return port;\n }\n\n private onWorkerMessage(event: MessageEvent<MessageData>): void {\n const message = event.data;\n log.debug('Recieved message from worker port', {\n channel: message.channel,\n payload: message.payload,\n });\n\n const callback = this._activeChannels.get(message.channel);\n callback?.(new Uint8Array(message.payload));\n }\n\n private onWindowMessage(event: MessageEvent<MessageData>): void {\n const message = event.data;\n log.debug('Recieved message from window', {\n channel: message.channel,\n payload: message.payload,\n });\n }\n}\n"],
|
|
5
|
+
"mappings": "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",
|
|
6
|
+
"names": ["UAParser", "log", "browser", "os", "navigator", "parser", "userAgent", "getBrowser", "name", "getOS", "sendToIFrame", "iframe", "origin", "message", "contentWindow", "postMessage", "payload", "sendToParentWindow", "window", "parent", "createIFramePort", "channel", "onOrigin", "send", "data", "length", "buffer", "slice", "byteOffset", "byteLength", "subscribe", "callback", "handler", "event", "source", "isMessageData", "undefined", "Uint8Array", "addEventListener", "removeEventListener", "createIFrame", "id", "hidden", "allow", "create", "document", "createElement", "src", "setAttribute", "body", "appendChild", "getElementById", "log", "createWorkerPort", "port", "channel", "subscribe", "send", "message", "payload", "buffer", "slice", "byteOffset", "byteLength", "postMessage", "callback", "handler", "event", "data", "debug", "Uint8Array", "onmessage", "log", "PortMuxer", "_activeChannels", "Map", "_rpcPorts", "_messagePort", "onmessage", "event", "onWorkerMessage", "window", "addEventListener", "onWindowMessage", "createWorkerPort", "options", "Error", "port", "subscribe", "callback", "set", "channel", "delete", "createIFramePort", "message", "data", "log", "debug", "payload", "get", "Uint8Array"]
|
|
7
7
|
}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"inputs":{"src/ports/iframe.ts":{"bytes":
|
|
1
|
+
{"inputs":{"src/ports/iframe.ts":{"bytes":13967,"imports":[{"path":"ua-parser-js","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"src/ports/worker.ts":{"bytes":4832,"imports":[{"path":"@dxos/log","kind":"import-statement","external":true}],"format":"esm"},"src/ports/index.ts":{"bytes":542,"imports":[{"path":"src/ports/iframe.ts","kind":"import-statement","original":"./iframe"},{"path":"src/ports/worker.ts","kind":"import-statement","original":"./worker"}],"format":"esm"},"src/port-muxer.ts":{"bytes":7534,"imports":[{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"src/ports/index.ts","kind":"import-statement","original":"./ports"}],"format":"esm"},"src/index.ts":{"bytes":587,"imports":[{"path":"src/ports/index.ts","kind":"import-statement","original":"./ports"},{"path":"src/port-muxer.ts","kind":"import-statement","original":"./port-muxer"}],"format":"esm"}},"outputs":{"dist/lib/node-esm/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":12795},"dist/lib/node-esm/index.mjs":{"imports":[{"path":"ua-parser-js","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true}],"exports":["PortMuxer","createIFrame","createIFramePort","createWorkerPort"],"entryPoint":"src/index.ts","inputs":{"src/ports/iframe.ts":{"bytesInOutput":3182},"src/ports/index.ts":{"bytesInOutput":0},"src/ports/worker.ts":{"bytesInOutput":902},"src/index.ts":{"bytesInOutput":0},"src/port-muxer.ts":{"bytesInOutput":1842}},"bytes":6203}}}
|