@dxos/edge-client 0.8.2-main.2f9c567 → 0.8.2-main.36232bc

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.
Files changed (48) hide show
  1. package/dist/lib/browser/chunk-XS3TKGM4.mjs +545 -0
  2. package/dist/lib/browser/chunk-XS3TKGM4.mjs.map +7 -0
  3. package/dist/lib/browser/index.mjs +58 -318
  4. package/dist/lib/browser/index.mjs.map +4 -4
  5. package/dist/lib/browser/meta.json +1 -1
  6. package/dist/lib/browser/testing/index.mjs +3 -3
  7. package/dist/lib/browser/testing/index.mjs.map +3 -3
  8. package/dist/lib/node/chunk-ZURVCY7K.cjs +577 -0
  9. package/dist/lib/node/chunk-ZURVCY7K.cjs.map +7 -0
  10. package/dist/lib/node/index.cjs +53 -322
  11. package/dist/lib/node/index.cjs.map +4 -4
  12. package/dist/lib/node/meta.json +1 -1
  13. package/dist/lib/node/testing/index.cjs +5 -6
  14. package/dist/lib/node/testing/index.cjs.map +3 -3
  15. package/dist/lib/node-esm/chunk-HNRMNQPG.mjs +547 -0
  16. package/dist/lib/node-esm/chunk-HNRMNQPG.mjs.map +7 -0
  17. package/dist/lib/node-esm/index.mjs +58 -318
  18. package/dist/lib/node-esm/index.mjs.map +4 -4
  19. package/dist/lib/node-esm/meta.json +1 -1
  20. package/dist/lib/node-esm/testing/index.mjs +3 -3
  21. package/dist/lib/node-esm/testing/index.mjs.map +3 -3
  22. package/dist/types/src/edge-ws-connection.d.ts +4 -0
  23. package/dist/types/src/edge-ws-connection.d.ts.map +1 -1
  24. package/dist/types/src/edge-ws-muxer.d.ts +7 -19
  25. package/dist/types/src/edge-ws-muxer.d.ts.map +1 -1
  26. package/dist/types/src/index.d.ts +0 -1
  27. package/dist/types/src/index.d.ts.map +1 -1
  28. package/dist/types/src/testing/test-utils.d.ts.map +1 -1
  29. package/package.json +14 -19
  30. package/src/edge-ws-connection.ts +11 -6
  31. package/src/edge-ws-muxer.ts +33 -63
  32. package/src/index.ts +0 -1
  33. package/src/testing/test-utils.ts +2 -2
  34. package/dist/lib/browser/chunk-TKYUZ5ZK.mjs +0 -302
  35. package/dist/lib/browser/chunk-TKYUZ5ZK.mjs.map +0 -7
  36. package/dist/lib/browser/edge-ws-muxer.mjs +0 -11
  37. package/dist/lib/browser/edge-ws-muxer.mjs.map +0 -7
  38. package/dist/lib/node/chunk-ZOL3YSDR.cjs +0 -322
  39. package/dist/lib/node/chunk-ZOL3YSDR.cjs.map +0 -7
  40. package/dist/lib/node/edge-ws-muxer.cjs +0 -33
  41. package/dist/lib/node/edge-ws-muxer.cjs.map +0 -7
  42. package/dist/lib/node-esm/chunk-25HGRGNZ.mjs +0 -304
  43. package/dist/lib/node-esm/chunk-25HGRGNZ.mjs.map +0 -7
  44. package/dist/lib/node-esm/edge-ws-muxer.mjs +0 -12
  45. package/dist/lib/node-esm/edge-ws-muxer.mjs.map +0 -7
  46. package/dist/types/src/edge-ws-muxer.test.d.ts +0 -2
  47. package/dist/types/src/edge-ws-muxer.test.d.ts.map +0 -1
  48. package/src/edge-ws-muxer.test.ts +0 -55
@@ -8,18 +8,23 @@ import { scheduleTask, scheduleTaskInterval } from '@dxos/async';
8
8
  import { Context, Resource } from '@dxos/context';
9
9
  import { invariant } from '@dxos/invariant';
10
10
  import { log, logInfo } from '@dxos/log';
11
- import { EdgeWebsocketProtocol } from '@dxos/protocols';
12
11
  import { buf } from '@dxos/protocols/buf';
