@dxos/edge-client 0.8.3 → 0.8.4-main.28f8d3d

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 (56) hide show
  1. package/dist/lib/browser/{chunk-VHS3XEIX.mjs → chunk-SUXH7FH6.mjs} +15 -8
  2. package/dist/lib/browser/{chunk-VHS3XEIX.mjs.map → chunk-SUXH7FH6.mjs.map} +3 -3
  3. package/dist/lib/browser/edge-ws-muxer.mjs +1 -1
  4. package/dist/lib/browser/index.mjs +239 -149
  5. package/dist/lib/browser/index.mjs.map +4 -4
  6. package/dist/lib/browser/meta.json +1 -1
  7. package/dist/lib/browser/testing/index.mjs +61 -16
  8. package/dist/lib/browser/testing/index.mjs.map +4 -4
  9. package/dist/lib/node-esm/{chunk-HGQUUFIJ.mjs → chunk-R6K4IIBW.mjs} +15 -8
  10. package/dist/lib/node-esm/{chunk-HGQUUFIJ.mjs.map → chunk-R6K4IIBW.mjs.map} +3 -3
  11. package/dist/lib/node-esm/edge-ws-muxer.mjs +1 -1
  12. package/dist/lib/node-esm/index.mjs +239 -149
  13. package/dist/lib/node-esm/index.mjs.map +4 -4
  14. package/dist/lib/node-esm/meta.json +1 -1
  15. package/dist/lib/node-esm/testing/index.mjs +61 -16
  16. package/dist/lib/node-esm/testing/index.mjs.map +4 -4
  17. package/dist/types/src/edge-client.d.ts +1 -1
  18. package/dist/types/src/edge-client.d.ts.map +1 -1
  19. package/dist/types/src/edge-http-client.d.ts +33 -30
  20. package/dist/types/src/edge-http-client.d.ts.map +1 -1
  21. package/dist/types/src/edge-http-client.test.d.ts +2 -0
  22. package/dist/types/src/edge-http-client.test.d.ts.map +1 -0
  23. package/dist/types/src/edge-ws-connection.d.ts +1 -0
  24. package/dist/types/src/edge-ws-connection.d.ts.map +1 -1
  25. package/dist/types/src/edge-ws-muxer.d.ts.map +1 -1
  26. package/dist/types/src/http-client.d.ts +22 -0
  27. package/dist/types/src/http-client.d.ts.map +1 -0
  28. package/dist/types/src/http-client.test.d.ts +2 -0
  29. package/dist/types/src/http-client.test.d.ts.map +1 -0
  30. package/dist/types/src/testing/index.d.ts +1 -0
  31. package/dist/types/src/testing/index.d.ts.map +1 -1
  32. package/dist/types/src/testing/test-server.d.ts +9 -0
  33. package/dist/types/src/testing/test-server.d.ts.map +1 -0
  34. package/dist/types/src/testing/test-utils.d.ts.map +1 -1
  35. package/dist/types/tsconfig.tsbuildinfo +1 -1
  36. package/package.json +21 -14
  37. package/src/edge-client.ts +2 -2
  38. package/src/edge-http-client.test.ts +22 -0
  39. package/src/edge-http-client.ts +192 -135
  40. package/src/edge-ws-connection.ts +11 -3
  41. package/src/edge-ws-muxer.ts +1 -1
  42. package/src/http-client.test.ts +54 -0
  43. package/src/http-client.ts +67 -0
  44. package/src/testing/index.ts +1 -0
  45. package/src/testing/test-server.ts +45 -0
  46. package/src/testing/test-utils.ts +2 -2
  47. package/src/websocket.test.ts +1 -1
  48. package/dist/lib/node/chunk-XNHBUTNB.cjs +0 -317
  49. package/dist/lib/node/chunk-XNHBUTNB.cjs.map +0 -7
  50. package/dist/lib/node/edge-ws-muxer.cjs +0 -33
  51. package/dist/lib/node/edge-ws-muxer.cjs.map +0 -7
  52. package/dist/lib/node/index.cjs +0 -1060
  53. package/dist/lib/node/index.cjs.map +0 -7
  54. package/dist/lib/node/meta.json +0 -1
  55. package/dist/lib/node/testing/index.cjs +0 -169
  56. package/dist/lib/node/testing/index.cjs.map +0 -7
