@dxos/messaging 0.3.8-next.f4e0086 → 0.3.8

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.
@@ -13,7 +13,7 @@ import { ComplexMap, ComplexSet } from "@dxos/util";
13
13
  var MESSAGE_TIMEOUT = 1e4;
14
14
 
15
15
  // packages/core/mesh/messaging/src/messenger.ts
16
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/messenger.ts";
16
+ var __dxlog_file = "/home/circleci/project/packages/core/mesh/messaging/src/messenger.ts";
17
17
  var ReliablePayload = schema.getCodecForType("dxos.mesh.messaging.ReliablePayload");
18
18
  var Acknowledgement = schema.getCodecForType("dxos.mesh.messaging.Acknowledgement");
19
19
  var RECEIVED_MESSAGES_GC_INTERVAL = 12e4;
@@ -373,7 +373,7 @@ import { PublicKey as PublicKey2 } from "@dxos/keys";
373
373
  import { log as log2 } from "@dxos/log";
374
374
  import { schema as schema2, trace as trace2 } from "@dxos/protocols";
375
375
  import { createProtoRpcPeer } from "@dxos/rpc";
376
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts";
376
+ var __dxlog_file2 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts";
377
377
  var SignalRPCClient = class {
378
378
  constructor({ url, callbacks = {} }) {
379
379
  this._connectTrigger = new Trigger();
@@ -608,7 +608,7 @@ var SignalRPCClient = class {
608
608
  };
609
609
 
610
610
  // packages/core/mesh/messaging/src/signal-client/signal-client.ts
611
- var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-client/signal-client.ts";
611
+ var __dxlog_file3 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-client/signal-client.ts";
612
612
  var DEFAULT_RECONNECT_TIMEOUT = 100;
613
613
  var MAX_RECONNECT_TIMEOUT = 5e3;
614
614
  var ERROR_RECONCILE_DELAY = 1e3;
@@ -1075,7 +1075,7 @@ import { PublicKey as PublicKey4 } from "@dxos/keys";
1075
1075
  import { log as log4 } from "@dxos/log";
1076
1076
  import { schema as schema3 } from "@dxos/protocols";
1077
1077
  import { ComplexMap as ComplexMap3, ComplexSet as ComplexSet3 } from "@dxos/util";
1078
- var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts";
1078
+ var __dxlog_file4 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts";
1079
1079
  var MemorySignalManagerContext = class {
1080
1080
  constructor() {
1081
1081
  // Swarm messages.
@@ -1347,7 +1347,7 @@ function _ts_decorate(decorators, target, key, desc) {
1347
1347
  r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1348
1348
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1349
1349
  }
1350
- var __dxlog_file5 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts";
1350
+ var __dxlog_file5 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts";
1351
1351
  var MAX_SERVER_FAILURES = 5;
1352
1352
  var WSS_SIGNAL_SERVER_REBOOT_DELAY = 3e3;
1353
1353
  var WebsocketSignalManager = class {
@@ -1 +1 @@
1
- {"inputs":{"packages/core/mesh/messaging/src/timeouts.ts":{"bytes":656,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/messenger.ts":{"bytes":34092,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/timeouts.ts","kind":"import-statement","original":"./timeouts"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytes":20064,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytes":52212,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts","kind":"import-statement","original":"./signal-rpc-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytes":499,"imports":[{"path":"packages/core/mesh/messaging/src/signal-client/signal-client.ts","kind":"import-statement","original":"./signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytes":24494,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts":{"bytes":1316,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytes":24728,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"../signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytes":750,"imports":[{"path":"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts","kind":"import-statement","original":"./memory-signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts","kind":"import-statement","original":"./websocket-signal-manager"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-methods.ts":{"bytes":1633,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/index.ts":{"bytes":782,"imports":[{"path":"packages/core/mesh/messaging/src/messenger.ts","kind":"import-statement","original":"./messenger"},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"./signal-client"},{"path":"packages/core/mesh/messaging/src/signal-manager/index.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-methods.ts","kind":"import-statement","original":"./signal-methods"}],"format":"esm"}},"outputs":{"packages/core/mesh/messaging/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":71750},"packages/core/mesh/messaging/dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true}],"exports":["MemorySignalManager","MemorySignalManagerContext","Messenger","SignalClient","WebsocketSignalManager"],"entryPoint":"packages/core/mesh/messaging/src/index.ts","inputs":{"packages/core/mesh/messaging/src/messenger.ts":{"bytesInOutput":9633},"packages/core/mesh/messaging/src/timeouts.ts":{"bytesInOutput":27},"packages/core/mesh/messaging/src/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytesInOutput":13587},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytesInOutput":6017},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytesInOutput":6661},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytesInOutput":8157}},"bytes":44783}}}
1
+ {"inputs":{"packages/core/mesh/messaging/src/timeouts.ts":{"bytes":651,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/messenger.ts":{"bytes":34087,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/timeouts.ts","kind":"import-statement","original":"./timeouts"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytes":20059,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytes":52207,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts","kind":"import-statement","original":"./signal-rpc-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytes":494,"imports":[{"path":"packages/core/mesh/messaging/src/signal-client/signal-client.ts","kind":"import-statement","original":"./signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytes":24489,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts":{"bytes":1311,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytes":24723,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"../signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytes":745,"imports":[{"path":"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts","kind":"import-statement","original":"./memory-signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts","kind":"import-statement","original":"./websocket-signal-manager"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-methods.ts":{"bytes":1628,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/index.ts":{"bytes":777,"imports":[{"path":"packages/core/mesh/messaging/src/messenger.ts","kind":"import-statement","original":"./messenger"},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"./signal-client"},{"path":"packages/core/mesh/messaging/src/signal-manager/index.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-methods.ts","kind":"import-statement","original":"./signal-methods"}],"format":"esm"}},"outputs":{"packages/core/mesh/messaging/dist/lib/browser/index.mjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":71750},"packages/core/mesh/messaging/dist/lib/browser/index.mjs":{"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true}],"exports":["MemorySignalManager","MemorySignalManagerContext","Messenger","SignalClient","WebsocketSignalManager"],"entryPoint":"packages/core/mesh/messaging/src/index.ts","inputs":{"packages/core/mesh/messaging/src/messenger.ts":{"bytesInOutput":9628},"packages/core/mesh/messaging/src/timeouts.ts":{"bytesInOutput":27},"packages/core/mesh/messaging/src/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytesInOutput":13582},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytesInOutput":6012},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytesInOutput":6656},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytesInOutput":8152}},"bytes":44758}}}
@@ -26,19 +26,15 @@ var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__ge
26
26
  mod
27
27
  ));
28
28
  var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: true }), mod);
29
-
30
- // packages/core/mesh/messaging/src/index.ts
31
- var src_exports = {};
32
- __export(src_exports, {
29
+ var node_exports = {};
30
+ __export(node_exports, {
33
31
  MemorySignalManager: () => MemorySignalManager,
34
32
  MemorySignalManagerContext: () => MemorySignalManagerContext,
35
33
  Messenger: () => Messenger,
36
34
  SignalClient: () => SignalClient,
37
35
  WebsocketSignalManager: () => WebsocketSignalManager
38
36
  });
39
- module.exports = __toCommonJS(src_exports);
40
-
41
- // packages/core/mesh/messaging/src/messenger.ts
37
+ module.exports = __toCommonJS(node_exports);
42
38
  var import_async = require("@dxos/async");
43
39
  var import_context = require("@dxos/context");
44
40
  var import_invariant = require("@dxos/invariant");
@@ -46,26 +42,45 @@ var import_keys = require("@dxos/keys");
46
42
  var import_log = require("@dxos/log");
47
43
  var import_protocols = require("@dxos/protocols");
48
44
  var import_util = require("@dxos/util");
49
-
50
- // packages/core/mesh/messaging/src/timeouts.ts
45
+ var import_async2 = require("@dxos/async");
46
+ var import_context2 = require("@dxos/context");
47
+ var import_invariant2 = require("@dxos/invariant");
48
+ var import_keys2 = require("@dxos/keys");
49
+ var import_log2 = require("@dxos/log");
50
+ var import_protocols2 = require("@dxos/protocols");
51
+ var import_signal = require("@dxos/protocols/proto/dxos/mesh/signal");
52
+ var import_util2 = require("@dxos/util");
53
+ var import_isomorphic_ws = __toESM(require("isomorphic-ws"));
54
+ var import_async3 = require("@dxos/async");
55
+ var import_invariant3 = require("@dxos/invariant");
56
+ var import_keys3 = require("@dxos/keys");
57
+ var import_log3 = require("@dxos/log");
58
+ var import_protocols3 = require("@dxos/protocols");
59
+ var import_rpc = require("@dxos/rpc");
60
+ var import_async4 = require("@dxos/async");
61
+ var import_context3 = require("@dxos/context");
62
+ var import_invariant4 = require("@dxos/invariant");
63
+ var import_keys4 = require("@dxos/keys");
64
+ var import_log4 = require("@dxos/log");
65
+ var import_protocols4 = require("@dxos/protocols");
66
+ var import_util3 = require("@dxos/util");
67
+ var import_async5 = require("@dxos/async");
68
+ var import_context4 = require("@dxos/context");
69
+ var import_invariant5 = require("@dxos/invariant");
70
+ var import_keys5 = require("@dxos/keys");
71
+ var import_log5 = require("@dxos/log");
72
+ var import_protocols5 = require("@dxos/protocols");
51
73
  var MESSAGE_TIMEOUT = 1e4;
52
-
53
- // packages/core/mesh/messaging/src/messenger.ts
54
- var __dxlog_file = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/messenger.ts";
74
+ var __dxlog_file = "/home/circleci/project/packages/core/mesh/messaging/src/messenger.ts";
55
75
  var ReliablePayload = import_protocols.schema.getCodecForType("dxos.mesh.messaging.ReliablePayload");
56
76
  var Acknowledgement = import_protocols.schema.getCodecForType("dxos.mesh.messaging.Acknowledgement");
57
77
  var RECEIVED_MESSAGES_GC_INTERVAL = 12e4;
58
78
  var Messenger = class {
59
79
  constructor({ signalManager, retryDelay = 300 }) {
60
- // { peerId, payloadType } => listeners set
61
80
  this._listeners = new import_util.ComplexMap(({ peerId, payloadType }) => peerId.toHex() + payloadType);
62
- // peerId => listeners set
63
81
  this._defaultListeners = new import_util.ComplexMap(import_keys.PublicKey.hash);
64
82
  this._onAckCallbacks = new import_util.ComplexMap(import_keys.PublicKey.hash);
65
83
  this._receivedMessages = new import_util.ComplexSet(import_keys.PublicKey.hash);
66
- /**
67
- * Keys scheduled to be cleared from _receivedMessages on the next iteration.
68
- */
69
84
  this._toClear = new import_util.ComplexSet(import_keys.PublicKey.hash);
70
85
  this._closed = true;
71
86
  this._signalManager = signalManager;
@@ -392,32 +407,13 @@ var Messenger = class {
392
407
  }
393
408
  }
394
409
  };
395
-
396
- // packages/core/mesh/messaging/src/signal-client/signal-client.ts
397
- var import_async3 = require("@dxos/async");
398
- var import_context2 = require("@dxos/context");
399
- var import_invariant3 = require("@dxos/invariant");
400
- var import_keys3 = require("@dxos/keys");
401
- var import_log3 = require("@dxos/log");
402
- var import_protocols3 = require("@dxos/protocols");
403
- var import_signal = require("@dxos/protocols/proto/dxos/mesh/signal");
404
- var import_util2 = require("@dxos/util");
405
-
406
- // packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts
407
- var import_isomorphic_ws = __toESM(require("isomorphic-ws"));
408
- var import_async2 = require("@dxos/async");
409
- var import_invariant2 = require("@dxos/invariant");
410
- var import_keys2 = require("@dxos/keys");
411
- var import_log2 = require("@dxos/log");
412
- var import_protocols2 = require("@dxos/protocols");
413
- var import_rpc = require("@dxos/rpc");
414
- var __dxlog_file2 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts";
410
+ var __dxlog_file2 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts";
415
411
  var SignalRPCClient = class {
416
412
  constructor({ url, callbacks = {} }) {
417
- this._connectTrigger = new import_async2.Trigger();
413
+ this._connectTrigger = new import_async3.Trigger();
418
414
  this._closed = false;
419
- const traceId = import_keys2.PublicKey.random().toHex();
420
- import_log2.log.trace("dxos.mesh.signal-rpc-client.constructor", import_protocols2.trace.begin({
415
+ const traceId = import_keys3.PublicKey.random().toHex();
416
+ import_log3.log.trace("dxos.mesh.signal-rpc-client.constructor", import_protocols3.trace.begin({
421
417
  id: traceId
422
418
  }), {
423
419
  F: __dxlog_file2,
@@ -430,7 +426,7 @@ var SignalRPCClient = class {
430
426
  this._socket = new import_isomorphic_ws.default(this._url);
431
427
  this._rpc = (0, import_rpc.createProtoRpcPeer)({
432
428
  requested: {
433
- Signal: import_protocols2.schema.getService("dxos.mesh.signal.Signal")
429
+ Signal: import_protocols3.schema.getService("dxos.mesh.signal.Signal")
434
430
  },
435
431
  noHandshake: true,
436
432
  port: {
@@ -441,7 +437,7 @@ var SignalRPCClient = class {
441
437
  try {
442
438
  this._socket.send(msg);
443
439
  } catch (err) {
444
- import_log2.log.warn("send error", err, {
440
+ import_log3.log.warn("send error", err, {
445
441
  F: __dxlog_file2,
446
442
  L: 68,
447
443
  S: this,
@@ -466,7 +462,7 @@ var SignalRPCClient = class {
466
462
  this._socket.onopen = async () => {
467
463
  try {
468
464
  await this._rpc.open();
469
- (0, import_log2.log)(`RPC open ${this._url}`, void 0, {
465
+ (0, import_log3.log)(`RPC open ${this._url}`, void 0, {
470
466
  F: __dxlog_file2,
471
467
  L: 89,
472
468
  S: this,
@@ -479,7 +475,7 @@ var SignalRPCClient = class {
479
475
  }
480
476
  };
481
477
  this._socket.onclose = async () => {
482
- (0, import_log2.log)(`Disconnected ${this._url}`, void 0, {
478
+ (0, import_log3.log)(`Disconnected ${this._url}`, void 0, {
483
479
  F: __dxlog_file2,
484
480
  L: 98,
485
481
  S: this,
@@ -497,7 +493,7 @@ var SignalRPCClient = class {
497
493
  try {
498
494
  await this._rpc?.close();
499
495
  } catch (err) {
500
- import_log2.log.catch(err, void 0, {
496
+ import_log3.log.catch(err, void 0, {
501
497
  F: __dxlog_file2,
502
498
  L: 115,
503
499
  S: this,
@@ -505,7 +501,7 @@ var SignalRPCClient = class {
505
501
  });
506
502
  }
507
503
  this._closed = true;
508
- import_log2.log.warn(event.message ?? "Socket error", {
504
+ import_log3.log.warn(event.message ?? "Socket error", {
509
505
  url: this._url
510
506
  }, {
511
507
  F: __dxlog_file2,
@@ -514,7 +510,7 @@ var SignalRPCClient = class {
514
510
  C: (f, a) => f(...a)
515
511
  });
516
512
  };
517
- import_log2.log.trace("dxos.mesh.signal-rpc-client.constructor", import_protocols2.trace.end({
513
+ import_log3.log.trace("dxos.mesh.signal-rpc-client.constructor", import_protocols3.trace.end({
518
514
  id: traceId
519
515
  }), {
520
516
  F: __dxlog_file2,
@@ -529,7 +525,7 @@ var SignalRPCClient = class {
529
525
  await this._rpc?.close();
530
526
  this._socket?.close();
531
527
  } catch (err) {
532
- import_log2.log.warn("close error", err, {
528
+ import_log3.log.warn("close error", err, {
533
529
  F: __dxlog_file2,
534
530
  L: 131,
535
531
  S: this,
@@ -538,7 +534,7 @@ var SignalRPCClient = class {
538
534
  }
539
535
  }
540
536
  async join({ topic, peerId }) {
541
- (0, import_log2.log)("join", {
537
+ (0, import_log3.log)("join", {
542
538
  topic,
543
539
  peerId
544
540
  }, {
@@ -548,7 +544,7 @@ var SignalRPCClient = class {
548
544
  C: (f, a) => f(...a)
549
545
  });
550
546
  await this._connectTrigger.wait();
551
- (0, import_invariant2.invariant)(!this._closed, "SignalRPCClient is closed", {
547
+ (0, import_invariant3.invariant)(!this._closed, "SignalRPCClient is closed", {
552
548
  F: __dxlog_file2,
553
549
  L: 138,
554
550
  S: this,
@@ -557,7 +553,7 @@ var SignalRPCClient = class {
557
553
  "'SignalRPCClient is closed'"
558
554
  ]
559
555
  });
560
- (0, import_invariant2.invariant)(this._rpc, "Rpc is not initialized", {
556
+ (0, import_invariant3.invariant)(this._rpc, "Rpc is not initialized", {
561
557
  F: __dxlog_file2,
562
558
  L: 139,
563
559
  S: this,
@@ -574,7 +570,7 @@ var SignalRPCClient = class {
574
570
  return swarmStream;
575
571
  }
576
572
  async receiveMessages(peerId) {
577
- (0, import_log2.log)("receiveMessages", {
573
+ (0, import_log3.log)("receiveMessages", {
578
574
  peerId
579
575
  }, {
580
576
  F: __dxlog_file2,
@@ -582,7 +578,7 @@ var SignalRPCClient = class {
582
578
  S: this,
583
579
  C: (f, a) => f(...a)
584
580
  });
585
- (0, import_invariant2.invariant)(!this._closed, "SignalRPCClient is closed", {
581
+ (0, import_invariant3.invariant)(!this._closed, "SignalRPCClient is closed", {
586
582
  F: __dxlog_file2,
587
583
  L: 150,
588
584
  S: this,
@@ -592,7 +588,7 @@ var SignalRPCClient = class {
592
588
  ]
593
589
  });
594
590
  await this._connectTrigger.wait();
595
- (0, import_invariant2.invariant)(this._rpc, "Rpc is not initialized", {
591
+ (0, import_invariant3.invariant)(this._rpc, "Rpc is not initialized", {
596
592
  F: __dxlog_file2,
597
593
  L: 152,
598
594
  S: this,
@@ -608,7 +604,7 @@ var SignalRPCClient = class {
608
604
  return messageStream;
609
605
  }
610
606
  async sendMessage({ author, recipient, payload }) {
611
- (0, import_log2.log)("sendMessage", {
607
+ (0, import_log3.log)("sendMessage", {
612
608
  author,
613
609
  recipient,
614
610
  payload
@@ -618,7 +614,7 @@ var SignalRPCClient = class {
618
614
  S: this,
619
615
  C: (f, a) => f(...a)
620
616
  });
621
- (0, import_invariant2.invariant)(!this._closed, "SignalRPCClient is closed", {
617
+ (0, import_invariant3.invariant)(!this._closed, "SignalRPCClient is closed", {
622
618
  F: __dxlog_file2,
623
619
  L: 162,
624
620
  S: this,
@@ -628,7 +624,7 @@ var SignalRPCClient = class {
628
624
  ]
629
625
  });
630
626
  await this._connectTrigger.wait();
631
- (0, import_invariant2.invariant)(this._rpc, "Rpc is not initialized", {
627
+ (0, import_invariant3.invariant)(this._rpc, "Rpc is not initialized", {
632
628
  F: __dxlog_file2,
633
629
  L: 164,
634
630
  S: this,
@@ -644,9 +640,7 @@ var SignalRPCClient = class {
644
640
  });
645
641
  }
646
642
  };
647
-
648
- // packages/core/mesh/messaging/src/signal-client/signal-client.ts
649
- var __dxlog_file3 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-client/signal-client.ts";
643
+ var __dxlog_file3 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-client/signal-client.ts";
650
644
  var DEFAULT_RECONNECT_TIMEOUT = 100;
651
645
  var MAX_RECONNECT_TIMEOUT = 5e3;
652
646
  var ERROR_RECONCILE_DELAY = 1e3;
@@ -664,15 +658,15 @@ var SignalClient = class {
664
658
  this._reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;
665
659
  this._connectionStarted = /* @__PURE__ */ new Date();
666
660
  this._lastStateChange = /* @__PURE__ */ new Date();
667
- this._clientReady = new import_async3.Trigger();
668
- this.statusChanged = new import_async3.Event();
669
- this.commandTrace = new import_async3.Event();
661
+ this._clientReady = new import_async2.Trigger();
662
+ this.statusChanged = new import_async2.Event();
663
+ this.commandTrace = new import_async2.Event();
670
664
  this._swarmStreams = new import_util2.ComplexMap(({ topic, peerId }) => topic.toHex() + peerId.toHex());
671
665
  this._joinedTopics = new import_util2.ComplexSet(({ topic, peerId }) => topic.toHex() + peerId.toHex());
672
666
  this._messageStreams = new import_util2.ComplexMap((key) => key.toHex());
673
667
  this._subscribedMessages = new import_util2.ComplexSet(({ peerId }) => peerId.toHex());
674
- this._reconciled = new import_async3.Event();
675
- this._instanceId = import_keys3.PublicKey.random().toHex();
668
+ this._reconciled = new import_async2.Event();
669
+ this._instanceId = import_keys2.PublicKey.random().toHex();
676
670
  this._performance = {
677
671
  sentMessages: 0,
678
672
  receivedMessages: 0,
@@ -685,7 +679,7 @@ var SignalClient = class {
685
679
  }
686
680
  }
687
681
  open() {
688
- import_log3.log.trace("dxos.mesh.signal-client.open", import_protocols3.trace.begin({
682
+ import_log2.log.trace("dxos.mesh.signal-client.open", import_protocols2.trace.begin({
689
683
  id: this._instanceId
690
684
  }), {
691
685
  F: __dxlog_file3,
@@ -705,7 +699,7 @@ var SignalClient = class {
705
699
  return;
706
700
  }
707
701
  if (this._state === import_signal.SignalState.CONNECTED) {
708
- import_log3.log.warn("SignalClient error:", err, {
702
+ import_log2.log.warn("SignalClient error:", err, {
709
703
  F: __dxlog_file3,
710
704
  L: 147,
711
705
  S: this,
@@ -715,22 +709,22 @@ var SignalClient = class {
715
709
  this._scheduleReconcileAfterError();
716
710
  }
717
711
  });
718
- this._reconcileTask = new import_async3.DeferredTask(this._ctx, async () => {
712
+ this._reconcileTask = new import_async2.DeferredTask(this._ctx, async () => {
719
713
  await this._reconcileSwarmSubscriptions();
720
714
  await this._reconcileMessageSubscriptions();
721
715
  this._reconciled.emit();
722
716
  });
723
- (0, import_async3.scheduleTaskInterval)(this._ctx, async () => {
717
+ (0, import_async2.scheduleTaskInterval)(this._ctx, async () => {
724
718
  if (this._state === import_signal.SignalState.CONNECTED) {
725
719
  this._reconcileTask.schedule();
726
720
  }
727
721
  }, RECONCILE_INTERVAL);
728
- this._reconnectTask = new import_async3.DeferredTask(this._ctx, async () => {
722
+ this._reconnectTask = new import_async2.DeferredTask(this._ctx, async () => {
729
723
  await this._reconnect();
730
724
  });
731
725
  this._setState(import_signal.SignalState.CONNECTING);
732
726
  this._createClient();
733
- import_log3.log.trace("dxos.mesh.signal-client.open", import_protocols3.trace.end({
727
+ import_log2.log.trace("dxos.mesh.signal-client.open", import_protocols2.trace.end({
734
728
  id: this._instanceId
735
729
  }), {
736
730
  F: __dxlog_file3,
@@ -740,7 +734,7 @@ var SignalClient = class {
740
734
  });
741
735
  }
742
736
  async close() {
743
- (0, import_log3.log)("closing...", void 0, {
737
+ (0, import_log2.log)("closing...", void 0, {
744
738
  F: __dxlog_file3,
745
739
  L: 180,
746
740
  S: this,
@@ -756,7 +750,7 @@ var SignalClient = class {
756
750
  await this._client?.close();
757
751
  this._client = void 0;
758
752
  this._setState(import_signal.SignalState.CLOSED);
759
- (0, import_log3.log)("closed", void 0, {
753
+ (0, import_log2.log)("closed", void 0, {
760
754
  F: __dxlog_file3,
761
755
  L: 191,
762
756
  S: this,
@@ -774,7 +768,7 @@ var SignalClient = class {
774
768
  };
775
769
  }
776
770
  async join({ topic, peerId }) {
777
- (0, import_log3.log)("joining", {
771
+ (0, import_log2.log)("joining", {
778
772
  topic,
779
773
  peerId
780
774
  }, {
@@ -792,7 +786,7 @@ var SignalClient = class {
792
786
  }
793
787
  async leave({ topic, peerId }) {
794
788
  this._performance.leaveCounter++;
795
- (0, import_log3.log)("leaving", {
789
+ (0, import_log2.log)("leaving", {
796
790
  topic,
797
791
  peerId
798
792
  }, {
@@ -817,7 +811,7 @@ var SignalClient = class {
817
811
  async sendMessage(msg) {
818
812
  this._performance.sentMessages++;
819
813
  await this._clientReady.wait();
820
- (0, import_invariant3.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
814
+ (0, import_invariant2.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
821
815
  F: __dxlog_file3,
822
816
  L: 224,
823
817
  S: this,
@@ -829,7 +823,7 @@ var SignalClient = class {
829
823
  await this._client.sendMessage(msg);
830
824
  }
831
825
  async subscribeMessages(peerId) {
832
- (0, import_log3.log)("subscribing to messages", {
826
+ (0, import_log2.log)("subscribing to messages", {
833
827
  peerId
834
828
  }, {
835
829
  F: __dxlog_file3,
@@ -843,7 +837,7 @@ var SignalClient = class {
843
837
  this._reconcileTask.schedule();
844
838
  }
845
839
  async unsubscribeMessages(peerId) {
846
- (0, import_log3.log)("unsubscribing from messages", {
840
+ (0, import_log2.log)("unsubscribing from messages", {
847
841
  peerId
848
842
  }, {
849
843
  F: __dxlog_file3,
@@ -858,14 +852,14 @@ var SignalClient = class {
858
852
  this._messageStreams.delete(peerId);
859
853
  }
860
854
  _scheduleReconcileAfterError() {
861
- (0, import_async3.scheduleTask)(this._ctx, () => {
855
+ (0, import_async2.scheduleTask)(this._ctx, () => {
862
856
  this._reconcileTask.schedule();
863
857
  }, ERROR_RECONCILE_DELAY);
864
858
  }
865
859
  _setState(newState) {
866
860
  this._state = newState;
867
861
  this._lastStateChange = /* @__PURE__ */ new Date();
868
- (0, import_log3.log)("signal state changed", {
862
+ (0, import_log2.log)("signal state changed", {
869
863
  status: this.getStatus()
870
864
  }, {
871
865
  F: __dxlog_file3,
@@ -876,7 +870,7 @@ var SignalClient = class {
876
870
  this.statusChanged.emit(this.getStatus());
877
871
  }
878
872
  _createClient() {
879
- (0, import_log3.log)("creating client", {
873
+ (0, import_log2.log)("creating client", {
880
874
  host: this._host,
881
875
  state: this._state
882
876
  }, {
@@ -885,7 +879,7 @@ var SignalClient = class {
885
879
  S: this,
886
880
  C: (f, a) => f(...a)
887
881
  });
888
- (0, import_invariant3.invariant)(!this._client, "Client already created", {
882
+ (0, import_invariant2.invariant)(!this._client, "Client already created", {
889
883
  F: __dxlog_file3,
890
884
  L: 260,
891
885
  S: this,
@@ -897,7 +891,7 @@ var SignalClient = class {
897
891
  this._connectionStarted = /* @__PURE__ */ new Date();
898
892
  this._connectionCtx = this._ctx.derive();
899
893
  this._connectionCtx.onDispose(async () => {
900
- (0, import_log3.log)("connection context disposed", void 0, {
894
+ (0, import_log2.log)("connection context disposed", void 0, {
901
895
  F: __dxlog_file3,
902
896
  L: 267,
903
897
  S: this,
@@ -913,7 +907,7 @@ var SignalClient = class {
913
907
  url: this._host,
914
908
  callbacks: {
915
909
  onConnected: () => {
916
- (0, import_log3.log)("socket connected", void 0, {
910
+ (0, import_log2.log)("socket connected", void 0, {
917
911
  F: __dxlog_file3,
918
912
  L: 279,
919
913
  S: this,
@@ -926,7 +920,7 @@ var SignalClient = class {
926
920
  this._reconcileTask.schedule();
927
921
  },
928
922
  onDisconnected: () => {
929
- (0, import_log3.log)("socket disconnected", {
923
+ (0, import_log2.log)("socket disconnected", {
930
924
  state: this._state
931
925
  }, {
932
926
  F: __dxlog_file3,
@@ -945,7 +939,7 @@ var SignalClient = class {
945
939
  this._reconnectTask.schedule();
946
940
  },
947
941
  onError: (error) => {
948
- (0, import_log3.log)("socket error", {
942
+ (0, import_log2.log)("socket error", {
949
943
  error,
950
944
  state: this._state
951
945
  }, {
@@ -977,7 +971,7 @@ var SignalClient = class {
977
971
  this._reconnectAfter = Math.min(this._reconnectAfter, MAX_RECONNECT_TIMEOUT);
978
972
  }
979
973
  async _reconnect() {
980
- (0, import_log3.log)(`reconnecting in ${this._reconnectAfter}ms`, {
974
+ (0, import_log2.log)(`reconnecting in ${this._reconnectAfter}ms`, {
981
975
  state: this._state
982
976
  }, {
983
977
  F: __dxlog_file3,
@@ -987,7 +981,7 @@ var SignalClient = class {
987
981
  });
988
982
  this._performance.reconnectCounter++;
989
983
  if (this._state === import_signal.SignalState.RECONNECTING) {
990
- import_log3.log.warn("Signal api already reconnecting.", void 0, {
984
+ import_log2.log.warn("Signal api already reconnecting.", void 0, {
991
985
  F: __dxlog_file3,
992
986
  L: 334,
993
987
  S: this,
@@ -1003,14 +997,14 @@ var SignalClient = class {
1003
997
  this._client?.close().catch(() => {
1004
998
  });
1005
999
  this._client = void 0;
1006
- await (0, import_context2.cancelWithContext)(this._ctx, (0, import_async3.sleep)(this._reconnectAfter));
1000
+ await (0, import_context2.cancelWithContext)(this._ctx, (0, import_async2.sleep)(this._reconnectAfter));
1007
1001
  this._setState(import_signal.SignalState.RECONNECTING);
1008
1002
  this._createClient();
1009
1003
  }
1010
1004
  async _reconcileSwarmSubscriptions() {
1011
- await (0, import_async3.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, this._clientReady.wait()), 5e3);
1005
+ await (0, import_async2.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, this._clientReady.wait()), 5e3);
1012
1006
  const client = this._client;
1013
- (0, import_invariant3.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
1007
+ (0, import_invariant2.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
1014
1008
  F: __dxlog_file3,
1015
1009
  L: 359,
1016
1010
  S: this,
@@ -1042,12 +1036,12 @@ var SignalClient = class {
1042
1036
  })) {
1043
1037
  continue;
1044
1038
  }
1045
- const swarmStream = await (0, import_async3.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, client.join({
1039
+ const swarmStream = await (0, import_async2.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, client.join({
1046
1040
  topic,
1047
1041
  peerId
1048
1042
  })), 5e3);
1049
1043
  swarmStream.subscribe(async (swarmEvent) => {
1050
- (0, import_log3.log)("swarm event", {
1044
+ (0, import_log2.log)("swarm event", {
1051
1045
  swarmEvent
1052
1046
  }, {
1053
1047
  F: __dxlog_file3,
@@ -1067,9 +1061,9 @@ var SignalClient = class {
1067
1061
  }
1068
1062
  }
1069
1063
  async _reconcileMessageSubscriptions() {
1070
- await (0, import_async3.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, this._clientReady.wait()), 5e3);
1064
+ await (0, import_async2.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, this._clientReady.wait()), 5e3);
1071
1065
  const client = this._client;
1072
- (0, import_invariant3.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
1066
+ (0, import_invariant2.invariant)(this._state === import_signal.SignalState.CONNECTED, "Not connected to Signal Server", {
1073
1067
  F: __dxlog_file3,
1074
1068
  L: 399,
1075
1069
  S: this,
@@ -1091,12 +1085,12 @@ var SignalClient = class {
1091
1085
  if (this._messageStreams.has(peerId)) {
1092
1086
  continue;
1093
1087
  }
1094
- const messageStream = await (0, import_async3.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, client.receiveMessages(peerId)), 5e3);
1088
+ const messageStream = await (0, import_async2.asyncTimeout)((0, import_context2.cancelWithContext)(this._connectionCtx, client.receiveMessages(peerId)), 5e3);
1095
1089
  messageStream.subscribe(async (message) => {
1096
1090
  this._performance.receivedMessages++;
1097
1091
  await this._onMessage({
1098
- author: import_keys3.PublicKey.from(message.author),
1099
- recipient: import_keys3.PublicKey.from(message.recipient),
1092
+ author: import_keys2.PublicKey.from(message.author),
1093
+ recipient: import_keys2.PublicKey.from(message.recipient),
1100
1094
  payload: message.payload
1101
1095
  });
1102
1096
  });
@@ -1104,23 +1098,11 @@ var SignalClient = class {
1104
1098
  }
1105
1099
  }
1106
1100
  };
1107
-
1108
- // packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts
1109
- var import_async4 = require("@dxos/async");
1110
- var import_context3 = require("@dxos/context");
1111
- var import_invariant4 = require("@dxos/invariant");
1112
- var import_keys4 = require("@dxos/keys");
1113
- var import_log4 = require("@dxos/log");
1114
- var import_protocols4 = require("@dxos/protocols");
1115
- var import_util3 = require("@dxos/util");
1116
- var __dxlog_file4 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts";
1101
+ var __dxlog_file4 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts";
1117
1102
  var MemorySignalManagerContext = class {
1118
1103
  constructor() {
1119
- // Swarm messages.
1120
1104
  this.swarmEvent = new import_async4.Event();
1121
- // Mapping from topic to set of peers.
1122
1105
  this.swarms = new import_util3.ComplexMap(import_keys4.PublicKey.hash);
1123
- // Map of connections for each peer for signaling.
1124
1106
  this.connections = new import_util3.ComplexMap(import_keys4.PublicKey.hash);
1125
1107
  }
1126
1108
  };
@@ -1367,14 +1349,6 @@ var dec = (payload) => {
1367
1349
  }
1368
1350
  return {};
1369
1351
  };
1370
-
1371
- // packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts
1372
- var import_async5 = require("@dxos/async");
1373
- var import_context4 = require("@dxos/context");
1374
- var import_invariant5 = require("@dxos/invariant");
1375
- var import_keys5 = require("@dxos/keys");
1376
- var import_log5 = require("@dxos/log");
1377
- var import_protocols5 = require("@dxos/protocols");
1378
1352
  function _ts_decorate(decorators, target, key, desc) {
1379
1353
  var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
1380
1354
  if (typeof Reflect === "object" && typeof Reflect.decorate === "function")
@@ -1385,7 +1359,7 @@ function _ts_decorate(decorators, target, key, desc) {
1385
1359
  r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
1386
1360
  return c > 3 && r && Object.defineProperty(target, key, r), r;
1387
1361
  }
1388
- var __dxlog_file5 = "/home/runner/work/dxos/dxos/packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts";
1362
+ var __dxlog_file5 = "/home/circleci/project/packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts";
1389
1363
  var MAX_SERVER_FAILURES = 5;
1390
1364
  var WSS_SIGNAL_SERVER_REBOOT_DELAY = 3e3;
1391
1365
  var WebsocketSignalManager = class {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
- "sources": ["../../../src/index.ts", "../../../src/messenger.ts", "../../../src/timeouts.ts", "../../../src/signal-client/signal-client.ts", "../../../src/signal-client/signal-rpc-client.ts", "../../../src/signal-manager/memory-signal-manager.ts", "../../../src/signal-manager/websocket-signal-manager.ts"],
4
- "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nexport * from './messenger';\nexport * from './signal-client';\nexport * from './signal-manager';\nexport * from './signal-methods';\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport { TimeoutError, scheduleExponentialBackoffTaskInterval, scheduleTask, scheduleTaskInterval } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { TimeoutError as ProtocolTimeoutError, schema, trace } from '@dxos/protocols';\nimport { ReliablePayload } from '@dxos/protocols/proto/dxos/mesh/messaging';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { type SignalManager } from './signal-manager';\nimport { type Message } from './signal-methods';\nimport { MESSAGE_TIMEOUT } from './timeouts';\n\nexport type OnMessage = (params: { author: PublicKey; recipient: PublicKey; payload: Any }) => Promise<void>;\n\nexport interface MessengerOptions {\n signalManager: SignalManager;\n retryDelay?: number;\n}\n\nconst ReliablePayload = schema.getCodecForType('dxos.mesh.messaging.ReliablePayload');\nconst Acknowledgement = schema.getCodecForType('dxos.mesh.messaging.Acknowledgement');\n\nconst RECEIVED_MESSAGES_GC_INTERVAL = 120_000;\n\n/**\n * Reliable messenger that works trough signal network.\n */\nexport class Messenger {\n private readonly _signalManager: SignalManager;\n // { peerId, payloadType } => listeners set\n private readonly _listeners = new ComplexMap<{ peerId: PublicKey; payloadType: string }, Set<OnMessage>>(\n ({ peerId, payloadType }) => peerId.toHex() + payloadType,\n );\n\n // peerId => listeners set\n private readonly _defaultListeners = new ComplexMap<PublicKey, Set<OnMessage>>(PublicKey.hash);\n\n private readonly _onAckCallbacks = new ComplexMap<PublicKey, () => void>(PublicKey.hash);\n\n private readonly _receivedMessages = new ComplexSet<PublicKey>(PublicKey.hash);\n\n /**\n * Keys scheduled to be cleared from _receivedMessages on the next iteration.\n */\n private readonly _toClear = new ComplexSet<PublicKey>(PublicKey.hash);\n\n private _ctx!: Context;\n private _closed = true;\n private readonly _retryDelay: number;\n\n constructor({ signalManager, retryDelay = 300 }: MessengerOptions) {\n this._signalManager = signalManager;\n this._retryDelay = retryDelay;\n\n this.open();\n }\n\n open() {\n if (!this._closed) {\n return;\n }\n const traceId = PublicKey.random().toHex();\n log.trace('dxos.mesh.messenger.open', trace.begin({ id: traceId }));\n this._ctx = new Context({\n onError: (err) => log.catch(err),\n });\n this._ctx.onDispose(\n this._signalManager.onMessage.on(async (message) => {\n log('received message', { from: message.author });\n await this._handleMessage(message);\n }),\n );\n\n // Clear the map periodically.\n scheduleTaskInterval(\n this._ctx,\n async () => {\n this._performGc();\n },\n RECEIVED_MESSAGES_GC_INTERVAL,\n );\n\n this._closed = false;\n log.trace('dxos.mesh.messenger.open', trace.end({ id: traceId }));\n }\n\n async close() {\n if (this._closed) {\n return;\n }\n this._closed = true;\n await this._ctx.dispose();\n }\n\n async sendMessage({ author, recipient, payload }: Message): Promise<void> {\n invariant(!this._closed, 'Closed');\n const messageContext = this._ctx.derive();\n\n const reliablePayload: ReliablePayload = {\n messageId: PublicKey.random(),\n payload,\n };\n invariant(!this._onAckCallbacks.has(reliablePayload.messageId!));\n log('send message', { messageId: reliablePayload.messageId, author, recipient });\n\n let messageReceived: () => void;\n let timeoutHit: (err: Error) => void;\n\n const promise = new Promise<void>((resolve, reject) => {\n messageReceived = resolve;\n timeoutHit = reject;\n });\n\n // Setting retry interval if signal was not acknowledged.\n scheduleExponentialBackoffTaskInterval(\n messageContext,\n async () => {\n log('retrying message', { messageId: reliablePayload.messageId });\n await this._encodeAndSend({ author, recipient, reliablePayload }).catch((err) =>\n log('failed to send message', { err }),\n );\n },\n this._retryDelay,\n );\n\n scheduleTask(\n messageContext,\n () => {\n log('message not delivered', { messageId: reliablePayload.messageId });\n this._onAckCallbacks.delete(reliablePayload.messageId!);\n timeoutHit(\n new ProtocolTimeoutError(\n 'signaling message not delivered',\n new TimeoutError(MESSAGE_TIMEOUT, 'Message not delivered'),\n ),\n );\n void messageContext.dispose();\n },\n MESSAGE_TIMEOUT,\n );\n\n this._onAckCallbacks.set(reliablePayload.messageId, () => {\n messageReceived();\n this._onAckCallbacks.delete(reliablePayload.messageId!);\n void messageContext.dispose();\n });\n\n await this._encodeAndSend({ author, recipient, reliablePayload });\n return promise;\n }\n\n /**\n * Subscribes onMessage function to messages that contains payload with payloadType.\n * @param payloadType if not specified, onMessage will be subscribed to all types of messages.\n */\n async listen({\n peerId,\n payloadType,\n onMessage,\n }: {\n peerId: PublicKey;\n payloadType?: string;\n onMessage: OnMessage;\n }): Promise<ListeningHandle> {\n invariant(!this._closed, 'Closed');\n\n await this._signalManager.subscribeMessages(peerId);\n let listeners: Set<OnMessage> | undefined;\n\n if (!payloadType) {\n listeners = this._defaultListeners.get(peerId);\n if (!listeners) {\n listeners = new Set();\n this._defaultListeners.set(peerId, listeners);\n }\n } else {\n listeners = this._listeners.get({ peerId, payloadType });\n if (!listeners) {\n listeners = new Set();\n this._listeners.set({ peerId, payloadType }, listeners);\n }\n }\n\n listeners.add(onMessage);\n\n return {\n unsubscribe: async () => {\n listeners!.delete(onMessage);\n },\n };\n }\n\n private async _encodeAndSend({\n author,\n recipient,\n reliablePayload,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n reliablePayload: ReliablePayload;\n }): Promise<void> {\n await this._signalManager.sendMessage({\n author,\n recipient,\n payload: {\n type_url: 'dxos.mesh.messaging.ReliablePayload',\n value: ReliablePayload.encode(reliablePayload, { preserveAny: true }),\n },\n });\n }\n\n private async _handleMessage(message: Message): Promise<void> {\n switch (message.payload.type_url) {\n case 'dxos.mesh.messaging.ReliablePayload': {\n await this._handleReliablePayload(message);\n break;\n }\n case 'dxos.mesh.messaging.Acknowledgement': {\n await this._handleAcknowledgement({ payload: message.payload });\n break;\n }\n }\n }\n\n private async _handleReliablePayload({ author, recipient, payload }: Message) {\n invariant(payload.type_url === 'dxos.mesh.messaging.ReliablePayload');\n const reliablePayload: ReliablePayload = ReliablePayload.decode(payload.value, { preserveAny: true });\n\n log('handling message', { messageId: reliablePayload.messageId });\n\n await this._sendAcknowledgement({\n author,\n recipient,\n messageId: reliablePayload.messageId,\n });\n\n if (this._receivedMessages.has(reliablePayload.messageId!)) {\n return;\n }\n\n this._receivedMessages.add(reliablePayload.messageId!);\n\n await this._callListeners({\n author,\n recipient,\n payload: reliablePayload.payload,\n });\n }\n\n private async _handleAcknowledgement({ payload }: { payload: Any }) {\n invariant(payload.type_url === 'dxos.mesh.messaging.Acknowledgement');\n this._onAckCallbacks.get(Acknowledgement.decode(payload.value).messageId)?.();\n }\n\n private async _sendAcknowledgement({\n author,\n recipient,\n messageId,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n messageId: PublicKey;\n }): Promise<void> {\n log('sending ACK', { messageId, from: recipient, to: author });\n\n await this._signalManager.sendMessage({\n author: recipient,\n recipient: author,\n payload: {\n type_url: 'dxos.mesh.messaging.Acknowledgement',\n value: Acknowledgement.encode({ messageId }),\n },\n });\n }\n\n private async _callListeners(message: Message): Promise<void> {\n {\n const defaultListenerMap = this._defaultListeners.get(message.recipient);\n if (defaultListenerMap) {\n for (const listener of defaultListenerMap) {\n await listener(message);\n }\n }\n }\n\n {\n const listenerMap = this._listeners.get({\n peerId: message.recipient,\n payloadType: message.payload.type_url,\n });\n if (listenerMap) {\n for (const listener of listenerMap) {\n await listener(message);\n }\n }\n }\n }\n\n private _performGc() {\n const start = performance.now();\n\n for (const key of this._toClear.keys()) {\n this._receivedMessages.delete(key);\n }\n this._toClear.clear();\n for (const key of this._receivedMessages.keys()) {\n this._toClear.add(key);\n }\n\n const elapsed = performance.now() - start;\n if (elapsed > 100) {\n log.warn('GC took too long', { elapsed });\n }\n }\n}\n\nexport interface ListeningHandle {\n unsubscribe: () => Promise<void>;\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Timeout for retrying messages.\n */\nexport const MESSAGE_TIMEOUT = 10_000;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { DeferredTask, Event, Trigger, asyncTimeout, scheduleTask, scheduleTaskInterval, sleep } from '@dxos/async';\nimport { type Any, type Stream } from '@dxos/codec-protobuf';\nimport { Context, cancelWithContext } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { trace } from '@dxos/protocols';\nimport { type Message as SignalMessage, SignalState, type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { SignalRPCClient } from './signal-rpc-client';\nimport { type Message, type SignalMethods } from '../signal-methods';\n\nconst DEFAULT_RECONNECT_TIMEOUT = 100;\nconst MAX_RECONNECT_TIMEOUT = 5000;\nconst ERROR_RECONCILE_DELAY = 1000;\nconst RECONCILE_INTERVAL = 5_000;\n\nexport type SignalStatus = {\n host: string;\n state: SignalState;\n error?: string;\n reconnectIn: number;\n connectionStarted: Date;\n lastStateChange: Date;\n};\n\nexport type CommandTrace = {\n messageId: string;\n host: string;\n incoming: boolean;\n time: number;\n method: string;\n payload: any;\n response?: any;\n error?: string;\n};\n\n/**\n * Establishes a websocket connection to signal server and provides RPC methods.\n */\nexport class SignalClient implements SignalMethods {\n private _state = SignalState.CLOSED;\n\n private _lastError?: Error;\n\n /**\n * Number of milliseconds after which the connection will be attempted again in case of error.\n */\n private _reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;\n\n /**\n * Timestamp of when the connection attempt was began.\n */\n private _connectionStarted = new Date();\n\n /**\n * Timestamp of last state change.\n */\n private _lastStateChange = new Date();\n\n private _client?: SignalRPCClient;\n private readonly _clientReady = new Trigger();\n\n private _ctx?: Context;\n\n private _connectionCtx?: Context;\n\n private _reconcileTask?: DeferredTask;\n private _reconnectTask?: DeferredTask;\n\n readonly statusChanged = new Event<SignalStatus>();\n readonly commandTrace = new Event<CommandTrace>();\n\n /**\n * Swarm events streams. Keys represent actually joined topic and peerId.\n */\n private readonly _swarmStreams = new ComplexMap<{ topic: PublicKey; peerId: PublicKey }, Stream<SwarmEvent>>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n /**\n * Represent desired joined topic and peerId.\n */\n private readonly _joinedTopics = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n /**\n * Message streams. Keys represents actually subscribed peers.\n * @internal\n */\n public readonly _messageStreams = new ComplexMap<PublicKey, Stream<SignalMessage>>((key) => key.toHex());\n\n /**\n * Represent desired message subscriptions.\n */\n private readonly _subscribedMessages = new ComplexSet<{ peerId: PublicKey }>(({ peerId }) => peerId.toHex());\n\n /**\n * Event to use in tests to wait till subscription is successfully established.\n * @internal\n */\n public _reconciled = new Event();\n\n private readonly _instanceId = PublicKey.random().toHex();\n\n private readonly _performance = {\n sentMessages: 0,\n receivedMessages: 0,\n reconnectCounter: 0,\n joinCounter: 0,\n leaveCounter: 0,\n };\n\n /**\n * @param _host Signal server websocket URL.\n * @param _onMessage\n */\n constructor(\n private readonly _host: string,\n private readonly _onMessage: (params: { author: PublicKey; recipient: PublicKey; payload: Any }) => Promise<void>,\n private readonly _onSwarmEvent: (params: { topic: PublicKey; swarmEvent: SwarmEvent }) => Promise<void>,\n ) {\n if (!this._host.startsWith('wss://') && !this._host.startsWith('ws://')) {\n throw new Error(`Signal server requires a websocket URL. Provided: ${this._host}`);\n }\n }\n\n open() {\n log.trace('dxos.mesh.signal-client.open', trace.begin({ id: this._instanceId }));\n\n if ([SignalState.CONNECTED, SignalState.CONNECTING].includes(this._state)) {\n return;\n }\n\n this._ctx = new Context({\n onError: (err) => {\n if (this._state === SignalState.CLOSED || this._ctx?.disposed) {\n return;\n }\n if (this._state === SignalState.CONNECTED) {\n log.warn('SignalClient error:', err);\n }\n this._scheduleReconcileAfterError();\n },\n });\n\n this._reconcileTask = new DeferredTask(this._ctx, async () => {\n await this._reconcileSwarmSubscriptions();\n await this._reconcileMessageSubscriptions();\n this._reconciled.emit();\n });\n\n // Reconcile subscriptions periodically.\n scheduleTaskInterval(\n this._ctx,\n async () => {\n if (this._state === SignalState.CONNECTED) {\n this._reconcileTask!.schedule();\n }\n },\n RECONCILE_INTERVAL,\n );\n\n this._reconnectTask = new DeferredTask(this._ctx, async () => {\n await this._reconnect();\n });\n\n this._setState(SignalState.CONNECTING);\n this._createClient();\n log.trace('dxos.mesh.signal-client.open', trace.end({ id: this._instanceId }));\n }\n\n async close() {\n log('closing...');\n if ([SignalState.CLOSED].includes(this._state)) {\n return;\n }\n\n await this._ctx?.dispose();\n\n this._clientReady.reset();\n await this._client?.close();\n this._client = undefined;\n this._setState(SignalState.CLOSED);\n log('closed');\n }\n\n getStatus(): SignalStatus {\n return {\n host: this._host,\n state: this._state,\n error: this._lastError?.message,\n reconnectIn: this._reconnectAfter,\n connectionStarted: this._connectionStarted,\n lastStateChange: this._lastStateChange,\n };\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }): Promise<void> {\n log('joining', { topic, peerId });\n this._performance.joinCounter++;\n this._joinedTopics.add({ topic, peerId });\n this._reconcileTask!.schedule();\n }\n\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }): Promise<void> {\n this._performance.leaveCounter++;\n log('leaving', { topic, peerId });\n\n void this._swarmStreams.get({ topic, peerId })?.close();\n this._swarmStreams.delete({ topic, peerId });\n this._joinedTopics.delete({ topic, peerId });\n }\n\n async sendMessage(msg: Message): Promise<void> {\n this._performance.sentMessages++;\n await this._clientReady.wait();\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n await this._client!.sendMessage(msg);\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log('subscribing to messages', { peerId });\n this._subscribedMessages.add({ peerId });\n this._reconcileTask!.schedule();\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log('unsubscribing from messages', { peerId });\n this._subscribedMessages.delete({ peerId });\n void this._messageStreams.get(peerId)?.close();\n this._messageStreams.delete(peerId);\n }\n\n private _scheduleReconcileAfterError() {\n scheduleTask(\n this._ctx!,\n () => {\n this._reconcileTask!.schedule();\n },\n ERROR_RECONCILE_DELAY,\n );\n }\n\n private _setState(newState: SignalState) {\n this._state = newState;\n this._lastStateChange = new Date();\n log('signal state changed', { status: this.getStatus() });\n this.statusChanged.emit(this.getStatus());\n }\n\n private _createClient() {\n log('creating client', { host: this._host, state: this._state });\n invariant(!this._client, 'Client already created');\n\n this._connectionStarted = new Date();\n\n // Create new context for each connection.\n this._connectionCtx = this._ctx!.derive();\n this._connectionCtx.onDispose(async () => {\n log('connection context disposed');\n await Promise.all(Array.from(this._swarmStreams.values()).map((stream) => stream.close()));\n await Promise.all(Array.from(this._messageStreams.values()).map((stream) => stream.close()));\n this._swarmStreams.clear();\n this._messageStreams.clear();\n });\n\n try {\n this._client = new SignalRPCClient({\n url: this._host,\n callbacks: {\n onConnected: () => {\n log('socket connected');\n this._lastError = undefined;\n this._reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;\n this._setState(SignalState.CONNECTED);\n this._clientReady.wake();\n this._reconcileTask!.schedule();\n },\n\n onDisconnected: () => {\n log('socket disconnected', { state: this._state });\n if (this._state === SignalState.ERROR) {\n // Ignore disconnects after error.\n // Handled by error handler before disconnect handler.\n this._setState(SignalState.DISCONNECTED);\n return;\n }\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._setState(SignalState.DISCONNECTED);\n this._reconnectTask!.schedule();\n },\n\n onError: (error) => {\n log('socket error', { error, state: this._state });\n this._lastError = error;\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._setState(SignalState.ERROR);\n\n this._reconnectTask!.schedule();\n },\n },\n });\n } catch (err: any) {\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._lastError = err;\n this._setState(SignalState.DISCONNECTED);\n this._reconnectTask!.schedule();\n }\n }\n\n private _incrementReconnectTimeout() {\n this._reconnectAfter *= 2;\n this._reconnectAfter = Math.min(this._reconnectAfter, MAX_RECONNECT_TIMEOUT);\n }\n\n private async _reconnect() {\n log(`reconnecting in ${this._reconnectAfter}ms`, { state: this._state });\n this._performance.reconnectCounter++;\n\n if (this._state === SignalState.RECONNECTING) {\n log.warn('Signal api already reconnecting.');\n return;\n }\n\n if (this._state === SignalState.CLOSED) {\n return;\n }\n\n // Close client if it wasn't already closed.\n this._clientReady.reset();\n await this._connectionCtx?.dispose();\n this._client?.close().catch(() => {});\n this._client = undefined;\n\n await cancelWithContext(this._ctx!, sleep(this._reconnectAfter));\n\n this._setState(SignalState.RECONNECTING);\n\n this._createClient();\n }\n\n private async _reconcileSwarmSubscriptions(): Promise<void> {\n await asyncTimeout(cancelWithContext(this._connectionCtx!, this._clientReady.wait()), 5_000);\n // Copy Client reference to avoid client change during the reconcile.\n const client = this._client!;\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n\n // Unsubscribe from topics that are no longer needed.\n for (const { topic, peerId } of this._swarmStreams.keys()) {\n // Join desired topics.\n if (this._joinedTopics.has({ topic, peerId })) {\n continue;\n }\n\n void this._swarmStreams.get({ topic, peerId })?.close();\n this._swarmStreams.delete({ topic, peerId });\n }\n\n // Subscribe to topics that are needed.\n for (const { topic, peerId } of this._joinedTopics.values()) {\n // Join desired topics.\n if (this._swarmStreams.has({ topic, peerId })) {\n continue;\n }\n\n const swarmStream = await asyncTimeout(\n cancelWithContext(this._connectionCtx!, client.join({ topic, peerId })),\n 5000,\n );\n // Subscribing to swarm events.\n // TODO(mykola): What happens when the swarm stream is closed? Maybe send leave event for each peer?\n swarmStream.subscribe(async (swarmEvent: SwarmEvent) => {\n log('swarm event', { swarmEvent });\n await this._onSwarmEvent({ topic, swarmEvent });\n });\n\n // Saving swarm stream.\n this._swarmStreams.set({ topic, peerId }, swarmStream);\n }\n }\n\n private async _reconcileMessageSubscriptions(): Promise<void> {\n await asyncTimeout(cancelWithContext(this._connectionCtx!, this._clientReady.wait()), 5_000);\n // Copy Client reference to avoid client change during the reconcile.\n const client = this._client!;\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n\n // Unsubscribe from messages that are no longer needed.\n for (const peerId of this._messageStreams.keys()) {\n // Join desired topics.\n if (this._subscribedMessages.has({ peerId })) {\n continue;\n }\n\n void this._messageStreams.get(peerId)?.close();\n this._messageStreams.delete(peerId);\n }\n\n // Subscribe to messages that are needed.\n for (const { peerId } of this._subscribedMessages.values()) {\n if (this._messageStreams.has(peerId)) {\n continue;\n }\n\n const messageStream = await asyncTimeout(\n cancelWithContext(this._connectionCtx!, client.receiveMessages(peerId)),\n 5000,\n );\n messageStream.subscribe(async (message: SignalMessage) => {\n this._performance.receivedMessages++;\n await this._onMessage({\n author: PublicKey.from(message.author),\n recipient: PublicKey.from(message.recipient),\n payload: message.payload,\n });\n });\n\n // Saving message stream.\n this._messageStreams.set(peerId, messageStream);\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport WebSocket from 'isomorphic-ws';\n\nimport { Trigger } from '@dxos/async';\nimport { type Any, type Stream } from '@dxos/codec-protobuf';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { schema, trace } from '@dxos/protocols';\nimport { type Message as SignalMessage, type Signal } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { createProtoRpcPeer, type ProtoRpcPeer } from '@dxos/rpc';\n\ninterface Services {\n Signal: Signal;\n}\n\nexport type SignalCallbacks = {\n onConnected?: () => void;\n\n /**\n * Called on disconnect.\n * In case of error, `onError` will be called first and then `onDisconnected`.\n */\n onDisconnected?: () => void;\n\n onError?: (error: Error) => void;\n};\n\nexport type SignalRPCClientParams = {\n url: string;\n callbacks?: SignalCallbacks;\n};\n\nexport class SignalRPCClient {\n private _socket?: WebSocket;\n private _rpc?: ProtoRpcPeer<Services>;\n private readonly _connectTrigger = new Trigger();\n\n private _closed = false;\n\n private readonly _url: string;\n private readonly _callbacks: SignalCallbacks;\n\n constructor({ url, callbacks = {} }: SignalRPCClientParams) {\n const traceId = PublicKey.random().toHex();\n log.trace('dxos.mesh.signal-rpc-client.constructor', trace.begin({ id: traceId }));\n this._url = url;\n this._callbacks = callbacks;\n this._socket = new WebSocket(this._url);\n\n this._rpc = createProtoRpcPeer({\n requested: {\n Signal: schema.getService('dxos.mesh.signal.Signal'),\n },\n noHandshake: true,\n port: {\n send: (msg) => {\n if (this._closed) {\n // Do not send messages after close.\n return;\n }\n try {\n this._socket!.send(msg);\n } catch (err) {\n log.warn('send error', err);\n }\n },\n subscribe: (cb) => {\n this._socket!.onmessage = async (msg: WebSocket.MessageEvent) => {\n if (typeof Blob !== 'undefined' && msg.data instanceof Blob) {\n cb(Buffer.from(await msg.data.arrayBuffer()));\n } else {\n cb(msg.data as any);\n }\n };\n },\n },\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n this._socket.onopen = async () => {\n try {\n await this._rpc!.open();\n log(`RPC open ${this._url}`);\n this._callbacks.onConnected?.();\n this._connectTrigger.wake();\n } catch (err: any) {\n this._callbacks.onError?.(err);\n }\n };\n\n this._socket.onclose = async () => {\n log(`Disconnected ${this._url}`);\n this._callbacks.onDisconnected?.();\n await this.close();\n };\n\n this._socket.onerror = async (event: WebSocket.ErrorEvent) => {\n if (this._closed) {\n // Ignore errors after close.\n return;\n }\n\n this._callbacks.onError?.(event.error ?? new Error(event.message));\n this._connectTrigger.reset();\n\n try {\n await this._rpc?.close();\n } catch (err) {\n log.catch(err);\n }\n this._closed = true;\n\n log.warn(event.message ?? 'Socket error', { url: this._url });\n };\n\n log.trace('dxos.mesh.signal-rpc-client.constructor', trace.end({ id: traceId }));\n }\n\n async close() {\n this._closed = true;\n try {\n await this._rpc?.close();\n this._socket?.close();\n } catch (err) {\n log.warn('close error', err);\n }\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('join', { topic, peerId });\n await this._connectTrigger.wait();\n invariant(!this._closed, 'SignalRPCClient is closed');\n invariant(this._rpc, 'Rpc is not initialized');\n const swarmStream = this._rpc.rpc.Signal.join({\n swarm: topic.asUint8Array(),\n peer: peerId.asUint8Array(),\n });\n await swarmStream.waitUntilReady();\n return swarmStream;\n }\n\n async receiveMessages(peerId: PublicKey): Promise<Stream<SignalMessage>> {\n log('receiveMessages', { peerId });\n invariant(!this._closed, 'SignalRPCClient is closed');\n await this._connectTrigger.wait();\n invariant(this._rpc, 'Rpc is not initialized');\n const messageStream = this._rpc.rpc.Signal.receiveMessages({\n peer: peerId.asUint8Array(),\n });\n await messageStream.waitUntilReady();\n return messageStream;\n }\n\n async sendMessage({ author, recipient, payload }: { author: PublicKey; recipient: PublicKey; payload: Any }) {\n log('sendMessage', { author, recipient, payload });\n invariant(!this._closed, 'SignalRPCClient is closed');\n await this._connectTrigger.wait();\n invariant(this._rpc, 'Rpc is not initialized');\n await this._rpc.rpc.Signal.sendMessage({\n author: author.asUint8Array(),\n recipient: recipient.asUint8Array(),\n payload,\n });\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event, Trigger } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport { type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { type SignalManager } from './signal-manager';\nimport { type CommandTrace, type SignalStatus } from '../signal-client';\n\n/**\n * Common signaling context that connects multiple MemorySignalManager instances.\n */\nexport class MemorySignalManagerContext {\n // Swarm messages.\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n // Mapping from topic to set of peers.\n readonly swarms = new ComplexMap<PublicKey, ComplexSet<PublicKey>>(PublicKey.hash);\n\n // Map of connections for each peer for signaling.\n readonly connections = new ComplexMap<PublicKey, MemorySignalManager>(PublicKey.hash);\n}\n\n/**\n * In memory signal manager for testing.\n */\nexport class MemorySignalManager implements SignalManager {\n readonly statusChanged = new Event<SignalStatus[]>();\n readonly commandTrace = new Event<CommandTrace>();\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n readonly onMessage = new Event<{\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }>();\n\n /** Will be used to emit SwarmEvents on .open() and .close() */\n private _joinedSwarms = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n private _ctx!: Context;\n\n // TODO(dmaretskyi): Replace with callback.\n private readonly _freezeTrigger = new Trigger().wake();\n\n constructor(private readonly _context: MemorySignalManagerContext) {\n this._ctx = new Context();\n\n this._ctx.onDispose(this._context.swarmEvent.on((data) => this.swarmEvent.emit(data)));\n }\n\n async open() {\n if (!this._ctx.disposed) {\n return;\n }\n this._ctx = new Context();\n this._ctx.onDispose(this._context.swarmEvent.on((data) => this.swarmEvent.emit(data)));\n\n await Promise.all([...this._joinedSwarms.values()].map((value) => this.join(value)));\n }\n\n async close() {\n if (this._ctx.disposed) {\n return;\n }\n // save copy of joined swarms.\n const joinedSwarmsCopy = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n [...this._joinedSwarms.values()],\n );\n\n await Promise.all([...this._joinedSwarms.values()].map((value) => this.leave(value)));\n\n // assign joined swarms back because .leave() deletes it.\n this._joinedSwarms = joinedSwarmsCopy;\n\n await this._ctx.dispose();\n }\n\n getStatus(): SignalStatus[] {\n return [];\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n invariant(!this._ctx.disposed, 'Closed');\n\n this._joinedSwarms.add({ topic, peerId });\n\n if (!this._context.swarms.has(topic)) {\n this._context.swarms.set(topic, new ComplexSet(PublicKey.hash));\n }\n\n this._context.swarms.get(topic)!.add(peerId);\n this._context.swarmEvent.emit({\n topic,\n swarmEvent: {\n peerAvailable: {\n peer: peerId.asUint8Array(),\n since: new Date(),\n },\n },\n });\n\n // Emitting swarm events for each peer.\n for (const [topic, peerIds] of this._context.swarms) {\n Array.from(peerIds).forEach((peerId) => {\n this.swarmEvent.emit({\n topic,\n swarmEvent: {\n peerAvailable: {\n peer: peerId.asUint8Array(),\n since: new Date(),\n },\n },\n });\n });\n }\n }\n\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n invariant(!this._ctx.disposed, 'Closed');\n\n this._joinedSwarms.delete({ topic, peerId });\n\n if (!this._context.swarms.has(topic)) {\n this._context.swarms.set(topic, new ComplexSet(PublicKey.hash));\n }\n\n this._context.swarms.get(topic)!.delete(peerId);\n\n const swarmEvent: SwarmEvent = {\n peerLeft: {\n peer: peerId.asUint8Array(),\n },\n };\n\n this._context.swarmEvent.emit({ topic, swarmEvent });\n }\n\n async sendMessage({ author, recipient, payload }: { author: PublicKey; recipient: PublicKey; payload: Any }) {\n log('send message', { author, recipient, ...dec(payload) });\n\n invariant(recipient);\n invariant(!this._ctx.disposed, 'Closed');\n\n await this._freezeTrigger.wait();\n\n const remote = this._context.connections.get(recipient);\n if (!remote) {\n log.warn('recipient is not subscribed for messages', { author, recipient });\n return;\n }\n\n if (remote._ctx.disposed) {\n log.warn('recipient is disposed', { author, recipient });\n return;\n }\n\n remote._freezeTrigger\n .wait()\n .then(() => {\n if (remote._ctx.disposed) {\n log.warn('recipient is disposed', { author, recipient });\n return;\n }\n\n log('receive message', { author, recipient, ...dec(payload) });\n\n remote.onMessage.emit({ author, recipient, payload });\n })\n .catch((err) => {\n log.error('error while waiting for freeze', { err });\n });\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log('subscribing', { peerId });\n this._context.connections.set(peerId, this);\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log('unsubscribing', { peerId });\n this._context.connections.delete(peerId);\n }\n\n freeze() {\n this._freezeTrigger.reset();\n }\n\n unfreeze() {\n this._freezeTrigger.wake();\n }\n}\nconst dec = (payload: Any) => {\n if (!payload.type_url.endsWith('ReliablePayload')) {\n return {};\n }\n\n const relPayload = schema.getCodecForType('dxos.mesh.messaging.ReliablePayload').decode(payload.value);\n\n if (typeof relPayload?.payload?.data === 'object') {\n return { payload: Object.keys(relPayload?.payload?.data)[0], sessionId: relPayload?.payload?.sessionId };\n }\n\n return {};\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event, sleep, synchronized } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { RateLimitExceededError, trace } from '@dxos/protocols';\nimport { type Runtime } from '@dxos/protocols/proto/dxos/config';\nimport { type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\n\nimport { type SignalManager } from './signal-manager';\nimport { type CommandTrace, SignalClient, type SignalStatus } from '../signal-client';\n\nconst MAX_SERVER_FAILURES = 5;\nconst WSS_SIGNAL_SERVER_REBOOT_DELAY = 3_000;\n/**\n * Manages connection to multiple Signal Servers over WebSocket\n */\nexport class WebsocketSignalManager implements SignalManager {\n private readonly _servers = new Map<string, SignalClient>();\n\n private _ctx!: Context;\n private _opened = false;\n\n readonly failureCount = new Map<string, number>();\n readonly statusChanged = new Event<SignalStatus[]>();\n readonly commandTrace = new Event<CommandTrace>();\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n readonly onMessage = new Event<{\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }>();\n\n private readonly _instanceId = PublicKey.random().toHex();\n\n constructor(private readonly _hosts: Runtime.Services.Signal[]) {\n log('Created WebsocketSignalManager', { hosts: this._hosts });\n for (const host of this._hosts) {\n if (this._servers.has(host.server)) {\n continue;\n }\n const server = new SignalClient(\n host.server,\n async (message) => this.onMessage.emit(message),\n async (data) => this.swarmEvent.emit(data),\n );\n server.statusChanged.on(() => this.statusChanged.emit(this.getStatus()));\n\n this._servers.set(host.server, server);\n this.failureCount.set(host.server, 0);\n server.commandTrace.on((trace) => this.commandTrace.emit(trace));\n }\n }\n\n @synchronized\n async open() {\n if (this._opened) {\n return;\n }\n log('open signal manager', { hosts: this._hosts });\n log.trace('dxos.mesh.websocket-signal-manager.open', trace.begin({ id: this._instanceId }));\n\n this._initContext();\n\n [...this._servers.values()].forEach((server) => server.open());\n\n this._opened = true;\n log.trace('dxos.mesh.websocket-signal-manager.open', trace.end({ id: this._instanceId }));\n }\n\n @synchronized\n async close() {\n if (!this._opened) {\n return;\n }\n this._opened = false;\n\n await this._ctx.dispose();\n\n await Promise.all(Array.from(this._servers.values()).map((server) => server.close()));\n }\n\n async restartServer(serverName: string) {\n log('Restarting server', { serverName });\n invariant(this._opened, 'server already closed');\n\n const server = this._servers.get(serverName);\n invariant(server, 'server not found');\n\n await server.close();\n await sleep(WSS_SIGNAL_SERVER_REBOOT_DELAY);\n await server.open();\n }\n\n getStatus(): SignalStatus[] {\n return Array.from(this._servers.values()).map((server) => server.getStatus());\n }\n\n @synchronized\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('Join', { topic, peerId });\n invariant(this._opened, 'Closed');\n await this._forEachServer((server) => server.join({ topic, peerId }));\n }\n\n @synchronized\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('leaving', { topic, peerId });\n invariant(this._opened, 'Closed');\n\n await this._forEachServer((server) => server.leave({ topic, peerId }));\n }\n\n async sendMessage({\n author,\n recipient,\n payload,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }): Promise<void> {\n log(`Signal ${recipient.truncate()}`);\n invariant(this._opened, 'Closed');\n\n void this._forEachServer(async (server, serverName) => {\n void server.sendMessage({ author, recipient, payload }).catch((err) => {\n if (err instanceof RateLimitExceededError) {\n log('WSS rate limit exceeded', { err });\n } else {\n log(`error sending to ${serverName}`, { err });\n void this.checkServerFailure(serverName);\n }\n });\n });\n }\n\n @synchronized\n async checkServerFailure(serverName: string) {\n const failureCount = this.failureCount.get(serverName!) ?? 0;\n if (failureCount > MAX_SERVER_FAILURES) {\n log.warn(`Too many failures sending to ${serverName} (${failureCount} > ${MAX_SERVER_FAILURES}), restarting`);\n await this.restartServer(serverName!);\n this.failureCount.set(serverName!, 0);\n return;\n }\n this.failureCount.set(serverName!, (this.failureCount.get(serverName!) ?? 0) + 1);\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log(`Subscribed for message stream peerId=${peerId}`);\n invariant(this._opened, 'Closed');\n\n await this._forEachServer(async (server) => server.subscribeMessages(peerId));\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log(`Subscribed for message stream peerId=${peerId}`);\n invariant(this._opened, 'Closed');\n\n await this._forEachServer(async (server) => server.unsubscribeMessages(peerId));\n }\n\n private _initContext() {\n this._ctx = new Context({\n onError: (err) => log.catch(err),\n });\n }\n\n private async _forEachServer<ReturnType>(\n fn: (server: SignalClient, serverName: string) => Promise<ReturnType>,\n ): Promise<ReturnType[]> {\n return Promise.all(Array.from(this._servers.entries()).map(([serverName, server]) => fn(server, serverName)));\n }\n}\n"],
5
- "mappings": ";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAAA;;;;;;;;;;;ACIA,mBAAyG;AAEzG,qBAAwB;AACxB,uBAA0B;AAC1B,kBAA0B;AAC1B,iBAAoB;AACpB,uBAAoE;AAEpE,kBAAuC;;;ACLhC,IAAMA,kBAAkB;;;;ADkB/B,IAAMC,kBAAkBC,wBAAOC,gBAAgB,qCAAA;AAC/C,IAAMC,kBAAkBF,wBAAOC,gBAAgB,qCAAA;AAE/C,IAAME,gCAAgC;AAK/B,IAAMC,YAAN,MAAMA;EAuBXC,YAAY,EAAEC,eAAeC,aAAa,IAAG,GAAsB;AApBlDC;sBAAa,IAAIC,uBAChC,CAAC,EAAEC,QAAQC,YAAW,MAAOD,OAAOE,MAAK,IAAKD,WAAAA;AAI/BE;6BAAoB,IAAIJ,uBAAsCK,sBAAUC,IAAI;AAE5EC,2BAAkB,IAAIP,uBAAkCK,sBAAUC,IAAI;AAEtEE,6BAAoB,IAAIC,uBAAsBJ,sBAAUC,IAAI;AAK5DI;;;oBAAW,IAAID,uBAAsBJ,sBAAUC,IAAI;AAG5DK,mBAAU;AAIhB,SAAKC,iBAAiBf;AACtB,SAAKgB,cAAcf;AAEnB,SAAKgB,KAAI;EACX;EAEAA,OAAO;AACL,QAAI,CAAC,KAAKH,SAAS;AACjB;IACF;AACA,UAAMI,UAAUV,sBAAUW,OAAM,EAAGb,MAAK;AACxCc,mBAAIC,MAAM,4BAA4BA,uBAAMC,MAAM;MAAEC,IAAIL;IAAQ,CAAA,GAAA;;;;;;AAChE,SAAKM,OAAO,IAAIC,uBAAQ;MACtBC,SAAS,CAACC,QAAQP,eAAIQ,MAAMD,KAAAA,QAAAA;;;;;;IAC9B,CAAA;AACA,SAAKH,KAAKK,UACR,KAAKd,eAAee,UAAUC,GAAG,OAAOC,YAAAA;AACtCZ,0BAAI,oBAAoB;QAAEa,MAAMD,QAAQE;MAAO,GAAA;;;;;;AAC/C,YAAM,KAAKC,eAAeH,OAAAA;IAC5B,CAAA,CAAA;AAIFI,2CACE,KAAKZ,MACL,YAAA;AACE,WAAKa,WAAU;IACjB,GACAxC,6BAAAA;AAGF,SAAKiB,UAAU;AACfM,mBAAIC,MAAM,4BAA4BA,uBAAMiB,IAAI;MAAEf,IAAIL;IAAQ,CAAA,GAAA;;;;;;EAChE;EAEA,MAAMqB,QAAQ;AACZ,QAAI,KAAKzB,SAAS;AAChB;IACF;AACA,SAAKA,UAAU;AACf,UAAM,KAAKU,KAAKgB,QAAO;EACzB;EAEA,MAAMC,YAAY,EAAEP,QAAQQ,WAAWC,QAAO,GAA4B;AACxEC,oCAAU,CAAC,KAAK9B,SAAS,UAAA;;;;;;;;;AACzB,UAAM+B,iBAAiB,KAAKrB,KAAKsB,OAAM;AAEvC,UAAMC,kBAAmC;MACvCC,WAAWxC,sBAAUW,OAAM;MAC3BwB;IACF;AACAC,oCAAU,CAAC,KAAKlC,gBAAgBuC,IAAIF,gBAAgBC,SAAS,GAAA,QAAA;;;;;;;;;AAC7D5B,wBAAI,gBAAgB;MAAE4B,WAAWD,gBAAgBC;MAAWd;MAAQQ;IAAU,GAAA;;;;;;AAE9E,QAAIQ;AACJ,QAAIC;AAEJ,UAAMC,UAAU,IAAIC,QAAc,CAACC,SAASC,WAAAA;AAC1CL,wBAAkBI;AAClBH,mBAAaI;IACf,CAAA;AAGAC,6DACEX,gBACA,YAAA;AACEzB,0BAAI,oBAAoB;QAAE4B,WAAWD,gBAAgBC;MAAU,GAAA;;;;;;AAC/D,YAAM,KAAKS,eAAe;QAAEvB;QAAQQ;QAAWK;MAAgB,CAAA,EAAGnB,MAAM,CAACD,YACvEP,gBAAI,0BAA0B;QAAEO;MAAI,GAAA;;;;;;IAExC,GACA,KAAKX,WAAW;AAGlB0C,mCACEb,gBACA,MAAA;AACEzB,0BAAI,yBAAyB;QAAE4B,WAAWD,gBAAgBC;MAAU,GAAA;;;;;;AACpE,WAAKtC,gBAAgBiD,OAAOZ,gBAAgBC,SAAS;AACrDG,iBACE,IAAIS,iBAAAA,aACF,mCACA,IAAIC,0BAAaC,iBAAiB,uBAAA,CAAA,CAAA;AAGtC,WAAKjB,eAAeL,QAAO;IAC7B,GACAsB,eAAAA;AAGF,SAAKpD,gBAAgBqD,IAAIhB,gBAAgBC,WAAW,MAAA;AAClDE,sBAAAA;AACA,WAAKxC,gBAAgBiD,OAAOZ,gBAAgBC,SAAS;AACrD,WAAKH,eAAeL,QAAO;IAC7B,CAAA;AAEA,UAAM,KAAKiB,eAAe;MAAEvB;MAAQQ;MAAWK;IAAgB,CAAA;AAC/D,WAAOK;EACT;;;;;EAMA,MAAMY,OAAO,EACX5D,QACAC,aACAyB,UAAS,GAKkB;AAC3Bc,oCAAU,CAAC,KAAK9B,SAAS,UAAA;;;;;;;;;AAEzB,UAAM,KAAKC,eAAekD,kBAAkB7D,MAAAA;AAC5C,QAAI8D;AAEJ,QAAI,CAAC7D,aAAa;AAChB6D,kBAAY,KAAK3D,kBAAkB4D,IAAI/D,MAAAA;AACvC,UAAI,CAAC8D,WAAW;AACdA,oBAAY,oBAAIE,IAAAA;AAChB,aAAK7D,kBAAkBwD,IAAI3D,QAAQ8D,SAAAA;MACrC;IACF,OAAO;AACLA,kBAAY,KAAKhE,WAAWiE,IAAI;QAAE/D;QAAQC;MAAY,CAAA;AACtD,UAAI,CAAC6D,WAAW;AACdA,oBAAY,oBAAIE,IAAAA;AAChB,aAAKlE,WAAW6D,IAAI;UAAE3D;UAAQC;QAAY,GAAG6D,SAAAA;MAC/C;IACF;AAEAA,cAAUG,IAAIvC,SAAAA;AAEd,WAAO;MACLwC,aAAa,YAAA;AACXJ,kBAAWP,OAAO7B,SAAAA;MACpB;IACF;EACF;EAEA,MAAc2B,eAAe,EAC3BvB,QACAQ,WACAK,gBAAe,GAKC;AAChB,UAAM,KAAKhC,eAAe0B,YAAY;MACpCP;MACAQ;MACAC,SAAS;QACP4B,UAAU;QACVC,OAAO/E,gBAAgBgF,OAAO1B,iBAAiB;UAAE2B,aAAa;QAAK,CAAA;MACrE;IACF,CAAA;EACF;EAEA,MAAcvC,eAAeH,SAAiC;AAC5D,YAAQA,QAAQW,QAAQ4B,UAAQ;MAC9B,KAAK,uCAAuC;AAC1C,cAAM,KAAKI,uBAAuB3C,OAAAA;AAClC;MACF;MACA,KAAK,uCAAuC;AAC1C,cAAM,KAAK4C,uBAAuB;UAAEjC,SAASX,QAAQW;QAAQ,CAAA;AAC7D;MACF;IACF;EACF;EAEA,MAAcgC,uBAAuB,EAAEzC,QAAQQ,WAAWC,QAAO,GAAa;AAC5EC,oCAAUD,QAAQ4B,aAAa,uCAAA,QAAA;;;;;;;;;AAC/B,UAAMxB,kBAAmCtD,gBAAgBoF,OAAOlC,QAAQ6B,OAAO;MAAEE,aAAa;IAAK,CAAA;AAEnGtD,wBAAI,oBAAoB;MAAE4B,WAAWD,gBAAgBC;IAAU,GAAA;;;;;;AAE/D,UAAM,KAAK8B,qBAAqB;MAC9B5C;MACAQ;MACAM,WAAWD,gBAAgBC;IAC7B,CAAA;AAEA,QAAI,KAAKrC,kBAAkBsC,IAAIF,gBAAgBC,SAAS,GAAI;AAC1D;IACF;AAEA,SAAKrC,kBAAkB0D,IAAItB,gBAAgBC,SAAS;AAEpD,UAAM,KAAK+B,eAAe;MACxB7C;MACAQ;MACAC,SAASI,gBAAgBJ;IAC3B,CAAA;EACF;EAEA,MAAciC,uBAAuB,EAAEjC,QAAO,GAAsB;AAClEC,oCAAUD,QAAQ4B,aAAa,uCAAA,QAAA;;;;;;;;;AAC/B,SAAK7D,gBAAgByD,IAAIvE,gBAAgBiF,OAAOlC,QAAQ6B,KAAK,EAAExB,SAAS,IAAA;EAC1E;EAEA,MAAc8B,qBAAqB,EACjC5C,QACAQ,WACAM,UAAS,GAKO;AAChB5B,wBAAI,eAAe;MAAE4B;MAAWf,MAAMS;MAAWsC,IAAI9C;IAAO,GAAA;;;;;;AAE5D,UAAM,KAAKnB,eAAe0B,YAAY;MACpCP,QAAQQ;MACRA,WAAWR;MACXS,SAAS;QACP4B,UAAU;QACVC,OAAO5E,gBAAgB6E,OAAO;UAAEzB;QAAU,CAAA;MAC5C;IACF,CAAA;EACF;EAEA,MAAc+B,eAAe/C,SAAiC;AAC5D;AACE,YAAMiD,qBAAqB,KAAK1E,kBAAkB4D,IAAInC,QAAQU,SAAS;AACvE,UAAIuC,oBAAoB;AACtB,mBAAWC,YAAYD,oBAAoB;AACzC,gBAAMC,SAASlD,OAAAA;QACjB;MACF;IACF;AAEA;AACE,YAAMmD,cAAc,KAAKjF,WAAWiE,IAAI;QACtC/D,QAAQ4B,QAAQU;QAChBrC,aAAa2B,QAAQW,QAAQ4B;MAC/B,CAAA;AACA,UAAIY,aAAa;AACf,mBAAWD,YAAYC,aAAa;AAClC,gBAAMD,SAASlD,OAAAA;QACjB;MACF;IACF;EACF;EAEQK,aAAa;AACnB,UAAM+C,QAAQC,YAAYC,IAAG;AAE7B,eAAWC,OAAO,KAAK1E,SAAS2E,KAAI,GAAI;AACtC,WAAK7E,kBAAkBgD,OAAO4B,GAAAA;IAChC;AACA,SAAK1E,SAAS4E,MAAK;AACnB,eAAWF,OAAO,KAAK5E,kBAAkB6E,KAAI,GAAI;AAC/C,WAAK3E,SAASwD,IAAIkB,GAAAA;IACpB;AAEA,UAAMG,UAAUL,YAAYC,IAAG,IAAKF;AACpC,QAAIM,UAAU,KAAK;AACjBtE,qBAAIuE,KAAK,oBAAoB;QAAED;MAAQ,GAAA;;;;;;IACzC;EACF;AACF;;;AE5TA,IAAAE,gBAAsG;AAEtG,IAAAC,kBAA2C;AAC3C,IAAAC,oBAA0B;AAC1B,IAAAC,eAA0B;AAC1B,IAAAC,cAAoB;AACpB,IAAAC,oBAAsB;AACtB,oBAA4E;AAC5E,IAAAC,eAAuC;;;ACRvC,2BAAsB;AAEtB,IAAAC,gBAAwB;AAExB,IAAAC,oBAA0B;AAC1B,IAAAC,eAA0B;AAC1B,IAAAC,cAAoB;AACpB,IAAAC,oBAA8B;AAE9B,iBAAsD;;AAuB/C,IAAMC,kBAAN,MAAMA;EAUXC,YAAY,EAAEC,KAAKC,YAAY,CAAC,EAAC,GAA2B;AAP3CC,2BAAkB,IAAIC,sBAAAA;AAE/BC,mBAAU;AAMhB,UAAMC,UAAUC,uBAAUC,OAAM,EAAGC,MAAK;AACxCC,oBAAIC,MAAM,2CAA2CA,wBAAMC,MAAM;MAAEC,IAAIP;IAAQ,CAAA,GAAA;;;;;;AAC/E,SAAKQ,OAAOb;AACZ,SAAKc,aAAab;AAClB,SAAKc,UAAU,IAAIC,qBAAAA,QAAU,KAAKH,IAAI;AAEtC,SAAKI,WAAOC,+BAAmB;MAC7BC,WAAW;QACTC,QAAQC,yBAAOC,WAAW,yBAAA;MAC5B;MACAC,aAAa;MACbC,MAAM;QACJC,MAAM,CAACC,QAAAA;AACL,cAAI,KAAKtB,SAAS;AAEhB;UACF;AACA,cAAI;AACF,iBAAKW,QAASU,KAAKC,GAAAA;UACrB,SAASC,KAAK;AACZlB,4BAAImB,KAAK,cAAcD,KAAAA;;;;;;UACzB;QACF;QACAE,WAAW,CAACC,OAAAA;AACV,eAAKf,QAASgB,YAAY,OAAOL,QAAAA;AAC/B,gBAAI,OAAOM,SAAS,eAAeN,IAAIO,gBAAgBD,MAAM;AAC3DF,iBAAGI,OAAOC,KAAK,MAAMT,IAAIO,KAAKG,YAAW,CAAA,CAAA;YAC3C,OAAO;AACLN,iBAAGJ,IAAIO,IAAI;YACb;UACF;QACF;MACF;MACAI,iBAAiB;QACfC,aAAa;MACf;IACF,CAAA;AAEA,SAAKvB,QAAQwB,SAAS,YAAA;AACpB,UAAI;AACF,cAAM,KAAKtB,KAAMuB,KAAI;AACrB/B,6BAAI,YAAY,KAAKI,IAAI,IAAE,QAAA;;;;;;AAC3B,aAAKC,WAAW2B,cAAW;AAC3B,aAAKvC,gBAAgBwC,KAAI;MAC3B,SAASf,KAAU;AACjB,aAAKb,WAAW6B,UAAUhB,GAAAA;MAC5B;IACF;AAEA,SAAKZ,QAAQ6B,UAAU,YAAA;AACrBnC,2BAAI,gBAAgB,KAAKI,IAAI,IAAE,QAAA;;;;;;AAC/B,WAAKC,WAAW+B,iBAAc;AAC9B,YAAM,KAAKC,MAAK;IAClB;AAEA,SAAK/B,QAAQgC,UAAU,OAAOC,UAAAA;AAC5B,UAAI,KAAK5C,SAAS;AAEhB;MACF;AAEA,WAAKU,WAAW6B,UAAUK,MAAMC,SAAS,IAAIC,MAAMF,MAAMG,OAAO,CAAA;AAChE,WAAKjD,gBAAgBkD,MAAK;AAE1B,UAAI;AACF,cAAM,KAAKnC,MAAM6B,MAAAA;MACnB,SAASnB,KAAK;AACZlB,wBAAI4C,MAAM1B,KAAAA,QAAAA;;;;;;MACZ;AACA,WAAKvB,UAAU;AAEfK,sBAAImB,KAAKoB,MAAMG,WAAW,gBAAgB;QAAEnD,KAAK,KAAKa;MAAK,GAAA;;;;;;IAC7D;AAEAJ,oBAAIC,MAAM,2CAA2CA,wBAAM4C,IAAI;MAAE1C,IAAIP;IAAQ,CAAA,GAAA;;;;;;EAC/E;EAEA,MAAMyC,QAAQ;AACZ,SAAK1C,UAAU;AACf,QAAI;AACF,YAAM,KAAKa,MAAM6B,MAAAA;AACjB,WAAK/B,SAAS+B,MAAAA;IAChB,SAASnB,KAAK;AACZlB,sBAAImB,KAAK,eAAeD,KAAAA;;;;;;IAC1B;EACF;EAEA,MAAM4B,KAAK,EAAEC,OAAOC,OAAM,GAA6C;AACrEhD,yBAAI,QAAQ;MAAE+C;MAAOC;IAAO,GAAA;;;;;;AAC5B,UAAM,KAAKvD,gBAAgBwD,KAAI;AAC/BC,qCAAU,CAAC,KAAKvD,SAAS,6BAAA;;;;;;;;;AACzBuD,qCAAU,KAAK1C,MAAM,0BAAA;;;;;;;;;AACrB,UAAM2C,cAAc,KAAK3C,KAAK4C,IAAIzC,OAAOmC,KAAK;MAC5CO,OAAON,MAAMO,aAAY;MACzBC,MAAMP,OAAOM,aAAY;IAC3B,CAAA;AACA,UAAMH,YAAYK,eAAc;AAChC,WAAOL;EACT;EAEA,MAAMM,gBAAgBT,QAAmD;AACvEhD,yBAAI,mBAAmB;MAAEgD;IAAO,GAAA;;;;;;AAChCE,qCAAU,CAAC,KAAKvD,SAAS,6BAAA;;;;;;;;;AACzB,UAAM,KAAKF,gBAAgBwD,KAAI;AAC/BC,qCAAU,KAAK1C,MAAM,0BAAA;;;;;;;;;AACrB,UAAMkD,gBAAgB,KAAKlD,KAAK4C,IAAIzC,OAAO8C,gBAAgB;MACzDF,MAAMP,OAAOM,aAAY;IAC3B,CAAA;AACA,UAAMI,cAAcF,eAAc;AAClC,WAAOE;EACT;EAEA,MAAMC,YAAY,EAAEC,QAAQC,WAAWC,QAAO,GAA+D;AAC3G9D,yBAAI,eAAe;MAAE4D;MAAQC;MAAWC;IAAQ,GAAA;;;;;;AAChDZ,qCAAU,CAAC,KAAKvD,SAAS,6BAAA;;;;;;;;;AACzB,UAAM,KAAKF,gBAAgBwD,KAAI;AAC/BC,qCAAU,KAAK1C,MAAM,0BAAA;;;;;;;;;AACrB,UAAM,KAAKA,KAAK4C,IAAIzC,OAAOgD,YAAY;MACrCC,QAAQA,OAAON,aAAY;MAC3BO,WAAWA,UAAUP,aAAY;MACjCQ;IACF,CAAA;EACF;AACF;;;;ADzJA,IAAMC,4BAA4B;AAClC,IAAMC,wBAAwB;AAC9B,IAAMC,wBAAwB;AAC9B,IAAMC,qBAAqB;AAyBpB,IAAMC,eAAN,MAAMA;;;;;EA8EXC,YACmBC,OACAC,YACAC,eACjB;iBAHiBF;sBACAC;yBACAC;SAhFXC,SAASC,0BAAYC;SAOrBC,kBAAkBZ;SAKlBa,qBAAqB,oBAAIC,KAAAA;SAKzBC,mBAAmB,oBAAID,KAAAA;SAGdE,eAAe,IAAIC,sBAAAA;SAS3BC,gBAAgB,IAAIC,oBAAAA;SACpBC,eAAe,IAAID,oBAAAA;SAKXE,gBAAgB,IAAIC,wBACnC,CAAC,EAAEC,OAAOC,OAAM,MAAOD,MAAME,MAAK,IAAKD,OAAOC,MAAK,CAAA;SAMpCC,gBAAgB,IAAIC,wBACnC,CAAC,EAAEJ,OAAOC,OAAM,MAAOD,MAAME,MAAK,IAAKD,OAAOC,MAAK,CAAA;SAOrCG,kBAAkB,IAAIN,wBAA6C,CAACO,QAAQA,IAAIJ,MAAK,CAAA;SAKpFK,sBAAsB,IAAIH,wBAAkC,CAAC,EAAEH,OAAM,MAAOA,OAAOC,MAAK,CAAA;SAMlGM,cAAc,IAAIZ,oBAAAA;SAERa,cAAcC,uBAAUC,OAAM,EAAGT,MAAK;SAEtCU,eAAe;MAC9BC,cAAc;MACdC,kBAAkB;MAClBC,kBAAkB;MAClBC,aAAa;MACbC,cAAc;IAChB;AAWE,QAAI,CAAC,KAAKlC,MAAMmC,WAAW,QAAA,KAAa,CAAC,KAAKnC,MAAMmC,WAAW,OAAA,GAAU;AACvE,YAAM,IAAIC,MAAM,qDAAqD,KAAKpC,KAAK,EAAE;IACnF;EACF;EAEAqC,OAAO;AACLC,oBAAIC,MAAM,gCAAgCA,wBAAMC,MAAM;MAAEC,IAAI,KAAKf;IAAY,CAAA,GAAA;;;;;;AAE7E,QAAI;MAACtB,0BAAYsC;MAAWtC,0BAAYuC;MAAYC,SAAS,KAAKzC,MAAM,GAAG;AACzE;IACF;AAEA,SAAK0C,OAAO,IAAIC,wBAAQ;MACtBC,SAAS,CAACC,QAAAA;AACR,YAAI,KAAK7C,WAAWC,0BAAYC,UAAU,KAAKwC,MAAMI,UAAU;AAC7D;QACF;AACA,YAAI,KAAK9C,WAAWC,0BAAYsC,WAAW;AACzCJ,0BAAIY,KAAK,uBAAuBF,KAAAA;;;;;;QAClC;AACA,aAAKG,6BAA4B;MACnC;IACF,CAAA;AAEA,SAAKC,iBAAiB,IAAIC,2BAAa,KAAKR,MAAM,YAAA;AAChD,YAAM,KAAKS,6BAA4B;AACvC,YAAM,KAAKC,+BAA8B;AACzC,WAAK9B,YAAY+B,KAAI;IACvB,CAAA;AAGAC,4CACE,KAAKZ,MACL,YAAA;AACE,UAAI,KAAK1C,WAAWC,0BAAYsC,WAAW;AACzC,aAAKU,eAAgBM,SAAQ;MAC/B;IACF,GACA7D,kBAAAA;AAGF,SAAK8D,iBAAiB,IAAIN,2BAAa,KAAKR,MAAM,YAAA;AAChD,YAAM,KAAKe,WAAU;IACvB,CAAA;AAEA,SAAKC,UAAUzD,0BAAYuC,UAAU;AACrC,SAAKmB,cAAa;AAClBxB,oBAAIC,MAAM,gCAAgCA,wBAAMwB,IAAI;MAAEtB,IAAI,KAAKf;IAAY,CAAA,GAAA;;;;;;EAC7E;EAEA,MAAMsC,QAAQ;AACZ1B,yBAAI,cAAA,QAAA;;;;;;AACJ,QAAI;MAAClC,0BAAYC;MAAQuC,SAAS,KAAKzC,MAAM,GAAG;AAC9C;IACF;AAEA,UAAM,KAAK0C,MAAMoB,QAAAA;AAEjB,SAAKvD,aAAawD,MAAK;AACvB,UAAM,KAAKC,SAASH,MAAAA;AACpB,SAAKG,UAAUC;AACf,SAAKP,UAAUzD,0BAAYC,MAAM;AACjCiC,yBAAI,UAAA,QAAA;;;;;;EACN;EAEA+B,YAA0B;AACxB,WAAO;MACLC,MAAM,KAAKtE;MACXuE,OAAO,KAAKpE;MACZqE,OAAO,KAAKC,YAAYC;MACxBC,aAAa,KAAKrE;MAClBsE,mBAAmB,KAAKrE;MACxBsE,iBAAiB,KAAKpE;IACxB;EACF;EAEA,MAAMqE,KAAK,EAAE7D,OAAOC,OAAM,GAA4D;AACpFoB,yBAAI,WAAW;MAAErB;MAAOC;IAAO,GAAA;;;;;;AAC/B,SAAKW,aAAaI;AAClB,SAAKb,cAAc2D,IAAI;MAAE9D;MAAOC;IAAO,CAAA;AACvC,SAAKkC,eAAgBM,SAAQ;EAC/B;EAEA,MAAMsB,MAAM,EAAE/D,OAAOC,OAAM,GAA4D;AACrF,SAAKW,aAAaK;AAClBI,yBAAI,WAAW;MAAErB;MAAOC;IAAO,GAAA;;;;;;AAE/B,SAAK,KAAKH,cAAckE,IAAI;MAAEhE;MAAOC;IAAO,CAAA,GAAI8C,MAAAA;AAChD,SAAKjD,cAAcmE,OAAO;MAAEjE;MAAOC;IAAO,CAAA;AAC1C,SAAKE,cAAc8D,OAAO;MAAEjE;MAAOC;IAAO,CAAA;EAC5C;EAEA,MAAMiE,YAAYC,KAA6B;AAC7C,SAAKvD,aAAaC;AAClB,UAAM,KAAKpB,aAAa2E,KAAI;AAC5BC,qCAAU,KAAKnF,WAAWC,0BAAYsC,WAAW,kCAAA;;;;;;;;;AACjD,UAAM,KAAKyB,QAASgB,YAAYC,GAAAA;EAClC;EAEA,MAAMG,kBAAkBrE,QAAmB;AACzCoB,yBAAI,2BAA2B;MAAEpB;IAAO,GAAA;;;;;;AACxC,SAAKM,oBAAoBuD,IAAI;MAAE7D;IAAO,CAAA;AACtC,SAAKkC,eAAgBM,SAAQ;EAC/B;EAEA,MAAM8B,oBAAoBtE,QAAmB;AAC3CoB,yBAAI,+BAA+B;MAAEpB;IAAO,GAAA;;;;;;AAC5C,SAAKM,oBAAoB0D,OAAO;MAAEhE;IAAO,CAAA;AACzC,SAAK,KAAKI,gBAAgB2D,IAAI/D,MAAAA,GAAS8C,MAAAA;AACvC,SAAK1C,gBAAgB4D,OAAOhE,MAAAA;EAC9B;EAEQiC,+BAA+B;AACrCsC,oCACE,KAAK5C,MACL,MAAA;AACE,WAAKO,eAAgBM,SAAQ;IAC/B,GACA9D,qBAAAA;EAEJ;EAEQiE,UAAU6B,UAAuB;AACvC,SAAKvF,SAASuF;AACd,SAAKjF,mBAAmB,oBAAID,KAAAA;AAC5B8B,yBAAI,wBAAwB;MAAEqD,QAAQ,KAAKtB,UAAS;IAAG,GAAA;;;;;;AACvD,SAAKzD,cAAc4C,KAAK,KAAKa,UAAS,CAAA;EACxC;EAEQP,gBAAgB;AACtBxB,yBAAI,mBAAmB;MAAEgC,MAAM,KAAKtE;MAAOuE,OAAO,KAAKpE;IAAO,GAAA;;;;;;AAC9DmF,qCAAU,CAAC,KAAKnB,SAAS,0BAAA;;;;;;;;;AAEzB,SAAK5D,qBAAqB,oBAAIC,KAAAA;AAG9B,SAAKoF,iBAAiB,KAAK/C,KAAMgD,OAAM;AACvC,SAAKD,eAAeE,UAAU,YAAA;AAC5BxD,2BAAI,+BAAA,QAAA;;;;;;AACJ,YAAMyD,QAAQC,IAAIC,MAAMC,KAAK,KAAKnF,cAAcoF,OAAM,CAAA,EAAIC,IAAI,CAACC,WAAWA,OAAOrC,MAAK,CAAA,CAAA;AACtF,YAAM+B,QAAQC,IAAIC,MAAMC,KAAK,KAAK5E,gBAAgB6E,OAAM,CAAA,EAAIC,IAAI,CAACC,WAAWA,OAAOrC,MAAK,CAAA,CAAA;AACxF,WAAKjD,cAAcuF,MAAK;AACxB,WAAKhF,gBAAgBgF,MAAK;IAC5B,CAAA;AAEA,QAAI;AACF,WAAKnC,UAAU,IAAIoC,gBAAgB;QACjCC,KAAK,KAAKxG;QACVyG,WAAW;UACTC,aAAa,MAAA;AACXpE,iCAAI,oBAAA,QAAA;;;;;;AACJ,iBAAKmC,aAAaL;AAClB,iBAAK9D,kBAAkBZ;AACvB,iBAAKmE,UAAUzD,0BAAYsC,SAAS;AACpC,iBAAKhC,aAAaiG,KAAI;AACtB,iBAAKvD,eAAgBM,SAAQ;UAC/B;UAEAkD,gBAAgB,MAAA;AACdtE,iCAAI,uBAAuB;cAAEiC,OAAO,KAAKpE;YAAO,GAAA;;;;;;AAChD,gBAAI,KAAKA,WAAWC,0BAAYyG,OAAO;AAGrC,mBAAKhD,UAAUzD,0BAAY0G,YAAY;AACvC;YACF;AACA,gBAAI,KAAK3G,WAAWC,0BAAYsC,aAAa,KAAKvC,WAAWC,0BAAYuC,YAAY;AACnF,mBAAKoE,2BAA0B;YACjC;AACA,iBAAKlD,UAAUzD,0BAAY0G,YAAY;AACvC,iBAAKnD,eAAgBD,SAAQ;UAC/B;UAEAX,SAAS,CAACyB,UAAAA;AACRlC,iCAAI,gBAAgB;cAAEkC;cAAOD,OAAO,KAAKpE;YAAO,GAAA;;;;;;AAChD,iBAAKsE,aAAaD;AAClB,gBAAI,KAAKrE,WAAWC,0BAAYsC,aAAa,KAAKvC,WAAWC,0BAAYuC,YAAY;AACnF,mBAAKoE,2BAA0B;YACjC;AACA,iBAAKlD,UAAUzD,0BAAYyG,KAAK;AAEhC,iBAAKlD,eAAgBD,SAAQ;UAC/B;QACF;MACF,CAAA;IACF,SAASV,KAAU;AACjB,UAAI,KAAK7C,WAAWC,0BAAYsC,aAAa,KAAKvC,WAAWC,0BAAYuC,YAAY;AACnF,aAAKoE,2BAA0B;MACjC;AACA,WAAKtC,aAAazB;AAClB,WAAKa,UAAUzD,0BAAY0G,YAAY;AACvC,WAAKnD,eAAgBD,SAAQ;IAC/B;EACF;EAEQqD,6BAA6B;AACnC,SAAKzG,mBAAmB;AACxB,SAAKA,kBAAkB0G,KAAKC,IAAI,KAAK3G,iBAAiBX,qBAAAA;EACxD;EAEA,MAAciE,aAAa;AACzBtB,yBAAI,mBAAmB,KAAKhC,eAAe,MAAM;MAAEiE,OAAO,KAAKpE;IAAO,GAAA;;;;;;AACtE,SAAK0B,aAAaG;AAElB,QAAI,KAAK7B,WAAWC,0BAAY8G,cAAc;AAC5C5E,sBAAIY,KAAK,oCAAA,QAAA;;;;;;AACT;IACF;AAEA,QAAI,KAAK/C,WAAWC,0BAAYC,QAAQ;AACtC;IACF;AAGA,SAAKK,aAAawD,MAAK;AACvB,UAAM,KAAK0B,gBAAgB3B,QAAAA;AAC3B,SAAKE,SAASH,MAAAA,EAAQmD,MAAM,MAAA;IAAO,CAAA;AACnC,SAAKhD,UAAUC;AAEf,cAAMgD,mCAAkB,KAAKvE,UAAOwE,qBAAM,KAAK/G,eAAe,CAAA;AAE9D,SAAKuD,UAAUzD,0BAAY8G,YAAY;AAEvC,SAAKpD,cAAa;EACpB;EAEA,MAAcR,+BAA8C;AAC1D,cAAMgE,gCAAaF,mCAAkB,KAAKxB,gBAAiB,KAAKlF,aAAa2E,KAAI,CAAA,GAAK,GAAA;AAEtF,UAAMkC,SAAS,KAAKpD;AACpBmB,qCAAU,KAAKnF,WAAWC,0BAAYsC,WAAW,kCAAA;;;;;;;;;AAGjD,eAAW,EAAEzB,OAAOC,OAAM,KAAM,KAAKH,cAAcyG,KAAI,GAAI;AAEzD,UAAI,KAAKpG,cAAcqG,IAAI;QAAExG;QAAOC;MAAO,CAAA,GAAI;AAC7C;MACF;AAEA,WAAK,KAAKH,cAAckE,IAAI;QAAEhE;QAAOC;MAAO,CAAA,GAAI8C,MAAAA;AAChD,WAAKjD,cAAcmE,OAAO;QAAEjE;QAAOC;MAAO,CAAA;IAC5C;AAGA,eAAW,EAAED,OAAOC,OAAM,KAAM,KAAKE,cAAc+E,OAAM,GAAI;AAE3D,UAAI,KAAKpF,cAAc0G,IAAI;QAAExG;QAAOC;MAAO,CAAA,GAAI;AAC7C;MACF;AAEA,YAAMwG,cAAc,UAAMJ,gCACxBF,mCAAkB,KAAKxB,gBAAiB2B,OAAOzC,KAAK;QAAE7D;QAAOC;MAAO,CAAA,CAAA,GACpE,GAAA;AAIFwG,kBAAYC,UAAU,OAAOC,eAAAA;AAC3BtF,6BAAI,eAAe;UAAEsF;QAAW,GAAA;;;;;;AAChC,cAAM,KAAK1H,cAAc;UAAEe;UAAO2G;QAAW,CAAA;MAC/C,CAAA;AAGA,WAAK7G,cAAc8G,IAAI;QAAE5G;QAAOC;MAAO,GAAGwG,WAAAA;IAC5C;EACF;EAEA,MAAcnE,iCAAgD;AAC5D,cAAM+D,gCAAaF,mCAAkB,KAAKxB,gBAAiB,KAAKlF,aAAa2E,KAAI,CAAA,GAAK,GAAA;AAEtF,UAAMkC,SAAS,KAAKpD;AACpBmB,qCAAU,KAAKnF,WAAWC,0BAAYsC,WAAW,kCAAA;;;;;;;;;AAGjD,eAAWxB,UAAU,KAAKI,gBAAgBkG,KAAI,GAAI;AAEhD,UAAI,KAAKhG,oBAAoBiG,IAAI;QAAEvG;MAAO,CAAA,GAAI;AAC5C;MACF;AAEA,WAAK,KAAKI,gBAAgB2D,IAAI/D,MAAAA,GAAS8C,MAAAA;AACvC,WAAK1C,gBAAgB4D,OAAOhE,MAAAA;IAC9B;AAGA,eAAW,EAAEA,OAAM,KAAM,KAAKM,oBAAoB2E,OAAM,GAAI;AAC1D,UAAI,KAAK7E,gBAAgBmG,IAAIvG,MAAAA,GAAS;AACpC;MACF;AAEA,YAAM4G,gBAAgB,UAAMR,gCAC1BF,mCAAkB,KAAKxB,gBAAiB2B,OAAOQ,gBAAgB7G,MAAAA,CAAAA,GAC/D,GAAA;AAEF4G,oBAAcH,UAAU,OAAOjD,YAAAA;AAC7B,aAAK7C,aAAaE;AAClB,cAAM,KAAK9B,WAAW;UACpB+H,QAAQrG,uBAAUuE,KAAKxB,QAAQsD,MAAM;UACrCC,WAAWtG,uBAAUuE,KAAKxB,QAAQuD,SAAS;UAC3CC,SAASxD,QAAQwD;QACnB,CAAA;MACF,CAAA;AAGA,WAAK5G,gBAAgBuG,IAAI3G,QAAQ4G,aAAAA;IACnC;EACF;AACF;;;AE9aA,IAAAK,gBAA+B;AAE/B,IAAAC,kBAAwB;AACxB,IAAAC,oBAA0B;AAC1B,IAAAC,eAA0B;AAC1B,IAAAC,cAAoB;AACpB,IAAAC,oBAAuB;AAEvB,IAAAC,eAAuC;;AAQhC,IAAMC,6BAAN,MAAMA;EAAN;AAEIC;sBAAa,IAAIC,oBAAAA;AAMjBC;kBAAS,IAAIC,wBAA6CC,uBAAUC,IAAI;AAGxEC;uBAAc,IAAIH,wBAA2CC,uBAAUC,IAAI;;AACtF;AAKO,IAAME,sBAAN,MAAMA;EAwBXC,YAA6BC,UAAsC;oBAAtCA;SAvBpBC,gBAAgB,IAAIT,oBAAAA;SACpBU,eAAe,IAAIV,oBAAAA;SACnBD,aAAa,IAAIC,oBAAAA;SAKjBW,YAAY,IAAIX,oBAAAA;SAOjBY,gBAAgB,IAAIC,wBAC1B,CAAC,EAAEC,OAAOC,OAAM,MAAOD,MAAME,MAAK,IAAKD,OAAOC,MAAK,CAAA;SAMpCC,iBAAiB,IAAIC,sBAAAA,EAAUC,KAAI;AAGlD,SAAKC,OAAO,IAAIC,wBAAAA;AAEhB,SAAKD,KAAKE,UAAU,KAAKd,SAAST,WAAWwB,GAAG,CAACC,SAAS,KAAKzB,WAAW0B,KAAKD,IAAAA,CAAAA,CAAAA;EACjF;EAEA,MAAME,OAAO;AACX,QAAI,CAAC,KAAKN,KAAKO,UAAU;AACvB;IACF;AACA,SAAKP,OAAO,IAAIC,wBAAAA;AAChB,SAAKD,KAAKE,UAAU,KAAKd,SAAST,WAAWwB,GAAG,CAACC,SAAS,KAAKzB,WAAW0B,KAAKD,IAAAA,CAAAA,CAAAA;AAE/E,UAAMI,QAAQC,IAAI;SAAI,KAAKjB,cAAckB,OAAM;MAAIC,IAAI,CAACC,UAAU,KAAKC,KAAKD,KAAAA,CAAAA,CAAAA;EAC9E;EAEA,MAAME,QAAQ;AACZ,QAAI,KAAKd,KAAKO,UAAU;AACtB;IACF;AAEA,UAAMQ,mBAAmB,IAAItB,wBAC3B,CAAC,EAAEC,OAAOC,OAAM,MAAOD,MAAME,MAAK,IAAKD,OAAOC,MAAK,GACnD;SAAI,KAAKJ,cAAckB,OAAM;KAAG;AAGlC,UAAMF,QAAQC,IAAI;SAAI,KAAKjB,cAAckB,OAAM;MAAIC,IAAI,CAACC,UAAU,KAAKI,MAAMJ,KAAAA,CAAAA,CAAAA;AAG7E,SAAKpB,gBAAgBuB;AAErB,UAAM,KAAKf,KAAKiB,QAAO;EACzB;EAEAC,YAA4B;AAC1B,WAAO,CAAA;EACT;EAEA,MAAML,KAAK,EAAEnB,OAAOC,OAAM,GAA6C;AACrEwB,qCAAU,CAAC,KAAKnB,KAAKO,UAAU,UAAA;;;;;;;;;AAE/B,SAAKf,cAAc4B,IAAI;MAAE1B;MAAOC;IAAO,CAAA;AAEvC,QAAI,CAAC,KAAKP,SAASP,OAAOwC,IAAI3B,KAAAA,GAAQ;AACpC,WAAKN,SAASP,OAAOyC,IAAI5B,OAAO,IAAID,wBAAWV,uBAAUC,IAAI,CAAA;IAC/D;AAEA,SAAKI,SAASP,OAAO0C,IAAI7B,KAAAA,EAAQ0B,IAAIzB,MAAAA;AACrC,SAAKP,SAAST,WAAW0B,KAAK;MAC5BX;MACAf,YAAY;QACV6C,eAAe;UACbC,MAAM9B,OAAO+B,aAAY;UACzBC,OAAO,oBAAIC,KAAAA;QACb;MACF;IACF,CAAA;AAGA,eAAW,CAAClC,QAAOmC,OAAAA,KAAY,KAAKzC,SAASP,QAAQ;AACnDiD,YAAMC,KAAKF,OAAAA,EAASG,QAAQ,CAACrC,YAAAA;AAC3B,aAAKhB,WAAW0B,KAAK;UACnBX,OAAAA;UACAf,YAAY;YACV6C,eAAe;cACbC,MAAM9B,QAAO+B,aAAY;cACzBC,OAAO,oBAAIC,KAAAA;YACb;UACF;QACF,CAAA;MACF,CAAA;IACF;EACF;EAEA,MAAMZ,MAAM,EAAEtB,OAAOC,OAAM,GAA6C;AACtEwB,qCAAU,CAAC,KAAKnB,KAAKO,UAAU,UAAA;;;;;;;;;AAE/B,SAAKf,cAAcyC,OAAO;MAAEvC;MAAOC;IAAO,CAAA;AAE1C,QAAI,CAAC,KAAKP,SAASP,OAAOwC,IAAI3B,KAAAA,GAAQ;AACpC,WAAKN,SAASP,OAAOyC,IAAI5B,OAAO,IAAID,wBAAWV,uBAAUC,IAAI,CAAA;IAC/D;AAEA,SAAKI,SAASP,OAAO0C,IAAI7B,KAAAA,EAAQuC,OAAOtC,MAAAA;AAExC,UAAMhB,aAAyB;MAC7BuD,UAAU;QACRT,MAAM9B,OAAO+B,aAAY;MAC3B;IACF;AAEA,SAAKtC,SAAST,WAAW0B,KAAK;MAAEX;MAAOf;IAAW,CAAA;EACpD;EAEA,MAAMwD,YAAY,EAAEC,QAAQC,WAAWC,QAAO,GAA+D;AAC3GC,yBAAI,gBAAgB;MAAEH;MAAQC;MAAW,GAAGG,IAAIF,OAAAA;IAAS,GAAA;;;;;;AAEzDnB,qCAAUkB,WAAAA,QAAAA;;;;;;;;;AACVlB,qCAAU,CAAC,KAAKnB,KAAKO,UAAU,UAAA;;;;;;;;;AAE/B,UAAM,KAAKV,eAAe4C,KAAI;AAE9B,UAAMC,SAAS,KAAKtD,SAASH,YAAYsC,IAAIc,SAAAA;AAC7C,QAAI,CAACK,QAAQ;AACXH,sBAAII,KAAK,4CAA4C;QAAEP;QAAQC;MAAU,GAAA;;;;;;AACzE;IACF;AAEA,QAAIK,OAAO1C,KAAKO,UAAU;AACxBgC,sBAAII,KAAK,yBAAyB;QAAEP;QAAQC;MAAU,GAAA;;;;;;AACtD;IACF;AAEAK,WAAO7C,eACJ4C,KAAI,EACJG,KAAK,MAAA;AACJ,UAAIF,OAAO1C,KAAKO,UAAU;AACxBgC,wBAAII,KAAK,yBAAyB;UAAEP;UAAQC;QAAU,GAAA;;;;;;AACtD;MACF;AAEAE,2BAAI,mBAAmB;QAAEH;QAAQC;QAAW,GAAGG,IAAIF,OAAAA;MAAS,GAAA;;;;;;AAE5DI,aAAOnD,UAAUc,KAAK;QAAE+B;QAAQC;QAAWC;MAAQ,CAAA;IACrD,CAAA,EACCO,MAAM,CAACC,QAAAA;AACNP,sBAAIQ,MAAM,kCAAkC;QAAED;MAAI,GAAA;;;;;;IACpD,CAAA;EACJ;EAEA,MAAME,kBAAkBrD,QAAmB;AACzC4C,yBAAI,eAAe;MAAE5C;IAAO,GAAA;;;;;;AAC5B,SAAKP,SAASH,YAAYqC,IAAI3B,QAAQ,IAAI;EAC5C;EAEA,MAAMsD,oBAAoBtD,QAAmB;AAC3C4C,yBAAI,iBAAiB;MAAE5C;IAAO,GAAA;;;;;;AAC9B,SAAKP,SAASH,YAAYgD,OAAOtC,MAAAA;EACnC;EAEAuD,SAAS;AACP,SAAKrD,eAAesD,MAAK;EAC3B;EAEAC,WAAW;AACT,SAAKvD,eAAeE,KAAI;EAC1B;AACF;AACA,IAAMyC,MAAM,CAACF,YAAAA;AACX,MAAI,CAACA,QAAQe,SAASC,SAAS,iBAAA,GAAoB;AACjD,WAAO,CAAC;EACV;AAEA,QAAMC,aAAaC,yBAAOC,gBAAgB,qCAAA,EAAuCC,OAAOpB,QAAQ1B,KAAK;AAErG,MAAI,OAAO2C,YAAYjB,SAASlC,SAAS,UAAU;AACjD,WAAO;MAAEkC,SAASqB,OAAOC,KAAKL,YAAYjB,SAASlC,IAAAA,EAAM,CAAA;MAAIyD,WAAWN,YAAYjB,SAASuB;IAAU;EACzG;AAEA,SAAO,CAAC;AACV;;;ACzNA,IAAAC,gBAA2C;AAE3C,IAAAC,kBAAwB;AACxB,IAAAC,oBAA0B;AAC1B,IAAAC,eAA0B;AAC1B,IAAAC,cAAoB;AACpB,IAAAC,oBAA8C;;;;;;;;;;;;AAO9C,IAAMC,sBAAsB;AAC5B,IAAMC,iCAAiC;AAIhC,IAAMC,yBAAN,MAAMA;EAsBXC,YAA6BC,QAAmC;kBAAnCA;SArBZC,WAAW,oBAAIC,IAAAA;SAGxBC,UAAU;SAETC,eAAe,oBAAIF,IAAAA;SACnBG,gBAAgB,IAAIC,oBAAAA;SACpBC,eAAe,IAAID,oBAAAA;SACnBE,aAAa,IAAIF,oBAAAA;SAKjBG,YAAY,IAAIH,oBAAAA;SAMRI,cAAcC,uBAAUC,OAAM,EAAGC,MAAK;AAGrDC,yBAAI,kCAAkC;MAAEC,OAAO,KAAKf;IAAO,GAAA;;;;;;AAC3D,eAAWgB,QAAQ,KAAKhB,QAAQ;AAC9B,UAAI,KAAKC,SAASgB,IAAID,KAAKE,MAAM,GAAG;AAClC;MACF;AACA,YAAMA,SAAS,IAAIC,aACjBH,KAAKE,QACL,OAAOE,YAAY,KAAKX,UAAUY,KAAKD,OAAAA,GACvC,OAAOE,SAAS,KAAKd,WAAWa,KAAKC,IAAAA,CAAAA;AAEvCJ,aAAOb,cAAckB,GAAG,MAAM,KAAKlB,cAAcgB,KAAK,KAAKG,UAAS,CAAA,CAAA;AAEpE,WAAKvB,SAASwB,IAAIT,KAAKE,QAAQA,MAAAA;AAC/B,WAAKd,aAAaqB,IAAIT,KAAKE,QAAQ,CAAA;AACnCA,aAAOX,aAAagB,GAAG,CAACG,WAAU,KAAKnB,aAAac,KAAKK,MAAAA,CAAAA;IAC3D;EACF;EAEA,MACMC,OAAO;AACX,QAAI,KAAKxB,SAAS;AAChB;IACF;AACAW,yBAAI,uBAAuB;MAAEC,OAAO,KAAKf;IAAO,GAAA;;;;;;AAChDc,oBAAIY,MAAM,2CAA2CA,wBAAME,MAAM;MAAEC,IAAI,KAAKnB;IAAY,CAAA,GAAA;;;;;;AAExF,SAAKoB,aAAY;AAEjB;SAAI,KAAK7B,SAAS8B,OAAM;MAAIC,QAAQ,CAACd,WAAWA,OAAOS,KAAI,CAAA;AAE3D,SAAKxB,UAAU;AACfW,oBAAIY,MAAM,2CAA2CA,wBAAMO,IAAI;MAAEJ,IAAI,KAAKnB;IAAY,CAAA,GAAA;;;;;;EACxF;EAEA,MACMwB,QAAQ;AACZ,QAAI,CAAC,KAAK/B,SAAS;AACjB;IACF;AACA,SAAKA,UAAU;AAEf,UAAM,KAAKgC,KAAKC,QAAO;AAEvB,UAAMC,QAAQC,IAAIC,MAAMC,KAAK,KAAKvC,SAAS8B,OAAM,CAAA,EAAIU,IAAI,CAACvB,WAAWA,OAAOgB,MAAK,CAAA,CAAA;EACnF;EAEA,MAAMQ,cAAcC,YAAoB;AACtC7B,yBAAI,qBAAqB;MAAE6B;IAAW,GAAA;;;;;;AACtCC,qCAAU,KAAKzC,SAAS,yBAAA;;;;;;;;;AAExB,UAAMe,SAAS,KAAKjB,SAAS4C,IAAIF,UAAAA;AACjCC,qCAAU1B,QAAQ,oBAAA;;;;;;;;;AAElB,UAAMA,OAAOgB,MAAK;AAClB,cAAMY,qBAAMjD,8BAAAA;AACZ,UAAMqB,OAAOS,KAAI;EACnB;EAEAH,YAA4B;AAC1B,WAAOe,MAAMC,KAAK,KAAKvC,SAAS8B,OAAM,CAAA,EAAIU,IAAI,CAACvB,WAAWA,OAAOM,UAAS,CAAA;EAC5E;EAEA,MACMuB,KAAK,EAAEC,OAAOC,OAAM,GAA6C;AACrEnC,yBAAI,QAAQ;MAAEkC;MAAOC;IAAO,GAAA;;;;;;AAC5BL,qCAAU,KAAKzC,SAAS,UAAA;;;;;;;;;AACxB,UAAM,KAAK+C,eAAe,CAAChC,WAAWA,OAAO6B,KAAK;MAAEC;MAAOC;IAAO,CAAA,CAAA;EACpE;EAEA,MACME,MAAM,EAAEH,OAAOC,OAAM,GAA6C;AACtEnC,yBAAI,WAAW;MAAEkC;MAAOC;IAAO,GAAA;;;;;;AAC/BL,qCAAU,KAAKzC,SAAS,UAAA;;;;;;;;;AAExB,UAAM,KAAK+C,eAAe,CAAChC,WAAWA,OAAOiC,MAAM;MAAEH;MAAOC;IAAO,CAAA,CAAA;EACrE;EAEA,MAAMG,YAAY,EAChBC,QACAC,WACAC,QAAO,GAKS;AAChBzC,yBAAI,UAAUwC,UAAUE,SAAQ,CAAA,IAAI,QAAA;;;;;;AACpCZ,qCAAU,KAAKzC,SAAS,UAAA;;;;;;;;;AAExB,SAAK,KAAK+C,eAAe,OAAOhC,QAAQyB,eAAAA;AACtC,WAAKzB,OAAOkC,YAAY;QAAEC;QAAQC;QAAWC;MAAQ,CAAA,EAAGE,MAAM,CAACC,QAAAA;AAC7D,YAAIA,eAAeC,0CAAwB;AACzC7C,+BAAI,2BAA2B;YAAE4C;UAAI,GAAA;;;;;;QACvC,OAAO;AACL5C,+BAAI,oBAAoB6B,UAAAA,IAAc;YAAEe;UAAI,GAAA;;;;;;AAC5C,eAAK,KAAKE,mBAAmBjB,UAAAA;QAC/B;MACF,CAAA;IACF,CAAA;EACF;EAEA,MACMiB,mBAAmBjB,YAAoB;AAC3C,UAAMvC,eAAe,KAAKA,aAAayC,IAAIF,UAAAA,KAAgB;AAC3D,QAAIvC,eAAeR,qBAAqB;AACtCkB,sBAAI+C,KAAK,gCAAgClB,UAAAA,KAAevC,YAAAA,MAAkBR,mBAAAA,iBAAkC,QAAA;;;;;;AAC5G,YAAM,KAAK8C,cAAcC,UAAAA;AACzB,WAAKvC,aAAaqB,IAAIkB,YAAa,CAAA;AACnC;IACF;AACA,SAAKvC,aAAaqB,IAAIkB,aAAc,KAAKvC,aAAayC,IAAIF,UAAAA,KAAgB,KAAK,CAAA;EACjF;EAEA,MAAMmB,kBAAkBb,QAAmB;AACzCnC,yBAAI,wCAAwCmC,MAAAA,IAAQ,QAAA;;;;;;AACpDL,qCAAU,KAAKzC,SAAS,UAAA;;;;;;;;;AAExB,UAAM,KAAK+C,eAAe,OAAOhC,WAAWA,OAAO4C,kBAAkBb,MAAAA,CAAAA;EACvE;EAEA,MAAMc,oBAAoBd,QAAmB;AAC3CnC,yBAAI,wCAAwCmC,MAAAA,IAAQ,QAAA;;;;;;AACpDL,qCAAU,KAAKzC,SAAS,UAAA;;;;;;;;;AAExB,UAAM,KAAK+C,eAAe,OAAOhC,WAAWA,OAAO6C,oBAAoBd,MAAAA,CAAAA;EACzE;EAEQnB,eAAe;AACrB,SAAKK,OAAO,IAAI6B,wBAAQ;MACtBC,SAAS,CAACP,QAAQ5C,gBAAI2C,MAAMC,KAAAA,QAAAA;;;;;;IAC9B,CAAA;EACF;EAEA,MAAcR,eACZgB,IACuB;AACvB,WAAO7B,QAAQC,IAAIC,MAAMC,KAAK,KAAKvC,SAASkE,QAAO,CAAA,EAAI1B,IAAI,CAAC,CAACE,YAAYzB,MAAAA,MAAYgD,GAAGhD,QAAQyB,UAAAA,CAAAA,CAAAA;EAClG;AACF;;EAxHGyB;GAzCUtE,uBAAAA,WAAAA,QAAAA,IAAAA;;EAyDVsE;GAzDUtE,uBAAAA,WAAAA,SAAAA,IAAAA;;EAqFVsE;GArFUtE,uBAAAA,WAAAA,QAAAA,IAAAA;;EA4FVsE;GA5FUtE,uBAAAA,WAAAA,SAAAA,IAAAA;;EA4HVsE;GA5HUtE,uBAAAA,WAAAA,sBAAAA,IAAAA;",
6
- "names": ["MESSAGE_TIMEOUT", "ReliablePayload", "schema", "getCodecForType", "Acknowledgement", "RECEIVED_MESSAGES_GC_INTERVAL", "Messenger", "constructor", "signalManager", "retryDelay", "_listeners", "ComplexMap", "peerId", "payloadType", "toHex", "_defaultListeners", "PublicKey", "hash", "_onAckCallbacks", "_receivedMessages", "ComplexSet", "_toClear", "_closed", "_signalManager", "_retryDelay", "open", "traceId", "random", "log", "trace", "begin", "id", "_ctx", "Context", "onError", "err", "catch", "onDispose", "onMessage", "on", "message", "from", "author", "_handleMessage", "scheduleTaskInterval", "_performGc", "end", "close", "dispose", "sendMessage", "recipient", "payload", "invariant", "messageContext", "derive", "reliablePayload", "messageId", "has", "messageReceived", "timeoutHit", "promise", "Promise", "resolve", "reject", "scheduleExponentialBackoffTaskInterval", "_encodeAndSend", "scheduleTask", "delete", "ProtocolTimeoutError", "TimeoutError", "MESSAGE_TIMEOUT", "set", "listen", "subscribeMessages", "listeners", "get", "Set", "add", "unsubscribe", "type_url", "value", "encode", "preserveAny", "_handleReliablePayload", "_handleAcknowledgement", "decode", "_sendAcknowledgement", "_callListeners", "to", "defaultListenerMap", "listener", "listenerMap", "start", "performance", "now", "key", "keys", "clear", "elapsed", "warn", "import_async", "import_context", "import_invariant", "import_keys", "import_log", "import_protocols", "import_util", "import_async", "import_invariant", "import_keys", "import_log", "import_protocols", "SignalRPCClient", "constructor", "url", "callbacks", "_connectTrigger", "Trigger", "_closed", "traceId", "PublicKey", "random", "toHex", "log", "trace", "begin", "id", "_url", "_callbacks", "_socket", "WebSocket", "_rpc", "createProtoRpcPeer", "requested", "Signal", "schema", "getService", "noHandshake", "port", "send", "msg", "err", "warn", "subscribe", "cb", "onmessage", "Blob", "data", "Buffer", "from", "arrayBuffer", "encodingOptions", "preserveAny", "onopen", "open", "onConnected", "wake", "onError", "onclose", "onDisconnected", "close", "onerror", "event", "error", "Error", "message", "reset", "catch", "end", "join", "topic", "peerId", "wait", "invariant", "swarmStream", "rpc", "swarm", "asUint8Array", "peer", "waitUntilReady", "receiveMessages", "messageStream", "sendMessage", "author", "recipient", "payload", "DEFAULT_RECONNECT_TIMEOUT", "MAX_RECONNECT_TIMEOUT", "ERROR_RECONCILE_DELAY", "RECONCILE_INTERVAL", "SignalClient", "constructor", "_host", "_onMessage", "_onSwarmEvent", "_state", "SignalState", "CLOSED", "_reconnectAfter", "_connectionStarted", "Date", "_lastStateChange", "_clientReady", "Trigger", "statusChanged", "Event", "commandTrace", "_swarmStreams", "ComplexMap", "topic", "peerId", "toHex", "_joinedTopics", "ComplexSet", "_messageStreams", "key", "_subscribedMessages", "_reconciled", "_instanceId", "PublicKey", "random", "_performance", "sentMessages", "receivedMessages", "reconnectCounter", "joinCounter", "leaveCounter", "startsWith", "Error", "open", "log", "trace", "begin", "id", "CONNECTED", "CONNECTING", "includes", "_ctx", "Context", "onError", "err", "disposed", "warn", "_scheduleReconcileAfterError", "_reconcileTask", "DeferredTask", "_reconcileSwarmSubscriptions", "_reconcileMessageSubscriptions", "emit", "scheduleTaskInterval", "schedule", "_reconnectTask", "_reconnect", "_setState", "_createClient", "end", "close", "dispose", "reset", "_client", "undefined", "getStatus", "host", "state", "error", "_lastError", "message", "reconnectIn", "connectionStarted", "lastStateChange", "join", "add", "leave", "get", "delete", "sendMessage", "msg", "wait", "invariant", "subscribeMessages", "unsubscribeMessages", "scheduleTask", "newState", "status", "_connectionCtx", "derive", "onDispose", "Promise", "all", "Array", "from", "values", "map", "stream", "clear", "SignalRPCClient", "url", "callbacks", "onConnected", "wake", "onDisconnected", "ERROR", "DISCONNECTED", "_incrementReconnectTimeout", "Math", "min", "RECONNECTING", "catch", "cancelWithContext", "sleep", "asyncTimeout", "client", "keys", "has", "swarmStream", "subscribe", "swarmEvent", "set", "messageStream", "receiveMessages", "author", "recipient", "payload", "import_async", "import_context", "import_invariant", "import_keys", "import_log", "import_protocols", "import_util", "MemorySignalManagerContext", "swarmEvent", "Event", "swarms", "ComplexMap", "PublicKey", "hash", "connections", "MemorySignalManager", "constructor", "_context", "statusChanged", "commandTrace", "onMessage", "_joinedSwarms", "ComplexSet", "topic", "peerId", "toHex", "_freezeTrigger", "Trigger", "wake", "_ctx", "Context", "onDispose", "on", "data", "emit", "open", "disposed", "Promise", "all", "values", "map", "value", "join", "close", "joinedSwarmsCopy", "leave", "dispose", "getStatus", "invariant", "add", "has", "set", "get", "peerAvailable", "peer", "asUint8Array", "since", "Date", "peerIds", "Array", "from", "forEach", "delete", "peerLeft", "sendMessage", "author", "recipient", "payload", "log", "dec", "wait", "remote", "warn", "then", "catch", "err", "error", "subscribeMessages", "unsubscribeMessages", "freeze", "reset", "unfreeze", "type_url", "endsWith", "relPayload", "schema", "getCodecForType", "decode", "Object", "keys", "sessionId", "import_async", "import_context", "import_invariant", "import_keys", "import_log", "import_protocols", "MAX_SERVER_FAILURES", "WSS_SIGNAL_SERVER_REBOOT_DELAY", "WebsocketSignalManager", "constructor", "_hosts", "_servers", "Map", "_opened", "failureCount", "statusChanged", "Event", "commandTrace", "swarmEvent", "onMessage", "_instanceId", "PublicKey", "random", "toHex", "log", "hosts", "host", "has", "server", "SignalClient", "message", "emit", "data", "on", "getStatus", "set", "trace", "open", "begin", "id", "_initContext", "values", "forEach", "end", "close", "_ctx", "dispose", "Promise", "all", "Array", "from", "map", "restartServer", "serverName", "invariant", "get", "sleep", "join", "topic", "peerId", "_forEachServer", "leave", "sendMessage", "author", "recipient", "payload", "truncate", "catch", "err", "RateLimitExceededError", "checkServerFailure", "warn", "subscribeMessages", "unsubscribeMessages", "Context", "onError", "fn", "entries", "synchronized"]
3
+ "sources": ["../../../src/messenger.ts", "../../../src/timeouts.ts", "../../../src/signal-client/signal-client.ts", "../../../src/signal-client/signal-rpc-client.ts", "../../../src/signal-manager/memory-signal-manager.ts", "../../../src/signal-manager/websocket-signal-manager.ts"],
4
+ "sourcesContent": ["//\n// Copyright 2022 DXOS.org\n//\n\nimport { TimeoutError, scheduleExponentialBackoffTaskInterval, scheduleTask, scheduleTaskInterval } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { TimeoutError as ProtocolTimeoutError, schema, trace } from '@dxos/protocols';\nimport { ReliablePayload } from '@dxos/protocols/proto/dxos/mesh/messaging';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { type SignalManager } from './signal-manager';\nimport { type Message } from './signal-methods';\nimport { MESSAGE_TIMEOUT } from './timeouts';\n\nexport type OnMessage = (params: { author: PublicKey; recipient: PublicKey; payload: Any }) => Promise<void>;\n\nexport interface MessengerOptions {\n signalManager: SignalManager;\n retryDelay?: number;\n}\n\nconst ReliablePayload = schema.getCodecForType('dxos.mesh.messaging.ReliablePayload');\nconst Acknowledgement = schema.getCodecForType('dxos.mesh.messaging.Acknowledgement');\n\nconst RECEIVED_MESSAGES_GC_INTERVAL = 120_000;\n\n/**\n * Reliable messenger that works trough signal network.\n */\nexport class Messenger {\n private readonly _signalManager: SignalManager;\n // { peerId, payloadType } => listeners set\n private readonly _listeners = new ComplexMap<{ peerId: PublicKey; payloadType: string }, Set<OnMessage>>(\n ({ peerId, payloadType }) => peerId.toHex() + payloadType,\n );\n\n // peerId => listeners set\n private readonly _defaultListeners = new ComplexMap<PublicKey, Set<OnMessage>>(PublicKey.hash);\n\n private readonly _onAckCallbacks = new ComplexMap<PublicKey, () => void>(PublicKey.hash);\n\n private readonly _receivedMessages = new ComplexSet<PublicKey>(PublicKey.hash);\n\n /**\n * Keys scheduled to be cleared from _receivedMessages on the next iteration.\n */\n private readonly _toClear = new ComplexSet<PublicKey>(PublicKey.hash);\n\n private _ctx!: Context;\n private _closed = true;\n private readonly _retryDelay: number;\n\n constructor({ signalManager, retryDelay = 300 }: MessengerOptions) {\n this._signalManager = signalManager;\n this._retryDelay = retryDelay;\n\n this.open();\n }\n\n open() {\n if (!this._closed) {\n return;\n }\n const traceId = PublicKey.random().toHex();\n log.trace('dxos.mesh.messenger.open', trace.begin({ id: traceId }));\n this._ctx = new Context({\n onError: (err) => log.catch(err),\n });\n this._ctx.onDispose(\n this._signalManager.onMessage.on(async (message) => {\n log('received message', { from: message.author });\n await this._handleMessage(message);\n }),\n );\n\n // Clear the map periodically.\n scheduleTaskInterval(\n this._ctx,\n async () => {\n this._performGc();\n },\n RECEIVED_MESSAGES_GC_INTERVAL,\n );\n\n this._closed = false;\n log.trace('dxos.mesh.messenger.open', trace.end({ id: traceId }));\n }\n\n async close() {\n if (this._closed) {\n return;\n }\n this._closed = true;\n await this._ctx.dispose();\n }\n\n async sendMessage({ author, recipient, payload }: Message): Promise<void> {\n invariant(!this._closed, 'Closed');\n const messageContext = this._ctx.derive();\n\n const reliablePayload: ReliablePayload = {\n messageId: PublicKey.random(),\n payload,\n };\n invariant(!this._onAckCallbacks.has(reliablePayload.messageId!));\n log('send message', { messageId: reliablePayload.messageId, author, recipient });\n\n let messageReceived: () => void;\n let timeoutHit: (err: Error) => void;\n\n const promise = new Promise<void>((resolve, reject) => {\n messageReceived = resolve;\n timeoutHit = reject;\n });\n\n // Setting retry interval if signal was not acknowledged.\n scheduleExponentialBackoffTaskInterval(\n messageContext,\n async () => {\n log('retrying message', { messageId: reliablePayload.messageId });\n await this._encodeAndSend({ author, recipient, reliablePayload }).catch((err) =>\n log('failed to send message', { err }),\n );\n },\n this._retryDelay,\n );\n\n scheduleTask(\n messageContext,\n () => {\n log('message not delivered', { messageId: reliablePayload.messageId });\n this._onAckCallbacks.delete(reliablePayload.messageId!);\n timeoutHit(\n new ProtocolTimeoutError(\n 'signaling message not delivered',\n new TimeoutError(MESSAGE_TIMEOUT, 'Message not delivered'),\n ),\n );\n void messageContext.dispose();\n },\n MESSAGE_TIMEOUT,\n );\n\n this._onAckCallbacks.set(reliablePayload.messageId, () => {\n messageReceived();\n this._onAckCallbacks.delete(reliablePayload.messageId!);\n void messageContext.dispose();\n });\n\n await this._encodeAndSend({ author, recipient, reliablePayload });\n return promise;\n }\n\n /**\n * Subscribes onMessage function to messages that contains payload with payloadType.\n * @param payloadType if not specified, onMessage will be subscribed to all types of messages.\n */\n async listen({\n peerId,\n payloadType,\n onMessage,\n }: {\n peerId: PublicKey;\n payloadType?: string;\n onMessage: OnMessage;\n }): Promise<ListeningHandle> {\n invariant(!this._closed, 'Closed');\n\n await this._signalManager.subscribeMessages(peerId);\n let listeners: Set<OnMessage> | undefined;\n\n if (!payloadType) {\n listeners = this._defaultListeners.get(peerId);\n if (!listeners) {\n listeners = new Set();\n this._defaultListeners.set(peerId, listeners);\n }\n } else {\n listeners = this._listeners.get({ peerId, payloadType });\n if (!listeners) {\n listeners = new Set();\n this._listeners.set({ peerId, payloadType }, listeners);\n }\n }\n\n listeners.add(onMessage);\n\n return {\n unsubscribe: async () => {\n listeners!.delete(onMessage);\n },\n };\n }\n\n private async _encodeAndSend({\n author,\n recipient,\n reliablePayload,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n reliablePayload: ReliablePayload;\n }): Promise<void> {\n await this._signalManager.sendMessage({\n author,\n recipient,\n payload: {\n type_url: 'dxos.mesh.messaging.ReliablePayload',\n value: ReliablePayload.encode(reliablePayload, { preserveAny: true }),\n },\n });\n }\n\n private async _handleMessage(message: Message): Promise<void> {\n switch (message.payload.type_url) {\n case 'dxos.mesh.messaging.ReliablePayload': {\n await this._handleReliablePayload(message);\n break;\n }\n case 'dxos.mesh.messaging.Acknowledgement': {\n await this._handleAcknowledgement({ payload: message.payload });\n break;\n }\n }\n }\n\n private async _handleReliablePayload({ author, recipient, payload }: Message) {\n invariant(payload.type_url === 'dxos.mesh.messaging.ReliablePayload');\n const reliablePayload: ReliablePayload = ReliablePayload.decode(payload.value, { preserveAny: true });\n\n log('handling message', { messageId: reliablePayload.messageId });\n\n await this._sendAcknowledgement({\n author,\n recipient,\n messageId: reliablePayload.messageId,\n });\n\n if (this._receivedMessages.has(reliablePayload.messageId!)) {\n return;\n }\n\n this._receivedMessages.add(reliablePayload.messageId!);\n\n await this._callListeners({\n author,\n recipient,\n payload: reliablePayload.payload,\n });\n }\n\n private async _handleAcknowledgement({ payload }: { payload: Any }) {\n invariant(payload.type_url === 'dxos.mesh.messaging.Acknowledgement');\n this._onAckCallbacks.get(Acknowledgement.decode(payload.value).messageId)?.();\n }\n\n private async _sendAcknowledgement({\n author,\n recipient,\n messageId,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n messageId: PublicKey;\n }): Promise<void> {\n log('sending ACK', { messageId, from: recipient, to: author });\n\n await this._signalManager.sendMessage({\n author: recipient,\n recipient: author,\n payload: {\n type_url: 'dxos.mesh.messaging.Acknowledgement',\n value: Acknowledgement.encode({ messageId }),\n },\n });\n }\n\n private async _callListeners(message: Message): Promise<void> {\n {\n const defaultListenerMap = this._defaultListeners.get(message.recipient);\n if (defaultListenerMap) {\n for (const listener of defaultListenerMap) {\n await listener(message);\n }\n }\n }\n\n {\n const listenerMap = this._listeners.get({\n peerId: message.recipient,\n payloadType: message.payload.type_url,\n });\n if (listenerMap) {\n for (const listener of listenerMap) {\n await listener(message);\n }\n }\n }\n }\n\n private _performGc() {\n const start = performance.now();\n\n for (const key of this._toClear.keys()) {\n this._receivedMessages.delete(key);\n }\n this._toClear.clear();\n for (const key of this._receivedMessages.keys()) {\n this._toClear.add(key);\n }\n\n const elapsed = performance.now() - start;\n if (elapsed > 100) {\n log.warn('GC took too long', { elapsed });\n }\n }\n}\n\nexport interface ListeningHandle {\n unsubscribe: () => Promise<void>;\n}\n", "//\n// Copyright 2023 DXOS.org\n//\n\n/**\n * Timeout for retrying messages.\n */\nexport const MESSAGE_TIMEOUT = 10_000;\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { DeferredTask, Event, Trigger, asyncTimeout, scheduleTask, scheduleTaskInterval, sleep } from '@dxos/async';\nimport { type Any, type Stream } from '@dxos/codec-protobuf';\nimport { Context, cancelWithContext } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { trace } from '@dxos/protocols';\nimport { type Message as SignalMessage, SignalState, type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { SignalRPCClient } from './signal-rpc-client';\nimport { type Message, type SignalMethods } from '../signal-methods';\n\nconst DEFAULT_RECONNECT_TIMEOUT = 100;\nconst MAX_RECONNECT_TIMEOUT = 5000;\nconst ERROR_RECONCILE_DELAY = 1000;\nconst RECONCILE_INTERVAL = 5_000;\n\nexport type SignalStatus = {\n host: string;\n state: SignalState;\n error?: string;\n reconnectIn: number;\n connectionStarted: Date;\n lastStateChange: Date;\n};\n\nexport type CommandTrace = {\n messageId: string;\n host: string;\n incoming: boolean;\n time: number;\n method: string;\n payload: any;\n response?: any;\n error?: string;\n};\n\n/**\n * Establishes a websocket connection to signal server and provides RPC methods.\n */\nexport class SignalClient implements SignalMethods {\n private _state = SignalState.CLOSED;\n\n private _lastError?: Error;\n\n /**\n * Number of milliseconds after which the connection will be attempted again in case of error.\n */\n private _reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;\n\n /**\n * Timestamp of when the connection attempt was began.\n */\n private _connectionStarted = new Date();\n\n /**\n * Timestamp of last state change.\n */\n private _lastStateChange = new Date();\n\n private _client?: SignalRPCClient;\n private readonly _clientReady = new Trigger();\n\n private _ctx?: Context;\n\n private _connectionCtx?: Context;\n\n private _reconcileTask?: DeferredTask;\n private _reconnectTask?: DeferredTask;\n\n readonly statusChanged = new Event<SignalStatus>();\n readonly commandTrace = new Event<CommandTrace>();\n\n /**\n * Swarm events streams. Keys represent actually joined topic and peerId.\n */\n private readonly _swarmStreams = new ComplexMap<{ topic: PublicKey; peerId: PublicKey }, Stream<SwarmEvent>>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n /**\n * Represent desired joined topic and peerId.\n */\n private readonly _joinedTopics = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n /**\n * Message streams. Keys represents actually subscribed peers.\n * @internal\n */\n public readonly _messageStreams = new ComplexMap<PublicKey, Stream<SignalMessage>>((key) => key.toHex());\n\n /**\n * Represent desired message subscriptions.\n */\n private readonly _subscribedMessages = new ComplexSet<{ peerId: PublicKey }>(({ peerId }) => peerId.toHex());\n\n /**\n * Event to use in tests to wait till subscription is successfully established.\n * @internal\n */\n public _reconciled = new Event();\n\n private readonly _instanceId = PublicKey.random().toHex();\n\n private readonly _performance = {\n sentMessages: 0,\n receivedMessages: 0,\n reconnectCounter: 0,\n joinCounter: 0,\n leaveCounter: 0,\n };\n\n /**\n * @param _host Signal server websocket URL.\n * @param _onMessage\n */\n constructor(\n private readonly _host: string,\n private readonly _onMessage: (params: { author: PublicKey; recipient: PublicKey; payload: Any }) => Promise<void>,\n private readonly _onSwarmEvent: (params: { topic: PublicKey; swarmEvent: SwarmEvent }) => Promise<void>,\n ) {\n if (!this._host.startsWith('wss://') && !this._host.startsWith('ws://')) {\n throw new Error(`Signal server requires a websocket URL. Provided: ${this._host}`);\n }\n }\n\n open() {\n log.trace('dxos.mesh.signal-client.open', trace.begin({ id: this._instanceId }));\n\n if ([SignalState.CONNECTED, SignalState.CONNECTING].includes(this._state)) {\n return;\n }\n\n this._ctx = new Context({\n onError: (err) => {\n if (this._state === SignalState.CLOSED || this._ctx?.disposed) {\n return;\n }\n if (this._state === SignalState.CONNECTED) {\n log.warn('SignalClient error:', err);\n }\n this._scheduleReconcileAfterError();\n },\n });\n\n this._reconcileTask = new DeferredTask(this._ctx, async () => {\n await this._reconcileSwarmSubscriptions();\n await this._reconcileMessageSubscriptions();\n this._reconciled.emit();\n });\n\n // Reconcile subscriptions periodically.\n scheduleTaskInterval(\n this._ctx,\n async () => {\n if (this._state === SignalState.CONNECTED) {\n this._reconcileTask!.schedule();\n }\n },\n RECONCILE_INTERVAL,\n );\n\n this._reconnectTask = new DeferredTask(this._ctx, async () => {\n await this._reconnect();\n });\n\n this._setState(SignalState.CONNECTING);\n this._createClient();\n log.trace('dxos.mesh.signal-client.open', trace.end({ id: this._instanceId }));\n }\n\n async close() {\n log('closing...');\n if ([SignalState.CLOSED].includes(this._state)) {\n return;\n }\n\n await this._ctx?.dispose();\n\n this._clientReady.reset();\n await this._client?.close();\n this._client = undefined;\n this._setState(SignalState.CLOSED);\n log('closed');\n }\n\n getStatus(): SignalStatus {\n return {\n host: this._host,\n state: this._state,\n error: this._lastError?.message,\n reconnectIn: this._reconnectAfter,\n connectionStarted: this._connectionStarted,\n lastStateChange: this._lastStateChange,\n };\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }): Promise<void> {\n log('joining', { topic, peerId });\n this._performance.joinCounter++;\n this._joinedTopics.add({ topic, peerId });\n this._reconcileTask!.schedule();\n }\n\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }): Promise<void> {\n this._performance.leaveCounter++;\n log('leaving', { topic, peerId });\n\n void this._swarmStreams.get({ topic, peerId })?.close();\n this._swarmStreams.delete({ topic, peerId });\n this._joinedTopics.delete({ topic, peerId });\n }\n\n async sendMessage(msg: Message): Promise<void> {\n this._performance.sentMessages++;\n await this._clientReady.wait();\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n await this._client!.sendMessage(msg);\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log('subscribing to messages', { peerId });\n this._subscribedMessages.add({ peerId });\n this._reconcileTask!.schedule();\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log('unsubscribing from messages', { peerId });\n this._subscribedMessages.delete({ peerId });\n void this._messageStreams.get(peerId)?.close();\n this._messageStreams.delete(peerId);\n }\n\n private _scheduleReconcileAfterError() {\n scheduleTask(\n this._ctx!,\n () => {\n this._reconcileTask!.schedule();\n },\n ERROR_RECONCILE_DELAY,\n );\n }\n\n private _setState(newState: SignalState) {\n this._state = newState;\n this._lastStateChange = new Date();\n log('signal state changed', { status: this.getStatus() });\n this.statusChanged.emit(this.getStatus());\n }\n\n private _createClient() {\n log('creating client', { host: this._host, state: this._state });\n invariant(!this._client, 'Client already created');\n\n this._connectionStarted = new Date();\n\n // Create new context for each connection.\n this._connectionCtx = this._ctx!.derive();\n this._connectionCtx.onDispose(async () => {\n log('connection context disposed');\n await Promise.all(Array.from(this._swarmStreams.values()).map((stream) => stream.close()));\n await Promise.all(Array.from(this._messageStreams.values()).map((stream) => stream.close()));\n this._swarmStreams.clear();\n this._messageStreams.clear();\n });\n\n try {\n this._client = new SignalRPCClient({\n url: this._host,\n callbacks: {\n onConnected: () => {\n log('socket connected');\n this._lastError = undefined;\n this._reconnectAfter = DEFAULT_RECONNECT_TIMEOUT;\n this._setState(SignalState.CONNECTED);\n this._clientReady.wake();\n this._reconcileTask!.schedule();\n },\n\n onDisconnected: () => {\n log('socket disconnected', { state: this._state });\n if (this._state === SignalState.ERROR) {\n // Ignore disconnects after error.\n // Handled by error handler before disconnect handler.\n this._setState(SignalState.DISCONNECTED);\n return;\n }\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._setState(SignalState.DISCONNECTED);\n this._reconnectTask!.schedule();\n },\n\n onError: (error) => {\n log('socket error', { error, state: this._state });\n this._lastError = error;\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._setState(SignalState.ERROR);\n\n this._reconnectTask!.schedule();\n },\n },\n });\n } catch (err: any) {\n if (this._state !== SignalState.CONNECTED && this._state !== SignalState.CONNECTING) {\n this._incrementReconnectTimeout();\n }\n this._lastError = err;\n this._setState(SignalState.DISCONNECTED);\n this._reconnectTask!.schedule();\n }\n }\n\n private _incrementReconnectTimeout() {\n this._reconnectAfter *= 2;\n this._reconnectAfter = Math.min(this._reconnectAfter, MAX_RECONNECT_TIMEOUT);\n }\n\n private async _reconnect() {\n log(`reconnecting in ${this._reconnectAfter}ms`, { state: this._state });\n this._performance.reconnectCounter++;\n\n if (this._state === SignalState.RECONNECTING) {\n log.warn('Signal api already reconnecting.');\n return;\n }\n\n if (this._state === SignalState.CLOSED) {\n return;\n }\n\n // Close client if it wasn't already closed.\n this._clientReady.reset();\n await this._connectionCtx?.dispose();\n this._client?.close().catch(() => {});\n this._client = undefined;\n\n await cancelWithContext(this._ctx!, sleep(this._reconnectAfter));\n\n this._setState(SignalState.RECONNECTING);\n\n this._createClient();\n }\n\n private async _reconcileSwarmSubscriptions(): Promise<void> {\n await asyncTimeout(cancelWithContext(this._connectionCtx!, this._clientReady.wait()), 5_000);\n // Copy Client reference to avoid client change during the reconcile.\n const client = this._client!;\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n\n // Unsubscribe from topics that are no longer needed.\n for (const { topic, peerId } of this._swarmStreams.keys()) {\n // Join desired topics.\n if (this._joinedTopics.has({ topic, peerId })) {\n continue;\n }\n\n void this._swarmStreams.get({ topic, peerId })?.close();\n this._swarmStreams.delete({ topic, peerId });\n }\n\n // Subscribe to topics that are needed.\n for (const { topic, peerId } of this._joinedTopics.values()) {\n // Join desired topics.\n if (this._swarmStreams.has({ topic, peerId })) {\n continue;\n }\n\n const swarmStream = await asyncTimeout(\n cancelWithContext(this._connectionCtx!, client.join({ topic, peerId })),\n 5000,\n );\n // Subscribing to swarm events.\n // TODO(mykola): What happens when the swarm stream is closed? Maybe send leave event for each peer?\n swarmStream.subscribe(async (swarmEvent: SwarmEvent) => {\n log('swarm event', { swarmEvent });\n await this._onSwarmEvent({ topic, swarmEvent });\n });\n\n // Saving swarm stream.\n this._swarmStreams.set({ topic, peerId }, swarmStream);\n }\n }\n\n private async _reconcileMessageSubscriptions(): Promise<void> {\n await asyncTimeout(cancelWithContext(this._connectionCtx!, this._clientReady.wait()), 5_000);\n // Copy Client reference to avoid client change during the reconcile.\n const client = this._client!;\n invariant(this._state === SignalState.CONNECTED, 'Not connected to Signal Server');\n\n // Unsubscribe from messages that are no longer needed.\n for (const peerId of this._messageStreams.keys()) {\n // Join desired topics.\n if (this._subscribedMessages.has({ peerId })) {\n continue;\n }\n\n void this._messageStreams.get(peerId)?.close();\n this._messageStreams.delete(peerId);\n }\n\n // Subscribe to messages that are needed.\n for (const { peerId } of this._subscribedMessages.values()) {\n if (this._messageStreams.has(peerId)) {\n continue;\n }\n\n const messageStream = await asyncTimeout(\n cancelWithContext(this._connectionCtx!, client.receiveMessages(peerId)),\n 5000,\n );\n messageStream.subscribe(async (message: SignalMessage) => {\n this._performance.receivedMessages++;\n await this._onMessage({\n author: PublicKey.from(message.author),\n recipient: PublicKey.from(message.recipient),\n payload: message.payload,\n });\n });\n\n // Saving message stream.\n this._messageStreams.set(peerId, messageStream);\n }\n }\n}\n", "//\n// Copyright 2022 DXOS.org\n//\n\nimport WebSocket from 'isomorphic-ws';\n\nimport { Trigger } from '@dxos/async';\nimport { type Any, type Stream } from '@dxos/codec-protobuf';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { schema, trace } from '@dxos/protocols';\nimport { type Message as SignalMessage, type Signal } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { createProtoRpcPeer, type ProtoRpcPeer } from '@dxos/rpc';\n\ninterface Services {\n Signal: Signal;\n}\n\nexport type SignalCallbacks = {\n onConnected?: () => void;\n\n /**\n * Called on disconnect.\n * In case of error, `onError` will be called first and then `onDisconnected`.\n */\n onDisconnected?: () => void;\n\n onError?: (error: Error) => void;\n};\n\nexport type SignalRPCClientParams = {\n url: string;\n callbacks?: SignalCallbacks;\n};\n\nexport class SignalRPCClient {\n private _socket?: WebSocket;\n private _rpc?: ProtoRpcPeer<Services>;\n private readonly _connectTrigger = new Trigger();\n\n private _closed = false;\n\n private readonly _url: string;\n private readonly _callbacks: SignalCallbacks;\n\n constructor({ url, callbacks = {} }: SignalRPCClientParams) {\n const traceId = PublicKey.random().toHex();\n log.trace('dxos.mesh.signal-rpc-client.constructor', trace.begin({ id: traceId }));\n this._url = url;\n this._callbacks = callbacks;\n this._socket = new WebSocket(this._url);\n\n this._rpc = createProtoRpcPeer({\n requested: {\n Signal: schema.getService('dxos.mesh.signal.Signal'),\n },\n noHandshake: true,\n port: {\n send: (msg) => {\n if (this._closed) {\n // Do not send messages after close.\n return;\n }\n try {\n this._socket!.send(msg);\n } catch (err) {\n log.warn('send error', err);\n }\n },\n subscribe: (cb) => {\n this._socket!.onmessage = async (msg: WebSocket.MessageEvent) => {\n if (typeof Blob !== 'undefined' && msg.data instanceof Blob) {\n cb(Buffer.from(await msg.data.arrayBuffer()));\n } else {\n cb(msg.data as any);\n }\n };\n },\n },\n encodingOptions: {\n preserveAny: true,\n },\n });\n\n this._socket.onopen = async () => {\n try {\n await this._rpc!.open();\n log(`RPC open ${this._url}`);\n this._callbacks.onConnected?.();\n this._connectTrigger.wake();\n } catch (err: any) {\n this._callbacks.onError?.(err);\n }\n };\n\n this._socket.onclose = async () => {\n log(`Disconnected ${this._url}`);\n this._callbacks.onDisconnected?.();\n await this.close();\n };\n\n this._socket.onerror = async (event: WebSocket.ErrorEvent) => {\n if (this._closed) {\n // Ignore errors after close.\n return;\n }\n\n this._callbacks.onError?.(event.error ?? new Error(event.message));\n this._connectTrigger.reset();\n\n try {\n await this._rpc?.close();\n } catch (err) {\n log.catch(err);\n }\n this._closed = true;\n\n log.warn(event.message ?? 'Socket error', { url: this._url });\n };\n\n log.trace('dxos.mesh.signal-rpc-client.constructor', trace.end({ id: traceId }));\n }\n\n async close() {\n this._closed = true;\n try {\n await this._rpc?.close();\n this._socket?.close();\n } catch (err) {\n log.warn('close error', err);\n }\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('join', { topic, peerId });\n await this._connectTrigger.wait();\n invariant(!this._closed, 'SignalRPCClient is closed');\n invariant(this._rpc, 'Rpc is not initialized');\n const swarmStream = this._rpc.rpc.Signal.join({\n swarm: topic.asUint8Array(),\n peer: peerId.asUint8Array(),\n });\n await swarmStream.waitUntilReady();\n return swarmStream;\n }\n\n async receiveMessages(peerId: PublicKey): Promise<Stream<SignalMessage>> {\n log('receiveMessages', { peerId });\n invariant(!this._closed, 'SignalRPCClient is closed');\n await this._connectTrigger.wait();\n invariant(this._rpc, 'Rpc is not initialized');\n const messageStream = this._rpc.rpc.Signal.receiveMessages({\n peer: peerId.asUint8Array(),\n });\n await messageStream.waitUntilReady();\n return messageStream;\n }\n\n async sendMessage({ author, recipient, payload }: { author: PublicKey; recipient: PublicKey; payload: Any }) {\n log('sendMessage', { author, recipient, payload });\n invariant(!this._closed, 'SignalRPCClient is closed');\n await this._connectTrigger.wait();\n invariant(this._rpc, 'Rpc is not initialized');\n await this._rpc.rpc.Signal.sendMessage({\n author: author.asUint8Array(),\n recipient: recipient.asUint8Array(),\n payload,\n });\n }\n}\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event, Trigger } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { schema } from '@dxos/protocols';\nimport { type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\nimport { ComplexMap, ComplexSet } from '@dxos/util';\n\nimport { type SignalManager } from './signal-manager';\nimport { type CommandTrace, type SignalStatus } from '../signal-client';\n\n/**\n * Common signaling context that connects multiple MemorySignalManager instances.\n */\nexport class MemorySignalManagerContext {\n // Swarm messages.\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n // Mapping from topic to set of peers.\n readonly swarms = new ComplexMap<PublicKey, ComplexSet<PublicKey>>(PublicKey.hash);\n\n // Map of connections for each peer for signaling.\n readonly connections = new ComplexMap<PublicKey, MemorySignalManager>(PublicKey.hash);\n}\n\n/**\n * In memory signal manager for testing.\n */\nexport class MemorySignalManager implements SignalManager {\n readonly statusChanged = new Event<SignalStatus[]>();\n readonly commandTrace = new Event<CommandTrace>();\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n readonly onMessage = new Event<{\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }>();\n\n /** Will be used to emit SwarmEvents on .open() and .close() */\n private _joinedSwarms = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n );\n\n private _ctx!: Context;\n\n // TODO(dmaretskyi): Replace with callback.\n private readonly _freezeTrigger = new Trigger().wake();\n\n constructor(private readonly _context: MemorySignalManagerContext) {\n this._ctx = new Context();\n\n this._ctx.onDispose(this._context.swarmEvent.on((data) => this.swarmEvent.emit(data)));\n }\n\n async open() {\n if (!this._ctx.disposed) {\n return;\n }\n this._ctx = new Context();\n this._ctx.onDispose(this._context.swarmEvent.on((data) => this.swarmEvent.emit(data)));\n\n await Promise.all([...this._joinedSwarms.values()].map((value) => this.join(value)));\n }\n\n async close() {\n if (this._ctx.disposed) {\n return;\n }\n // save copy of joined swarms.\n const joinedSwarmsCopy = new ComplexSet<{ topic: PublicKey; peerId: PublicKey }>(\n ({ topic, peerId }) => topic.toHex() + peerId.toHex(),\n [...this._joinedSwarms.values()],\n );\n\n await Promise.all([...this._joinedSwarms.values()].map((value) => this.leave(value)));\n\n // assign joined swarms back because .leave() deletes it.\n this._joinedSwarms = joinedSwarmsCopy;\n\n await this._ctx.dispose();\n }\n\n getStatus(): SignalStatus[] {\n return [];\n }\n\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n invariant(!this._ctx.disposed, 'Closed');\n\n this._joinedSwarms.add({ topic, peerId });\n\n if (!this._context.swarms.has(topic)) {\n this._context.swarms.set(topic, new ComplexSet(PublicKey.hash));\n }\n\n this._context.swarms.get(topic)!.add(peerId);\n this._context.swarmEvent.emit({\n topic,\n swarmEvent: {\n peerAvailable: {\n peer: peerId.asUint8Array(),\n since: new Date(),\n },\n },\n });\n\n // Emitting swarm events for each peer.\n for (const [topic, peerIds] of this._context.swarms) {\n Array.from(peerIds).forEach((peerId) => {\n this.swarmEvent.emit({\n topic,\n swarmEvent: {\n peerAvailable: {\n peer: peerId.asUint8Array(),\n since: new Date(),\n },\n },\n });\n });\n }\n }\n\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n invariant(!this._ctx.disposed, 'Closed');\n\n this._joinedSwarms.delete({ topic, peerId });\n\n if (!this._context.swarms.has(topic)) {\n this._context.swarms.set(topic, new ComplexSet(PublicKey.hash));\n }\n\n this._context.swarms.get(topic)!.delete(peerId);\n\n const swarmEvent: SwarmEvent = {\n peerLeft: {\n peer: peerId.asUint8Array(),\n },\n };\n\n this._context.swarmEvent.emit({ topic, swarmEvent });\n }\n\n async sendMessage({ author, recipient, payload }: { author: PublicKey; recipient: PublicKey; payload: Any }) {\n log('send message', { author, recipient, ...dec(payload) });\n\n invariant(recipient);\n invariant(!this._ctx.disposed, 'Closed');\n\n await this._freezeTrigger.wait();\n\n const remote = this._context.connections.get(recipient);\n if (!remote) {\n log.warn('recipient is not subscribed for messages', { author, recipient });\n return;\n }\n\n if (remote._ctx.disposed) {\n log.warn('recipient is disposed', { author, recipient });\n return;\n }\n\n remote._freezeTrigger\n .wait()\n .then(() => {\n if (remote._ctx.disposed) {\n log.warn('recipient is disposed', { author, recipient });\n return;\n }\n\n log('receive message', { author, recipient, ...dec(payload) });\n\n remote.onMessage.emit({ author, recipient, payload });\n })\n .catch((err) => {\n log.error('error while waiting for freeze', { err });\n });\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log('subscribing', { peerId });\n this._context.connections.set(peerId, this);\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log('unsubscribing', { peerId });\n this._context.connections.delete(peerId);\n }\n\n freeze() {\n this._freezeTrigger.reset();\n }\n\n unfreeze() {\n this._freezeTrigger.wake();\n }\n}\nconst dec = (payload: Any) => {\n if (!payload.type_url.endsWith('ReliablePayload')) {\n return {};\n }\n\n const relPayload = schema.getCodecForType('dxos.mesh.messaging.ReliablePayload').decode(payload.value);\n\n if (typeof relPayload?.payload?.data === 'object') {\n return { payload: Object.keys(relPayload?.payload?.data)[0], sessionId: relPayload?.payload?.sessionId };\n }\n\n return {};\n};\n", "//\n// Copyright 2020 DXOS.org\n//\n\nimport { Event, sleep, synchronized } from '@dxos/async';\nimport { type Any } from '@dxos/codec-protobuf';\nimport { Context } from '@dxos/context';\nimport { invariant } from '@dxos/invariant';\nimport { PublicKey } from '@dxos/keys';\nimport { log } from '@dxos/log';\nimport { RateLimitExceededError, trace } from '@dxos/protocols';\nimport { type Runtime } from '@dxos/protocols/proto/dxos/config';\nimport { type SwarmEvent } from '@dxos/protocols/proto/dxos/mesh/signal';\n\nimport { type SignalManager } from './signal-manager';\nimport { type CommandTrace, SignalClient, type SignalStatus } from '../signal-client';\n\nconst MAX_SERVER_FAILURES = 5;\nconst WSS_SIGNAL_SERVER_REBOOT_DELAY = 3_000;\n/**\n * Manages connection to multiple Signal Servers over WebSocket\n */\nexport class WebsocketSignalManager implements SignalManager {\n private readonly _servers = new Map<string, SignalClient>();\n\n private _ctx!: Context;\n private _opened = false;\n\n readonly failureCount = new Map<string, number>();\n readonly statusChanged = new Event<SignalStatus[]>();\n readonly commandTrace = new Event<CommandTrace>();\n readonly swarmEvent = new Event<{\n topic: PublicKey;\n swarmEvent: SwarmEvent;\n }>();\n\n readonly onMessage = new Event<{\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }>();\n\n private readonly _instanceId = PublicKey.random().toHex();\n\n constructor(private readonly _hosts: Runtime.Services.Signal[]) {\n log('Created WebsocketSignalManager', { hosts: this._hosts });\n for (const host of this._hosts) {\n if (this._servers.has(host.server)) {\n continue;\n }\n const server = new SignalClient(\n host.server,\n async (message) => this.onMessage.emit(message),\n async (data) => this.swarmEvent.emit(data),\n );\n server.statusChanged.on(() => this.statusChanged.emit(this.getStatus()));\n\n this._servers.set(host.server, server);\n this.failureCount.set(host.server, 0);\n server.commandTrace.on((trace) => this.commandTrace.emit(trace));\n }\n }\n\n @synchronized\n async open() {\n if (this._opened) {\n return;\n }\n log('open signal manager', { hosts: this._hosts });\n log.trace('dxos.mesh.websocket-signal-manager.open', trace.begin({ id: this._instanceId }));\n\n this._initContext();\n\n [...this._servers.values()].forEach((server) => server.open());\n\n this._opened = true;\n log.trace('dxos.mesh.websocket-signal-manager.open', trace.end({ id: this._instanceId }));\n }\n\n @synchronized\n async close() {\n if (!this._opened) {\n return;\n }\n this._opened = false;\n\n await this._ctx.dispose();\n\n await Promise.all(Array.from(this._servers.values()).map((server) => server.close()));\n }\n\n async restartServer(serverName: string) {\n log('Restarting server', { serverName });\n invariant(this._opened, 'server already closed');\n\n const server = this._servers.get(serverName);\n invariant(server, 'server not found');\n\n await server.close();\n await sleep(WSS_SIGNAL_SERVER_REBOOT_DELAY);\n await server.open();\n }\n\n getStatus(): SignalStatus[] {\n return Array.from(this._servers.values()).map((server) => server.getStatus());\n }\n\n @synchronized\n async join({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('Join', { topic, peerId });\n invariant(this._opened, 'Closed');\n await this._forEachServer((server) => server.join({ topic, peerId }));\n }\n\n @synchronized\n async leave({ topic, peerId }: { topic: PublicKey; peerId: PublicKey }) {\n log('leaving', { topic, peerId });\n invariant(this._opened, 'Closed');\n\n await this._forEachServer((server) => server.leave({ topic, peerId }));\n }\n\n async sendMessage({\n author,\n recipient,\n payload,\n }: {\n author: PublicKey;\n recipient: PublicKey;\n payload: Any;\n }): Promise<void> {\n log(`Signal ${recipient.truncate()}`);\n invariant(this._opened, 'Closed');\n\n void this._forEachServer(async (server, serverName) => {\n void server.sendMessage({ author, recipient, payload }).catch((err) => {\n if (err instanceof RateLimitExceededError) {\n log('WSS rate limit exceeded', { err });\n } else {\n log(`error sending to ${serverName}`, { err });\n void this.checkServerFailure(serverName);\n }\n });\n });\n }\n\n @synchronized\n async checkServerFailure(serverName: string) {\n const failureCount = this.failureCount.get(serverName!) ?? 0;\n if (failureCount > MAX_SERVER_FAILURES) {\n log.warn(`Too many failures sending to ${serverName} (${failureCount} > ${MAX_SERVER_FAILURES}), restarting`);\n await this.restartServer(serverName!);\n this.failureCount.set(serverName!, 0);\n return;\n }\n this.failureCount.set(serverName!, (this.failureCount.get(serverName!) ?? 0) + 1);\n }\n\n async subscribeMessages(peerId: PublicKey) {\n log(`Subscribed for message stream peerId=${peerId}`);\n invariant(this._opened, 'Closed');\n\n await this._forEachServer(async (server) => server.subscribeMessages(peerId));\n }\n\n async unsubscribeMessages(peerId: PublicKey) {\n log(`Subscribed for message stream peerId=${peerId}`);\n invariant(this._opened, 'Closed');\n\n await this._forEachServer(async (server) => server.unsubscribeMessages(peerId));\n }\n\n private _initContext() {\n this._ctx = new Context({\n onError: (err) => log.catch(err),\n });\n }\n\n private async _forEachServer<ReturnType>(\n fn: (server: SignalClient, serverName: string) => Promise<ReturnType>,\n ): Promise<ReturnType[]> {\n return Promise.all(Array.from(this._servers.entries()).map(([serverName, server]) => fn(server, serverName)));\n }\n}\n"],
5
+ "mappings": "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",
6
+ "names": ["import_async", "import_context", "import_invariant", "import_keys", "import_log", "import_protocols", "import_util", "MESSAGE_TIMEOUT", "ReliablePayload", "schema", "getCodecForType", "Acknowledgement", "RECEIVED_MESSAGES_GC_INTERVAL", "Messenger", "constructor", "signalManager", "retryDelay", "ComplexMap", "peerId", "payloadType", "toHex", "PublicKey", "hash", "_onAckCallbacks", "_receivedMessages", "ComplexSet", "_closed", "_signalManager", "_retryDelay", "open", "traceId", "random", "log", "trace", "begin", "id", "_ctx", "Context", "onError", "err", "catch", "onDispose", "onMessage", "on", "message", "from", "author", "_handleMessage", "scheduleTaskInterval", "_performGc", "end", "close", "dispose", "sendMessage", "recipient", "payload", "invariant", "messageContext", "derive", "reliablePayload", "messageId", "has", "messageReceived", "timeoutHit", "promise", "Promise", "resolve", "reject", "scheduleExponentialBackoffTaskInterval", "_encodeAndSend", "scheduleTask", "delete", "ProtocolTimeoutError", "TimeoutError", "set", "listen", "subscribeMessages", "listeners", "_defaultListeners", "get", "Set", "_listeners", "add", "unsubscribe", "type_url", "value", "encode", "preserveAny", "_handleReliablePayload", "_handleAcknowledgement", "decode", "_sendAcknowledgement", "_callListeners", "to", "defaultListenerMap", "listener", "listenerMap", "start", "performance", "now", "key", "_toClear", "keys", "clear", "elapsed", "warn", "SignalRPCClient", "url", "callbacks", "_connectTrigger", "Trigger", "_url", "_callbacks", "_socket", "WebSocket", "_rpc", "createProtoRpcPeer", "requested", "Signal", "getService", "noHandshake", "port", "send", "msg", "subscribe", "cb", "onmessage", "Blob", "data", "Buffer", "arrayBuffer", "encodingOptions", "onopen", "onConnected", "wake", "onclose", "onDisconnected", "onerror", "event", "error", "Error", "reset", "join", "topic", "wait", "swarmStream", "rpc", "swarm", "asUint8Array", "peer", "waitUntilReady", "receiveMessages", "messageStream", "DEFAULT_RECONNECT_TIMEOUT", "MAX_RECONNECT_TIMEOUT", "ERROR_RECONCILE_DELAY", "RECONCILE_INTERVAL", "SignalClient", "_host", "_onMessage", "_onSwarmEvent", "_state", "SignalState", "CLOSED", "_reconnectAfter", "_connectionStarted", "Date", "_lastStateChange", "_clientReady", "statusChanged", "Event", "commandTrace", "_swarmStreams", "_joinedTopics", "_messageStreams", "_subscribedMessages", "_reconciled", "_instanceId", "_performance", "sentMessages", "receivedMessages", "reconnectCounter", "joinCounter", "leaveCounter", "startsWith", "CONNECTED", "CONNECTING", "includes", "disposed", "_scheduleReconcileAfterError", "_reconcileTask", "DeferredTask", "_reconcileSwarmSubscriptions", "_reconcileMessageSubscriptions", "emit", "schedule", "_reconnectTask", "_reconnect", "_setState", "_createClient", "_client", "undefined", "getStatus", "host", "state", "_lastError", "reconnectIn", "connectionStarted", "lastStateChange", "leave", "unsubscribeMessages", "newState", "status", "_connectionCtx", "all", "Array", "values", "map", "stream", "ERROR", "DISCONNECTED", "_incrementReconnectTimeout", "Math", "min", "RECONNECTING", "cancelWithContext", "sleep", "asyncTimeout", "client", "swarmEvent", "MemorySignalManagerContext", "MemorySignalManager", "_context", "_joinedSwarms", "_freezeTrigger", "joinedSwarmsCopy", "swarms", "peerAvailable", "since", "peerIds", "forEach", "peerLeft", "dec", "remote", "connections", "then", "freeze", "unfreeze", "endsWith", "relPayload", "Object", "sessionId", "MAX_SERVER_FAILURES", "WSS_SIGNAL_SERVER_REBOOT_DELAY", "WebsocketSignalManager", "_hosts", "_servers", "Map", "_opened", "failureCount", "hosts", "server", "_initContext", "restartServer", "serverName", "_forEachServer", "truncate", "RateLimitExceededError", "checkServerFailure", "fn", "entries", "synchronized"]
7
7
  }
@@ -1 +1 @@
1
- {"inputs":{"packages/core/mesh/messaging/src/timeouts.ts":{"bytes":656,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/messenger.ts":{"bytes":34092,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/timeouts.ts","kind":"import-statement","original":"./timeouts"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytes":20064,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytes":52212,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts","kind":"import-statement","original":"./signal-rpc-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytes":499,"imports":[{"path":"packages/core/mesh/messaging/src/signal-client/signal-client.ts","kind":"import-statement","original":"./signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytes":24494,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts":{"bytes":1316,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytes":24728,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"../signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytes":750,"imports":[{"path":"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts","kind":"import-statement","original":"./memory-signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts","kind":"import-statement","original":"./websocket-signal-manager"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-methods.ts":{"bytes":1633,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/index.ts":{"bytes":782,"imports":[{"path":"packages/core/mesh/messaging/src/messenger.ts","kind":"import-statement","original":"./messenger"},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"./signal-client"},{"path":"packages/core/mesh/messaging/src/signal-manager/index.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-methods.ts","kind":"import-statement","original":"./signal-methods"}],"format":"esm"}},"outputs":{"packages/core/mesh/messaging/dist/lib/node/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":71248},"packages/core/mesh/messaging/dist/lib/node/index.cjs":{"imports":[{"path":"@dxos/async","kind":"require-call","external":true},{"path":"@dxos/context","kind":"require-call","external":true},{"path":"@dxos/invariant","kind":"require-call","external":true},{"path":"@dxos/keys","kind":"require-call","external":true},{"path":"@dxos/log","kind":"require-call","external":true},{"path":"@dxos/protocols","kind":"require-call","external":true},{"path":"@dxos/util","kind":"require-call","external":true},{"path":"@dxos/async","kind":"require-call","external":true},{"path":"@dxos/context","kind":"require-call","external":true},{"path":"@dxos/invariant","kind":"require-call","external":true},{"path":"@dxos/keys","kind":"require-call","external":true},{"path":"@dxos/log","kind":"require-call","external":true},{"path":"@dxos/protocols","kind":"require-call","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"require-call","external":true},{"path":"@dxos/util","kind":"require-call","external":true},{"path":"isomorphic-ws","kind":"require-call","external":true},{"path":"@dxos/async","kind":"require-call","external":true},{"path":"@dxos/invariant","kind":"require-call","external":true},{"path":"@dxos/keys","kind":"require-call","external":true},{"path":"@dxos/log","kind":"require-call","external":true},{"path":"@dxos/protocols","kind":"require-call","external":true},{"path":"@dxos/rpc","kind":"require-call","external":true},{"path":"@dxos/async","kind":"require-call","external":true},{"path":"@dxos/context","kind":"require-call","external":true},{"path":"@dxos/invariant","kind":"require-call","external":true},{"path":"@dxos/keys","kind":"require-call","external":true},{"path":"@dxos/log","kind":"require-call","external":true},{"path":"@dxos/protocols","kind":"require-call","external":true},{"path":"@dxos/util","kind":"require-call","external":true},{"path":"@dxos/async","kind":"require-call","external":true},{"path":"@dxos/context","kind":"require-call","external":true},{"path":"@dxos/invariant","kind":"require-call","external":true},{"path":"@dxos/keys","kind":"require-call","external":true},{"path":"@dxos/log","kind":"require-call","external":true},{"path":"@dxos/protocols","kind":"require-call","external":true}],"exports":[],"entryPoint":"packages/core/mesh/messaging/src/index.ts","inputs":{"packages/core/mesh/messaging/src/index.ts":{"bytesInOutput":329},"packages/core/mesh/messaging/src/messenger.ts":{"bytesInOutput":10084},"packages/core/mesh/messaging/src/timeouts.ts":{"bytesInOutput":27},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytesInOutput":14563},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytesInOutput":6388},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytesInOutput":7011},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytesInOutput":8652}},"bytes":49243}}}
1
+ {"inputs":{"packages/core/mesh/messaging/src/timeouts.ts":{"bytes":651,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/messenger.ts":{"bytes":34087,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/timeouts.ts","kind":"import-statement","original":"./timeouts"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytes":20059,"imports":[{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytes":52207,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts","kind":"import-statement","original":"./signal-rpc-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytes":494,"imports":[{"path":"packages/core/mesh/messaging/src/signal-client/signal-client.ts","kind":"import-statement","original":"./signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytes":24489,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts":{"bytes":1311,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytes":24723,"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"../signal-client"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytes":745,"imports":[{"path":"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts","kind":"import-statement","original":"./memory-signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/signal-manager.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts","kind":"import-statement","original":"./websocket-signal-manager"}],"format":"esm"},"packages/core/mesh/messaging/src/signal-methods.ts":{"bytes":1628,"imports":[],"format":"esm"},"packages/core/mesh/messaging/src/index.ts":{"bytes":777,"imports":[{"path":"packages/core/mesh/messaging/src/messenger.ts","kind":"import-statement","original":"./messenger"},{"path":"packages/core/mesh/messaging/src/signal-client/index.ts","kind":"import-statement","original":"./signal-client"},{"path":"packages/core/mesh/messaging/src/signal-manager/index.ts","kind":"import-statement","original":"./signal-manager"},{"path":"packages/core/mesh/messaging/src/signal-methods.ts","kind":"import-statement","original":"./signal-methods"}],"format":"esm"}},"outputs":{"packages/core/mesh/messaging/dist/lib/node/index.cjs.map":{"imports":[],"exports":[],"inputs":{},"bytes":71748},"packages/core/mesh/messaging/dist/lib/node/index.cjs":{"imports":[{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/protocols/proto/dxos/mesh/signal","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"isomorphic-ws","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/rpc","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true},{"path":"@dxos/util","kind":"import-statement","external":true},{"path":"@dxos/async","kind":"import-statement","external":true},{"path":"@dxos/context","kind":"import-statement","external":true},{"path":"@dxos/invariant","kind":"import-statement","external":true},{"path":"@dxos/keys","kind":"import-statement","external":true},{"path":"@dxos/log","kind":"import-statement","external":true},{"path":"@dxos/protocols","kind":"import-statement","external":true}],"exports":["MemorySignalManager","MemorySignalManagerContext","Messenger","SignalClient","WebsocketSignalManager"],"entryPoint":"packages/core/mesh/messaging/src/index.ts","inputs":{"packages/core/mesh/messaging/src/messenger.ts":{"bytesInOutput":9628},"packages/core/mesh/messaging/src/timeouts.ts":{"bytesInOutput":27},"packages/core/mesh/messaging/src/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-client/signal-client.ts":{"bytesInOutput":13582},"packages/core/mesh/messaging/src/signal-client/signal-rpc-client.ts":{"bytesInOutput":6012},"packages/core/mesh/messaging/src/signal-client/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/memory-signal-manager.ts":{"bytesInOutput":6656},"packages/core/mesh/messaging/src/signal-manager/index.ts":{"bytesInOutput":0},"packages/core/mesh/messaging/src/signal-manager/websocket-signal-manager.ts":{"bytesInOutput":8152}},"bytes":44724}}}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@dxos/messaging",
3
- "version": "0.3.8-next.f4e0086",
3
+ "version": "0.3.8",
4
4
  "description": "Messaging",
5
5
  "homepage": "https://dxos.org",
6
6
  "bugs": "https://github.com/dxos/dxos/issues",
@@ -18,24 +18,24 @@
18
18
  ],
19
19
  "dependencies": {
20
20
  "isomorphic-ws": "^4.0.1",
21
- "ws": "^7.4.4",
22
- "@dxos/context": "0.3.8-next.f4e0086",
23
- "@dxos/invariant": "0.3.8-next.f4e0086",
24
- "@dxos/keys": "0.3.8-next.f4e0086",
25
- "@dxos/log": "0.3.8-next.f4e0086",
26
- "@dxos/async": "0.3.8-next.f4e0086",
27
- "@dxos/codec-protobuf": "0.3.8-next.f4e0086",
28
- "@dxos/node-std": "0.3.8-next.f4e0086",
29
- "@dxos/protocols": "0.3.8-next.f4e0086",
30
- "@dxos/rpc": "0.3.8-next.f4e0086",
31
- "@dxos/util": "0.3.8-next.f4e0086"
21
+ "ws": "^8.14.2",
22
+ "@dxos/codec-protobuf": "0.3.8",
23
+ "@dxos/context": "0.3.8",
24
+ "@dxos/invariant": "0.3.8",
25
+ "@dxos/keys": "0.3.8",
26
+ "@dxos/async": "0.3.8",
27
+ "@dxos/node-std": "0.3.8",
28
+ "@dxos/log": "0.3.8",
29
+ "@dxos/protocols": "0.3.8",
30
+ "@dxos/rpc": "0.3.8",
31
+ "@dxos/util": "0.3.8"
32
32
  },
33
33
  "devDependencies": {
34
34
  "@types/node": "^18.11.9",
35
35
  "earljs": "~0.1.10",
36
36
  "typescript": "^5.2.2",
37
37
  "wait-for-expect": "^3.0.2",
38
- "@dxos/signal": "0.3.8-next.f4e0086"
38
+ "@dxos/signal": "0.3.8"
39
39
  },
40
40
  "publishConfig": {
41
41
  "access": "public"