@automerge/automerge-repo-network-broadcastchannel 1.1.0 → 1.1.1

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/index.d.ts CHANGED
@@ -20,7 +20,7 @@ export type BroadcastChannelNetworkAdapterOptions = {
20
20
  export declare class BroadcastChannelNetworkAdapter extends NetworkAdapter {
21
21
  #private;
22
22
  constructor(options?: BroadcastChannelNetworkAdapterOptions);
23
- connect(peerId: PeerId, peerMetadata: PeerMetadata): void;
23
+ connect(peerId: PeerId, peerMetadata?: PeerMetadata): void;
24
24
  send(message: Message): void;
25
25
  disconnect(): void;
26
26
  }
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EACL,cAAc,EACd,KAAK,OAAO,EACZ,KAAK,MAAM,EACX,KAAK,YAAY,EAClB,MAAM,2BAA2B,CAAA;AAElC,MAAM,MAAM,qCAAqC,GAAG;IAClD,WAAW,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,qBAAa,8BAA+B,SAAQ,cAAc;;gBAKpD,OAAO,CAAC,EAAE,qCAAqC;IAK3D,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,EAAE,YAAY;IAsDlD,IAAI,CAAC,OAAO,EAAE,OAAO;IAcrB,UAAU;CAIX"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;GAcG;AAEH,OAAO,EACL,cAAc,EACd,KAAK,OAAO,EACZ,KAAK,MAAM,EACX,KAAK,YAAY,EAClB,MAAM,2BAA2B,CAAA;AAElC,MAAM,MAAM,qCAAqC,GAAG;IAClD,WAAW,EAAE,MAAM,CAAA;CACpB,CAAA;AAED,qBAAa,8BAA+B,SAAQ,cAAc;;gBAKpD,OAAO,CAAC,EAAE,qCAAqC;IAM3D,OAAO,CAAC,MAAM,EAAE,MAAM,EAAE,YAAY,CAAC,EAAE,YAAY;IA6DnD,IAAI,CAAC,OAAO,EAAE,OAAO;IAgBrB,UAAU;CAIX"}
package/dist/index.js CHANGED
@@ -20,11 +20,11 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
20
20
  constructor(options) {
21
21
  super();
22
22
  this.#options = { channelName: "broadcast", ...(options ?? {}) };
23
+ this.#broadcastChannel = new BroadcastChannel(this.#options.channelName);
23
24
  }
24
25
  connect(peerId, peerMetadata) {
25
26
  this.peerId = peerId;
26
27
  this.peerMetadata = peerMetadata;
27
- this.#broadcastChannel = new BroadcastChannel(this.#options.channelName);
28
28
  this.#broadcastChannel.addEventListener("message", (e) => {
29
29
  const message = e.data;
30
30
  if ("targetId" in message && message.targetId !== this.peerId) {
@@ -33,15 +33,22 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
33
33
  const { senderId, type } = message;
34
34
  switch (type) {
35
35
  case "arrive":
36
- this.#broadcastChannel.postMessage({
37
- senderId: this.peerId,
38
- targetId: senderId,
39
- type: "welcome",
40
- });
41
- this.#announceConnection(senderId, peerMetadata);
36
+ {
37
+ const { peerMetadata } = message;
38
+ this.#broadcastChannel.postMessage({
39
+ senderId: this.peerId,
40
+ targetId: senderId,
41
+ type: "welcome",
42
+ peerMetadata: this.peerMetadata,
43
+ });
44
+ this.#announceConnection(senderId, peerMetadata);
45
+ }
42
46
  break;
43
47
  case "welcome":
44
- this.#announceConnection(senderId, peerMetadata);
48
+ {
49
+ const { peerMetadata } = message;
50
+ this.#announceConnection(senderId, peerMetadata);
51
+ }
45
52
  break;
46
53
  default:
47
54
  if (!("data" in message)) {
@@ -60,6 +67,7 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
60
67
  this.#broadcastChannel.postMessage({
61
68
  senderId: this.peerId,
62
69
  type: "arrive",
70
+ peerMetadata,
63
71
  });
64
72
  this.emit("ready", { network: this });
65
73
  }
@@ -70,7 +78,9 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
70
78
  if ("data" in message) {
71
79
  this.#broadcastChannel.postMessage({
72
80
  ...message,
73
- data: message.data.buffer.slice(message.data.byteOffset, message.data.byteOffset + message.data.byteLength),
81
+ data: message.data
82
+ ? message.data.buffer.slice(message.data.byteOffset, message.data.byteOffset + message.data.byteLength)
83
+ : undefined,
74
84
  });