13
12
  import { MessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';
14
13
 
15
14
  import { protocol } from './defs';
16
15
  import { type EdgeIdentity } from './edge-identity';
17
- import { CLOUDFLARE_MESSAGE_MAX_BYTES, WebSocketMuxer } from './edge-ws-muxer';
16
+ import { CLOUDFLARE_MESSAGE_LENGTH_LIMIT, WebSocketMuxer } from './edge-ws-muxer';
18
17
  import { toUint8Array } from './protocol';
19
18
 
20
19
  const SIGNAL_KEEPALIVE_INTERVAL = 4_000;
21
20
  const SIGNAL_KEEPALIVE_TIMEOUT = 12_000;
22
21
 
22
+ const EDGE_WEBSOCKET_PROTOCOL_V0 = 'edge-ws-v0';
23
+ /**
24
+ * Supports message segmentation and muxing.
25
+ */
26
+ export const EDGE_WEBSOCKET_PROTOCOL_V1 = 'edge-ws-v1';
27
+
23
28
  export type EdgeWsConnectionCallbacks = {
24
29
  onConnected: () => void;
25
30
  onMessage: (message: Message) => void;
@@ -52,9 +57,9 @@ export class EdgeWsConnection extends Resource {
52
57
  invariant(this._ws);
53
58
  invariant(this._wsMuxer);
54
59
  log('sending...', { peerKey: this._identity.peerKey, payload: protocol.getPayloadType(message) });
55
- if (this._ws?.protocol.includes(EdgeWebsocketProtocol.V0)) {
60
+ if (this._ws?.protocol.includes(EDGE_WEBSOCKET_PROTOCOL_V0)) {
56
61
  const binary = buf.toBinary(MessageSchema, message);
57
- if (binary.length > CLOUDFLARE_MESSAGE_MAX_BYTES) {
62
+ if (binary.length > CLOUDFLARE_MESSAGE_LENGTH_LIMIT) {
58
63
  log.error('Message dropped because it was too large (>1MB).', {
59
64
  byteLength: binary.byteLength,
60
65
  serviceId: message.serviceId,
@@ -69,7 +74,7 @@ export class EdgeWsConnection extends Resource {
69
74
  }
70
75
 
71
76
  protected override async _open() {
72
- const baseProtocols = [...Object.values(EdgeWebsocketProtocol)];
77
+ const baseProtocols = [EDGE_WEBSOCKET_PROTOCOL_V0, EDGE_WEBSOCKET_PROTOCOL_V1];
73
78
  this._ws = new WebSocket(
74
79
  this._connectionInfo.url.toString(),
75
80
  this._connectionInfo.protocolHeader
@@ -120,7 +125,7 @@ export class EdgeWsConnection extends Resource {
120
125
  return;
121
126
  }
122
127
 
123
- const message = this._ws?.protocol?.includes(EdgeWebsocketProtocol.V0)
128
+ const message = this._ws?.protocol?.includes(EDGE_WEBSOCKET_PROTOCOL_V0)
124
129
  ? buf.fromBinary(MessageSchema, bytes)
125
130
  : muxer.receiveData(bytes);
126
131
 
@@ -1,6 +1,7 @@
1
1
  //
2
2
  // Copyright 2025 DXOS.org
3
3
  //
4
+ import WebSocket from 'isomorphic-ws';
4
5
 
5
6
  import { Trigger } from '@dxos/async';
6
7
  import { log } from '@dxos/log';
@@ -24,30 +25,22 @@ const FLAG_SEGMENT_SEQ = 1;
24
25
  const FLAG_SEGMENT_SEQ_TERMINATED = 1 << 1;
25
26
 
26
27
  /**
27
- * https://developers.cloudflare.com/durable-objects/platform/limits/
28
+ * 1MB websocket message limit: https://developers.cloudflare.com/durable-objects/platform/limits/
28
29
  */
29
- export const CLOUDFLARE_MESSAGE_MAX_BYTES = 1000 * 1000; // 1MB
30
- export const CLOUDFLARE_RPC_MAX_BYTES = 32 * 1000 * 1000; // 32MB
30
+ export const CLOUDFLARE_MESSAGE_LENGTH_LIMIT = 1024 * 1024;
31
31
 
32
32
  const MAX_CHUNK_LENGTH = 16384;
33
- const MAX_BUFFERED_AMOUNT = CLOUDFLARE_MESSAGE_MAX_BYTES;
33
+ const MAX_BUFFERED_AMOUNT = CLOUDFLARE_MESSAGE_LENGTH_LIMIT;
34
34
  const BUFFER_FULL_BACKOFF_TIMEOUT = 100;
35
35
 
36
36
  export class WebSocketMuxer {
37
- private readonly _inMessageAccumulator = new Map<number, Buffer[]>();
38
- private readonly _outMessageChunks = new Map<number, MessageChunk[]>();
39
- private readonly _outMessageChannelByService = new Map<string, number>();
37
+ private readonly _incomingMessageAccumulator = new Map<number, Buffer[]>();
38
+ private readonly _outgoingMessageChunks = new Map<number, MessageChunk[]>();
39
+ private readonly _serviceToChannel = new Map<string, number>();
40
40
 
41
41
  private _sendTimeout: any | undefined;
42
42
 
43
- private readonly _maxChunkLength: number;
44
-
45
- constructor(
46
- private readonly _ws: WebSocketCompat,
47
- config?: { maxChunkLength: number },
48
- ) {
49
- this._maxChunkLength = config?.maxChunkLength ?? MAX_CHUNK_LENGTH;
50
- }
43
+ constructor(private readonly _ws: WebSocket) {}
51
44
 
52
45
  /**
53
46
  * Resolves when all the message chunks get enqueued for sending.
@@ -55,20 +48,16 @@ export class WebSocketMuxer {
55
48
  public async send(message: Message): Promise<void> {
56
49
  const binary = buf.toBinary(MessageSchema, message);
57
50
  const channelId = this._resolveChannel(message);
58
- if (
59
- (channelId == null && binary.byteLength > CLOUDFLARE_MESSAGE_MAX_BYTES) ||
60
- binary.byteLength > CLOUDFLARE_RPC_MAX_BYTES
61
- ) {
62
- log.error('Large message dropped', {
51
+ if (channelId == null && binary.length > CLOUDFLARE_MESSAGE_LENGTH_LIMIT) {
52
+ log.error('Large message dropped because channel resolution failed.', {
63
53
  byteLength: binary.byteLength,
64
54
  serviceId: message.serviceId,
65
55
  payload: protocol.getPayloadType(message),
66
- channelId,
67
56
  });
68
57
  return;
69
58
  }
70
59
 
71
- if (channelId == null || binary.length < this._maxChunkLength) {
60
+ if (channelId == null || binary.length < MAX_CHUNK_LENGTH) {
72
61
  const flags = Buffer.from([0]);
73
62
  this._ws.send(Buffer.concat([flags, binary]));
74
63
  return;
@@ -76,23 +65,23 @@ export class WebSocketMuxer {
76
65
 
77
66
  const terminatorSentTrigger = new Trigger();
78
67
  const messageChunks: MessageChunk[] = [];
79
- for (let i = 0; i < binary.length; i += this._maxChunkLength) {
80
- const chunk = binary.slice(i, i + this._maxChunkLength);
81
- const isLastChunk = i + this._maxChunkLength >= binary.length;
68
+ for (let i = 0; i < binary.length; i += MAX_CHUNK_LENGTH) {
69
+ const chunk = binary.slice(i, i + MAX_CHUNK_LENGTH);
70
+ const isLastChunk = i + MAX_CHUNK_LENGTH < binary.length;
82
71
  if (isLastChunk) {
83
72
  const flags = Buffer.from([FLAG_SEGMENT_SEQ | FLAG_SEGMENT_SEQ_TERMINATED, channelId]);
84
73
  messageChunks.push({ payload: Buffer.concat([flags, chunk]), trigger: terminatorSentTrigger });
85
74
  } else {
86
- const flags = Buffer.from([FLAG_SEGMENT_SEQ, channelId]);
75
+ const flags = Buffer.from([FLAG_SEGMENT_SEQ]);
87
76
  messageChunks.push({ payload: Buffer.concat([flags, chunk]) });
88
77
  }
89
78
  }
90
79
 
91
- const queuedMessages = this._outMessageChunks.get(channelId);
80
+ const queuedMessages = this._outgoingMessageChunks.get(channelId);
92
81
  if (queuedMessages) {
93
82
  queuedMessages.push(...messageChunks);
94
83
  } else {
95
- this._outMessageChunks.set(channelId, messageChunks);
84
+ this._outgoingMessageChunks.set(channelId, messageChunks);
96
85
  }
97
86
 
98
87
  this._sendChunkedMessages();
@@ -106,12 +95,12 @@ export class WebSocketMuxer {
106
95
  }
107
96
 
108
97
  const [flags, channelId, ...payload] = data;
109
- let chunkAccumulator = this._inMessageAccumulator.get(channelId);
98
+ let chunkAccumulator = this._incomingMessageAccumulator.get(channelId);
110
99
  if (chunkAccumulator) {
111
100
  chunkAccumulator.push(Buffer.from(payload));
112
101
  } else {
113
102
  chunkAccumulator = [Buffer.from(payload)];
114
- this._inMessageAccumulator.set(channelId, chunkAccumulator);
103
+ this._incomingMessageAccumulator.set(channelId, chunkAccumulator);
115
104
  }
116
105
 
117
106
  if ((flags & FLAG_SEGMENT_SEQ_TERMINATED) === 0) {
@@ -119,7 +108,7 @@ export class WebSocketMuxer {
119
108
  }
120
109
 
121
110
  const message = buf.fromBinary(MessageSchema, Buffer.concat(chunkAccumulator));
122
- this._inMessageAccumulator.delete(channelId);
111
+ this._incomingMessageAccumulator.delete(channelId);
123
112
  return message;
124
113
  }
125
114
 
@@ -128,12 +117,12 @@ export class WebSocketMuxer {
128
117
  clearTimeout(this._sendTimeout);
129
118
  this._sendTimeout = undefined;
130
119
  }
131
- for (const channelChunks of this._outMessageChunks.values()) {
120
+ for (const channelChunks of this._outgoingMessageChunks.values()) {
132
121
  channelChunks.forEach((chunk) => chunk.trigger?.wake());
133
122
  }
134
- this._outMessageChunks.clear();
135
- this._inMessageAccumulator.clear();
136
- this._outMessageChannelByService.clear();
123
+ this._outgoingMessageChunks.clear();
124
+ this._incomingMessageAccumulator.clear();
125
+ this._serviceToChannel.clear();
137
126
  }
138
127
 
139
128
  private _sendChunkedMessages() {
@@ -150,12 +139,10 @@ export class WebSocketMuxer {
150
139
 
151
140
  let timeout = 0;
152
141
  const emptyChannels: number[] = [];
153
- for (const [channelId, messages] of this._outMessageChunks.entries()) {
154
- if (this._ws.bufferedAmount != null) {
155
- if (this._ws.bufferedAmount + MAX_CHUNK_LENGTH > MAX_BUFFERED_AMOUNT) {
156
- timeout = BUFFER_FULL_BACKOFF_TIMEOUT;
157
- break;
158
- }
142
+ for (const [channelId, messages] of this._outgoingMessageChunks.entries()) {
143
+ if (this._ws.bufferedAmount + MAX_CHUNK_LENGTH > MAX_BUFFERED_AMOUNT) {
144
+ timeout = BUFFER_FULL_BACKOFF_TIMEOUT;
145
+ break;
159
146
  }
160
147
 
161
148
  const nextMessage = messages.shift();
@@ -167,9 +154,9 @@ export class WebSocketMuxer {
167
154
  }
168
155
  }
169
156
 
170
- emptyChannels.forEach((channelId) => this._outMessageChunks.delete(channelId));
157
+ emptyChannels.forEach((channelId) => this._outgoingMessageChunks.delete(channelId));
171
158
 
172
- if (this._outMessageChunks.size > 0) {
159
+ if (this._outgoingMessageChunks.size > 0) {
173
160
  this._sendTimeout = setTimeout(send, timeout);
174
161
  } else {
175
162
  this._sendTimeout = undefined;
@@ -182,24 +169,15 @@ export class WebSocketMuxer {
182
169
  if (!message.serviceId) {
183
170
  return undefined;
184
171
  }
185
- let id = this._outMessageChannelByService.get(message.serviceId);
172
+ let id = this._serviceToChannel.get(message.serviceId);
186
173
  if (!id) {
187
- id = this._outMessageChannelByService.size + 1;
188
- this._outMessageChannelByService.set(message.serviceId, id);
174
+ id = this._serviceToChannel.size + 1;
175
+ this._serviceToChannel.set(message.serviceId, id);
189
176
  }
190
177
  return id;
191
178
  }
192
179
  }
193
180
 
194
- type WebSocketCompat = {
195
- readonly readyState: number;
196
- /**
197
- * Not available in workerd.
198
- */
199
- bufferedAmount?: number;
200
- send(message: (ArrayBuffer | ArrayBufferView) | string): void;
201
- };
202
-
203
181
  type MessageChunk = {
204
182
  payload: Buffer;
205
183
  /**
@@ -207,11 +185,3 @@ type MessageChunk = {
207
185
  */
208
186
  trigger?: Trigger;
209
187
  };
210
-
211
- /**
212
- * To avoid using isomorphic-ws on edge.
213
- */
214
- enum WebSocket {
215
- CLOSING = 2,
216
- CLOSED = 3,
217
- }
package/src/index.ts CHANGED
@@ -11,4 +11,3 @@ export * from './errors';
11
11
  export * from './auth';
12
12
  export * from './edge-http-client';
13
13
  export * from './edge-identity';
14
- export * from './edge-ws-muxer';
@@ -6,11 +6,11 @@ import WebSocket from 'isomorphic-ws';
6
6
 
7
7
  import { Trigger } from '@dxos/async';
8
8
  import { log } from '@dxos/log';
9
- import { EdgeWebsocketProtocol } from '@dxos/protocols';
10
9
  import { buf } from '@dxos/protocols/buf';
11
10
  import { MessageSchema, TextMessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';
12
11
 
13
12
  import { protocol } from '../defs';
13
+ import { EDGE_WEBSOCKET_PROTOCOL_V1 } from '../edge-ws-connection';
14
14
  import { WebSocketMuxer } from '../edge-ws-muxer';
15
15
  import { toUint8Array } from '../protocol';
16
16
 
@@ -26,7 +26,7 @@ export const createTestEdgeWsServer = async (port = DEFAULT_PORT, params?: TestE
26
26
  const wsServer = new WebSocket.Server({
27
27
  port,
28
28
  verifyClient: createConnectionDelayHandler(params),
29
- handleProtocols: () => [EdgeWebsocketProtocol.V1],
29
+ handleProtocols: () => [EDGE_WEBSOCKET_PROTOCOL_V1],
30
30
  });
31
31
 
32
32
  let connection: { ws: WebSocket; muxer: WebSocketMuxer } | undefined;
@@ -1,302 +0,0 @@
1
- // packages/core/mesh/edge-client/src/edge-ws-muxer.ts
2
- import { Trigger } from "@dxos/async";
3
- import { log } from "@dxos/log";
4
- import { buf as buf2 } from "@dxos/protocols/buf";
5
- import { MessageSchema as MessageSchema2 } from "@dxos/protocols/buf/dxos/edge/messenger_pb";
6
-
7
- // packages/core/mesh/edge-client/src/defs.ts
8
- import { bufWkt as bufWkt2 } from "@dxos/protocols/buf";
9
- import { SwarmRequestSchema, SwarmResponseSchema, TextMessageSchema } from "@dxos/protocols/buf/dxos/edge/messenger_pb";
10
-
11
- // packages/core/mesh/edge-client/src/protocol.ts
12
- import { invariant } from "@dxos/invariant";
13
- import { buf, bufWkt } from "@dxos/protocols/buf";
14
- import { MessageSchema } from "@dxos/protocols/buf/dxos/edge/messenger_pb";
15
- import { bufferToArray } from "@dxos/util";
16
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/protocol.ts";
17
- var getTypename = (typeName) => `type.googleapis.com/${typeName}`;
18
- var Protocol = class {
19
- constructor(types) {
20
- this._typeRegistry = buf.createRegistry(...types);
21
- }
22
- get typeRegistry() {
23
- return this._typeRegistry;
24
- }
25
- toJson(message) {
26
- try {
27
- return buf.toJson(MessageSchema, message, {
28
- registry: this.typeRegistry
29
- });
30
- } catch (err) {
31
- return {
32
- type: this.getPayloadType(message)
33
- };
34
- }
35
- }
36
- /**
37
- * Return the payload with the given type.
38
- */
39
- getPayload(message, type) {
40
- invariant(message.payload, void 0, {
41
- F: __dxlog_file,
42
- L: 40,
43
- S: this,
44
- A: [
45
- "message.payload",
46
- ""
47
- ]
48
- });
49
- const payloadTypename = this.getPayloadType(message);
50
- if (type && type.typeName !== payloadTypename) {
51
- throw new Error(`Unexpected payload type: ${payloadTypename}; expected ${type.typeName}`);
52
- }
53
- invariant(bufWkt.anyIs(message.payload, type), `Unexpected payload type: ${payloadTypename}}`, {
54
- F: __dxlog_file,
55
- L: 46,
56
- S: this,
57
- A: [
58
- "bufWkt.anyIs(message.payload, type)",
59
- "`Unexpected payload type: ${payloadTypename}}`"
60
- ]
61
- });
62
- const payload = bufWkt.anyUnpack(message.payload, this.typeRegistry);
63
- invariant(payload, `Empty payload: ${payloadTypename}}`, {
64
- F: __dxlog_file,
65
- L: 48,
66
- S: this,
67
- A: [
68
- "payload",
69
- "`Empty payload: ${payloadTypename}}`"
70
- ]
71
- });
72
- return payload;
73
- }
74
- /**
75
- * Get the payload type.
76
- */
77
- getPayloadType(message) {
78
- if (!message.payload) {
79
- return void 0;
80
- }
81
- const [, type] = message.payload.typeUrl.split("/");
82
- return type;
83
- }
84
- /**
85
- * Create a packed message.
86
- */
87
- createMessage(type, { source, target, payload, serviceId }) {
88
- return buf.create(MessageSchema, {
89
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
90
- source,
91
- target,
92
- serviceId,
93
- payload: payload ? bufWkt.anyPack(type, buf.create(type, payload)) : void 0
94
- });
95
- }
96
- };
97
- var toUint8Array = async (data) => {
98
- if (data instanceof Buffer) {
99
- return bufferToArray(data);
100
- }
101
- if (data instanceof Blob) {
102
- return new Uint8Array(await data.arrayBuffer());
103
- }
104
- throw new Error(`Unexpected datatype: ${data}`);
105
- };
106
-
107
- // packages/core/mesh/edge-client/src/defs.ts
108
- var protocol = new Protocol([
109
- SwarmRequestSchema,
110
- SwarmResponseSchema,
111
- TextMessageSchema,
112
- bufWkt2.AnySchema
113
- ]);
114
-
115
- // packages/core/mesh/edge-client/src/edge-ws-muxer.ts
116
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/edge-ws-muxer.ts";
117
- var FLAG_SEGMENT_SEQ = 1;
118
- var FLAG_SEGMENT_SEQ_TERMINATED = 1 << 1;
119
- var CLOUDFLARE_MESSAGE_MAX_BYTES = 1e3 * 1e3;
120
- var CLOUDFLARE_RPC_MAX_BYTES = 32 * 1e3 * 1e3;
121
- var MAX_CHUNK_LENGTH = 16384;
122
- var MAX_BUFFERED_AMOUNT = CLOUDFLARE_MESSAGE_MAX_BYTES;
123
- var BUFFER_FULL_BACKOFF_TIMEOUT = 100;
124
- var WebSocketMuxer = class {
125
- constructor(_ws, config) {
126
- this._ws = _ws;
127
- this._inMessageAccumulator = /* @__PURE__ */ new Map();
128
- this._outMessageChunks = /* @__PURE__ */ new Map();
129
- this._outMessageChannelByService = /* @__PURE__ */ new Map();
130
- this._maxChunkLength = config?.maxChunkLength ?? MAX_CHUNK_LENGTH;
131
- }
132
- /**
133
- * Resolves when all the message chunks get enqueued for sending.
134
- */
135
- async send(message) {
136
- const binary = buf2.toBinary(MessageSchema2, message);
137
- const channelId = this._resolveChannel(message);
138
- if (channelId == null && binary.byteLength > CLOUDFLARE_MESSAGE_MAX_BYTES || binary.byteLength > CLOUDFLARE_RPC_MAX_BYTES) {
139
- log.error("Large message dropped", {
140
- byteLength: binary.byteLength,
141
- serviceId: message.serviceId,
142
- payload: protocol.getPayloadType(message),
143
- channelId
144
- }, {
145
- F: __dxlog_file2,
146
- L: 62,
147
- S: this,
148
- C: (f, a) => f(...a)
149
- });
150
- return;
151
- }
152
- if (channelId == null || binary.length < this._maxChunkLength) {
153
- const flags = Buffer.from([
154
- 0
155
- ]);
156
- this._ws.send(Buffer.concat([
157
- flags,
158
- binary
159
- ]));
160
- return;
161
- }
162
- const terminatorSentTrigger = new Trigger();
163
- const messageChunks = [];
164
- for (let i = 0; i < binary.length; i += this._maxChunkLength) {
165
- const chunk = binary.slice(i, i + this._maxChunkLength);
166
- const isLastChunk = i + this._maxChunkLength >= binary.length;
167
- if (isLastChunk) {
168
- const flags = Buffer.from([
169
- FLAG_SEGMENT_SEQ | FLAG_SEGMENT_SEQ_TERMINATED,
170
- channelId
171
- ]);
172
- messageChunks.push({
173
- payload: Buffer.concat([
174
- flags,
175
- chunk
176
- ]),
177
- trigger: terminatorSentTrigger
178
- });
179
- } else {
180
- const flags = Buffer.from([
181
- FLAG_SEGMENT_SEQ,
182
- channelId
183
- ]);
184
- messageChunks.push({
185
- payload: Buffer.concat([
186
- flags,
187
- chunk
188
- ])
189
- });
190
- }
191
- }
192
- const queuedMessages = this._outMessageChunks.get(channelId);
193
- if (queuedMessages) {
194
- queuedMessages.push(...messageChunks);
195
- } else {
196
- this._outMessageChunks.set(channelId, messageChunks);
197
- }
198
- this._sendChunkedMessages();
199
- return terminatorSentTrigger.wait();
200
- }
201
- receiveData(data) {
202
- if ((data[0] & FLAG_SEGMENT_SEQ) === 0) {
203
- return buf2.fromBinary(MessageSchema2, data.slice(1));
204
- }
205
- const [flags, channelId, ...payload] = data;
206
- let chunkAccumulator = this._inMessageAccumulator.get(channelId);
207
- if (chunkAccumulator) {
208
- chunkAccumulator.push(Buffer.from(payload));
209
- } else {
210
- chunkAccumulator = [
211
- Buffer.from(payload)
212
- ];
213
- this._inMessageAccumulator.set(channelId, chunkAccumulator);
214
- }
215
- if ((flags & FLAG_SEGMENT_SEQ_TERMINATED) === 0) {
216
- return void 0;
217
- }
218
- const message = buf2.fromBinary(MessageSchema2, Buffer.concat(chunkAccumulator));
219
- this._inMessageAccumulator.delete(channelId);
220
- return message;
221
- }
222
- destroy() {
223
- if (this._sendTimeout) {
224
- clearTimeout(this._sendTimeout);
225
- this._sendTimeout = void 0;
226
- }
227
- for (const channelChunks of this._outMessageChunks.values()) {
228
- channelChunks.forEach((chunk) => chunk.trigger?.wake());
229
- }
230
- this._outMessageChunks.clear();
231
- this._inMessageAccumulator.clear();
232
- this._outMessageChannelByService.clear();
233
- }
234
- _sendChunkedMessages() {
235
- if (this._sendTimeout) {
236
- return;
237
- }
238
- const send = () => {
239
- if (this._ws.readyState === 2 || this._ws.readyState === 3) {
240
- log.warn("send called for closed websocket", void 0, {
241
- F: __dxlog_file2,
242
- L: 146,
243
- S: this,
244
- C: (f, a) => f(...a)
245
- });
246
- this._sendTimeout = void 0;
247
- return;
248
- }
249
- let timeout = 0;
250
- const emptyChannels = [];
251
- for (const [channelId, messages] of this._outMessageChunks.entries()) {
252
- if (this._ws.bufferedAmount != null) {
253
- if (this._ws.bufferedAmount + MAX_CHUNK_LENGTH > MAX_BUFFERED_AMOUNT) {
254
- timeout = BUFFER_FULL_BACKOFF_TIMEOUT;
255
- break;
256
- }
257
- }
258
- const nextMessage = messages.shift();
259
- if (nextMessage) {
260
- this._ws.send(nextMessage.payload);
261
- nextMessage.trigger?.wake();
262
- } else {
263
- emptyChannels.push(channelId);
264
- }
265
- }
266
- emptyChannels.forEach((channelId) => this._outMessageChunks.delete(channelId));
267
- if (this._outMessageChunks.size > 0) {
268
- this._sendTimeout = setTimeout(send, timeout);
269
- } else {
270
- this._sendTimeout = void 0;
271
- }
272
- };
273
- this._sendTimeout = setTimeout(send);
274
- }
275
- _resolveChannel(message) {
276
- if (!message.serviceId) {
277
- return void 0;
278
- }
279
- let id = this._outMessageChannelByService.get(message.serviceId);
280
- if (!id) {
281
- id = this._outMessageChannelByService.size + 1;
282
- this._outMessageChannelByService.set(message.serviceId, id);
283
- }
284
- return id;
285
- }
286
- };
287
- var WebSocket;
288
- (function(WebSocket2) {
289
- WebSocket2[WebSocket2["CLOSING"] = 2] = "CLOSING";
290
- WebSocket2[WebSocket2["CLOSED"] = 3] = "CLOSED";
291
- })(WebSocket || (WebSocket = {}));
292
-
293
- export {
294
- getTypename,
295
- Protocol,
296
- toUint8Array,
297
- protocol,
298
- CLOUDFLARE_MESSAGE_MAX_BYTES,
299
- CLOUDFLARE_RPC_MAX_BYTES,
300
- WebSocketMuxer
301
- };
302
- //# sourceMappingURL=chunk-TKYUZ5ZK.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["../../../src/edge-ws-muxer.ts", "../../../src/defs.ts", "../../../src/protocol.ts"],
4
- "sourcesContent": ["//\n// Copyright 2025 DXOS.org\n//\n\nimport { Trigger } from '@dxos/async';\nimport { log } from '@dxos/log';\nimport { buf } from '@dxos/protocols/buf';\nimport { MessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { protocol } from './defs';\n\n/**\n * 0000 0001 - message contains a part of segmented message chunk sequence.\n * The next byte defines a channel id and the rest of the message contains a part of Message proto binary.\n * Messages from different channels might interleave.\n * When the flag is NOT set the rest of the message should be interpreted as the valid Message proto binary.\n */\nconst FLAG_SEGMENT_SEQ = 1;\n/**\n * 0000 0010 - message terminates a segmented message chunk sequence.\n * All the chunks accumulated for the channel specified by the second byte can be concatenated\n * and interpreted as a valid Message proto binary.\n */\nconst FLAG_SEGMENT_SEQ_TERMINATED = 1 << 1;\n\n/**\n * https://developers.cloudflare.com/durable-objects/platform/limits/\n */\nexport const CLOUDFLARE_MESSAGE_MAX_BYTES = 1000 * 1000; // 1MB\nexport const CLOUDFLARE_RPC_MAX_BYTES = 32 * 1000 * 1000; // 32MB\n\nconst MAX_CHUNK_LENGTH = 16384;\nconst MAX_BUFFERED_AMOUNT = CLOUDFLARE_MESSAGE_MAX_BYTES;\nconst BUFFER_FULL_BACKOFF_TIMEOUT = 100;\n\nexport class WebSocketMuxer {\n private readonly _inMessageAccumulator = new Map<number, Buffer[]>();\n private readonly _outMessageChunks = new Map<number, MessageChunk[]>();\n private readonly _outMessageChannelByService = new Map<string, number>();\n\n private _sendTimeout: any | undefined;\n\n private readonly _maxChunkLength: number;\n\n constructor(\n private readonly _ws: WebSocketCompat,\n config?: { maxChunkLength: number },\n ) {\n this._maxChunkLength = config?.maxChunkLength ?? MAX_CHUNK_LENGTH;\n }\n\n /**\n * Resolves when all the message chunks get enqueued for sending.\n */\n public async send(message: Message): Promise<void> {\n const binary = buf.toBinary(MessageSchema, message);\n const channelId = this._resolveChannel(message);\n if (\n (channelId == null && binary.byteLength > CLOUDFLARE_MESSAGE_MAX_BYTES) ||\n binary.byteLength > CLOUDFLARE_RPC_MAX_BYTES\n ) {\n log.error('Large message dropped', {\n byteLength: binary.byteLength,\n serviceId: message.serviceId,\n payload: protocol.getPayloadType(message),\n channelId,\n });\n return;\n }\n\n if (channelId == null || binary.length < this._maxChunkLength) {\n const flags = Buffer.from([0]);\n this._ws.send(Buffer.concat([flags, binary]));\n return;\n }\n\n const terminatorSentTrigger = new Trigger();\n const messageChunks: MessageChunk[] = [];\n for (let i = 0; i < binary.length; i += this._maxChunkLength) {\n const chunk = binary.slice(i, i + this._maxChunkLength);\n const isLastChunk = i + this._maxChunkLength >= binary.length;\n if (isLastChunk) {\n const flags = Buffer.from([FLAG_SEGMENT_SEQ | FLAG_SEGMENT_SEQ_TERMINATED, channelId]);\n messageChunks.push({ payload: Buffer.concat([flags, chunk]), trigger: terminatorSentTrigger });\n } else {\n const flags = Buffer.from([FLAG_SEGMENT_SEQ, channelId]);\n messageChunks.push({ payload: Buffer.concat([flags, chunk]) });\n }\n }\n\n const queuedMessages = this._outMessageChunks.get(channelId);\n if (queuedMessages) {\n queuedMessages.push(...messageChunks);\n } else {\n this._outMessageChunks.set(channelId, messageChunks);\n }\n\n this._sendChunkedMessages();\n\n return terminatorSentTrigger.wait();\n }\n\n public receiveData(data: Uint8Array): Message | undefined {\n if ((data[0] & FLAG_SEGMENT_SEQ) === 0) {\n return buf.fromBinary(MessageSchema, data.slice(1));\n }\n\n const [flags, channelId, ...payload] = data;\n let chunkAccumulator = this._inMessageAccumulator.get(channelId);\n if (chunkAccumulator) {\n chunkAccumulator.push(Buffer.from(payload));\n } else {\n chunkAccumulator = [Buffer.from(payload)];\n this._inMessageAccumulator.set(channelId, chunkAccumulator);\n }\n\n if ((flags & FLAG_SEGMENT_SEQ_TERMINATED) === 0) {\n return undefined;\n }\n\n const message = buf.fromBinary(MessageSchema, Buffer.concat(chunkAccumulator));\n this._inMessageAccumulator.delete(channelId);\n return message;\n }\n\n public destroy() {\n if (this._sendTimeout) {\n clearTimeout(this._sendTimeout);\n this._sendTimeout = undefined;\n }\n for (const channelChunks of this._outMessageChunks.values()) {\n channelChunks.forEach((chunk) => chunk.trigger?.wake());\n }\n this._outMessageChunks.clear();\n this._inMessageAccumulator.clear();\n this._outMessageChannelByService.clear();\n }\n\n private _sendChunkedMessages() {\n if (this._sendTimeout) {\n return;\n }\n\n const send = () => {\n if (this._ws.readyState === WebSocket.CLOSING || this._ws.readyState === WebSocket.CLOSED) {\n log.warn('send called for closed websocket');\n this._sendTimeout = undefined;\n return;\n }\n\n let timeout = 0;\n const emptyChannels: number[] = [];\n for (const [channelId, messages] of this._outMessageChunks.entries()) {\n if (this._ws.bufferedAmount != null) {\n if (this._ws.bufferedAmount + MAX_CHUNK_LENGTH > MAX_BUFFERED_AMOUNT) {\n timeout = BUFFER_FULL_BACKOFF_TIMEOUT;\n break;\n }\n }\n\n const nextMessage = messages.shift();\n if (nextMessage) {\n this._ws.send(nextMessage.payload);\n nextMessage.trigger?.wake();\n } else {\n emptyChannels.push(channelId);\n }\n }\n\n emptyChannels.forEach((channelId) => this._outMessageChunks.delete(channelId));\n\n if (this._outMessageChunks.size > 0) {\n this._sendTimeout = setTimeout(send, timeout);\n } else {\n this._sendTimeout = undefined;\n }\n };\n this._sendTimeout = setTimeout(send);\n }\n\n private _resolveChannel(message: Message): number | undefined {\n if (!message.serviceId) {\n return undefined;\n }\n let id = this._outMessageChannelByService.get(message.serviceId);\n if (!id) {\n id = this._outMessageChannelByService.size + 1;\n this._outMessageChannelByService.set(message.serviceId, id);\n }\n return id;\n }\n}\n\ntype WebSocketCompat = {\n readonly readyState: number;\n /**\n * Not available in workerd.\n */\n bufferedAmount?: number;\n send(message: (ArrayBuffer | ArrayBufferView) | string): void;\n};\n\ntype MessageChunk = {\n payload: Buffer;\n /**\n * Wakes when the payload is enqueued by WebSocket.\n */\n trigger?: Trigger;\n};\n\n/**\n * To avoid using isomorphic-ws on edge.\n */\nenum WebSocket {\n CLOSING = 2,\n CLOSED = 3,\n}\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { bufWkt } from '@dxos/protocols/buf';\nimport { SwarmRequestSchema, SwarmResponseSchema, TextMessageSchema } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\n\nimport { Protocol } from './protocol';\n\nexport const protocol = new Protocol([SwarmRequestSchema, SwarmResponseSchema, TextMessageSchema, bufWkt.AnySchema]);\n", "//\n// Copyright 2024 DXOS.org\n//\n\nimport { invariant } from '@dxos/invariant';\nimport { buf, bufWkt } from '@dxos/protocols/buf';\nimport { type Message, MessageSchema, type PeerSchema } from '@dxos/protocols/buf/dxos/edge/messenger_pb';\nimport { bufferToArray } from '@dxos/util';\n\nexport type PeerData = buf.MessageInitShape<typeof PeerSchema>;\n\nexport const getTypename = (typeName: string) => `type.googleapis.com/${typeName}`;\n\n/**\n * NOTE: The type registry should be extended with all message types.\n */\nexport class Protocol {\n private readonly _typeRegistry: buf.Registry;\n\n constructor(types: buf.DescMessage[]) {\n this._typeRegistry = buf.createRegistry(...types);\n }\n\n get typeRegistry(): buf.Registry {\n return this._typeRegistry;\n }\n\n toJson(message: Message): any {\n try {\n return buf.toJson(MessageSchema, message, { registry: this.typeRegistry });\n } catch (err) {\n return { type: this.getPayloadType(message) };\n }\n }\n\n /**\n * Return the payload with the given type.\n */\n getPayload<Desc extends buf.DescMessage>(message: Message, type: Desc): buf.MessageShape<Desc> {\n invariant(message.payload);\n const payloadTypename = this.getPayloadType(message);\n if (type && type.typeName !== payloadTypename) {\n throw new Error(`Unexpected payload type: ${payloadTypename}; expected ${type.typeName}`);\n }\n\n invariant(bufWkt.anyIs(message.payload, type), `Unexpected payload type: ${payloadTypename}}`);\n const payload = bufWkt.anyUnpack(message.payload, this.typeRegistry) as buf.MessageShape<Desc>;\n invariant(payload, `Empty payload: ${payloadTypename}}`);\n return payload;\n }\n\n /**\n * Get the payload type.\n */\n getPayloadType(message: Message): string | undefined {\n if (!message.payload) {\n return undefined;\n }\n\n const [, type] = message.payload.typeUrl.split('/');\n return type;\n }\n\n /**\n * Create a packed message.\n */\n createMessage<Desc extends buf.DescMessage>(\n type: Desc,\n {\n source,\n target,\n payload,\n serviceId,\n }: {\n source?: PeerData;\n target?: PeerData[];\n payload?: buf.MessageInitShape<Desc>;\n serviceId?: string;\n },\n ) {\n return buf.create(MessageSchema, {\n timestamp: new Date().toISOString(),\n source,\n target,\n serviceId,\n payload: payload ? bufWkt.anyPack(type, buf.create(type, payload)) : undefined,\n });\n }\n}\n\n/**\n * Convert websocket data to Uint8Array.\n */\nexport const toUint8Array = async (data: any): Promise<Uint8Array> => {\n // Node.\n if (data instanceof Buffer) {\n return bufferToArray(data);\n }\n\n // Browser.\n if (data instanceof Blob) {\n return new Uint8Array(await (data as Blob).arrayBuffer());\n }\n\n throw new Error(`Unexpected datatype: ${data}`);\n};\n"],
5
- "mappings": "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",
6
- "names": ["Trigger", "log", "buf", "MessageSchema", "bufWkt", "SwarmRequestSchema", "SwarmResponseSchema", "TextMessageSchema", "invariant", "buf", "bufWkt", "MessageSchema", "bufferToArray", "getTypename", "typeName", "Protocol", "constructor", "types", "_typeRegistry", "createRegistry", "typeRegistry", "toJson", "message", "registry", "err", "type", "getPayloadType", "getPayload", "payload", "payloadTypename", "Error", "anyIs", "anyUnpack", "undefined", "typeUrl", "split", "createMessage", "source", "target", "serviceId", "create", "timestamp", "Date", "toISOString", "anyPack", "toUint8Array", "data", "Buffer", "Blob", "Uint8Array", "arrayBuffer", "protocol", "Protocol", "SwarmRequestSchema", "SwarmResponseSchema", "TextMessageSchema", "bufWkt", "AnySchema", "FLAG_SEGMENT_SEQ", "FLAG_SEGMENT_SEQ_TERMINATED", "CLOUDFLARE_MESSAGE_MAX_BYTES", "CLOUDFLARE_RPC_MAX_BYTES", "MAX_CHUNK_LENGTH", "MAX_BUFFERED_AMOUNT", "BUFFER_FULL_BACKOFF_TIMEOUT", "WebSocketMuxer", "constructor", "_ws", "config", "_inMessageAccumulator", "Map", "_outMessageChunks", "_outMessageChannelByService", "_maxChunkLength", "maxChunkLength", "send", "message", "binary", "buf", "toBinary", "MessageSchema", "channelId", "_resolveChannel", "byteLength", "log", "error", "serviceId", "payload", "protocol", "getPayloadType", "length", "flags", "Buffer", "from", "concat", "terminatorSentTrigger", "Trigger", "messageChunks", "i", "chunk", "slice", "isLastChunk", "push", "trigger", "queuedMessages", "get", "set", "_sendChunkedMessages", "wait", "receiveData", "data", "fromBinary", "chunkAccumulator", "undefined", "delete", "destroy", "_sendTimeout", "clearTimeout", "channelChunks", "values", "forEach", "wake", "clear", "readyState", "warn", "timeout", "emptyChannels", "messages", "entries", "bufferedAmount", "nextMessage", "shift", "size", "setTimeout", "id", "WebSocket"]
7
- }
@@ -1,11 +0,0 @@
1
- import {
2
- CLOUDFLARE_MESSAGE_MAX_BYTES,
3
- CLOUDFLARE_RPC_MAX_BYTES,
4
- WebSocketMuxer
5
- } from "./chunk-TKYUZ5ZK.mjs";
6
- export {
7
- CLOUDFLARE_MESSAGE_MAX_BYTES,
8
- CLOUDFLARE_RPC_MAX_BYTES,
9
- WebSocketMuxer
10
- };
11
- //# sourceMappingURL=edge-ws-muxer.mjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": [],
4
- "sourcesContent": [],
5
- "mappings": "",
6
- "names": []
7
- }