@streamr/trackerless-network 100.0.0-pretestnet.2 → 100.0.0-pretestnet.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (105) hide show
  1. package/dist/package.json +8 -8
  2. package/dist/src/NetworkNode.d.ts +1 -1
  3. package/dist/src/NetworkNode.js +3 -3
  4. package/dist/src/NetworkNode.js.map +1 -1
  5. package/dist/src/NetworkStack.js +2 -1
  6. package/dist/src/NetworkStack.js.map +1 -1
  7. package/dist/src/logic/DeliveryRpcLocal.d.ts +1 -1
  8. package/dist/src/logic/EntryPointDiscovery.d.ts +1 -1
  9. package/dist/src/logic/EntryPointDiscovery.js +5 -5
  10. package/dist/src/logic/EntryPointDiscovery.js.map +1 -1
  11. package/dist/src/logic/Layer0Node.d.ts +1 -1
  12. package/dist/src/logic/Layer1Node.d.ts +1 -1
  13. package/dist/src/logic/RandomGraphNode.d.ts +2 -1
  14. package/dist/src/logic/RandomGraphNode.js +7 -7
  15. package/dist/src/logic/RandomGraphNode.js.map +1 -1
  16. package/dist/src/logic/StreamrNode.d.ts +3 -2
  17. package/dist/src/logic/StreamrNode.js +42 -39
  18. package/dist/src/logic/StreamrNode.js.map +1 -1
  19. package/dist/src/logic/createRandomGraphNode.js +8 -7
  20. package/dist/src/logic/createRandomGraphNode.js.map +1 -1
  21. package/dist/src/logic/inspect/Inspector.d.ts +2 -2
  22. package/dist/src/logic/inspect/Inspector.js +2 -2
  23. package/dist/src/logic/inspect/Inspector.js.map +1 -1
  24. package/dist/src/logic/neighbor-discovery/Handshaker.d.ts +2 -1
  25. package/dist/src/logic/neighbor-discovery/Handshaker.js +3 -3
  26. package/dist/src/logic/neighbor-discovery/Handshaker.js.map +1 -1
  27. package/dist/src/logic/neighbor-discovery/NeighborUpdateManager.d.ts +1 -1
  28. package/dist/src/logic/neighbor-discovery/NeighborUpdateManager.js +1 -1
  29. package/dist/src/logic/neighbor-discovery/NeighborUpdateManager.js.map +1 -1
  30. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.d.ts +1 -1
  31. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.js +2 -2
  32. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.js.map +1 -1
  33. package/dist/src/logic/proxy/ProxyClient.d.ts +1 -1
  34. package/dist/src/logic/proxy/ProxyClient.js +4 -4
  35. package/dist/src/logic/proxy/ProxyClient.js.map +1 -1
  36. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.d.ts +1 -1
  37. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.js +1 -1
  38. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.js.map +1 -1
  39. package/dist/src/logic/proxy/ProxyConnectionRpcRemote.js +1 -1
  40. package/dist/src/logic/proxy/ProxyConnectionRpcRemote.js.map +1 -1
  41. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.d.ts +1 -1
  42. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.js +2 -2
  43. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.js.map +1 -1
  44. package/dist/src/proto/packages/dht/protos/DhtRpc.client.d.ts +77 -60
  45. package/dist/src/proto/packages/dht/protos/DhtRpc.client.js +71 -58
  46. package/dist/src/proto/packages/dht/protos/DhtRpc.client.js.map +1 -1
  47. package/dist/src/proto/packages/dht/protos/DhtRpc.d.ts +112 -136
  48. package/dist/src/proto/packages/dht/protos/DhtRpc.js +103 -107
  49. package/dist/src/proto/packages/dht/protos/DhtRpc.js.map +1 -1
  50. package/dist/src/proto/packages/dht/protos/DhtRpc.server.d.ts +37 -32
  51. package/dist/test/benchmark/first-message.js +1 -1
  52. package/dist/test/benchmark/first-message.js.map +1 -1
  53. package/dist/test/utils/utils.d.ts +1 -1
  54. package/dist/test/utils/utils.js +12 -9
  55. package/dist/test/utils/utils.js.map +1 -1
  56. package/karma.config.js +2 -2
  57. package/package.json +8 -8
  58. package/src/NetworkNode.ts +3 -3
  59. package/src/NetworkStack.ts +2 -1
  60. package/src/logic/DeliveryRpcLocal.ts +1 -1
  61. package/src/logic/EntryPointDiscovery.ts +6 -6
  62. package/src/logic/Layer0Node.ts +1 -1
  63. package/src/logic/Layer1Node.ts +1 -1
  64. package/src/logic/RandomGraphNode.ts +18 -12
  65. package/src/logic/StreamrNode.ts +31 -24
  66. package/src/logic/createRandomGraphNode.ts +8 -7
  67. package/src/logic/inspect/Inspector.ts +4 -4
  68. package/src/logic/neighbor-discovery/Handshaker.ts +15 -6
  69. package/src/logic/neighbor-discovery/NeighborUpdateManager.ts +2 -2
  70. package/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.ts +3 -3
  71. package/src/logic/proxy/ProxyClient.ts +6 -6
  72. package/src/logic/proxy/ProxyConnectionRpcLocal.ts +2 -2
  73. package/src/logic/proxy/ProxyConnectionRpcRemote.ts +2 -2
  74. package/src/logic/temporary-connection/TemporaryConnectionRpcLocal.ts +3 -3
  75. package/src/proto/packages/dht/protos/DhtRpc.client.ts +113 -97
  76. package/src/proto/packages/dht/protos/DhtRpc.server.ts +37 -32
  77. package/src/proto/packages/dht/protos/DhtRpc.ts +146 -178
  78. package/test/benchmark/first-message.ts +1 -1
  79. package/test/end-to-end/inspect.test.ts +6 -3
  80. package/test/end-to-end/proxy-and-full-node.test.ts +1 -0
  81. package/test/end-to-end/proxy-connections.test.ts +3 -1
  82. package/test/end-to-end/proxy-key-exchange.test.ts +1 -0
  83. package/test/end-to-end/random-graph-with-real-connections.test.ts +10 -10
  84. package/test/end-to-end/webrtc-full-node-network.test.ts +2 -1
  85. package/test/end-to-end/websocket-full-node-network.test.ts +3 -1
  86. package/test/integration/Handshakes.test.ts +1 -1
  87. package/test/integration/Inspect.test.ts +2 -2
  88. package/test/integration/NetworkStack.test.ts +4 -2
  89. package/test/integration/RandomGraphNode-Layer1Node-Latencies.test.ts +2 -2
  90. package/test/integration/RandomGraphNode-Layer1Node.test.ts +2 -2
  91. package/test/integration/StreamrNode.test.ts +1 -1
  92. package/test/integration/joining-streams-on-offline-peers.test.ts +12 -7
  93. package/test/integration/stream-without-default-entrypoints.test.ts +4 -3
  94. package/test/unit/DeliveryRpcLocal.test.ts +1 -1
  95. package/test/unit/EntrypointDiscovery.test.ts +3 -3
  96. package/test/unit/HandshakeRpcLocal.test.ts +2 -2
  97. package/test/unit/Handshaker.test.ts +3 -2
  98. package/test/unit/Inspector.test.ts +1 -1
  99. package/test/unit/NodeList.test.ts +1 -1
  100. package/test/unit/RandomGraphNode.test.ts +1 -1
  101. package/test/unit/StreamrNode.test.ts +1 -1
  102. package/test/utils/mock/MockLayer0Node.ts +1 -1
  103. package/test/utils/mock/Transport.ts +1 -1
  104. package/test/utils/utils.ts +13 -10
  105. package/test/integration/NetworkStackStoppedDuringStart.test.ts +0 -37