@@ -0,0 +1,54 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { FetchHttpClient, HttpClient } from '@effect/platform';
6
+ import { Effect, pipe } from 'effect';
7
+ import { afterEach, beforeEach, describe, it } from 'vitest';
8
+
9
+ import { invariant } from '@dxos/invariant';
10
+
11
+ import { HttpConfig, withLogging, withRetry, withRetryConfig } from './http-client';
12
+ import { type TestServer, createTestServer, responseHandler } from './testing';
13
+
14
+ describe('HttpClient', () => {
15
+ let server: TestServer | undefined;
16
+
17
+ beforeEach(async () => {
18
+ server = await createTestServer(responseHandler((attempt) => (attempt > 2 ? { value: 100 } : false)));
19
+ });
20
+
21
+ afterEach(() => {
22
+ server?.close();
23
+ server = undefined;
24
+ });
25
+
26
+ // TODO(burdon): Auth headers.
27
+ // TODO(burdon): Add request/response schema type checking.
28
+ it.skipIf(process.env.CI)('should retry', async ({ expect }) => {
29
+ invariant(server);
30
+
31
+ {
32
+ const result = await pipe(
33
+ withRetry(HttpClient.get(server.url)),
34
+ Effect.provide(FetchHttpClient.layer),
35
+ Effect.withSpan('EdgeHttpClient'),
36
+ Effect.runPromise,
37
+ );
38
+ expect(result).toMatchObject({ success: true, data: { value: 100 } });
39
+ }
40
+
41
+ {
42
+ const result = await pipe(
43
+ HttpClient.get(server.url),
44
+ withLogging,
45
+ withRetryConfig,
46
+ Effect.provide(FetchHttpClient.layer),
47
+ Effect.provide(HttpConfig.default), // TODO(burdon): Swap out to mock.
48
+ Effect.withSpan('EdgeHttpClient'), // TODO(burdon): OTEL.
49
+ Effect.runPromise,
50
+ );
51
+ expect(result).toMatchObject({ success: true, data: { value: 100 } });
52
+ }
53
+ });
54
+ });
@@ -0,0 +1,67 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import { type HttpClient } from '@effect/platform';
6
+ import { type HttpClientError } from '@effect/platform/HttpClientError';
7
+ import { type HttpClientResponse } from '@effect/platform/HttpClientResponse';
8
+ import { Context, Duration, Effect, Layer, Schedule } from 'effect';
9
+
10
+ import { log } from '@dxos/log';
11
+
12
+ // TODO(burdon): Factor out.
13
+
14
+ export type RetryOptions = {
15
+ timeout: Duration.Duration;
16
+ retryTimes: number;
17
+ retryBaseDelay: Duration.Duration;
18
+ };
19
+
20
+ // Layer pattern.
21
+ export class HttpConfig extends Context.Tag('HttpConfig')<HttpConfig, RetryOptions>() {
22
+ static default = Layer.succeed(HttpConfig, {
23
+ timeout: Duration.millis(1_000),
24
+ retryTimes: 3,
25
+ retryBaseDelay: Duration.millis(1_000),
26
+ });
27
+ }
28
+
29
+ // HOC pattern.
30
+ export const withRetry = (
31
+ effect: Effect.Effect<HttpClientResponse, HttpClientError, HttpClient.HttpClient>,
32
+ {
33
+ timeout = Duration.millis(1_000),
34
+ retryBaseDelay = Duration.millis(1_000),
35
+ retryTimes = 3,
36
+ }: Partial<RetryOptions> = {},
37
+ ) => {
38
+ return effect.pipe(
39
+ Effect.flatMap((res) =>
40
+ // Treat 500 errors as retryable?
41
+ res.status === 500 ? Effect.fail(new Error(res.status.toString())) : res.json,
42
+ ),
43
+ Effect.timeout(timeout),
44
+ Effect.retry({
45
+ schedule: Schedule.exponential(retryBaseDelay).pipe(Schedule.jittered),
46
+ times: retryTimes,
47
+ }),
48
+ );
49
+ };
50
+
51
+ export const withRetryConfig = (effect: Effect.Effect<HttpClientResponse, HttpClientError, HttpClient.HttpClient>) =>
52
+ Effect.gen(function* () {
53
+ const config = yield* HttpConfig;
54
+ return yield* withRetry(effect, config);
55
+ });
56
+
57
+ export const withLogging = <A extends HttpClientResponse, E, R>(effect: Effect.Effect<A, E, R>) =>
58
+ effect.pipe(Effect.tap((res) => log.info('response', { status: res.status })));
59
+
60
+ /**
61
+ *
62
+ */
63
+ // TODO(burdon): Document.
64
+ export const encodeAuthHeader = (challenge: Uint8Array) => {
65
+ const encodedChallenge = Buffer.from(challenge).toString('base64');
66
+ return `VerifiablePresentation pb;base64,${encodedChallenge}`;
67
+ };
@@ -2,4 +2,5 @@
2
2
  // Copyright 2024 DXOS.org
