From e68e8fb05fee0ec9ee8883e39658a1c654ade5b8 Mon Sep 17 00:00:00 2001 From: Peter van Hardenberg Date: Wed, 24 Jul 2024 17:56:37 -0700 Subject: [PATCH] sketch of a messagePortRef-based disconnect/reconnect for messagechannel --- .../src/MessagePortRef.ts | 1 + .../src/StrongMessagePortRef.ts | 15 +++++++++++++-- .../src/WeakMessagePortRef.ts | 14 +++++++++++++- .../src/index.ts | 4 ++-- 4 files changed, 29 insertions(+), 5 deletions(-) diff --git a/packages/automerge-repo-network-messagechannel/src/MessagePortRef.ts b/packages/automerge-repo-network-messagechannel/src/MessagePortRef.ts index 3ea3cf094..b6a409f63 100644 --- a/packages/automerge-repo-network-messagechannel/src/MessagePortRef.ts +++ b/packages/automerge-repo-network-messagechannel/src/MessagePortRef.ts @@ -7,6 +7,7 @@ export interface PortRefEvents { export interface MessagePortRef extends EventEmitter { start(): void + stop(): void postMessage(message: any, transferable?: Transferable[]): void isAlive(): boolean } diff --git a/packages/automerge-repo-network-messagechannel/src/StrongMessagePortRef.ts b/packages/automerge-repo-network-messagechannel/src/StrongMessagePortRef.ts index 87f7524d5..5d28779cb 100644 --- a/packages/automerge-repo-network-messagechannel/src/StrongMessagePortRef.ts +++ b/packages/automerge-repo-network-messagechannel/src/StrongMessagePortRef.ts @@ -5,22 +5,33 @@ export class StrongMessagePortRef extends EventEmitter implements MessagePortRef { + isDisconnected: boolean = false + constructor(private port: MessagePort) { port.addEventListener("message", event => { - this.emit("message", event) + if (!this.isDisconnected) { + this.emit("message", event) + } }) super() } postMessage(message: any, transfer: Transferable[]): void { - this.port.postMessage(message, transfer) + if (!this.isDisconnected) { + this.port.postMessage(message, transfer) + } } start(): void { + this.isDisconnected = false this.port.start() } + stop() { + this.isDisconnected = true + } + isAlive(): boolean { /* c8 ignore next */ return true diff --git a/packages/automerge-repo-network-messagechannel/src/WeakMessagePortRef.ts b/packages/automerge-repo-network-messagechannel/src/WeakMessagePortRef.ts index f173a630f..bc33e3f6d 100644 --- a/packages/automerge-repo-network-messagechannel/src/WeakMessagePortRef.ts +++ b/packages/automerge-repo-network-messagechannel/src/WeakMessagePortRef.ts @@ -15,7 +15,9 @@ export class WeakMessagePortRef this.weakRef = new WeakRef(port) port.addEventListener("message", event => { - this.emit("message", event) + if (!this.isDisconnected) { + this.emit("message", event) + } }) } @@ -27,6 +29,10 @@ export class WeakMessagePortRef return } + if (this.isDisconnected) { + return + } + try { port.postMessage(message, transfer) } catch (err) { @@ -42,6 +48,8 @@ export class WeakMessagePortRef return } + this.isDisconnected = false + try { port.start() } catch (err) { @@ -49,6 +57,10 @@ export class WeakMessagePortRef } } + stop() { + this.isDisconnected = true + } + private disconnnect() { if (!this.isDisconnected) { this.emit("close") diff --git a/packages/automerge-repo-network-messagechannel/src/index.ts b/packages/automerge-repo-network-messagechannel/src/index.ts index 4b2b5adcb..e3549b19a 100644 --- a/packages/automerge-repo-network-messagechannel/src/index.ts +++ b/packages/automerge-repo-network-messagechannel/src/index.ts @@ -62,6 +62,7 @@ export class MessageChannelNetworkAdapter extends NetworkAdapter { log("messageport connecting") this.peerId = peerId this.peerMetadata = peerMetadata + this.messagePortRef.start() this.messagePortRef.addListener( "message", @@ -153,8 +154,7 @@ export class MessageChannelNetworkAdapter extends NetworkAdapter { } disconnect() { - // TODO - throw new Error("Unimplemented: leave on MessagePortNetworkAdapter") + this.messagePortRef.stop() } }