@@ -161,26 +161,26 @@ export interface ClosestPeersResponse {
161
161
  requestId: string;
162
162
  }
163
163
  /**
164
- * @generated from protobuf message dht.RecursiveFindRequest
164
+ * @generated from protobuf message dht.FindRequest
165
165
  */
166
- export interface RecursiveFindRequest {
166
+ export interface FindRequest {
167
167
  /**
168
- * @generated from protobuf field: string recursiveFindSessionId = 1;
168
+ * @generated from protobuf field: string sessionId = 1;
169
169
  */
170
- recursiveFindSessionId: string;
170
+ sessionId: string;
171
171
  /**
172
- * @generated from protobuf field: dht.FindMode findMode = 2;
172
+ * @generated from protobuf field: bool fetchData = 2;
173
173
  */
174
- findMode: FindMode;
174
+ fetchData: boolean;
175
175
  }
176
176
  /**
177
- * @generated from protobuf message dht.RecursiveFindReport
177
+ * @generated from protobuf message dht.FindResponse
178
178
  */
179
- export interface RecursiveFindReport {
179
+ export interface FindResponse {
180
180
  /**
181
- * @generated from protobuf field: repeated dht.PeerDescriptor nodes = 1;
181
+ * @generated from protobuf field: repeated dht.PeerDescriptor closestConnectedPeers = 1;
182
182
  */
183
- nodes: PeerDescriptor[];
183
+ closestConnectedPeers: PeerDescriptor[];
184
184
  /**
185
185
  * @generated from protobuf field: repeated dht.DataEntry dataEntries = 2;
186
186
  */
@@ -246,11 +246,7 @@ export interface PeerDescriptor {
246
246
  */
247
247
  websocket?: ConnectivityMethod;
248
248
  /**
249
- * @generated from protobuf field: optional bool openInternet = 6;
250
- */
251
- openInternet?: boolean;
252
- /**
253
- * @generated from protobuf field: optional uint32 region = 7;
249
+ * @generated from protobuf field: optional uint32 region = 6;
254
250
  */
255
251
  region?: number;
256
252
  }
@@ -288,19 +284,15 @@ export interface RouteMessageWrapper {
288
284
  */
289
285
  destinationPeer?: PeerDescriptor;
290
286
  /**
291
- * @generated from protobuf field: dht.PeerDescriptor previousPeer = 4;
292
- */
293
- previousPeer?: PeerDescriptor;
294
- /**
295
- * @generated from protobuf field: dht.Message message = 5;
287
+ * @generated from protobuf field: dht.Message message = 4;
296
288
  */
297
289
  message?: Message;
298
290
  /**
299
- * @generated from protobuf field: repeated dht.PeerDescriptor reachableThrough = 6;
291
+ * @generated from protobuf field: repeated dht.PeerDescriptor reachableThrough = 5;
300
292
  */
301
293
  reachableThrough: PeerDescriptor[];
302
294
  /**
303
- * @generated from protobuf field: repeated dht.PeerDescriptor routingPath = 7;
295
+ * @generated from protobuf field: repeated dht.PeerDescriptor routingPath = 6;
304
296
  */
305
297
  routingPath: PeerDescriptor[];
306
298
  }
@@ -335,25 +327,25 @@ export interface ConnectivityRequest {
335
327
  * @generated from protobuf field: optional string host = 3;
336
328
  */
337
329
  host?: string;
330
+ /**
331
+ * @generated from protobuf field: bool selfSigned = 4;
332
+ */
333
+ selfSigned: boolean;
338
334
  }
339
335
  /**
340
336
  * @generated from protobuf message dht.ConnectivityResponse
341
337
  */
342
338
  export interface ConnectivityResponse {
343
339
  /**
344
- * @generated from protobuf field: bool open_internet = 1;
345
- */
346
- openInternet: boolean;
347
- /**
348
- * @generated from protobuf field: string host = 2;
340
+ * @generated from protobuf field: string host = 1;
349
341
  */
350
342
  host: string;
351
343
  /**
352
- * @generated from protobuf field: string natType = 3;
344
+ * @generated from protobuf field: string natType = 2;
353
345
  */
354
346
  natType: string;
355
347
  /**
356
- * @generated from protobuf field: dht.ConnectivityMethod websocket = 4;
348
+ * @generated from protobuf field: dht.ConnectivityMethod websocket = 3;
357
349
  */
358
350
  websocket?: ConnectivityMethod;
359
351
  }
@@ -362,30 +354,26 @@ export interface ConnectivityResponse {
362
354
  */
363
355
  export interface HandshakeRequest {
364
356
  /**
365
- * @generated from protobuf field: bytes sourceId = 1;
357
+ * @generated from protobuf field: dht.PeerDescriptor sourcePeerDescriptor = 1;
366
358
  */
367
- sourceId: Uint8Array;
359
+ sourcePeerDescriptor?: PeerDescriptor;
368
360
  /**
369
- * @generated from protobuf field: dht.PeerDescriptor peerDescriptor = 2;
361
+ * @generated from protobuf field: optional dht.PeerDescriptor targetPeerDescriptor = 2;
370
362
  */
371
- peerDescriptor?: PeerDescriptor;
363
+ targetPeerDescriptor?: PeerDescriptor;
372
364
  }
373
365
  /**
374
366
  * @generated from protobuf message dht.HandshakeResponse
375
367
  */
376
368
  export interface HandshakeResponse {
377
369
  /**
378
- * @generated from protobuf field: bytes sourceId = 1;
370
+ * @generated from protobuf field: dht.PeerDescriptor sourcePeerDescriptor = 1;
379
371
  */
380
- sourceId: Uint8Array;
372
+ sourcePeerDescriptor?: PeerDescriptor;
381
373
  /**
382
- * @generated from protobuf field: dht.PeerDescriptor peerDescriptor = 2;
374
+ * @generated from protobuf field: optional dht.HandshakeError error = 2;
383
375
  */
384
- peerDescriptor?: PeerDescriptor;
385
- /**
386
- * @generated from protobuf field: optional string responseError = 3;
387
- */
388
- responseError?: string;
376
+ error?: HandshakeError;
389
377
  }
390
378
  /**
391
379
  * @generated from protobuf message dht.Message
@@ -445,11 +433,11 @@ export interface Message {
445
433
  */
446
434
  rpcMessage: RpcMessage;
447
435
  } | {
448
- oneofKind: "recursiveFindRequest";
436
+ oneofKind: "findRequest";
449
437
  /**
450
- * @generated from protobuf field: dht.RecursiveFindRequest RecursiveFindRequest = 11 [json_name = "RecursiveFindRequest"];
438
+ * @generated from protobuf field: dht.FindRequest findRequest = 11;
451
439
  */
452
- recursiveFindRequest: RecursiveFindRequest;
440
+ findRequest: FindRequest;
453
441
  } | {
454
442
  oneofKind: undefined;
455
443
  };
@@ -459,41 +447,25 @@ export interface Message {
459
447
  /**
460
448
  * WebSocket
461
449
  *
462
- * @generated from protobuf message dht.WebSocketConnectionRequest
450
+ * @generated from protobuf message dht.WebsocketConnectionRequest
463
451
  */
464
- export interface WebSocketConnectionRequest {
465
- /**
466
- * @generated from protobuf field: string ip = 1;
467
- */
468
- ip: string;
469
- /**
470
- * @generated from protobuf field: uint32 port = 2;
471
- */
472
- port: number;
452
+ export interface WebsocketConnectionRequest {
473
453
  }
474
454
  /**
475
- * @generated from protobuf message dht.WebSocketConnectionResponse
455
+ * @generated from protobuf message dht.WebsocketConnectionResponse
476
456
  */
477
- export interface WebSocketConnectionResponse {
457
+ export interface WebsocketConnectionResponse {
478
458
  /**
479
459
  * @generated from protobuf field: bool accepted = 1;
480
460
  */
481
461
  accepted: boolean;
482
- /**
483
- * @generated from protobuf field: optional string reason = 2;
484
- */
485
- reason?: string;
486
462
  }
487
463
  /**
488
464
  * WebRTC
489
465
  *
490
- * @generated from protobuf message dht.WebRtcConnectionRequest
466
+ * @generated from protobuf message dht.WebrtcConnectionRequest
491
467
  */
492
- export interface WebRtcConnectionRequest {
493
- /**
494
- * @generated from protobuf field: string connectionId = 1;
495
- */
496
- connectionId: string;
468
+ export interface WebrtcConnectionRequest {
497
469
  }
498
470
  /**
499
471
  * @generated from protobuf message dht.RtcOffer
@@ -543,18 +515,18 @@ export interface IceCandidate {
543
515
  */
544
516
  export interface LockRequest {
545
517
  /**
546
- * @generated from protobuf field: string serviceId = 1;
518
+ * @generated from protobuf field: string lockId = 1;
547
519
  */
548
- serviceId: string;
520
+ lockId: string;
549
521
  }
550
522
  /**
551
523
  * @generated from protobuf message dht.UnlockRequest
552
524
  */
553
525
  export interface UnlockRequest {
554
526
  /**
555
- * @generated from protobuf field: string serviceId = 1;
527
+ * @generated from protobuf field: string lockId = 1;
556
528
  */
557
- serviceId: string;
529
+ lockId: string;
558
530
  }
559
531
  /**
560
532
  * @generated from protobuf message dht.LockResponse
@@ -584,18 +556,18 @@ export interface DisconnectNotice {
584
556
  export interface DisconnectNoticeResponse {
585
557
  }
586
558
  /**
587
- * @generated from protobuf message dht.FindDataRequest
559
+ * @generated from protobuf message dht.ExternalFindDataRequest
588
560
  */
589
- export interface FindDataRequest {
561
+ export interface ExternalFindDataRequest {
590
562
  /**
591
563
  * @generated from protobuf field: bytes kademliaId = 1;
592
564
  */
593
565
  kademliaId: Uint8Array;
594
566
  }
595
567
  /**
596
- * @generated from protobuf message dht.FindDataResponse
568
+ * @generated from protobuf message dht.ExternalFindDataResponse
597
569
  */
598
- export interface FindDataResponse {
570
+ export interface ExternalFindDataResponse {
599
571
  /**
600
572
  * @generated from protobuf field: repeated dht.DataEntry dataEntries = 1;
601
573
  */
@@ -605,19 +577,6 @@ export interface FindDataResponse {
605
577
  */
606
578
  error?: string;
607
579
  }
608
- /**
609
- * @generated from protobuf enum dht.FindMode
610
- */
611
- export enum FindMode {
612
- /**
613
- * @generated from protobuf enum value: NODE = 0;
614
- */
615
- NODE = 0,
616
- /**
617
- * @generated from protobuf enum value: DATA = 1;
618
- */
619
- DATA = 1
620
- }
621
580
  /**
622
581
  * @generated from protobuf enum dht.NodeType
623
582
  */
@@ -656,6 +615,19 @@ export enum RpcResponseError {
656
615
  */
657
616
  UNKNOWN_RPC_METHOD = 3
658
617
  }
618
+ /**
619
+ * @generated from protobuf enum dht.HandshakeError
620
+ */
621
+ export enum HandshakeError {
622
+ /**
623
+ * @generated from protobuf enum value: DUPLICATE_CONNECTION = 0;
624
+ */
625
+ DUPLICATE_CONNECTION = 0,
626
+ /**
627
+ * @generated from protobuf enum value: INVALID_TARGET_PEER_DESCRIPTOR = 1;
628
+ */
629
+ INVALID_TARGET_PEER_DESCRIPTOR = 1
630
+ }
659
631
  // Wraps all messages
660
632
 
661
633
  /**
@@ -663,29 +635,29 @@ export enum RpcResponseError {
663
635
  */
664
636
  export enum MessageType {
665
637
  /**
666
- * @generated from protobuf enum value: CONNECTIVITY_REQUEST = 0;
638
+ * @generated from protobuf enum value: RPC = 0;
667
639
  */
668
- CONNECTIVITY_REQUEST = 0,
640
+ RPC = 0,
669
641
  /**
670
- * @generated from protobuf enum value: CONNECTIVITY_RESPONSE = 1;
642
+ * @generated from protobuf enum value: CONNECTIVITY_REQUEST = 1;
671
643
  */
672
- CONNECTIVITY_RESPONSE = 1,
644
+ CONNECTIVITY_REQUEST = 1,
673
645
  /**
674
- * @generated from protobuf enum value: HANDSHAKE_REQUEST = 2;
646
+ * @generated from protobuf enum value: CONNECTIVITY_RESPONSE = 2;
675
647
  */
676
- HANDSHAKE_REQUEST = 2,
648
+ CONNECTIVITY_RESPONSE = 2,
677
649
  /**
678
- * @generated from protobuf enum value: HANDSHAKE_RESPONSE = 3;
650
+ * @generated from protobuf enum value: HANDSHAKE_REQUEST = 3;
679
651
  */
680
- HANDSHAKE_RESPONSE = 3,
652
+ HANDSHAKE_REQUEST = 3,
681
653
  /**
682
- * @generated from protobuf enum value: RPC = 4;
654
+ * @generated from protobuf enum value: HANDSHAKE_RESPONSE = 4;
683
655
  */
684
- RPC = 4,
656
+ HANDSHAKE_RESPONSE = 4,
685
657
  /**
686
- * @generated from protobuf enum value: RECURSIVE_FIND_REQUEST = 5;
658
+ * @generated from protobuf enum value: FIND_REQUEST = 5;
687
659
  */
688
- RECURSIVE_FIND_REQUEST = 5
660
+ FIND_REQUEST = 5
689
661
  }
690
662
  /**
691
663
  * @generated from protobuf enum dht.DisconnectMode
@@ -846,23 +818,23 @@ class ClosestPeersResponse$Type extends MessageType$<ClosestPeersResponse> {
846
818
  */
847
819
  export const ClosestPeersResponse = new ClosestPeersResponse$Type();
848
820
  // @generated message type with reflection information, may provide speed optimized methods
849
- class RecursiveFindRequest$Type extends MessageType$<RecursiveFindRequest> {
821
+ class FindRequest$Type extends MessageType$<FindRequest> {
850
822
  constructor() {
851
- super("dht.RecursiveFindRequest", [
852
- { no: 1, name: "recursiveFindSessionId", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
853
- { no: 2, name: "findMode", kind: "enum", T: () => ["dht.FindMode", FindMode] }
823
+ super("dht.FindRequest", [
824
+ { no: 1, name: "sessionId", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
825
+ { no: 2, name: "fetchData", kind: "scalar", T: 8 /*ScalarType.BOOL*/ }
854
826
  ]);
855
827
  }
856
828
  }
857
829
  /**
858
- * @generated MessageType for protobuf message dht.RecursiveFindRequest
830
+ * @generated MessageType for protobuf message dht.FindRequest
859
831
  */
860
- export const RecursiveFindRequest = new RecursiveFindRequest$Type();
832
+ export const FindRequest = new FindRequest$Type();
861
833
  // @generated message type with reflection information, may provide speed optimized methods
862
- class RecursiveFindReport$Type extends MessageType$<RecursiveFindReport> {
834
+ class FindResponse$Type extends MessageType$<FindResponse> {
863
835
  constructor() {
864
- super("dht.RecursiveFindReport", [
865
- { no: 1, name: "nodes", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor },
836
+ super("dht.FindResponse", [
837
+ { no: 1, name: "closestConnectedPeers", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor },
866
838
  { no: 2, name: "dataEntries", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => DataEntry },
867
839
  { no: 3, name: "noCloserNodesFound", kind: "scalar", opt: true, T: 8 /*ScalarType.BOOL*/ },
868
840
  { no: 4, name: "routingPath", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor }
@@ -870,9 +842,9 @@ class RecursiveFindReport$Type extends MessageType$<RecursiveFindReport> {
870
842
  }
871
843
  }
872
844
  /**
873
- * @generated MessageType for protobuf message dht.RecursiveFindReport
845
+ * @generated MessageType for protobuf message dht.FindResponse
874
846
  */
875
- export const RecursiveFindReport = new RecursiveFindReport$Type();
847
+ export const FindResponse = new FindResponse$Type();
876
848
  // @generated message type with reflection information, may provide speed optimized methods
877
849
  class PingRequest$Type extends MessageType$<PingRequest> {
878
850
  constructor() {
@@ -918,8 +890,7 @@ class PeerDescriptor$Type extends MessageType$<PeerDescriptor> {
918
890
  { no: 3, name: "udp", kind: "message", T: () => ConnectivityMethod },
919
891
  { no: 4, name: "tcp", kind: "message", T: () => ConnectivityMethod },
920
892
  { no: 5, name: "websocket", kind: "message", T: () => ConnectivityMethod },
921
- { no: 6, name: "openInternet", kind: "scalar", opt: true, T: 8 /*ScalarType.BOOL*/ },
922
- { no: 7, name: "region", kind: "scalar", opt: true, T: 13 /*ScalarType.UINT32*/ }
893
+ { no: 6, name: "region", kind: "scalar", opt: true, T: 13 /*ScalarType.UINT32*/ }
923
894
  ]);
924
895
  }
925
896
  }
@@ -948,10 +919,9 @@ class RouteMessageWrapper$Type extends MessageType$<RouteMessageWrapper> {
948
919
  { no: 1, name: "sourcePeer", kind: "message", T: () => PeerDescriptor },
949
920
  { no: 2, name: "requestId", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
950
921
  { no: 3, name: "destinationPeer", kind: "message", T: () => PeerDescriptor },
951
- { no: 4, name: "previousPeer", kind: "message", T: () => PeerDescriptor },
952
- { no: 5, name: "message", kind: "message", T: () => Message },
953
- { no: 6, name: "reachableThrough", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor },
954
- { no: 7, name: "routingPath", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor }
922
+ { no: 4, name: "message", kind: "message", T: () => Message },
923
+ { no: 5, name: "reachableThrough", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor },
924
+ { no: 6, name: "routingPath", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => PeerDescriptor }
955
925
  ]);
956
926
  }
957
927
  }
@@ -978,7 +948,8 @@ class ConnectivityRequest$Type extends MessageType$<ConnectivityRequest> {
978
948
  super("dht.ConnectivityRequest", [
979
949
  { no: 1, name: "port", kind: "scalar", T: 13 /*ScalarType.UINT32*/ },
980
950
  { no: 2, name: "tls", kind: "scalar", T: 8 /*ScalarType.BOOL*/ },
981
- { no: 3, name: "host", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ }
951
+ { no: 3, name: "host", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ },
952
+ { no: 4, name: "selfSigned", kind: "scalar", T: 8 /*ScalarType.BOOL*/ }
982
953
  ]);
983
954
  }
984
955
  }
@@ -990,10 +961,9 @@ export const ConnectivityRequest = new ConnectivityRequest$Type();
990
961
  class ConnectivityResponse$Type extends MessageType$<ConnectivityResponse> {
991
962
  constructor() {
992
963
  super("dht.ConnectivityResponse", [
993
- { no: 1, name: "open_internet", kind: "scalar", T: 8 /*ScalarType.BOOL*/ },
994
- { no: 2, name: "host", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
995
- { no: 3, name: "natType", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
996
- { no: 4, name: "websocket", kind: "message", T: () => ConnectivityMethod }
964
+ { no: 1, name: "host", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
965
+ { no: 2, name: "natType", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
966
+ { no: 3, name: "websocket", kind: "message", T: () => ConnectivityMethod }
997
967
  ]);
998
968
  }
999
969
  }
@@ -1005,8 +975,8 @@ export const ConnectivityResponse = new ConnectivityResponse$Type();
1005
975
  class HandshakeRequest$Type extends MessageType$<HandshakeRequest> {
1006
976
  constructor() {
1007
977
  super("dht.HandshakeRequest", [
1008
- { no: 1, name: "sourceId", kind: "scalar", T: 12 /*ScalarType.BYTES*/ },
1009
- { no: 2, name: "peerDescriptor", kind: "message", T: () => PeerDescriptor }
978
+ { no: 1, name: "sourcePeerDescriptor", kind: "message", T: () => PeerDescriptor },
979
+ { no: 2, name: "targetPeerDescriptor", kind: "message", T: () => PeerDescriptor }
1010
980
  ]);
1011
981
  }
1012
982
  }
@@ -1018,9 +988,8 @@ export const HandshakeRequest = new HandshakeRequest$Type();
1018
988
  class HandshakeResponse$Type extends MessageType$<HandshakeResponse> {
1019
989
  constructor() {
1020
990
  super("dht.HandshakeResponse", [
1021
- { no: 1, name: "sourceId", kind: "scalar", T: 12 /*ScalarType.BYTES*/ },
1022
- { no: 2, name: "peerDescriptor", kind: "message", T: () => PeerDescriptor },
1023
- { no: 3, name: "responseError", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ }
991
+ { no: 1, name: "sourcePeerDescriptor", kind: "message", T: () => PeerDescriptor },
992
+ { no: 2, name: "error", kind: "enum", opt: true, T: () => ["dht.HandshakeError", HandshakeError] }
1024
993
  ]);
1025
994
  }
1026
995
  }
@@ -1042,7 +1011,7 @@ class Message$Type extends MessageType$<Message> {
1042
1011
  { no: 8, name: "handshakeRequest", kind: "message", oneof: "body", T: () => HandshakeRequest },
1043
1012
  { no: 9, name: "handshakeResponse", kind: "message", oneof: "body", T: () => HandshakeResponse },
1044
1013
  { no: 10, name: "rpcMessage", kind: "message", oneof: "body", T: () => RpcMessage },
1045
- { no: 11, name: "RecursiveFindRequest", kind: "message", jsonName: "RecursiveFindRequest", oneof: "body", T: () => RecursiveFindRequest }
1014
+ { no: 11, name: "findRequest", kind: "message", oneof: "body", T: () => FindRequest }
1046
1015
  ]);
1047
1016
  }
1048
1017
  }
@@ -1051,43 +1020,37 @@ class Message$Type extends MessageType$<Message> {
1051
1020
  */
1052
1021
  export const Message = new Message$Type();
1053
1022
  // @generated message type with reflection information, may provide speed optimized methods
1054
- class WebSocketConnectionRequest$Type extends MessageType$<WebSocketConnectionRequest> {
1023
+ class WebsocketConnectionRequest$Type extends MessageType$<WebsocketConnectionRequest> {
1055
1024
  constructor() {
1056
- super("dht.WebSocketConnectionRequest", [
1057
- { no: 1, name: "ip", kind: "scalar", T: 9 /*ScalarType.STRING*/ },
1058
- { no: 2, name: "port", kind: "scalar", T: 13 /*ScalarType.UINT32*/ }
1059
- ]);
1025
+ super("dht.WebsocketConnectionRequest", []);
1060
1026
  }
1061
1027
  }
1062
1028
  /**
1063
- * @generated MessageType for protobuf message dht.WebSocketConnectionRequest
1029
+ * @generated MessageType for protobuf message dht.WebsocketConnectionRequest
1064
1030
  */
1065
- export const WebSocketConnectionRequest = new WebSocketConnectionRequest$Type();
1031
+ export const WebsocketConnectionRequest = new WebsocketConnectionRequest$Type();
1066
1032
  // @generated message type with reflection information, may provide speed optimized methods
1067
- class WebSocketConnectionResponse$Type extends MessageType$<WebSocketConnectionResponse> {
1033
+ class WebsocketConnectionResponse$Type extends MessageType$<WebsocketConnectionResponse> {
1068
1034
  constructor() {
1069
- super("dht.WebSocketConnectionResponse", [
1070
- { no: 1, name: "accepted", kind: "scalar", T: 8 /*ScalarType.BOOL*/ },
1071
- { no: 2, name: "reason", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ }
1035
+ super("dht.WebsocketConnectionResponse", [
1036
+ { no: 1, name: "accepted", kind: "scalar", T: 8 /*ScalarType.BOOL*/ }
1072
1037
  ]);
1073
1038
  }
1074
1039
  }
1075
1040
  /**
1076
- * @generated MessageType for protobuf message dht.WebSocketConnectionResponse
1041
+ * @generated MessageType for protobuf message dht.WebsocketConnectionResponse
1077
1042
  */
1078
- export const WebSocketConnectionResponse = new WebSocketConnectionResponse$Type();
1043
+ export const WebsocketConnectionResponse = new WebsocketConnectionResponse$Type();
1079
1044
  // @generated message type with reflection information, may provide speed optimized methods
1080
- class WebRtcConnectionRequest$Type extends MessageType$<WebRtcConnectionRequest> {
1045
+ class WebrtcConnectionRequest$Type extends MessageType$<WebrtcConnectionRequest> {
1081
1046
  constructor() {
1082
- super("dht.WebRtcConnectionRequest", [
1083
- { no: 1, name: "connectionId", kind: "scalar", T: 9 /*ScalarType.STRING*/ }
1084
- ]);
1047
+ super("dht.WebrtcConnectionRequest", []);
1085
1048
  }
1086
1049
  }
1087
1050
  /**
1088
- * @generated MessageType for protobuf message dht.WebRtcConnectionRequest
1051
+ * @generated MessageType for protobuf message dht.WebrtcConnectionRequest
1089
1052
  */
1090
- export const WebRtcConnectionRequest = new WebRtcConnectionRequest$Type();
1053
+ export const WebrtcConnectionRequest = new WebrtcConnectionRequest$Type();
1091
1054
  // @generated message type with reflection information, may provide speed optimized methods
1092
1055
  class RtcOffer$Type extends MessageType$<RtcOffer> {
1093
1056
  constructor() {
@@ -1132,7 +1095,7 @@ export const IceCandidate = new IceCandidate$Type();
1132
1095
  class LockRequest$Type extends MessageType$<LockRequest> {
1133
1096
  constructor() {
1134
1097
  super("dht.LockRequest", [
1135
- { no: 1, name: "serviceId", kind: "scalar", T: 9 /*ScalarType.STRING*/ }
1098
+ { no: 1, name: "lockId", kind: "scalar", T: 9 /*ScalarType.STRING*/ }
1136
1099
  ]);
1137
1100
  }
1138
1101
  }
@@ -1144,7 +1107,7 @@ export const LockRequest = new LockRequest$Type();
1144
1107
  class UnlockRequest$Type extends MessageType$<UnlockRequest> {
1145
1108
  constructor() {
1146
1109
  super("dht.UnlockRequest", [
1147
- { no: 1, name: "serviceId", kind: "scalar", T: 9 /*ScalarType.STRING*/ }
1110
+ { no: 1, name: "lockId", kind: "scalar", T: 9 /*ScalarType.STRING*/ }
1148
1111
  ]);
1149
1112
  }
1150
1113
  }
@@ -1188,87 +1151,92 @@ class DisconnectNoticeResponse$Type extends MessageType$<DisconnectNoticeRespons
1188
1151
  */
1189
1152
  export const DisconnectNoticeResponse = new DisconnectNoticeResponse$Type();
1190
1153
  // @generated message type with reflection information, may provide speed optimized methods
1191
- class FindDataRequest$Type extends MessageType$<FindDataRequest> {
1154
+ class ExternalFindDataRequest$Type extends MessageType$<ExternalFindDataRequest> {
1192
1155
  constructor() {
1193
- super("dht.FindDataRequest", [
1156
+ super("dht.ExternalFindDataRequest", [
1194
1157
  { no: 1, name: "kademliaId", kind: "scalar", T: 12 /*ScalarType.BYTES*/ }
1195
1158
  ]);
1196
1159
  }
1197
1160
  }
1198
1161
  /**
1199
- * @generated MessageType for protobuf message dht.FindDataRequest
1162
+ * @generated MessageType for protobuf message dht.ExternalFindDataRequest
1200
1163
  */
1201
- export const FindDataRequest = new FindDataRequest$Type();
1164
+ export const ExternalFindDataRequest = new ExternalFindDataRequest$Type();
1202
1165
  // @generated message type with reflection information, may provide speed optimized methods
1203
- class FindDataResponse$Type extends MessageType$<FindDataResponse> {
1166
+ class ExternalFindDataResponse$Type extends MessageType$<ExternalFindDataResponse> {
1204
1167
  constructor() {
1205
- super("dht.FindDataResponse", [
1168
+ super("dht.ExternalFindDataResponse", [
1206
1169
  { no: 1, name: "dataEntries", kind: "message", repeat: 1 /*RepeatType.PACKED*/, T: () => DataEntry },
1207
1170
  { no: 2, name: "error", kind: "scalar", opt: true, T: 9 /*ScalarType.STRING*/ }
1208
1171
  ]);
1209
1172
  }
1210
1173
  }
1211
1174
  /**
1212
- * @generated MessageType for protobuf message dht.FindDataResponse
1175
+ * @generated MessageType for protobuf message dht.ExternalFindDataResponse
1213
1176
  */
1214
- export const FindDataResponse = new FindDataResponse$Type();
1177
+ export const ExternalFindDataResponse = new ExternalFindDataResponse$Type();
1215
1178
  /**
1216
- * @generated ServiceType for protobuf service dht.DhtRpcService
1179
+ * @generated ServiceType for protobuf service dht.DhtNodeRpc
1217
1180
  */
1218
- export const DhtRpcService = new ServiceType("dht.DhtRpcService", [
1181
+ export const DhtNodeRpc = new ServiceType("dht.DhtNodeRpc", [
1219
1182
  { name: "getClosestPeers", options: {}, I: ClosestPeersRequest, O: ClosestPeersResponse },
1220
1183
  { name: "ping", options: {}, I: PingRequest, O: PingResponse },
1221
1184
  { name: "leaveNotice", options: {}, I: LeaveNotice, O: Empty }
1222
1185
  ]);
1223
1186
  /**
1224
- * @generated ServiceType for protobuf service dht.RoutingService
1187
+ * @generated ServiceType for protobuf service dht.RouterRpc
1225
1188
  */
1226
- export const RoutingService = new ServiceType("dht.RoutingService", [
1189
+ export const RouterRpc = new ServiceType("dht.RouterRpc", [
1227
1190
  { name: "routeMessage", options: {}, I: RouteMessageWrapper, O: RouteMessageAck },
1228
- { name: "forwardMessage", options: {}, I: RouteMessageWrapper, O: RouteMessageAck },
1229
- { name: "findRecursively", options: {}, I: RouteMessageWrapper, O: RouteMessageAck }
1191
+ { name: "forwardMessage", options: {}, I: RouteMessageWrapper, O: RouteMessageAck }
1192
+ ]);
1193
+ /**
1194
+ * @generated ServiceType for protobuf service dht.FindRpc
1195
+ */
1196
+ export const FindRpc = new ServiceType("dht.FindRpc", [
1197
+ { name: "routeFindRequest", options: {}, I: RouteMessageWrapper, O: RouteMessageAck }
1230
1198
  ]);
1231
1199
  /**
1232
- * @generated ServiceType for protobuf service dht.StoreService
1200
+ * @generated ServiceType for protobuf service dht.StoreRpc
1233
1201
  */
1234
- export const StoreService = new ServiceType("dht.StoreService", [
1202
+ export const StoreRpc = new ServiceType("dht.StoreRpc", [
1235
1203
  { name: "storeData", options: {}, I: StoreDataRequest, O: StoreDataResponse },
1236
1204
  { name: "migrateData", options: {}, I: MigrateDataRequest, O: MigrateDataResponse },
1237
1205
  { name: "deleteData", options: {}, I: DeleteDataRequest, O: DeleteDataResponse }
1238
1206
  ]);
1239
1207
  /**
1240
- * @generated ServiceType for protobuf service dht.RecursiveFindSessionService
1208
+ * @generated ServiceType for protobuf service dht.FindSessionRpc
1241
1209
  */
1242
- export const RecursiveFindSessionService = new ServiceType("dht.RecursiveFindSessionService", [
1243
- { name: "reportRecursiveFindResult", options: {}, I: RecursiveFindReport, O: Empty }
1210
+ export const FindSessionRpc = new ServiceType("dht.FindSessionRpc", [
1211
+ { name: "sendFindResponse", options: {}, I: FindResponse, O: Empty }
1244
1212
  ]);
1245
1213
  /**
1246
- * @generated ServiceType for protobuf service dht.WebSocketConnectorService
1214
+ * @generated ServiceType for protobuf service dht.WebsocketConnectorRpc
1247
1215
  */
1248
- export const WebSocketConnectorService = new ServiceType("dht.WebSocketConnectorService", [
1249
- { name: "requestConnection", options: {}, I: WebSocketConnectionRequest, O: WebSocketConnectionResponse }
1216
+ export const WebsocketConnectorRpc = new ServiceType("dht.WebsocketConnectorRpc", [
1217
+ { name: "requestConnection", options: {}, I: WebsocketConnectionRequest, O: WebsocketConnectionResponse }
1250
1218
  ]);
1251
1219
  /**
1252
- * @generated ServiceType for protobuf service dht.WebRtcConnectorService
1220
+ * @generated ServiceType for protobuf service dht.WebrtcConnectorRpc
1253
1221
  */
1254
- export const WebRtcConnectorService = new ServiceType("dht.WebRtcConnectorService", [
1255
- { name: "requestConnection", options: {}, I: WebRtcConnectionRequest, O: Empty },
1222
+ export const WebrtcConnectorRpc = new ServiceType("dht.WebrtcConnectorRpc", [
1223
+ { name: "requestConnection", options: {}, I: WebrtcConnectionRequest, O: Empty },
1256
1224
  { name: "rtcOffer", options: {}, I: RtcOffer, O: Empty },
1257
1225
  { name: "rtcAnswer", options: {}, I: RtcAnswer, O: Empty },
1258
1226
  { name: "iceCandidate", options: {}, I: IceCandidate, O: Empty }
1259
1227
  ]);
1260
1228
  /**
1261
- * @generated ServiceType for protobuf service dht.ConnectionLocker
1229
+ * @generated ServiceType for protobuf service dht.ConnectionLockRpc
1262
1230
  */
1263
- export const ConnectionLocker = new ServiceType("dht.ConnectionLocker", [
1231
+ export const ConnectionLockRpc = new ServiceType("dht.ConnectionLockRpc", [
1264
1232
  { name: "lockRequest", options: {}, I: LockRequest, O: LockResponse },
1265
1233
  { name: "unlockRequest", options: {}, I: UnlockRequest, O: Empty },
1266
1234
  { name: "gracefulDisconnect", options: {}, I: DisconnectNotice, O: DisconnectNoticeResponse }
1267
1235
  ]);
1268
1236
  /**
1269
- * @generated ServiceType for protobuf service dht.ExternalApiService
1237
+ * @generated ServiceType for protobuf service dht.ExternalApiRpc
1270
1238
  */
1271
- export const ExternalApiService = new ServiceType("dht.ExternalApiService", [
1272
- { name: "findData", options: {}, I: FindDataRequest, O: FindDataResponse },
1239
+ export const ExternalApiRpc = new ServiceType("dht.ExternalApiRpc", [
1240
+ { name: "externalFindData", options: {}, I: ExternalFindDataRequest, O: ExternalFindDataResponse },
1273
1241
  { name: "externalStoreData", options: {}, I: ExternalStoreDataRequest, O: ExternalStoreDataResponse }
1274
1242
  ]);
@@ -90,7 +90,7 @@ const measureJoiningTime = async () => {
90
90
  }, 1000)
91
91
  // get random node from network to use as entrypoint
92
92
  const randomNode = nodes[Math.floor(Math.random() * nodes.length)]
93
- const streamSubscriber = createNetworkNodeWithSimulator(peerDescriptor, simulator, [randomNode.stack.getLayer0Node().getPeerDescriptor()])
93
+ const streamSubscriber = createNetworkNodeWithSimulator(peerDescriptor, simulator, [randomNode.stack.getLayer0Node().getLocalPeerDescriptor()])
94
94
  currentNode = streamSubscriber
95
95
  const start = performance.now()
96
96
  await streamSubscriber.start()