@streamr/dht 103.1.2 → 103.2.0-experiment.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/exports-browser.cjs +7636 -0
- package/dist/exports-browser.cjs.map +1 -0
- package/dist/exports-browser.d.ts +1321 -0
- package/dist/exports-browser.js +7611 -0
- package/dist/exports-browser.js.map +1 -0
- package/dist/exports-nodejs.cjs +7833 -0
- package/dist/exports-nodejs.cjs.map +1 -0
- package/dist/exports-nodejs.d.ts +1321 -0
- package/dist/exports-nodejs.js +7808 -0
- package/dist/exports-nodejs.js.map +1 -0
- package/package.json +41 -25
- package/dist/generated/google/protobuf/any.d.ts +0 -180
- package/dist/generated/google/protobuf/any.js +0 -155
- package/dist/generated/google/protobuf/any.js.map +0 -1
- package/dist/generated/google/protobuf/empty.d.ts +0 -31
- package/dist/generated/google/protobuf/empty.js +0 -45
- package/dist/generated/google/protobuf/empty.js.map +0 -1
- package/dist/generated/google/protobuf/timestamp.d.ts +0 -156
- package/dist/generated/google/protobuf/timestamp.js +0 -136
- package/dist/generated/google/protobuf/timestamp.js.map +0 -1
- package/dist/generated/packages/dht/protos/DhtRpc.client.d.ts +0 -371
- package/dist/generated/packages/dht/protos/DhtRpc.client.js +0 -292
- package/dist/generated/packages/dht/protos/DhtRpc.client.js.map +0 -1
- package/dist/generated/packages/dht/protos/DhtRpc.d.ts +0 -1031
- package/dist/generated/packages/dht/protos/DhtRpc.js +0 -702
- package/dist/generated/packages/dht/protos/DhtRpc.js.map +0 -1
- package/dist/generated/packages/dht/protos/DhtRpc.server.d.ts +0 -168
- package/dist/generated/packages/dht/protos/DhtRpc.server.js +0 -3
- package/dist/generated/packages/dht/protos/DhtRpc.server.js.map +0 -1
- package/dist/generated/packages/proto-rpc/protos/ProtoRpc.d.ts +0 -87
- package/dist/generated/packages/proto-rpc/protos/ProtoRpc.js +0 -66
- package/dist/generated/packages/proto-rpc/protos/ProtoRpc.js.map +0 -1
- package/dist/package.json +0 -61
- package/dist/src/connection/Connection.d.ts +0 -12
- package/dist/src/connection/Connection.js +0 -30
- package/dist/src/connection/Connection.js.map +0 -1
- package/dist/src/connection/ConnectionLockRpcLocal.d.ts +0 -22
- package/dist/src/connection/ConnectionLockRpcLocal.js +0 -54
- package/dist/src/connection/ConnectionLockRpcLocal.js.map +0 -1
- package/dist/src/connection/ConnectionLockRpcRemote.d.ts +0 -10
- package/dist/src/connection/ConnectionLockRpcRemote.js +0 -61
- package/dist/src/connection/ConnectionLockRpcRemote.js.map +0 -1
- package/dist/src/connection/ConnectionLockStates.d.ts +0 -27
- package/dist/src/connection/ConnectionLockStates.js +0 -114
- package/dist/src/connection/ConnectionLockStates.js.map +0 -1
- package/dist/src/connection/ConnectionManager.d.ts +0 -85
- package/dist/src/connection/ConnectionManager.js +0 -569
- package/dist/src/connection/ConnectionManager.js.map +0 -1
- package/dist/src/connection/ConnectionsView.d.ts +0 -7
- package/dist/src/connection/ConnectionsView.js +0 -3
- package/dist/src/connection/ConnectionsView.js.map +0 -1
- package/dist/src/connection/ConnectorFacade.d.ts +0 -58
- package/dist/src/connection/ConnectorFacade.js +0 -154
- package/dist/src/connection/ConnectorFacade.js.map +0 -1
- package/dist/src/connection/Handshaker.d.ts +0 -27
- package/dist/src/connection/Handshaker.js +0 -179
- package/dist/src/connection/Handshaker.js.map +0 -1
- package/dist/src/connection/IConnection.d.ts +0 -32
- package/dist/src/connection/IConnection.js +0 -12
- package/dist/src/connection/IConnection.js.map +0 -1
- package/dist/src/connection/ManagedConnection.d.ts +0 -30
- package/dist/src/connection/ManagedConnection.js +0 -129
- package/dist/src/connection/ManagedConnection.js.map +0 -1
- package/dist/src/connection/OutputBuffer.d.ts +0 -9
- package/dist/src/connection/OutputBuffer.js +0 -26
- package/dist/src/connection/OutputBuffer.js.map +0 -1
- package/dist/src/connection/PendingConnection.d.ts +0 -19
- package/dist/src/connection/PendingConnection.js +0 -59
- package/dist/src/connection/PendingConnection.js.map +0 -1
- package/dist/src/connection/connectivityChecker.d.ts +0 -9
- package/dist/src/connection/connectivityChecker.js +0 -138
- package/dist/src/connection/connectivityChecker.js.map +0 -1
- package/dist/src/connection/connectivityRequestHandler.d.ts +0 -4
- package/dist/src/connection/connectivityRequestHandler.js +0 -108
- package/dist/src/connection/connectivityRequestHandler.js.map +0 -1
- package/dist/src/connection/simulator/Simulator.d.ts +0 -36
- package/dist/src/connection/simulator/Simulator.js +0 -290
- package/dist/src/connection/simulator/Simulator.js.map +0 -1
- package/dist/src/connection/simulator/SimulatorConnection.d.ts +0 -18
- package/dist/src/connection/simulator/SimulatorConnection.js +0 -123
- package/dist/src/connection/simulator/SimulatorConnection.js.map +0 -1
- package/dist/src/connection/simulator/SimulatorConnector.d.ts +0 -16
- package/dist/src/connection/simulator/SimulatorConnector.js +0 -80
- package/dist/src/connection/simulator/SimulatorConnector.js.map +0 -1
- package/dist/src/connection/simulator/SimulatorTransport.d.ts +0 -6
- package/dist/src/connection/simulator/SimulatorTransport.js +0 -17
- package/dist/src/connection/simulator/SimulatorTransport.js.map +0 -1
- package/dist/src/connection/simulator/pings.d.ts +0 -21
- package/dist/src/connection/simulator/pings.js +0 -61
- package/dist/src/connection/simulator/pings.js.map +0 -1
- package/dist/src/connection/webrtc/BrowserWebrtcConnection.d.ts +0 -37
- package/dist/src/connection/webrtc/BrowserWebrtcConnection.js +0 -229
- package/dist/src/connection/webrtc/BrowserWebrtcConnection.js.map +0 -1
- package/dist/src/connection/webrtc/IWebrtcConnection.d.ts +0 -21
- package/dist/src/connection/webrtc/IWebrtcConnection.js +0 -9
- package/dist/src/connection/webrtc/IWebrtcConnection.js.map +0 -1
- package/dist/src/connection/webrtc/NodeWebrtcConnection.d.ts +0 -45
- package/dist/src/connection/webrtc/NodeWebrtcConnection.js +0 -229
- package/dist/src/connection/webrtc/NodeWebrtcConnection.js.map +0 -1
- package/dist/src/connection/webrtc/WebrtcConnector.d.ts +0 -43
- package/dist/src/connection/webrtc/WebrtcConnector.js +0 -208
- package/dist/src/connection/webrtc/WebrtcConnector.js.map +0 -1
- package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.d.ts +0 -26
- package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.js +0 -82
- package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.js.map +0 -1
- package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.d.ts +0 -8
- package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.js +0 -50
- package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.js.map +0 -1
- package/dist/src/connection/webrtc/iceServerAsString.d.ts +0 -2
- package/dist/src/connection/webrtc/iceServerAsString.js +0 -17
- package/dist/src/connection/webrtc/iceServerAsString.js.map +0 -1
- package/dist/src/connection/websocket/AbstractWebsocketClientConnection.d.ts +0 -27
- package/dist/src/connection/websocket/AbstractWebsocketClientConnection.js +0 -107
- package/dist/src/connection/websocket/AbstractWebsocketClientConnection.js.map +0 -1
- package/dist/src/connection/websocket/AutoCertifierClientFacade.d.ts +0 -26
- package/dist/src/connection/websocket/AutoCertifierClientFacade.js +0 -39
- package/dist/src/connection/websocket/AutoCertifierClientFacade.js.map +0 -1
- package/dist/src/connection/websocket/BrowserWebsocketClientConnection.d.ts +0 -7
- package/dist/src/connection/websocket/BrowserWebsocketClientConnection.js +0 -44
- package/dist/src/connection/websocket/BrowserWebsocketClientConnection.js.map +0 -1
- package/dist/src/connection/websocket/NodeWebsocketClientConnection.d.ts +0 -7
- package/dist/src/connection/websocket/NodeWebsocketClientConnection.js +0 -39
- package/dist/src/connection/websocket/NodeWebsocketClientConnection.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketClientConnector.d.ts +0 -26
- package/dist/src/connection/websocket/WebsocketClientConnector.js +0 -86
- package/dist/src/connection/websocket/WebsocketClientConnector.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.d.ts +0 -18
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.js +0 -23
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.d.ts +0 -5
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.js +0 -17
- package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketServer.d.ts +0 -25
- package/dist/src/connection/websocket/WebsocketServer.js +0 -146
- package/dist/src/connection/websocket/WebsocketServer.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketServerConnection.d.ts +0 -22
- package/dist/src/connection/websocket/WebsocketServerConnection.js +0 -101
- package/dist/src/connection/websocket/WebsocketServerConnection.js.map +0 -1
- package/dist/src/connection/websocket/WebsocketServerConnector.d.ts +0 -44
- package/dist/src/connection/websocket/WebsocketServerConnector.js +0 -279
- package/dist/src/connection/websocket/WebsocketServerConnector.js.map +0 -1
- package/dist/src/dht/DhtNode.d.ts +0 -119
- package/dist/src/dht/DhtNode.js +0 -500
- package/dist/src/dht/DhtNode.js.map +0 -1
- package/dist/src/dht/DhtNodeRpcLocal.d.ts +0 -23
- package/dist/src/dht/DhtNodeRpcLocal.js +0 -54
- package/dist/src/dht/DhtNodeRpcLocal.js.map +0 -1
- package/dist/src/dht/DhtNodeRpcRemote.d.ts +0 -25
- package/dist/src/dht/DhtNodeRpcRemote.js +0 -83
- package/dist/src/dht/DhtNodeRpcRemote.js.map +0 -1
- package/dist/src/dht/ExternalApiRpcLocal.d.ts +0 -18
- package/dist/src/dht/ExternalApiRpcLocal.js +0 -32
- package/dist/src/dht/ExternalApiRpcLocal.js.map +0 -1
- package/dist/src/dht/ExternalApiRpcRemote.d.ts +0 -10
- package/dist/src/dht/ExternalApiRpcRemote.js +0 -58
- package/dist/src/dht/ExternalApiRpcRemote.js.map +0 -1
- package/dist/src/dht/PeerManager.d.ts +0 -63
- package/dist/src/dht/PeerManager.js +0 -251
- package/dist/src/dht/PeerManager.js.map +0 -1
- package/dist/src/dht/contact/Contact.d.ts +0 -8
- package/dist/src/dht/contact/Contact.js +0 -18
- package/dist/src/dht/contact/Contact.js.map +0 -1
- package/dist/src/dht/contact/ContactList.d.ts +0 -19
- package/dist/src/dht/contact/ContactList.js +0 -35
- package/dist/src/dht/contact/ContactList.js.map +0 -1
- package/dist/src/dht/contact/RandomContactList.d.ts +0 -11
- package/dist/src/dht/contact/RandomContactList.js +0 -47
- package/dist/src/dht/contact/RandomContactList.js.map +0 -1
- package/dist/src/dht/contact/RingContactList.d.ts +0 -28
- package/dist/src/dht/contact/RingContactList.js +0 -126
- package/dist/src/dht/contact/RingContactList.js.map +0 -1
- package/dist/src/dht/contact/RpcRemote.d.ts +0 -19
- package/dist/src/dht/contact/RpcRemote.js +0 -61
- package/dist/src/dht/contact/RpcRemote.js.map +0 -1
- package/dist/src/dht/contact/SortedContactList.d.ts +0 -37
- package/dist/src/dht/contact/SortedContactList.js +0 -134
- package/dist/src/dht/contact/SortedContactList.js.map +0 -1
- package/dist/src/dht/contact/getClosestNodes.d.ts +0 -6
- package/dist/src/dht/contact/getClosestNodes.js +0 -19
- package/dist/src/dht/contact/getClosestNodes.js.map +0 -1
- package/dist/src/dht/contact/ringIdentifiers.d.ts +0 -16
- package/dist/src/dht/contact/ringIdentifiers.js +0 -54
- package/dist/src/dht/contact/ringIdentifiers.js.map +0 -1
- package/dist/src/dht/discovery/DiscoverySession.d.ts +0 -29
- package/dist/src/dht/discovery/DiscoverySession.js +0 -102
- package/dist/src/dht/discovery/DiscoverySession.js.map +0 -1
- package/dist/src/dht/discovery/PeerDiscovery.d.ts +0 -42
- package/dist/src/dht/discovery/PeerDiscovery.js +0 -193
- package/dist/src/dht/discovery/PeerDiscovery.js.map +0 -1
- package/dist/src/dht/discovery/RingDiscoverySession.d.ts +0 -28
- package/dist/src/dht/discovery/RingDiscoverySession.js +0 -116
- package/dist/src/dht/discovery/RingDiscoverySession.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationManager.d.ts +0 -38
- package/dist/src/dht/recursive-operation/RecursiveOperationManager.js +0 -165
- package/dist/src/dht/recursive-operation/RecursiveOperationManager.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.d.ts +0 -14
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.js +0 -26
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.d.ts +0 -6
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.js +0 -44
- package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationSession.d.ts +0 -45
- package/dist/src/dht/recursive-operation/RecursiveOperationSession.js +0 -185
- package/dist/src/dht/recursive-operation/RecursiveOperationSession.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.d.ts +0 -14
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.js +0 -20
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.js.map +0 -1
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.d.ts +0 -6
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.js +0 -21
- package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.js.map +0 -1
- package/dist/src/dht/routing/DuplicateDetector.d.ts +0 -10
- package/dist/src/dht/routing/DuplicateDetector.js +0 -31
- package/dist/src/dht/routing/DuplicateDetector.js.map +0 -1
- package/dist/src/dht/routing/Router.d.ts +0 -35
- package/dist/src/dht/routing/Router.js +0 -204
- package/dist/src/dht/routing/Router.js.map +0 -1
- package/dist/src/dht/routing/RouterRpcLocal.d.ts +0 -20
- package/dist/src/dht/routing/RouterRpcLocal.js +0 -67
- package/dist/src/dht/routing/RouterRpcLocal.js.map +0 -1
- package/dist/src/dht/routing/RouterRpcRemote.d.ts +0 -8
- package/dist/src/dht/routing/RouterRpcRemote.js +0 -81
- package/dist/src/dht/routing/RouterRpcRemote.js.map +0 -1
- package/dist/src/dht/routing/RoutingSession.d.ts +0 -56
- package/dist/src/dht/routing/RoutingSession.js +0 -201
- package/dist/src/dht/routing/RoutingSession.js.map +0 -1
- package/dist/src/dht/routing/RoutingTablesCache.d.ts +0 -24
- package/dist/src/dht/routing/RoutingTablesCache.js +0 -46
- package/dist/src/dht/routing/RoutingTablesCache.js.map +0 -1
- package/dist/src/dht/routing/getPreviousPeer.d.ts +0 -2
- package/dist/src/dht/routing/getPreviousPeer.js +0 -12
- package/dist/src/dht/routing/getPreviousPeer.js.map +0 -1
- package/dist/src/dht/store/LocalDataStore.d.ts +0 -14
- package/dist/src/dht/store/LocalDataStore.js +0 -78
- package/dist/src/dht/store/LocalDataStore.js.map +0 -1
- package/dist/src/dht/store/StoreManager.d.ts +0 -32
- package/dist/src/dht/store/StoreManager.js +0 -126
- package/dist/src/dht/store/StoreManager.js.map +0 -1
- package/dist/src/dht/store/StoreRpcLocal.d.ts +0 -21
- package/dist/src/dht/store/StoreRpcLocal.js +0 -65
- package/dist/src/dht/store/StoreRpcLocal.js.map +0 -1
- package/dist/src/dht/store/StoreRpcRemote.d.ts +0 -7
- package/dist/src/dht/store/StoreRpcRemote.js +0 -29
- package/dist/src/dht/store/StoreRpcRemote.js.map +0 -1
- package/dist/src/exports.d.ts +0 -25
- package/dist/src/exports.js +0 -48
- package/dist/src/exports.js.map +0 -1
- package/dist/src/helpers/AddressTools.d.ts +0 -2
- package/dist/src/helpers/AddressTools.js +0 -32
- package/dist/src/helpers/AddressTools.js.map +0 -1
- package/dist/src/helpers/Connectivity.d.ts +0 -4
- package/dist/src/helpers/Connectivity.js +0 -24
- package/dist/src/helpers/Connectivity.js.map +0 -1
- package/dist/src/helpers/browser/isBrowserEnvironment.d.ts +0 -1
- package/dist/src/helpers/browser/isBrowserEnvironment.js +0 -6
- package/dist/src/helpers/browser/isBrowserEnvironment.js.map +0 -1
- package/dist/src/helpers/browser/isBrowserEnvironment_override.d.ts +0 -1
- package/dist/src/helpers/browser/isBrowserEnvironment_override.js +0 -7
- package/dist/src/helpers/browser/isBrowserEnvironment_override.js.map +0 -1
- package/dist/src/helpers/createPeerDescriptor.d.ts +0 -3
- package/dist/src/helpers/createPeerDescriptor.js +0 -58
- package/dist/src/helpers/createPeerDescriptor.js.map +0 -1
- package/dist/src/helpers/createPeerDescriptorSignaturePayload.d.ts +0 -2
- package/dist/src/helpers/createPeerDescriptorSignaturePayload.js +0 -30
- package/dist/src/helpers/createPeerDescriptorSignaturePayload.js.map +0 -1
- package/dist/src/helpers/debugHelpers.d.ts +0 -3
- package/dist/src/helpers/debugHelpers.js +0 -11
- package/dist/src/helpers/debugHelpers.js.map +0 -1
- package/dist/src/helpers/errors.d.ts +0 -72
- package/dist/src/helpers/errors.js +0 -97
- package/dist/src/helpers/errors.js.map +0 -1
- package/dist/src/helpers/offering.d.ts +0 -4
- package/dist/src/helpers/offering.js +0 -18
- package/dist/src/helpers/offering.js.map +0 -1
- package/dist/src/helpers/protoClasses.d.ts +0 -2
- package/dist/src/helpers/protoClasses.js +0 -32
- package/dist/src/helpers/protoClasses.js.map +0 -1
- package/dist/src/helpers/protoToString.d.ts +0 -2
- package/dist/src/helpers/protoToString.js +0 -19
- package/dist/src/helpers/protoToString.js.map +0 -1
- package/dist/src/helpers/version.d.ts +0 -6
- package/dist/src/helpers/version.js +0 -38
- package/dist/src/helpers/version.js.map +0 -1
- package/dist/src/identifiers.d.ts +0 -10
- package/dist/src/identifiers.js +0 -31
- package/dist/src/identifiers.js.map +0 -1
- package/dist/src/rpc-protocol/DhtCallContext.d.ts +0 -12
- package/dist/src/rpc-protocol/DhtCallContext.js +0 -17
- package/dist/src/rpc-protocol/DhtCallContext.js.map +0 -1
- package/dist/src/rpc-protocol/DhtRpcOptions.d.ts +0 -10
- package/dist/src/rpc-protocol/DhtRpcOptions.js +0 -3
- package/dist/src/rpc-protocol/DhtRpcOptions.js.map +0 -1
- package/dist/src/transport/ITransport.d.ts +0 -31
- package/dist/src/transport/ITransport.js +0 -9
- package/dist/src/transport/ITransport.js.map +0 -1
- package/dist/src/transport/ListeningRpcCommunicator.d.ts +0 -11
- package/dist/src/transport/ListeningRpcCommunicator.js +0 -31
- package/dist/src/transport/ListeningRpcCommunicator.js.map +0 -1
- package/dist/src/transport/RoutingRpcCommunicator.d.ts +0 -10
- package/dist/src/transport/RoutingRpcCommunicator.js +0 -60
- package/dist/src/transport/RoutingRpcCommunicator.js.map +0 -1
- package/dist/src/types/ServiceID.d.ts +0 -1
- package/dist/src/types/ServiceID.js +0 -3
- package/dist/src/types/ServiceID.js.map +0 -1
|
@@ -1,83 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.DhtNodeRpcRemote = void 0;
|
|
4
|
-
const utils_1 = require("@streamr/utils");
|
|
5
|
-
const uuid_1 = require("uuid");
|
|
6
|
-
const identifiers_1 = require("../identifiers");
|
|
7
|
-
const DhtRpc_client_1 = require("../../generated/packages/dht/protos/DhtRpc.client");
|
|
8
|
-
const RpcRemote_1 = require("./contact/RpcRemote");
|
|
9
|
-
const logger = new utils_1.Logger(module);
|
|
10
|
-
class DhtNodeRpcRemote extends RpcRemote_1.RpcRemote {
|
|
11
|
-
static counter = 0;
|
|
12
|
-
vectorClock;
|
|
13
|
-
id;
|
|
14
|
-
serviceId;
|
|
15
|
-
constructor(localPeerDescriptor, peerDescriptor, serviceId, rpcCommunicator, rpcRequestTimeout) {
|
|
16
|
-
super(localPeerDescriptor, peerDescriptor, rpcCommunicator, DhtRpc_client_1.DhtNodeRpcClient, rpcRequestTimeout);
|
|
17
|
-
this.id = this.getPeerDescriptor().nodeId;
|
|
18
|
-
this.vectorClock = DhtNodeRpcRemote.counter++;
|
|
19
|
-
this.serviceId = serviceId;
|
|
20
|
-
}
|
|
21
|
-
async getClosestPeers(nodeId) {
|
|
22
|
-
logger.trace(`Requesting getClosestPeers on ${this.serviceId} from ${this.getNodeId()}`);
|
|
23
|
-
const request = {
|
|
24
|
-
nodeId: (0, identifiers_1.toDhtAddressRaw)(nodeId),
|
|
25
|
-
requestId: (0, uuid_1.v4)()
|
|
26
|
-
};
|
|
27
|
-
try {
|
|
28
|
-
const peers = await this.getClient().getClosestPeers(request, this.formDhtRpcOptions());
|
|
29
|
-
return peers.peers;
|
|
30
|
-
}
|
|
31
|
-
catch (err) {
|
|
32
|
-
logger.trace(`getClosestPeers error ${this.serviceId}`, { err });
|
|
33
|
-
throw err;
|
|
34
|
-
}
|
|
35
|
-
}
|
|
36
|
-
// TODO rename to getClosestRingContacts (breaking change)
|
|
37
|
-
async getClosestRingPeers(ringIdRaw) {
|
|
38
|
-
logger.trace(`Requesting getClosestRingPeers on ${this.serviceId} from ${this.getNodeId()}`);
|
|
39
|
-
const request = {
|
|
40
|
-
ringId: ringIdRaw,
|
|
41
|
-
requestId: (0, uuid_1.v4)()
|
|
42
|
-
};
|
|
43
|
-
try {
|
|
44
|
-
const response = await this.getClient().getClosestRingPeers(request, this.formDhtRpcOptions());
|
|
45
|
-
return { left: response.leftPeers ?? [], right: response.rightPeers ?? [] };
|
|
46
|
-
}
|
|
47
|
-
catch (err) {
|
|
48
|
-
logger.trace(`getClosestRingPeers error ${this.serviceId}`, { err });
|
|
49
|
-
throw err;
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
|
-
async ping() {
|
|
53
|
-
logger.trace(`Requesting ping on ${this.serviceId} from ${this.getNodeId()}`);
|
|
54
|
-
const request = {
|
|
55
|
-
requestId: (0, uuid_1.v4)()
|
|
56
|
-
};
|
|
57
|
-
const options = this.formDhtRpcOptions();
|
|
58
|
-
try {
|
|
59
|
-
const pong = await this.getClient().ping(request, options);
|
|
60
|
-
if (pong.requestId === request.requestId) {
|
|
61
|
-
return true;
|
|
62
|
-
}
|
|
63
|
-
}
|
|
64
|
-
catch (err) {
|
|
65
|
-
logger.trace(`ping failed on ${this.serviceId} to ${this.getNodeId()}`, { err });
|
|
66
|
-
}
|
|
67
|
-
return false;
|
|
68
|
-
}
|
|
69
|
-
leaveNotice() {
|
|
70
|
-
logger.trace(`Sending leaveNotice on ${this.serviceId} from ${this.getNodeId()}`);
|
|
71
|
-
const options = this.formDhtRpcOptions({
|
|
72
|
-
notification: true
|
|
73
|
-
});
|
|
74
|
-
this.getClient().leaveNotice({}, options).catch((e) => {
|
|
75
|
-
logger.trace('Failed to send leaveNotice' + e);
|
|
76
|
-
});
|
|
77
|
-
}
|
|
78
|
-
getNodeId() {
|
|
79
|
-
return (0, identifiers_1.toNodeId)(this.getPeerDescriptor());
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
exports.DhtNodeRpcRemote = DhtNodeRpcRemote;
|
|
83
|
-
//# sourceMappingURL=DhtNodeRpcRemote.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"DhtNodeRpcRemote.js","sourceRoot":"","sources":["../../../src/dht/DhtNodeRpcRemote.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
import { IExternalApiRpc } from '../../generated/packages/dht/protos/DhtRpc.server';
|
|
2
|
-
import { ExternalFetchDataRequest, ExternalFetchDataResponse, ExternalStoreDataRequest, ExternalStoreDataResponse, RecursiveOperation, PeerDescriptor, ExternalFindClosestNodesRequest, ExternalFindClosestNodesResponse } from '../../generated/packages/dht/protos/DhtRpc';
|
|
3
|
-
import { ServerCallContext } from '@protobuf-ts/runtime-rpc';
|
|
4
|
-
import { RecursiveOperationResult } from './recursive-operation/RecursiveOperationManager';
|
|
5
|
-
import { Any } from '../../generated/google/protobuf/any';
|
|
6
|
-
import { DhtAddress } from '../identifiers';
|
|
7
|
-
interface ExternalApiRpcLocalOptions {
|
|
8
|
-
executeRecursiveOperation: (targetId: DhtAddress, operation: RecursiveOperation, excludedPeer: DhtAddress) => Promise<RecursiveOperationResult>;
|
|
9
|
-
storeDataToDht: (key: DhtAddress, data: Any, creator: DhtAddress) => Promise<PeerDescriptor[]>;
|
|
10
|
-
}
|
|
11
|
-
export declare class ExternalApiRpcLocal implements IExternalApiRpc {
|
|
12
|
-
private readonly options;
|
|
13
|
-
constructor(options: ExternalApiRpcLocalOptions);
|
|
14
|
-
externalFetchData(request: ExternalFetchDataRequest, context: ServerCallContext): Promise<ExternalFetchDataResponse>;
|
|
15
|
-
externalStoreData(request: ExternalStoreDataRequest, context: ServerCallContext): Promise<ExternalStoreDataResponse>;
|
|
16
|
-
externalFindClosestNodes(request: ExternalFindClosestNodesRequest, context: ServerCallContext): Promise<ExternalFindClosestNodesResponse>;
|
|
17
|
-
}
|
|
18
|
-
export {};
|
|
@@ -1,32 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ExternalApiRpcLocal = void 0;
|
|
4
|
-
const DhtRpc_1 = require("../../generated/packages/dht/protos/DhtRpc");
|
|
5
|
-
const identifiers_1 = require("../identifiers");
|
|
6
|
-
class ExternalApiRpcLocal {
|
|
7
|
-
options;
|
|
8
|
-
constructor(options) {
|
|
9
|
-
this.options = options;
|
|
10
|
-
}
|
|
11
|
-
async externalFetchData(request, context) {
|
|
12
|
-
const senderPeerDescriptor = context.incomingSourceDescriptor;
|
|
13
|
-
const result = await this.options.executeRecursiveOperation((0, identifiers_1.toDhtAddress)(request.key), DhtRpc_1.RecursiveOperation.FETCH_DATA, (0, identifiers_1.toNodeId)(senderPeerDescriptor));
|
|
14
|
-
return DhtRpc_1.ExternalFetchDataResponse.create({ entries: result.dataEntries ?? [] });
|
|
15
|
-
}
|
|
16
|
-
async externalStoreData(request, context) {
|
|
17
|
-
const senderPeerDescriptor = context.incomingSourceDescriptor;
|
|
18
|
-
const result = await this.options.storeDataToDht((0, identifiers_1.toDhtAddress)(request.key), request.data, (0, identifiers_1.toNodeId)(senderPeerDescriptor));
|
|
19
|
-
return DhtRpc_1.ExternalStoreDataResponse.create({
|
|
20
|
-
storers: result
|
|
21
|
-
});
|
|
22
|
-
}
|
|
23
|
-
async externalFindClosestNodes(request, context) {
|
|
24
|
-
const senderPeerDescriptor = context.incomingSourceDescriptor;
|
|
25
|
-
const result = await this.options.executeRecursiveOperation((0, identifiers_1.toDhtAddress)(request.nodeId), DhtRpc_1.RecursiveOperation.FIND_CLOSEST_NODES, (0, identifiers_1.toNodeId)(senderPeerDescriptor));
|
|
26
|
-
return DhtRpc_1.ExternalFindClosestNodesResponse.create({
|
|
27
|
-
closestNodes: result.closestNodes
|
|
28
|
-
});
|
|
29
|
-
}
|
|
30
|
-
}
|
|
31
|
-
exports.ExternalApiRpcLocal = ExternalApiRpcLocal;
|
|
32
|
-
//# sourceMappingURL=ExternalApiRpcLocal.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ExternalApiRpcLocal.js","sourceRoot":"","sources":["../../../src/dht/ExternalApiRpcLocal.ts"],"names":[],"mappings":";;;AACA,uEASmD;AAKnD,gDAAmE;AAenE,MAAa,mBAAmB;IAEX,OAAO,CAA4B;IAEpD,YAAY,OAAmC;QAC3C,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IAC1B,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,OAAiC,EAAE,OAA0B;QACjF,MAAM,oBAAoB,GAAI,OAA0B,CAAC,wBAAyB,CAAA;QAClF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,yBAAyB,CACvD,IAAA,0BAAY,EAAC,OAAO,CAAC,GAAG,CAAC,EACzB,2BAAkB,CAAC,UAAU,EAC7B,IAAA,sBAAQ,EAAC,oBAAoB,CAAC,CACjC,CAAA;QACD,OAAO,kCAAyB,CAAC,MAAM,CAAC,EAAE,OAAO,EAAE,MAAM,CAAC,WAAW,IAAI,EAAE,EAAE,CAAC,CAAA;IAClF,CAAC;IAED,KAAK,CAAC,iBAAiB,CAAC,OAAiC,EAAE,OAA0B;QACjF,MAAM,oBAAoB,GAAI,OAA0B,CAAC,wBAAyB,CAAA;QAClF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,cAAc,CAC5C,IAAA,0BAAY,EAAC,OAAO,CAAC,GAAG,CAAC,EACzB,OAAO,CAAC,IAAK,EACb,IAAA,sBAAQ,EAAC,oBAAoB,CAAC,CACjC,CAAA;QACD,OAAO,kCAAyB,CAAC,MAAM,CAAC;YACpC,OAAO,EAAE,MAAM;SAClB,CAAC,CAAA;IACN,CAAC;IAED,KAAK,CAAC,wBAAwB,CAAC,OAAwC,EAAE,OAA0B;QAC/F,MAAM,oBAAoB,GAAI,OAA0B,CAAC,wBAAyB,CAAA;QAClF,MAAM,MAAM,GAAG,MAAM,IAAI,CAAC,OAAO,CAAC,yBAAyB,CACvD,IAAA,0BAAY,EAAC,OAAO,CAAC,MAAM,CAAC,EAC5B,2BAAkB,CAAC,kBAAkB,EACrC,IAAA,sBAAQ,EAAC,oBAAoB,CAAC,CACjC,CAAA;QACD,OAAO,yCAAgC,CAAC,MAAM,CAAC;YAC3C,YAAY,EAAE,MAAM,CAAC,YAAY;SACpC,CAAC,CAAA;IACN,CAAC;CAEJ;AA1CD,kDA0CC"}
|
|
@@ -1,10 +0,0 @@
|
|
|
1
|
-
import { DhtAddress } from '../identifiers';
|
|
2
|
-
import { Any } from '../../generated/google/protobuf/any';
|
|
3
|
-
import { DataEntry, PeerDescriptor } from '../../generated/packages/dht/protos/DhtRpc';
|
|
4
|
-
import { ExternalApiRpcClient } from '../../generated/packages/dht/protos/DhtRpc.client';
|
|
5
|
-
import { RpcRemote } from './contact/RpcRemote';
|
|
6
|
-
export declare class ExternalApiRpcRemote extends RpcRemote<ExternalApiRpcClient> {
|
|
7
|
-
externalFetchData(key: DhtAddress): Promise<DataEntry[]>;
|
|
8
|
-
storeData(key: DhtAddress, data: Any): Promise<PeerDescriptor[]>;
|
|
9
|
-
externalFindClosestNode(key: DhtAddress): Promise<PeerDescriptor[]>;
|
|
10
|
-
}
|
|
@@ -1,58 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ExternalApiRpcRemote = void 0;
|
|
4
|
-
const identifiers_1 = require("../identifiers");
|
|
5
|
-
const RpcRemote_1 = require("./contact/RpcRemote");
|
|
6
|
-
const DEFAULT_TIMEOUT = 10000;
|
|
7
|
-
class ExternalApiRpcRemote extends RpcRemote_1.RpcRemote {
|
|
8
|
-
async externalFetchData(key) {
|
|
9
|
-
const request = {
|
|
10
|
-
key: (0, identifiers_1.toDhtAddressRaw)(key)
|
|
11
|
-
};
|
|
12
|
-
const options = this.formDhtRpcOptions({
|
|
13
|
-
// TODO use options option or named constant?
|
|
14
|
-
timeout: DEFAULT_TIMEOUT
|
|
15
|
-
});
|
|
16
|
-
try {
|
|
17
|
-
const data = await this.getClient().externalFetchData(request, options);
|
|
18
|
-
return data.entries;
|
|
19
|
-
}
|
|
20
|
-
catch {
|
|
21
|
-
return [];
|
|
22
|
-
}
|
|
23
|
-
}
|
|
24
|
-
async storeData(key, data) {
|
|
25
|
-
const request = {
|
|
26
|
-
key: (0, identifiers_1.toDhtAddressRaw)(key),
|
|
27
|
-
data
|
|
28
|
-
};
|
|
29
|
-
const options = this.formDhtRpcOptions({
|
|
30
|
-
// TODO use options option or named constant?
|
|
31
|
-
timeout: DEFAULT_TIMEOUT
|
|
32
|
-
});
|
|
33
|
-
try {
|
|
34
|
-
const response = await this.getClient().externalStoreData(request, options);
|
|
35
|
-
return response.storers;
|
|
36
|
-
}
|
|
37
|
-
catch {
|
|
38
|
-
return [];
|
|
39
|
-
}
|
|
40
|
-
}
|
|
41
|
-
async externalFindClosestNode(key) {
|
|
42
|
-
const request = {
|
|
43
|
-
nodeId: (0, identifiers_1.toDhtAddressRaw)(key)
|
|
44
|
-
};
|
|
45
|
-
const options = this.formDhtRpcOptions({
|
|
46
|
-
timeout: DEFAULT_TIMEOUT
|
|
47
|
-
});
|
|
48
|
-
try {
|
|
49
|
-
const response = await this.getClient().externalFindClosestNodes(request, options);
|
|
50
|
-
return response.closestNodes;
|
|
51
|
-
}
|
|
52
|
-
catch {
|
|
53
|
-
return [];
|
|
54
|
-
}
|
|
55
|
-
}
|
|
56
|
-
}
|
|
57
|
-
exports.ExternalApiRpcRemote = ExternalApiRpcRemote;
|
|
58
|
-
//# sourceMappingURL=ExternalApiRpcRemote.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ExternalApiRpcRemote.js","sourceRoot":"","sources":["../../../src/dht/ExternalApiRpcRemote.ts"],"names":[],"mappings":";;;AAAA,gDAA4D;AAU5D,mDAA+C;AAE/C,MAAM,eAAe,GAAG,KAAK,CAAA;AAC7B,MAAa,oBAAqB,SAAQ,qBAA+B;IAErE,KAAK,CAAC,iBAAiB,CAAC,GAAe;QACnC,MAAM,OAAO,GAA6B;YACtC,GAAG,EAAE,IAAA,6BAAe,EAAC,GAAG,CAAC;SAC5B,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACnC,6CAA6C;YAC7C,OAAO,EAAE,eAAe;SAC3B,CAAC,CAAA;QACF,IAAI,CAAC;YACD,MAAM,IAAI,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;YACvE,OAAO,IAAI,CAAC,OAAO,CAAA;QACvB,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,EAAE,CAAA;QACb,CAAC;IACL,CAAC;IAED,KAAK,CAAC,SAAS,CAAC,GAAe,EAAE,IAAS;QACtC,MAAM,OAAO,GAA6B;YACtC,GAAG,EAAE,IAAA,6BAAe,EAAC,GAAG,CAAC;YACzB,IAAI;SACP,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACnC,6CAA6C;YAC7C,OAAO,EAAE,eAAe;SAC3B,CAAC,CAAA;QACF,IAAI,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;YAC3E,OAAO,QAAQ,CAAC,OAAO,CAAA;QAC3B,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,EAAE,CAAA;QACb,CAAC;IACL,CAAC;IAED,KAAK,CAAC,uBAAuB,CAAC,GAAe;QACzC,MAAM,OAAO,GAAoC;YAC7C,MAAM,EAAE,IAAA,6BAAe,EAAC,GAAG,CAAC;SAC/B,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACnC,OAAO,EAAE,eAAe;SAC3B,CAAC,CAAA;QACF,IAAI,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,wBAAwB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;YAClF,OAAO,QAAQ,CAAC,YAAY,CAAA;QAChC,CAAC;QAAC,MAAM,CAAC;YACL,OAAO,EAAE,CAAA;QACb,CAAC;IACL,CAAC;CACJ;AAjDD,oDAiDC"}
|
|
@@ -1,63 +0,0 @@
|
|
|
1
|
-
import EventEmitter from 'eventemitter3';
|
|
2
|
-
import { LockID } from '../connection/ConnectionLockStates';
|
|
3
|
-
import { ConnectionLocker } from '../connection/ConnectionManager';
|
|
4
|
-
import { DhtAddress, DhtAddressRaw } from '../identifiers';
|
|
5
|
-
import { PeerDescriptor } from '../../generated/packages/dht/protos/DhtRpc';
|
|
6
|
-
import { DhtNodeRpcRemote } from './DhtNodeRpcRemote';
|
|
7
|
-
import { RandomContactList } from './contact/RandomContactList';
|
|
8
|
-
import { RingContactList } from './contact/RingContactList';
|
|
9
|
-
import { ReadonlySortedContactList } from './contact/SortedContactList';
|
|
10
|
-
import { RingIdRaw } from './contact/ringIdentifiers';
|
|
11
|
-
interface PeerManagerOptions {
|
|
12
|
-
numberOfNodesPerKBucket: number;
|
|
13
|
-
maxContactCount: number;
|
|
14
|
-
localNodeId: DhtAddress;
|
|
15
|
-
localPeerDescriptor: PeerDescriptor;
|
|
16
|
-
connectionLocker?: ConnectionLocker;
|
|
17
|
-
neighborPingLimit?: number;
|
|
18
|
-
lockId: LockID;
|
|
19
|
-
createDhtNodeRpcRemote: (peerDescriptor: PeerDescriptor) => DhtNodeRpcRemote;
|
|
20
|
-
hasConnection: (nodeId: DhtAddress) => boolean;
|
|
21
|
-
}
|
|
22
|
-
export interface PeerManagerEvents {
|
|
23
|
-
nearbyContactAdded: (peerDescriptor: PeerDescriptor) => void;
|
|
24
|
-
nearbyContactRemoved: (peerDescriptor: PeerDescriptor) => void;
|
|
25
|
-
randomContactAdded: (peerDescriptor: PeerDescriptor) => void;
|
|
26
|
-
randomContactRemoved: (peerDescriptor: PeerDescriptor) => void;
|
|
27
|
-
ringContactAdded: (peerDescriptor: PeerDescriptor) => void;
|
|
28
|
-
ringContactRemoved: (peerDescriptor: PeerDescriptor) => void;
|
|
29
|
-
kBucketEmpty: () => void;
|
|
30
|
-
}
|
|
31
|
-
export declare const getDistance: (nodeIdOrDataKeyRaw1: DhtAddressRaw, nodeIdOrDataKeyRaw2: DhtAddressRaw) => number;
|
|
32
|
-
export declare class PeerManager extends EventEmitter<PeerManagerEvents> {
|
|
33
|
-
private neighbors;
|
|
34
|
-
private nearbyContacts;
|
|
35
|
-
private activeContacts;
|
|
36
|
-
private ringContacts;
|
|
37
|
-
private randomContacts;
|
|
38
|
-
private stopped;
|
|
39
|
-
private readonly options;
|
|
40
|
-
constructor(options: PeerManagerOptions);
|
|
41
|
-
private onKBucketPing;
|
|
42
|
-
private onKBucketRemoved;
|
|
43
|
-
private onKBucketAdded;
|
|
44
|
-
private addNearbyContactToNeighbors;
|
|
45
|
-
private getNearbyActiveContactNotInNeighbors;
|
|
46
|
-
removeContact(nodeId: DhtAddress): void;
|
|
47
|
-
removeNeighbor(nodeId: DhtAddress): void;
|
|
48
|
-
pruneOfflineNodes(nodes: DhtNodeRpcRemote[]): Promise<void>;
|
|
49
|
-
stop(): void;
|
|
50
|
-
getNearbyContacts(): ReadonlySortedContactList<DhtNodeRpcRemote>;
|
|
51
|
-
getClosestRingContactsTo(ringIdRaw: RingIdRaw, limit?: number, excludedIds?: Set<DhtAddress>): {
|
|
52
|
-
left: DhtNodeRpcRemote[];
|
|
53
|
-
right: DhtNodeRpcRemote[];
|
|
54
|
-
};
|
|
55
|
-
getRandomContacts(): RandomContactList<DhtNodeRpcRemote>;
|
|
56
|
-
getRingContacts(): RingContactList<DhtNodeRpcRemote>;
|
|
57
|
-
getNearbyContactCount(excludedNodeIds?: Set<DhtAddress>): number;
|
|
58
|
-
getNeighborCount(): number;
|
|
59
|
-
getNeighbors(): readonly DhtNodeRpcRemote[];
|
|
60
|
-
setContactActive(nodeId: DhtAddress): void;
|
|
61
|
-
addContact(peerDescriptor: PeerDescriptor): void;
|
|
62
|
-
}
|
|
63
|
-
export {};
|
|
@@ -1,251 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.PeerManager = exports.getDistance = void 0;
|
|
7
|
-
const utils_1 = require("@streamr/utils");
|
|
8
|
-
const eventemitter3_1 = __importDefault(require("eventemitter3"));
|
|
9
|
-
const k_bucket_1 = __importDefault(require("k-bucket"));
|
|
10
|
-
const identifiers_1 = require("../identifiers");
|
|
11
|
-
const RandomContactList_1 = require("./contact/RandomContactList");
|
|
12
|
-
const RingContactList_1 = require("./contact/RingContactList");
|
|
13
|
-
const SortedContactList_1 = require("./contact/SortedContactList");
|
|
14
|
-
const ringIdentifiers_1 = require("./contact/ringIdentifiers");
|
|
15
|
-
const logger = new utils_1.Logger(module);
|
|
16
|
-
// Returns all offline nodes, sets contacts as active if they are online
|
|
17
|
-
const pingNodes = async (nodes, activeContacts) => {
|
|
18
|
-
const offlineNeighbors = [];
|
|
19
|
-
await Promise.allSettled(nodes.map(async (contact) => {
|
|
20
|
-
const isOnline = await contact.ping();
|
|
21
|
-
if (!isOnline) {
|
|
22
|
-
activeContacts.delete(contact.getNodeId());
|
|
23
|
-
offlineNeighbors.push(contact.getPeerDescriptor());
|
|
24
|
-
}
|
|
25
|
-
else {
|
|
26
|
-
activeContacts.add(contact.getNodeId());
|
|
27
|
-
}
|
|
28
|
-
}));
|
|
29
|
-
return offlineNeighbors;
|
|
30
|
-
};
|
|
31
|
-
const getDistance = (nodeIdOrDataKeyRaw1, nodeIdOrDataKeyRaw2) => {
|
|
32
|
-
return k_bucket_1.default.distance(nodeIdOrDataKeyRaw1, nodeIdOrDataKeyRaw2);
|
|
33
|
-
};
|
|
34
|
-
exports.getDistance = getDistance;
|
|
35
|
-
class PeerManager extends eventemitter3_1.default {
|
|
36
|
-
// Glossary:
|
|
37
|
-
// * 'neighbors' are the nodes that are our neighbors according to
|
|
38
|
-
// the protocol of the layer we are in
|
|
39
|
-
// * 'connections' are the nodes that are connected to this node on Layer0
|
|
40
|
-
// * 'contacts' are all non-unresponsive nodes that we know about
|
|
41
|
-
neighbors;
|
|
42
|
-
nearbyContacts;
|
|
43
|
-
activeContacts;
|
|
44
|
-
ringContacts;
|
|
45
|
-
randomContacts;
|
|
46
|
-
stopped = false;
|
|
47
|
-
options;
|
|
48
|
-
constructor(options) {
|
|
49
|
-
super();
|
|
50
|
-
this.options = options;
|
|
51
|
-
this.neighbors = new k_bucket_1.default({
|
|
52
|
-
localNodeId: (0, identifiers_1.toDhtAddressRaw)(this.options.localNodeId),
|
|
53
|
-
numberOfNodesPerKBucket: this.options.numberOfNodesPerKBucket,
|
|
54
|
-
numberOfNodesToPing: this.options.numberOfNodesPerKBucket
|
|
55
|
-
});
|
|
56
|
-
this.ringContacts = new RingContactList_1.RingContactList((0, ringIdentifiers_1.getRingIdRawFromPeerDescriptor)(this.options.localPeerDescriptor));
|
|
57
|
-
this.ringContacts.on('contactAdded', (contact) => {
|
|
58
|
-
this.emit('ringContactAdded', contact.getPeerDescriptor());
|
|
59
|
-
});
|
|
60
|
-
this.ringContacts.on('contactRemoved', (contact) => {
|
|
61
|
-
this.emit('ringContactRemoved', contact.getPeerDescriptor());
|
|
62
|
-
});
|
|
63
|
-
this.neighbors.on('ping', (oldContacts, newContact) => this.onKBucketPing(oldContacts, newContact));
|
|
64
|
-
this.neighbors.on('removed', (contact) => this.onKBucketRemoved((0, identifiers_1.toNodeId)(contact.getPeerDescriptor())));
|
|
65
|
-
this.neighbors.on('added', (contact) => this.onKBucketAdded(contact));
|
|
66
|
-
this.neighbors.on('updated', () => {
|
|
67
|
-
// TODO: Update contact info to the connection manager and reconnect
|
|
68
|
-
});
|
|
69
|
-
this.nearbyContacts = new SortedContactList_1.SortedContactList({
|
|
70
|
-
referenceId: this.options.localNodeId,
|
|
71
|
-
maxSize: this.options.maxContactCount,
|
|
72
|
-
allowToContainReferenceId: false
|
|
73
|
-
});
|
|
74
|
-
this.nearbyContacts.on('contactRemoved', (contact) => {
|
|
75
|
-
if (this.stopped) {
|
|
76
|
-
return;
|
|
77
|
-
}
|
|
78
|
-
this.emit('nearbyContactRemoved', contact.getPeerDescriptor());
|
|
79
|
-
this.randomContacts.addContact(this.options.createDhtNodeRpcRemote(contact.getPeerDescriptor()));
|
|
80
|
-
});
|
|
81
|
-
this.nearbyContacts.on('contactAdded', (contact) => this.emit('nearbyContactAdded', contact.getPeerDescriptor()));
|
|
82
|
-
this.activeContacts = new Set();
|
|
83
|
-
this.randomContacts = new RandomContactList_1.RandomContactList(this.options.localNodeId, this.options.maxContactCount);
|
|
84
|
-
this.randomContacts.on('contactRemoved', (removedContact) => this.emit('randomContactRemoved', removedContact.getPeerDescriptor()));
|
|
85
|
-
this.randomContacts.on('contactAdded', (contactAdded) => this.emit('randomContactAdded', contactAdded.getPeerDescriptor()));
|
|
86
|
-
}
|
|
87
|
-
onKBucketPing(oldContacts, newContact) {
|
|
88
|
-
if (this.stopped) {
|
|
89
|
-
return;
|
|
90
|
-
}
|
|
91
|
-
const sortingList = new SortedContactList_1.SortedContactList({
|
|
92
|
-
referenceId: this.options.localNodeId,
|
|
93
|
-
allowToContainReferenceId: false
|
|
94
|
-
});
|
|
95
|
-
sortingList.addContacts(oldContacts);
|
|
96
|
-
const removableNodeId = sortingList.getFurthestContacts(1)[0].getNodeId();
|
|
97
|
-
this.options.connectionLocker?.weakUnlockConnection(removableNodeId, this.options.lockId);
|
|
98
|
-
this.neighbors.remove((0, identifiers_1.toDhtAddressRaw)(removableNodeId));
|
|
99
|
-
this.neighbors.add(newContact);
|
|
100
|
-
}
|
|
101
|
-
onKBucketRemoved(nodeId) {
|
|
102
|
-
if (this.stopped) {
|
|
103
|
-
return;
|
|
104
|
-
}
|
|
105
|
-
this.options.connectionLocker?.weakUnlockConnection(nodeId, this.options.lockId);
|
|
106
|
-
logger.trace(`Removed contact ${nodeId}`);
|
|
107
|
-
if (this.neighbors.count() === 0) {
|
|
108
|
-
this.emit('kBucketEmpty');
|
|
109
|
-
}
|
|
110
|
-
}
|
|
111
|
-
onKBucketAdded(contact) {
|
|
112
|
-
if (this.stopped) {
|
|
113
|
-
return;
|
|
114
|
-
}
|
|
115
|
-
if (contact.getNodeId() !== this.options.localNodeId) {
|
|
116
|
-
const peerDescriptor = contact.getPeerDescriptor();
|
|
117
|
-
const nodeId = (0, identifiers_1.toNodeId)(peerDescriptor);
|
|
118
|
-
// Important to lock here, before the ping result is known
|
|
119
|
-
this.options.connectionLocker?.weakLockConnection(nodeId, this.options.lockId);
|
|
120
|
-
if (this.options.hasConnection(contact.getNodeId())
|
|
121
|
-
|| (this.options.neighborPingLimit !== undefined && this.neighbors.count() > this.options.neighborPingLimit)) {
|
|
122
|
-
logger.trace(`Added new contact ${nodeId}`);
|
|
123
|
-
}
|
|
124
|
-
else { // open connection by pinging
|
|
125
|
-
logger.trace('starting ping ' + nodeId);
|
|
126
|
-
contact.ping().then((result) => {
|
|
127
|
-
if (result) {
|
|
128
|
-
logger.trace(`Added new contact ${nodeId}`);
|
|
129
|
-
}
|
|
130
|
-
else {
|
|
131
|
-
logger.trace('ping failed ' + nodeId);
|
|
132
|
-
this.options.connectionLocker?.weakUnlockConnection(nodeId, this.options.lockId);
|
|
133
|
-
this.removeContact(nodeId);
|
|
134
|
-
this.addNearbyContactToNeighbors();
|
|
135
|
-
}
|
|
136
|
-
}).catch((_e) => {
|
|
137
|
-
this.options.connectionLocker?.weakUnlockConnection(nodeId, this.options.lockId);
|
|
138
|
-
this.removeContact(nodeId);
|
|
139
|
-
this.addNearbyContactToNeighbors();
|
|
140
|
-
});
|
|
141
|
-
}
|
|
142
|
-
}
|
|
143
|
-
}
|
|
144
|
-
addNearbyContactToNeighbors() {
|
|
145
|
-
if (this.stopped) {
|
|
146
|
-
return;
|
|
147
|
-
}
|
|
148
|
-
const closest = this.getNearbyActiveContactNotInNeighbors();
|
|
149
|
-
if (closest) {
|
|
150
|
-
this.addContact(closest.getPeerDescriptor());
|
|
151
|
-
}
|
|
152
|
-
}
|
|
153
|
-
getNearbyActiveContactNotInNeighbors() {
|
|
154
|
-
for (const contactId of this.nearbyContacts.getContactIds()) {
|
|
155
|
-
if (!this.neighbors.get((0, identifiers_1.toDhtAddressRaw)(contactId)) && this.activeContacts.has(contactId)) {
|
|
156
|
-
return this.nearbyContacts.getContact(contactId);
|
|
157
|
-
}
|
|
158
|
-
}
|
|
159
|
-
return undefined;
|
|
160
|
-
}
|
|
161
|
-
removeContact(nodeId) {
|
|
162
|
-
if (this.stopped) {
|
|
163
|
-
return;
|
|
164
|
-
}
|
|
165
|
-
logger.trace(`Removing contact ${nodeId}`);
|
|
166
|
-
this.ringContacts.removeContact(this.nearbyContacts.getContact(nodeId));
|
|
167
|
-
this.neighbors.remove((0, identifiers_1.toDhtAddressRaw)(nodeId));
|
|
168
|
-
this.nearbyContacts.removeContact(nodeId);
|
|
169
|
-
this.activeContacts.delete(nodeId);
|
|
170
|
-
this.randomContacts.removeContact(nodeId);
|
|
171
|
-
}
|
|
172
|
-
removeNeighbor(nodeId) {
|
|
173
|
-
this.neighbors.remove((0, identifiers_1.toDhtAddressRaw)(nodeId));
|
|
174
|
-
}
|
|
175
|
-
async pruneOfflineNodes(nodes) {
|
|
176
|
-
logger.trace('Pruning offline nodes', { nodes: nodes.length });
|
|
177
|
-
const offlineNeighbors = await pingNodes(nodes, this.activeContacts);
|
|
178
|
-
offlineNeighbors.forEach((offlineNeighbor) => {
|
|
179
|
-
logger.trace('Removing offline node', { node: (0, identifiers_1.toNodeId)(offlineNeighbor) });
|
|
180
|
-
this.removeContact((0, identifiers_1.toNodeId)(offlineNeighbor));
|
|
181
|
-
});
|
|
182
|
-
}
|
|
183
|
-
stop() {
|
|
184
|
-
this.stopped = true;
|
|
185
|
-
this.neighbors.toArray().forEach((rpcRemote) => {
|
|
186
|
-
rpcRemote.leaveNotice();
|
|
187
|
-
this.neighbors.remove(rpcRemote.id);
|
|
188
|
-
});
|
|
189
|
-
this.neighbors.removeAllListeners();
|
|
190
|
-
this.ringContacts.getAllContacts().forEach((rpcRemote) => {
|
|
191
|
-
rpcRemote.leaveNotice();
|
|
192
|
-
this.ringContacts.removeContact(rpcRemote);
|
|
193
|
-
});
|
|
194
|
-
this.nearbyContacts.stop();
|
|
195
|
-
this.randomContacts.stop();
|
|
196
|
-
}
|
|
197
|
-
getNearbyContacts() {
|
|
198
|
-
return this.nearbyContacts;
|
|
199
|
-
}
|
|
200
|
-
getClosestRingContactsTo(ringIdRaw, limit, excludedIds) {
|
|
201
|
-
const closest = new RingContactList_1.RingContactList(ringIdRaw, excludedIds);
|
|
202
|
-
this.ringContacts.getAllContacts().map((contact) => closest.addContact(contact));
|
|
203
|
-
// TODO use options option or named constant?
|
|
204
|
-
return closest.getClosestContacts(limit ?? 8);
|
|
205
|
-
}
|
|
206
|
-
getRandomContacts() {
|
|
207
|
-
return this.randomContacts;
|
|
208
|
-
}
|
|
209
|
-
getRingContacts() {
|
|
210
|
-
return this.ringContacts;
|
|
211
|
-
}
|
|
212
|
-
getNearbyContactCount(excludedNodeIds) {
|
|
213
|
-
return this.nearbyContacts.getSize(excludedNodeIds);
|
|
214
|
-
}
|
|
215
|
-
getNeighborCount() {
|
|
216
|
-
return this.neighbors.count();
|
|
217
|
-
}
|
|
218
|
-
getNeighbors() {
|
|
219
|
-
return this.neighbors.toArray();
|
|
220
|
-
}
|
|
221
|
-
setContactActive(nodeId) {
|
|
222
|
-
this.activeContacts.add(nodeId);
|
|
223
|
-
}
|
|
224
|
-
addContact(peerDescriptor) {
|
|
225
|
-
if (this.stopped) {
|
|
226
|
-
return;
|
|
227
|
-
}
|
|
228
|
-
const nodeId = (0, identifiers_1.toNodeId)(peerDescriptor);
|
|
229
|
-
if (nodeId !== this.options.localNodeId) {
|
|
230
|
-
logger.trace(`Adding new contact ${nodeId}`);
|
|
231
|
-
const remote = this.options.createDhtNodeRpcRemote(peerDescriptor);
|
|
232
|
-
const isInNeighbors = (this.neighbors.get(peerDescriptor.nodeId) !== null);
|
|
233
|
-
const isInNearbyContacts = (this.nearbyContacts.getContact(nodeId) !== undefined);
|
|
234
|
-
const isInRingContacts = this.ringContacts.getContact(peerDescriptor) !== undefined;
|
|
235
|
-
if (isInNeighbors || isInNearbyContacts) {
|
|
236
|
-
this.randomContacts.addContact(remote);
|
|
237
|
-
}
|
|
238
|
-
if (!isInNeighbors) {
|
|
239
|
-
this.neighbors.add(remote);
|
|
240
|
-
}
|
|
241
|
-
if (!isInNearbyContacts) {
|
|
242
|
-
this.nearbyContacts.addContact(remote);
|
|
243
|
-
}
|
|
244
|
-
if (!isInRingContacts) {
|
|
245
|
-
this.ringContacts.addContact(remote);
|
|
246
|
-
}
|
|
247
|
-
}
|
|
248
|
-
}
|
|
249
|
-
}
|
|
250
|
-
exports.PeerManager = PeerManager;
|
|
251
|
-
//# sourceMappingURL=PeerManager.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"PeerManager.js","sourceRoot":"","sources":["../../../src/dht/PeerManager.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,8 +0,0 @@
|
|
|
1
|
-
import { PeerDescriptor } from '../../../generated/packages/dht/protos/DhtRpc';
|
|
2
|
-
import { DhtAddress } from '../../identifiers';
|
|
3
|
-
export declare class Contact {
|
|
4
|
-
private peerDescriptor;
|
|
5
|
-
constructor(peerDescriptor: PeerDescriptor);
|
|
6
|
-
getPeerDescriptor(): PeerDescriptor;
|
|
7
|
-
getNodeId(): DhtAddress;
|
|
8
|
-
}
|
|
@@ -1,18 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.Contact = void 0;
|
|
4
|
-
const identifiers_1 = require("../../identifiers");
|
|
5
|
-
class Contact {
|
|
6
|
-
peerDescriptor;
|
|
7
|
-
constructor(peerDescriptor) {
|
|
8
|
-
this.peerDescriptor = peerDescriptor;
|
|
9
|
-
}
|
|
10
|
-
getPeerDescriptor() {
|
|
11
|
-
return this.peerDescriptor;
|
|
12
|
-
}
|
|
13
|
-
getNodeId() {
|
|
14
|
-
return (0, identifiers_1.toNodeId)(this.peerDescriptor);
|
|
15
|
-
}
|
|
16
|
-
}
|
|
17
|
-
exports.Contact = Contact;
|
|
18
|
-
//# sourceMappingURL=Contact.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"Contact.js","sourceRoot":"","sources":["../../../../src/dht/contact/Contact.ts"],"names":[],"mappings":";;;AACA,mDAAwD;AAExD,MAAa,OAAO;IAER,cAAc,CAAgB;IAEtC,YAAY,cAA8B;QACtC,IAAI,CAAC,cAAc,GAAG,cAAc,CAAA;IACxC,CAAC;IAEM,iBAAiB;QACpB,OAAO,IAAI,CAAC,cAAc,CAAA;IAC9B,CAAC;IAEM,SAAS;QACZ,OAAO,IAAA,sBAAQ,EAAC,IAAI,CAAC,cAAc,CAAC,CAAA;IACxC,CAAC;CACJ;AAfD,0BAeC"}
|
|
@@ -1,19 +0,0 @@
|
|
|
1
|
-
import EventEmitter from 'eventemitter3';
|
|
2
|
-
import { DhtAddress } from '../../identifiers';
|
|
3
|
-
export interface Events<C> {
|
|
4
|
-
contactRemoved: (removedContact: C) => void;
|
|
5
|
-
contactAdded: (contactAdded: C) => void;
|
|
6
|
-
}
|
|
7
|
-
export declare class ContactList<C extends {
|
|
8
|
-
getNodeId: () => DhtAddress;
|
|
9
|
-
}> extends EventEmitter<Events<C>> {
|
|
10
|
-
protected contactsById: Map<DhtAddress, C>;
|
|
11
|
-
protected contactIds: DhtAddress[];
|
|
12
|
-
protected localNodeId: DhtAddress;
|
|
13
|
-
protected maxSize: number;
|
|
14
|
-
constructor(localNodeId: DhtAddress, maxSize: number);
|
|
15
|
-
getContact(id: DhtAddress): C | undefined;
|
|
16
|
-
getSize(): number;
|
|
17
|
-
clear(): void;
|
|
18
|
-
stop(): void;
|
|
19
|
-
}
|
|
@@ -1,35 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|
3
|
-
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|
4
|
-
};
|
|
5
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
6
|
-
exports.ContactList = void 0;
|
|
7
|
-
const eventemitter3_1 = __importDefault(require("eventemitter3"));
|
|
8
|
-
class ContactList extends eventemitter3_1.default {
|
|
9
|
-
contactsById = new Map();
|
|
10
|
-
// TODO move this to SortedContactList
|
|
11
|
-
contactIds = [];
|
|
12
|
-
localNodeId;
|
|
13
|
-
maxSize;
|
|
14
|
-
constructor(localNodeId, maxSize) {
|
|
15
|
-
super();
|
|
16
|
-
this.localNodeId = localNodeId;
|
|
17
|
-
this.maxSize = maxSize;
|
|
18
|
-
}
|
|
19
|
-
getContact(id) {
|
|
20
|
-
return this.contactsById.get(id);
|
|
21
|
-
}
|
|
22
|
-
getSize() {
|
|
23
|
-
return this.contactIds.length;
|
|
24
|
-
}
|
|
25
|
-
clear() {
|
|
26
|
-
this.contactsById.clear();
|
|
27
|
-
this.contactIds = [];
|
|
28
|
-
}
|
|
29
|
-
stop() {
|
|
30
|
-
this.removeAllListeners();
|
|
31
|
-
this.clear();
|
|
32
|
-
}
|
|
33
|
-
}
|
|
34
|
-
exports.ContactList = ContactList;
|
|
35
|
-
//# sourceMappingURL=ContactList.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ContactList.js","sourceRoot":"","sources":["../../../../src/dht/contact/ContactList.ts"],"names":[],"mappings":";;;;;;AAAA,kEAAwC;AAQxC,MAAa,WAAuD,SAAQ,uBAAuB;IAErF,YAAY,GAAuB,IAAI,GAAG,EAAE,CAAA;IACtD,sCAAsC;IAC5B,UAAU,GAAiB,EAAE,CAAA;IAC7B,WAAW,CAAY;IACvB,OAAO,CAAQ;IAEzB,YACI,WAAuB,EACvB,OAAe;QAEf,KAAK,EAAE,CAAA;QACP,IAAI,CAAC,WAAW,GAAG,WAAW,CAAA;QAC9B,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IAC1B,CAAC;IAEM,UAAU,CAAC,EAAc;QAC5B,OAAO,IAAI,CAAC,YAAY,CAAC,GAAG,CAAC,EAAE,CAAC,CAAA;IACpC,CAAC;IAEM,OAAO;QACV,OAAO,IAAI,CAAC,UAAU,CAAC,MAAM,CAAA;IACjC,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,CAAA;QACzB,IAAI,CAAC,UAAU,GAAG,EAAE,CAAA;IACxB,CAAC;IAEM,IAAI;QACP,IAAI,CAAC,kBAAkB,EAAE,CAAA;QACzB,IAAI,CAAC,KAAK,EAAE,CAAA;IAChB,CAAC;CACJ;AAlCD,kCAkCC"}
|