75
85
  }
76
86
  else {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@automerge/automerge-repo-network-broadcastchannel",
3
- "version": "1.1.0",
3
+ "version": "1.1.1",
4
4
  "description": "BroadcastChannel network adapter for Automerge Repo",
5
5
  "repository": "https://github.com/automerge/automerge-repo/tree/master/packages/automerge-repo-network-broadcastchannel",
6
6
  "author": "Peter van Hardenberg <pvh@pvh.ca>",
@@ -13,7 +13,7 @@
13
13
  "test": "vitest"
14
14
  },
15
15
  "dependencies": {
16
- "@automerge/automerge-repo": "1.1.0"
16
+ "@automerge/automerge-repo": "1.1.1"
17
17
  },
18
18
  "watch": {
19
19
  "build": {
@@ -26,5 +26,5 @@
26
26
  "publishConfig": {
27
27
  "access": "public"
28
28
  },
29
- "gitHead": "e9e7d3f27ec2ac8a2e9d122ece80598918940067"
29
+ "gitHead": "7e0681014b8c5f672e2abc2a653a954ccb6d7aba"
30
30
  }
package/src/index.ts CHANGED
@@ -33,12 +33,12 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
33
33
  constructor(options?: BroadcastChannelNetworkAdapterOptions) {
34
34
  super()
35
35
  this.#options = { channelName: "broadcast", ...(options ?? {}) }
36
+ this.#broadcastChannel = new BroadcastChannel(this.#options.channelName)
36
37
  }
37
38
 
38
- connect(peerId: PeerId, peerMetadata: PeerMetadata) {
39
+ connect(peerId: PeerId, peerMetadata?: PeerMetadata) {
39
40
  this.peerId = peerId
40
41
  this.peerMetadata = peerMetadata
41
- this.#broadcastChannel = new BroadcastChannel(this.#options.channelName)
42
42
 
43
43
  this.#broadcastChannel.addEventListener(
44
44
  "message",
@@ -52,15 +52,22 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
52
52
 
53
53
  switch (type) {
54
54
  case "arrive":
55
- this.#broadcastChannel.postMessage({
56
- senderId: this.peerId,
57
- targetId: senderId,
58
- type: "welcome",
59
- })
60
- this.#announceConnection(senderId, peerMetadata)
55
+ {
56
+ const { peerMetadata } = message as ArriveMessage
57
+ this.#broadcastChannel.postMessage({
58
+ senderId: this.peerId,
59
+ targetId: senderId,
60
+ type: "welcome",
61
+ peerMetadata: this.peerMetadata,
62
+ })
63
+ this.#announceConnection(senderId, peerMetadata)
64
+ }
61
65
  break
62
66
  case "welcome":
63
- this.#announceConnection(senderId, peerMetadata)
67
+ {
68
+ const { peerMetadata } = message as WelcomeMessage
69
+ this.#announceConnection(senderId, peerMetadata)
70
+ }
64
71
  break
65
72
  default:
66
73
  if (!("data" in message)) {
@@ -80,6 +87,7 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
80
87
  this.#broadcastChannel.postMessage({
81
88
  senderId: this.peerId,
82
89
  type: "arrive",
90
+ peerMetadata,
83
91
  })
84
92
 
85
93
  this.emit("ready", { network: this })
@@ -93,10 +101,12 @@ export class BroadcastChannelNetworkAdapter extends NetworkAdapter {
93
101
  if ("data" in message) {
94
102
  this.#broadcastChannel.postMessage({
95
103
  ...message,
96
- data: message.data.buffer.slice(
97
- message.data.byteOffset,
98
- message.data.byteOffset + message.data.byteLength
99
- ),
104
+ data: message.data
105
+ ? message.data.buffer.slice(
106
+ message.data.byteOffset,
107
+ message.data.byteOffset + message.data.byteLength
108
+ )
109
+ : undefined,
100
110
  })
101
111
  } else {
102
112
  this.#broadcastChannel.postMessage(message)
package/tsconfig.json CHANGED
@@ -9,7 +9,7 @@
9
9
  "outDir": "./dist",
10
10
  "esModuleInterop": true,
11
11
  "forceConsistentCasingInFileNames": true,
12
- "strict": false,
12
+ "strict": true,
13
13
  "skipLibCheck": true
14
14
  },
15
15
  "include": ["src/**/*.ts"]