3
3
  //
4
4
 
5
+ export * from './test-server';
5
6
  export * from './test-utils';
@@ -0,0 +1,45 @@
1
+ //
2
+ // Copyright 2025 DXOS.org
3
+ //
4
+
5
+ import http from 'node:http';
6
+
7
+ import { log } from '@dxos/log';
8
+
9
+ export type TestServer = {
10
+ url: string;
11
+ close: () => void;
12
+ };
13
+
14
+ export type ResponseHandler = (req: http.IncomingMessage, res: http.ServerResponse) => void;
15
+
16
+ export const createTestServer = (responseHandler: ResponseHandler) => {
17
+ const server = http.createServer(responseHandler);
18
+
19
+ return new Promise<TestServer>((resolve) => {
20
+ server.listen(0, () => {
21
+ const address = server.address();
22
+ const port = typeof address === 'object' && address ? address.port : 0;
23
+ resolve({
24
+ url: `http://localhost:${port}`,
25
+ close: () => server.close(),
26
+ });
27
+ });
28
+ });
29
+ };
30
+
31
+ export const responseHandler = (cb: (attempt: number) => false | object): ResponseHandler => {
32
+ let attempt = 0;
33
+ return (req, res) => {
34
+ const data = cb(++attempt) ?? {};
35
+ if (data === false) {
36
+ log('simulating failure', { attempt });
37
+ res.statusCode = 500;
38
+ res.statusMessage = 'Simulating failure';
39
+ res.end('');
40
+ } else {
41
+ res.writeHead(200, { 'Content-Type': 'application/json' });
42
+ res.end(JSON.stringify({ success: true, data }));
43
+ }
44
+ };
45
+ };
@@ -8,7 +8,7 @@ import { Trigger } from '@dxos/async';
8
8
  import { log } from '@dxos/log';
9
9
  import { EdgeWebsocketProtocol } from '@dxos/protocols';
10
10
  import { buf } from '@dxos/protocols/buf';
11
- import { MessageSchema, TextMessageSchema, type Message } from '@dxos/protocols/buf/dxos/edge/messenger_pb';
11
+ import { type Message, MessageSchema, TextMessageSchema } from '@dxos/protocols/buf/dxos/edge/messenger_pb';
12
12
 
13
13
  import { protocol } from '../defs';
14
14
  import { WebSocketMuxer } from '../edge-ws-muxer';
@@ -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: () => EdgeWebsocketProtocol.V1,
30
30
  });
31
31
 
32
32
  let connection: { ws: WebSocket; muxer: WebSocketMuxer } | undefined;
@@ -3,7 +3,7 @@
3
3
  //
4
4
 
5
5
  import WebSocket from 'isomorphic-ws';
6
- import { describe, expect, test, onTestFinished } from 'vitest';
6
+ import { describe, expect, onTestFinished, test } from 'vitest';
7
7
 
8
8
  import { Trigger, TriggerState } from '@dxos/async';
9
9
 
@@ -1,317 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var chunk_XNHBUTNB_exports = {};
20
- __export(chunk_XNHBUTNB_exports, {
21
- CLOUDFLARE_MESSAGE_MAX_BYTES: () => CLOUDFLARE_MESSAGE_MAX_BYTES,
22
- CLOUDFLARE_RPC_MAX_BYTES: () => CLOUDFLARE_RPC_MAX_BYTES,
23
- Protocol: () => Protocol,
24
- WebSocketMuxer: () => WebSocketMuxer,
25
- getTypename: () => getTypename,
26
- protocol: () => protocol,
27
- toUint8Array: () => toUint8Array
28
- });
29
- module.exports = __toCommonJS(chunk_XNHBUTNB_exports);
30
- var import_async = require("@dxos/async");
31
- var import_log = require("@dxos/log");
32
- var import_buf = require("@dxos/protocols/buf");
33
- var import_messenger_pb = require("@dxos/protocols/buf/dxos/edge/messenger_pb");
34
- var import_buf2 = require("@dxos/protocols/buf");
35
- var import_messenger_pb2 = require("@dxos/protocols/buf/dxos/edge/messenger_pb");
36
- var import_invariant = require("@dxos/invariant");
37
- var import_buf3 = require("@dxos/protocols/buf");
38
- var import_messenger_pb3 = require("@dxos/protocols/buf/dxos/edge/messenger_pb");
39
- var import_util = require("@dxos/util");
40
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/protocol.ts";
41
- var getTypename = (typeName) => `type.googleapis.com/${typeName}`;
42
- var Protocol = class {
43
- constructor(types) {
44
- this._typeRegistry = import_buf3.buf.createRegistry(...types);
45
- }
46
- get typeRegistry() {
47
- return this._typeRegistry;
48
- }
49
- toJson(message) {
50
- try {
51
- return import_buf3.buf.toJson(import_messenger_pb3.MessageSchema, message, {
52
- registry: this.typeRegistry
53
- });
54
- } catch (err) {
55
- return {
56
- type: this.getPayloadType(message)
57
- };
58
- }
59
- }
60
- /**
61
- * Return the payload with the given type.
62
- */
63
- getPayload(message, type) {
64
- (0, import_invariant.invariant)(message.payload, void 0, {
65
- F: __dxlog_file,
66
- L: 40,
67
- S: this,
68
- A: [
69
- "message.payload",
70
- ""
71
- ]
72
- });
73
- const payloadTypename = this.getPayloadType(message);
74
- if (type && type.typeName !== payloadTypename) {
75
- throw new Error(`Unexpected payload type: ${payloadTypename}; expected ${type.typeName}`);
76
- }
77
- (0, import_invariant.invariant)(import_buf3.bufWkt.anyIs(message.payload, type), `Unexpected payload type: ${payloadTypename}}`, {
78
- F: __dxlog_file,
79
- L: 46,
80
- S: this,
81
- A: [
82
- "bufWkt.anyIs(message.payload, type)",
83
- "`Unexpected payload type: ${payloadTypename}}`"
84
- ]
85
- });
86
- const payload = import_buf3.bufWkt.anyUnpack(message.payload, this.typeRegistry);
87
- (0, import_invariant.invariant)(payload, `Empty payload: ${payloadTypename}}`, {
88
- F: __dxlog_file,
89
- L: 48,
90
- S: this,
91
- A: [
92
- "payload",
93
- "`Empty payload: ${payloadTypename}}`"
94
- ]
95
- });
96
- return payload;
97
- }
98
- /**
99
- * Get the payload type.
100
- */
101
- getPayloadType(message) {
102
- if (!message.payload) {
103
- return void 0;
104
- }
105
- const [, type] = message.payload.typeUrl.split("/");
106
- return type;
107
- }
108
- /**
109
- * Create a packed message.
110
- */
111
- createMessage(type, { source, target, payload, serviceId }) {
112
- return import_buf3.buf.create(import_messenger_pb3.MessageSchema, {
113
- timestamp: (/* @__PURE__ */ new Date()).toISOString(),
114
- source,
115
- target,
116
- serviceId,
117
- payload: payload ? import_buf3.bufWkt.anyPack(type, import_buf3.buf.create(type, payload)) : void 0
118
- });
119
- }
120
- };
121
- var toUint8Array = async (data) => {
122
- if (data instanceof Buffer) {
123
- return (0, import_util.bufferToArray)(data);
124
- }
125
- if (data instanceof Blob) {
126
- return new Uint8Array(await data.arrayBuffer());
127
- }
128
- throw new Error(`Unexpected datatype: ${data}`);
129
- };
130
- var protocol = new Protocol([
131
- import_messenger_pb2.SwarmRequestSchema,
132
- import_messenger_pb2.SwarmResponseSchema,
133
- import_messenger_pb2.TextMessageSchema,
134
- import_buf2.bufWkt.AnySchema
135
- ]);
136
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/edge-client/src/edge-ws-muxer.ts";
137
- var FLAG_SEGMENT_SEQ = 1;
138
- var FLAG_SEGMENT_SEQ_TERMINATED = 1 << 1;
139
- var CLOUDFLARE_MESSAGE_MAX_BYTES = 1e3 * 1e3;
140
- var CLOUDFLARE_RPC_MAX_BYTES = 32 * 1e3 * 1e3;
141
- var MAX_CHUNK_LENGTH = 16384;
142
- var MAX_BUFFERED_AMOUNT = CLOUDFLARE_MESSAGE_MAX_BYTES;
143
- var BUFFER_FULL_BACKOFF_TIMEOUT = 100;
144
- var WebSocketMuxer = class {
145
- constructor(_ws, config) {
146
- this._ws = _ws;
147
- this._inMessageAccumulator = /* @__PURE__ */ new Map();
148
- this._outMessageChunks = /* @__PURE__ */ new Map();
149
- this._outMessageChannelByService = /* @__PURE__ */ new Map();
150
- this._maxChunkLength = config?.maxChunkLength ?? MAX_CHUNK_LENGTH;
151
- }
152
- /**
153
- * Resolves when all the message chunks get enqueued for sending.
154
- */
155
- async send(message) {
156
- const binary = import_buf.buf.toBinary(import_messenger_pb.MessageSchema, message);
157
- const channelId = this._resolveChannel(message);
158
- if (channelId == null && binary.byteLength > CLOUDFLARE_MESSAGE_MAX_BYTES || binary.byteLength > CLOUDFLARE_RPC_MAX_BYTES) {
159
- import_log.log.error("Large message dropped", {
160
- byteLength: binary.byteLength,
161
- serviceId: message.serviceId,
162
- payload: protocol.getPayloadType(message),
163
- channelId
164
- }, {
165
- F: __dxlog_file2,
166
- L: 62,
167
- S: this,
168
- C: (f, a) => f(...a)
169
- });
170
- return;
171
- }
172
- if (channelId == null || binary.length < this._maxChunkLength) {
173
- const flags = Buffer.from([
174
- 0
175
- ]);
176
- this._ws.send(Buffer.concat([
177
- flags,
178
- binary
179
- ]));
180
- return;
181
- }
182
- const terminatorSentTrigger = new import_async.Trigger();
183
- const messageChunks = [];
184
- for (let i = 0; i < binary.length; i += this._maxChunkLength) {
185
- const chunk = binary.slice(i, i + this._maxChunkLength);
186
- const isLastChunk = i + this._maxChunkLength >= binary.length;
187
- if (isLastChunk) {
188
- const flags = Buffer.from([
189
- FLAG_SEGMENT_SEQ | FLAG_SEGMENT_SEQ_TERMINATED,
190
- channelId
191
- ]);
192
- messageChunks.push({
193
- payload: Buffer.concat([
194
- flags,
195
- chunk
196
- ]),
197
- trigger: terminatorSentTrigger
198
- });
199
- } else {
200
- const flags = Buffer.from([
201
- FLAG_SEGMENT_SEQ,
202
- channelId
203
- ]);
204
- messageChunks.push({
205
- payload: Buffer.concat([
206
- flags,
207
- chunk
208
- ])
209
- });
210
- }
211
- }
212
- const queuedMessages = this._outMessageChunks.get(channelId);
213
- if (queuedMessages) {
214
- queuedMessages.push(...messageChunks);
215
- } else {
216
- this._outMessageChunks.set(channelId, messageChunks);
217
- }
218
- this._sendChunkedMessages();
219
- return terminatorSentTrigger.wait();
220
- }
221
- receiveData(data) {
222
- if ((data[0] & FLAG_SEGMENT_SEQ) === 0) {
223
- return import_buf.buf.fromBinary(import_messenger_pb.MessageSchema, data.slice(1));
224
- }
225
- const [flags, channelId, ...payload] = data;
226
- let chunkAccumulator = this._inMessageAccumulator.get(channelId);
227
- if (chunkAccumulator) {
228
- chunkAccumulator.push(Buffer.from(payload));
229
- } else {
230
- chunkAccumulator = [
231
- Buffer.from(payload)
232
- ];
233
- this._inMessageAccumulator.set(channelId, chunkAccumulator);
234
- }
235
- if ((flags & FLAG_SEGMENT_SEQ_TERMINATED) === 0) {
236
- return void 0;
237
- }
238
- const message = import_buf.buf.fromBinary(import_messenger_pb.MessageSchema, Buffer.concat(chunkAccumulator));
239
- this._inMessageAccumulator.delete(channelId);
240
- return message;
241
- }
242
- destroy() {
243
- if (this._sendTimeout) {
244
- clearTimeout(this._sendTimeout);
245
- this._sendTimeout = void 0;
246
- }
247
- for (const channelChunks of this._outMessageChunks.values()) {
248
- channelChunks.forEach((chunk) => chunk.trigger?.wake());
249
- }
250
- this._outMessageChunks.clear();
251
- this._inMessageAccumulator.clear();
252
- this._outMessageChannelByService.clear();
253
- }
254
- _sendChunkedMessages() {
255
- if (this._sendTimeout) {
256
- return;
257
- }
258
- const send = () => {
259
- if (this._ws.readyState === 2 || this._ws.readyState === 3) {
260
- import_log.log.warn("send called for closed websocket", void 0, {
261
- F: __dxlog_file2,
262
- L: 146,
263
- S: this,
264
- C: (f, a) => f(...a)
265
- });
266
- this._sendTimeout = void 0;
267
- return;
268
- }
269
- let timeout = 0;
270
- const emptyChannels = [];
271
- for (const [channelId, messages] of this._outMessageChunks.entries()) {
272
- if (this._ws.bufferedAmount != null) {
273
- if (this._ws.bufferedAmount + MAX_CHUNK_LENGTH > MAX_BUFFERED_AMOUNT) {
274
- timeout = BUFFER_FULL_BACKOFF_TIMEOUT;
275
- break;
276
- }
277
- }
278
- const nextMessage = messages.shift();
279
- if (nextMessage) {
280
- this._ws.send(nextMessage.payload);
281
- nextMessage.trigger?.wake();
282
- } else {
283
- emptyChannels.push(channelId);
284
- }
285
- }
286
- emptyChannels.forEach((channelId) => this._outMessageChunks.delete(channelId));
287
- if (this._outMessageChunks.size > 0) {
288
- this._sendTimeout = setTimeout(send, timeout);
289
- } else {
290
- this._sendTimeout = void 0;
291
- }
292
- };
293
- this._sendTimeout = setTimeout(send);
294
- }
295
- _resolveChannel(message) {
296
- if (!message.serviceId) {
297
- return void 0;
298
- }
299
- let id = this._outMessageChannelByService.get(message.serviceId);
300
- if (!id) {
301
- id = this._outMessageChannelByService.size + 1;
302
- this._outMessageChannelByService.set(message.serviceId, id);
303
- }
304
- return id;
305
- }
306
- };
307
- // Annotate the CommonJS export names for ESM import in node:
308
- 0 && (module.exports = {
309
- CLOUDFLARE_MESSAGE_MAX_BYTES,
310
- CLOUDFLARE_RPC_MAX_BYTES,
311
- Protocol,
312
- WebSocketMuxer,
313
- getTypename,
314
- protocol,
315
- toUint8Array
316
- });
317
- //# sourceMappingURL=chunk-XNHBUTNB.cjs.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(): void {\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(): void {\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 ): Message {\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": ["import_buf", "import_messenger_pb", "getTypename", "typeName", "Protocol", "types", "_typeRegistry", "buf", "createRegistry", "typeRegistry", "toJson", "message", "MessageSchema", "registry", "err", "type", "getPayloadType", "getPayload", "invariant", "payload", "payloadTypename", "Error", "bufWkt", "anyIs", "anyUnpack", "undefined", "typeUrl", "split", "createMessage", "source", "target", "serviceId", "create", "timestamp", "Date", "toISOString", "anyPack", "toUint8Array", "data", "Buffer", "bufferToArray", "Blob", "Uint8Array", "arrayBuffer", "protocol", "SwarmRequestSchema", "SwarmResponseSchema", "TextMessageSchema", "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", "_ws", "config", "_inMessageAccumulator", "Map", "_outMessageChunks", "_outMessageChannelByService", "_maxChunkLength", "maxChunkLength", "send", "binary", "toBinary", "channelId", "_resolveChannel", "byteLength", "log", "error", "length", "flags", "from", "concat", "terminatorSentTrigger", "Trigger", "messageChunks", "i", "chunk", "slice", "isLastChunk", "push", "trigger", "queuedMessages", "get", "set", "_sendChunkedMessages", "wait", "receiveData", "fromBinary", "chunkAccumulator", "delete", "destroy", "_sendTimeout", "clearTimeout", "channelChunks", "values", "forEach", "wake", "clear", "readyState", "warn", "timeout", "emptyChannels", "messages", "entries", "bufferedAmount", "nextMessage", "shift", "size", "setTimeout", "id"]
7
- }
@@ -1,33 +0,0 @@
1
- "use strict";
2
- var __defProp = Object.defineProperty;
3
- var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
4
- var __getOwnPropNames = Object.getOwnPropertyNames;
5
- var __hasOwnProp = Object.prototype.hasOwnProperty;
6
- var __export = (target, all) => {
7
- for (var name in all)
8
- __defProp(target, name, { get: all[name], enumerable: true });
9
- };
10
- var __copyProps = (to, from, except, desc) => {
11
- if (from && typeof from === "object" || typeof from === "function") {
12
- for (let key of __getOwnPropNames(from))
13
- if (!__hasOwnProp.call(to, key) && key !== except)
14
- __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
15
- }
16
- return to;
17
- };
18
- var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
19
- var edge_ws_muxer_exports = {};
20
- __export(edge_ws_muxer_exports, {
21
- CLOUDFLARE_MESSAGE_MAX_BYTES: () => import_chunk_XNHBUTNB.CLOUDFLARE_MESSAGE_MAX_BYTES,
22
- CLOUDFLARE_RPC_MAX_BYTES: () => import_chunk_XNHBUTNB.CLOUDFLARE_RPC_MAX_BYTES,
23
- WebSocketMuxer: () => import_chunk_XNHBUTNB.WebSocketMuxer
24
- });
25
- module.exports = __toCommonJS(edge_ws_muxer_exports);
26
- var import_chunk_XNHBUTNB = require("./chunk-XNHBUTNB.cjs");
27
- // Annotate the CommonJS export names for ESM import in node:
28
- 0 && (module.exports = {
29
- CLOUDFLARE_MESSAGE_MAX_BYTES,
30
- CLOUDFLARE_RPC_MAX_BYTES,
31
- WebSocketMuxer
32
- });
33
- //# sourceMappingURL=edge-ws-muxer.cjs.map
@@ -1,7 +0,0 @@
1
- {
2
- "version": 3,
3
- "sources": ["edge-ws-muxer.cjs"],
4
- "sourcesContent": ["import {\n CLOUDFLARE_MESSAGE_MAX_BYTES,\n CLOUDFLARE_RPC_MAX_BYTES,\n WebSocketMuxer\n} from \"./chunk-XNHBUTNB.cjs\";\nexport {\n CLOUDFLARE_MESSAGE_MAX_BYTES,\n CLOUDFLARE_RPC_MAX_BYTES,\n WebSocketMuxer\n};\n//# sourceMappingURL=edge-ws-muxer.cjs.map\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,4BAIO;",
6
- "names": []
7
- }