@streamr/trackerless-network 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.cjs +4489 -0
- package/dist/exports.cjs.map +1 -0
- package/dist/exports.d.ts +1391 -0
- package/dist/exports.js +4477 -0
- package/dist/exports.js.map +1 -0
- package/package.json +25 -18
- 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/generated/packages/trackerless-network/protos/NetworkRpc.client.d.ts +0 -237
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.client.js +0 -190
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.client.js.map +0 -1
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.d.ts +0 -687
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.js +0 -479
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.js.map +0 -1
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.server.d.ts +0 -102
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.server.js +0 -3
- package/dist/generated/packages/trackerless-network/protos/NetworkRpc.server.js.map +0 -1
- package/dist/package.json +0 -56
- package/dist/src/ContentDeliveryManager.d.ts +0 -82
- package/dist/src/ContentDeliveryManager.js +0 -325
- package/dist/src/ContentDeliveryManager.js.map +0 -1
- package/dist/src/NetworkNode.d.ts +0 -44
- package/dist/src/NetworkNode.js +0 -98
- package/dist/src/NetworkNode.js.map +0 -1
- package/dist/src/NetworkStack.d.ts +0 -36
- package/dist/src/NetworkStack.js +0 -165
- package/dist/src/NetworkStack.js.map +0 -1
- package/dist/src/NodeInfoClient.d.ts +0 -9
- package/dist/src/NodeInfoClient.js +0 -21
- package/dist/src/NodeInfoClient.js.map +0 -1
- package/dist/src/NodeInfoRpcLocal.d.ts +0 -12
- package/dist/src/NodeInfoRpcLocal.js +0 -22
- package/dist/src/NodeInfoRpcLocal.js.map +0 -1
- package/dist/src/NodeInfoRpcRemote.d.ts +0 -6
- package/dist/src/NodeInfoRpcRemote.js +0 -11
- package/dist/src/NodeInfoRpcRemote.js.map +0 -1
- package/dist/src/StreamPartNetworkSplitAvoidance.d.ts +0 -18
- package/dist/src/StreamPartNetworkSplitAvoidance.js +0 -74
- package/dist/src/StreamPartNetworkSplitAvoidance.js.map +0 -1
- package/dist/src/StreamPartReconnect.d.ts +0 -11
- package/dist/src/StreamPartReconnect.js +0 -37
- package/dist/src/StreamPartReconnect.js.map +0 -1
- package/dist/src/content-delivery-layer/ContentDeliveryLayerNode.d.ts +0 -78
- package/dist/src/content-delivery-layer/ContentDeliveryLayerNode.js +0 -240
- package/dist/src/content-delivery-layer/ContentDeliveryLayerNode.js.map +0 -1
- package/dist/src/content-delivery-layer/ContentDeliveryRpcLocal.d.ts +0 -23
- package/dist/src/content-delivery-layer/ContentDeliveryRpcLocal.js +0 -40
- package/dist/src/content-delivery-layer/ContentDeliveryRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/ContentDeliveryRpcRemote.d.ts +0 -11
- package/dist/src/content-delivery-layer/ContentDeliveryRpcRemote.js +0 -38
- package/dist/src/content-delivery-layer/ContentDeliveryRpcRemote.js.map +0 -1
- package/dist/src/content-delivery-layer/DuplicateMessageDetector.d.ts +0 -55
- package/dist/src/content-delivery-layer/DuplicateMessageDetector.js +0 -159
- package/dist/src/content-delivery-layer/DuplicateMessageDetector.js.map +0 -1
- package/dist/src/content-delivery-layer/NodeList.d.ts +0 -26
- package/dist/src/content-delivery-layer/NodeList.js +0 -93
- package/dist/src/content-delivery-layer/NodeList.js.map +0 -1
- package/dist/src/content-delivery-layer/createContentDeliveryLayerNode.d.ts +0 -14
- package/dist/src/content-delivery-layer/createContentDeliveryLayerNode.js +0 -129
- package/dist/src/content-delivery-layer/createContentDeliveryLayerNode.js.map +0 -1
- package/dist/src/content-delivery-layer/formStreamPartDeliveryServiceId.d.ts +0 -3
- package/dist/src/content-delivery-layer/formStreamPartDeliveryServiceId.js +0 -9
- package/dist/src/content-delivery-layer/formStreamPartDeliveryServiceId.js.map +0 -1
- package/dist/src/content-delivery-layer/inspection/InspectSession.d.ts +0 -19
- package/dist/src/content-delivery-layer/inspection/InspectSession.js +0 -43
- package/dist/src/content-delivery-layer/inspection/InspectSession.js.map +0 -1
- package/dist/src/content-delivery-layer/inspection/Inspector.d.ts +0 -30
- package/dist/src/content-delivery-layer/inspection/Inspector.js +0 -75
- package/dist/src/content-delivery-layer/inspection/Inspector.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcLocal.d.ts +0 -29
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcLocal.js +0 -106
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcRemote.d.ts +0 -14
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcRemote.js +0 -55
- package/dist/src/content-delivery-layer/neighbor-discovery/HandshakeRpcRemote.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/Handshaker.d.ts +0 -32
- package/dist/src/content-delivery-layer/neighbor-discovery/Handshaker.js +0 -149
- package/dist/src/content-delivery-layer/neighbor-discovery/Handshaker.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborFinder.d.ts +0 -22
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborFinder.js +0 -64
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborFinder.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateManager.d.ts +0 -27
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateManager.js +0 -47
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateManager.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcLocal.d.ts +0 -25
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcLocal.js +0 -52
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcRemote.d.ts +0 -11
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcRemote.js +0 -31
- package/dist/src/content-delivery-layer/neighbor-discovery/NeighborUpdateRpcRemote.js.map +0 -1
- package/dist/src/content-delivery-layer/plumtree/PausedNeighbors.d.ts +0 -12
- package/dist/src/content-delivery-layer/plumtree/PausedNeighbors.js +0 -50
- package/dist/src/content-delivery-layer/plumtree/PausedNeighbors.js.map +0 -1
- package/dist/src/content-delivery-layer/plumtree/PlumtreeManager.d.ts +0 -37
- package/dist/src/content-delivery-layer/plumtree/PlumtreeManager.js +0 -141
- package/dist/src/content-delivery-layer/plumtree/PlumtreeManager.js.map +0 -1
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcLocal.d.ts +0 -20
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcLocal.js +0 -37
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcRemote.d.ts +0 -8
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcRemote.js +0 -26
- package/dist/src/content-delivery-layer/plumtree/PlumtreeRpcRemote.js.map +0 -1
- package/dist/src/content-delivery-layer/propagation/FifoMapWithTTL.d.ts +0 -29
- package/dist/src/content-delivery-layer/propagation/FifoMapWithTTL.js +0 -93
- package/dist/src/content-delivery-layer/propagation/FifoMapWithTTL.js.map +0 -1
- package/dist/src/content-delivery-layer/propagation/Propagation.d.ts +0 -35
- package/dist/src/content-delivery-layer/propagation/Propagation.js +0 -68
- package/dist/src/content-delivery-layer/propagation/Propagation.js.map +0 -1
- package/dist/src/content-delivery-layer/propagation/PropagationTaskStore.d.ts +0 -22
- package/dist/src/content-delivery-layer/propagation/PropagationTaskStore.js +0 -33
- package/dist/src/content-delivery-layer/propagation/PropagationTaskStore.js.map +0 -1
- package/dist/src/content-delivery-layer/proxy/ProxyClient.d.ts +0 -46
- package/dist/src/content-delivery-layer/proxy/ProxyClient.js +0 -214
- package/dist/src/content-delivery-layer/proxy/ProxyClient.js.map +0 -1
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcLocal.d.ts +0 -34
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcLocal.js +0 -72
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcRemote.d.ts +0 -7
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcRemote.js +0 -27
- package/dist/src/content-delivery-layer/proxy/ProxyConnectionRpcRemote.js.map +0 -1
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.d.ts +0 -26
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.js +0 -45
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.js.map +0 -1
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.d.ts +0 -6
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.js +0 -31
- package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.js.map +0 -1
- package/dist/src/control-layer/ControlLayerNode.d.ts +0 -16
- package/dist/src/control-layer/ControlLayerNode.js +0 -3
- package/dist/src/control-layer/ControlLayerNode.js.map +0 -1
- package/dist/src/control-layer/ExternalNetworkRpc.d.ts +0 -16
- package/dist/src/control-layer/ExternalNetworkRpc.js +0 -23
- package/dist/src/control-layer/ExternalNetworkRpc.js.map +0 -1
- package/dist/src/control-layer/PeerDescriptorStoreManager.d.ts +0 -28
- package/dist/src/control-layer/PeerDescriptorStoreManager.js +0 -78
- package/dist/src/control-layer/PeerDescriptorStoreManager.js.map +0 -1
- package/dist/src/discovery-layer/DiscoveryLayerNode.d.ts +0 -28
- package/dist/src/discovery-layer/DiscoveryLayerNode.js +0 -3
- package/dist/src/discovery-layer/DiscoveryLayerNode.js.map +0 -1
- package/dist/src/exports.d.ts +0 -6
- package/dist/src/exports.js +0 -24
- package/dist/src/exports.js.map +0 -1
- package/dist/src/types.d.ts +0 -6
- package/dist/src/types.js +0 -3
- package/dist/src/types.js.map +0 -1
- package/dist/src/utils.d.ts +0 -3
- package/dist/src/utils.js +0 -17
- package/dist/src/utils.js.map +0 -1
- package/dist/test/benchmark/first-message.d.ts +0 -1
- package/dist/test/benchmark/first-message.js +0 -139
- package/dist/test/benchmark/first-message.js.map +0 -1
- package/dist/test/utils/utils.d.ts +0 -15
- package/dist/test/utils/utils.js +0 -106
- package/dist/test/utils/utils.js.map +0 -1
|
@@ -1,214 +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.ProxyClient = exports.retry = void 0;
|
|
7
|
-
const dht_1 = require("@streamr/dht");
|
|
8
|
-
const utils_1 = require("@streamr/utils");
|
|
9
|
-
const eventemitter3_1 = require("eventemitter3");
|
|
10
|
-
const sampleSize_1 = __importDefault(require("lodash/sampleSize"));
|
|
11
|
-
const NetworkRpc_1 = require("../../../generated/packages/trackerless-network/protos/NetworkRpc");
|
|
12
|
-
const NetworkRpc_client_1 = require("../../../generated/packages/trackerless-network/protos/NetworkRpc.client");
|
|
13
|
-
const ContentDeliveryRpcLocal_1 = require("../ContentDeliveryRpcLocal");
|
|
14
|
-
const ContentDeliveryRpcRemote_1 = require("../ContentDeliveryRpcRemote");
|
|
15
|
-
const NodeList_1 = require("../NodeList");
|
|
16
|
-
const formStreamPartDeliveryServiceId_1 = require("../formStreamPartDeliveryServiceId");
|
|
17
|
-
const Propagation_1 = require("../propagation/Propagation");
|
|
18
|
-
const utils_2 = require("../../utils");
|
|
19
|
-
const ProxyConnectionRpcRemote_1 = require("./ProxyConnectionRpcRemote");
|
|
20
|
-
// TODO use options option or named constant?
|
|
21
|
-
const retry = async (task, description, abortSignal, delay = 10000) => {
|
|
22
|
-
while (true) {
|
|
23
|
-
try {
|
|
24
|
-
const result = await task();
|
|
25
|
-
return result;
|
|
26
|
-
}
|
|
27
|
-
catch {
|
|
28
|
-
logger.warn(`Failed ${description} (retrying after delay)`, {
|
|
29
|
-
delayInMs: delay
|
|
30
|
-
});
|
|
31
|
-
}
|
|
32
|
-
await (0, utils_1.wait)(delay, abortSignal);
|
|
33
|
-
}
|
|
34
|
-
};
|
|
35
|
-
exports.retry = retry;
|
|
36
|
-
const logger = new utils_1.Logger(module);
|
|
37
|
-
const SERVICE_ID = 'system/proxy-client';
|
|
38
|
-
class ProxyClient extends eventemitter3_1.EventEmitter {
|
|
39
|
-
rpcCommunicator;
|
|
40
|
-
contentDeliveryRpcLocal;
|
|
41
|
-
options;
|
|
42
|
-
duplicateDetectors = new Map();
|
|
43
|
-
definition;
|
|
44
|
-
connections = new Map();
|
|
45
|
-
propagation;
|
|
46
|
-
neighbors;
|
|
47
|
-
abortController;
|
|
48
|
-
constructor(options) {
|
|
49
|
-
super();
|
|
50
|
-
this.options = options;
|
|
51
|
-
this.rpcCommunicator = new dht_1.ListeningRpcCommunicator((0, formStreamPartDeliveryServiceId_1.formStreamPartContentDeliveryServiceId)(options.streamPartId), options.transport);
|
|
52
|
-
// TODO use options option or named constant?
|
|
53
|
-
this.neighbors = new NodeList_1.NodeList((0, dht_1.toNodeId)(this.options.localPeerDescriptor), 1000);
|
|
54
|
-
this.contentDeliveryRpcLocal = new ContentDeliveryRpcLocal_1.ContentDeliveryRpcLocal({
|
|
55
|
-
localPeerDescriptor: this.options.localPeerDescriptor,
|
|
56
|
-
streamPartId: this.options.streamPartId,
|
|
57
|
-
markAndCheckDuplicate: (msg, prev) => (0, utils_2.markAndCheckDuplicate)(this.duplicateDetectors, msg, prev),
|
|
58
|
-
broadcast: (message, previousNode) => this.broadcast(message, previousNode),
|
|
59
|
-
onLeaveNotice: (remoteNodeId) => {
|
|
60
|
-
const contact = this.neighbors.get(remoteNodeId);
|
|
61
|
-
if (contact) {
|
|
62
|
-
// TODO should we catch possible promise rejection?
|
|
63
|
-
setImmediate(() => this.onNodeDisconnected(contact.getPeerDescriptor()));
|
|
64
|
-
}
|
|
65
|
-
},
|
|
66
|
-
rpcCommunicator: this.rpcCommunicator,
|
|
67
|
-
markForInspection: () => { }
|
|
68
|
-
});
|
|
69
|
-
this.propagation = new Propagation_1.Propagation({
|
|
70
|
-
minPropagationTargets: options.minPropagationTargets,
|
|
71
|
-
maxMessages: options.maxPropagationBufferSize,
|
|
72
|
-
ttl: options.propagationBufferTtl,
|
|
73
|
-
sendToNeighbor: async (neighborId, msg) => {
|
|
74
|
-
const remote = this.neighbors.get(neighborId);
|
|
75
|
-
if (remote) {
|
|
76
|
-
await remote.sendStreamMessage(msg);
|
|
77
|
-
}
|
|
78
|
-
else {
|
|
79
|
-
throw new Error('Propagation target not found');
|
|
80
|
-
}
|
|
81
|
-
}
|
|
82
|
-
});
|
|
83
|
-
this.abortController = new AbortController();
|
|
84
|
-
}
|
|
85
|
-
registerDefaultServerMethods() {
|
|
86
|
-
this.rpcCommunicator.registerRpcNotification(NetworkRpc_1.StreamMessage, 'sendStreamMessage', (msg, context) => this.contentDeliveryRpcLocal.sendStreamMessage(msg, context));
|
|
87
|
-
this.rpcCommunicator.registerRpcNotification(NetworkRpc_1.LeaveStreamPartNotice, 'leaveStreamPartNotice', (req, context) => this.contentDeliveryRpcLocal.leaveStreamPartNotice(req, context));
|
|
88
|
-
}
|
|
89
|
-
async setProxies(nodes, direction, userId, connectionCount) {
|
|
90
|
-
logger.trace('Setting proxies', { streamPartId: this.options.streamPartId, peerDescriptors: nodes, direction, userId, connectionCount });
|
|
91
|
-
if (connectionCount !== undefined && connectionCount > nodes.length) {
|
|
92
|
-
throw new Error('Cannot set connectionCount above the size of the configured array of nodes');
|
|
93
|
-
}
|
|
94
|
-
const nodesIds = new Map();
|
|
95
|
-
nodes.forEach((peerDescriptor) => {
|
|
96
|
-
nodesIds.set((0, dht_1.toNodeId)(peerDescriptor), peerDescriptor);
|
|
97
|
-
});
|
|
98
|
-
this.definition = {
|
|
99
|
-
nodes: nodesIds,
|
|
100
|
-
userId,
|
|
101
|
-
direction,
|
|
102
|
-
connectionCount: connectionCount ?? nodes.length
|
|
103
|
-
};
|
|
104
|
-
await this.updateConnections();
|
|
105
|
-
}
|
|
106
|
-
async updateConnections() {
|
|
107
|
-
await Promise.all(this.getInvalidConnections().map(async (id) => {
|
|
108
|
-
await this.closeConnection(id);
|
|
109
|
-
}));
|
|
110
|
-
const connectionCountDiff = this.definition.connectionCount - this.connections.size;
|
|
111
|
-
if (connectionCountDiff > 0) {
|
|
112
|
-
await this.openRandomConnections(connectionCountDiff);
|
|
113
|
-
}
|
|
114
|
-
else if (connectionCountDiff < 0) {
|
|
115
|
-
await this.closeRandomConnections(-connectionCountDiff);
|
|
116
|
-
}
|
|
117
|
-
}
|
|
118
|
-
getInvalidConnections() {
|
|
119
|
-
return Array.from(this.connections.keys()).filter((id) => {
|
|
120
|
-
return !this.definition.nodes.has(id)
|
|
121
|
-
|| this.definition.direction !== this.connections.get(id).direction;
|
|
122
|
-
});
|
|
123
|
-
}
|
|
124
|
-
async openRandomConnections(connectionCount) {
|
|
125
|
-
const proxiesToAttempt = (0, sampleSize_1.default)(Array.from(this.definition.nodes.keys()).filter((id) => !this.connections.has(id)), connectionCount);
|
|
126
|
-
await Promise.all(proxiesToAttempt.map((id) => this.attemptConnection(id, this.definition.direction, this.definition.userId)));
|
|
127
|
-
}
|
|
128
|
-
async attemptConnection(nodeId, direction, userId) {
|
|
129
|
-
const peerDescriptor = this.definition.nodes.get(nodeId);
|
|
130
|
-
const rpcRemote = new ProxyConnectionRpcRemote_1.ProxyConnectionRpcRemote(this.options.localPeerDescriptor, peerDescriptor, this.rpcCommunicator, NetworkRpc_client_1.ProxyConnectionRpcClient);
|
|
131
|
-
const accepted = await rpcRemote.requestConnection(direction, userId);
|
|
132
|
-
if (accepted) {
|
|
133
|
-
this.options.connectionLocker.lockConnection(peerDescriptor, SERVICE_ID);
|
|
134
|
-
this.connections.set(nodeId, { peerDescriptor, direction });
|
|
135
|
-
const remote = new ContentDeliveryRpcRemote_1.ContentDeliveryRpcRemote(this.options.localPeerDescriptor, peerDescriptor, this.rpcCommunicator, NetworkRpc_client_1.ContentDeliveryRpcClient);
|
|
136
|
-
this.neighbors.add(remote);
|
|
137
|
-
this.propagation.onNeighborJoined(nodeId);
|
|
138
|
-
logger.info('Open proxy connection', {
|
|
139
|
-
nodeId,
|
|
140
|
-
streamPartId: this.options.streamPartId
|
|
141
|
-
});
|
|
142
|
-
}
|
|
143
|
-
else {
|
|
144
|
-
logger.warn('Unable to open proxy connection', {
|
|
145
|
-
nodeId,
|
|
146
|
-
streamPartId: this.options.streamPartId
|
|
147
|
-
});
|
|
148
|
-
}
|
|
149
|
-
}
|
|
150
|
-
async closeRandomConnections(connectionCount) {
|
|
151
|
-
const proxiesToDisconnect = (0, sampleSize_1.default)(Array.from(this.connections.keys()), connectionCount);
|
|
152
|
-
await Promise.allSettled(proxiesToDisconnect.map((node) => this.closeConnection(node)));
|
|
153
|
-
}
|
|
154
|
-
async closeConnection(nodeId) {
|
|
155
|
-
if (this.connections.has(nodeId)) {
|
|
156
|
-
logger.info('Close proxy connection', {
|
|
157
|
-
nodeId
|
|
158
|
-
});
|
|
159
|
-
const server = this.neighbors.get(nodeId);
|
|
160
|
-
server?.leaveStreamPartNotice(this.options.streamPartId, false);
|
|
161
|
-
this.removeConnection(this.connections.get(nodeId).peerDescriptor);
|
|
162
|
-
}
|
|
163
|
-
}
|
|
164
|
-
removeConnection(peerDescriptor) {
|
|
165
|
-
const nodeId = (0, dht_1.toNodeId)(peerDescriptor);
|
|
166
|
-
this.connections.delete(nodeId);
|
|
167
|
-
this.neighbors.remove(nodeId);
|
|
168
|
-
this.options.connectionLocker.unlockConnection(peerDescriptor, SERVICE_ID);
|
|
169
|
-
}
|
|
170
|
-
broadcast(msg, previousNode) {
|
|
171
|
-
if (!previousNode) {
|
|
172
|
-
(0, utils_2.markAndCheckDuplicate)(this.duplicateDetectors, msg.messageId, msg.previousMessageRef);
|
|
173
|
-
}
|
|
174
|
-
this.emit('message', msg);
|
|
175
|
-
this.propagation.feedUnseenMessage(msg, this.neighbors.getIds(), previousNode ?? null);
|
|
176
|
-
}
|
|
177
|
-
hasConnection(nodeId, direction) {
|
|
178
|
-
return this.connections.has(nodeId) && this.connections.get(nodeId).direction === direction;
|
|
179
|
-
}
|
|
180
|
-
getDirection() {
|
|
181
|
-
return this.definition.direction;
|
|
182
|
-
}
|
|
183
|
-
async onNodeDisconnected(peerDescriptor) {
|
|
184
|
-
const nodeId = (0, dht_1.toNodeId)(peerDescriptor);
|
|
185
|
-
if (this.connections.has(nodeId)) {
|
|
186
|
-
this.options.connectionLocker.unlockConnection(peerDescriptor, SERVICE_ID);
|
|
187
|
-
this.removeConnection(peerDescriptor);
|
|
188
|
-
await (0, exports.retry)(() => this.updateConnections(), 'updating proxy connections', this.abortController.signal);
|
|
189
|
-
}
|
|
190
|
-
}
|
|
191
|
-
async start() {
|
|
192
|
-
this.registerDefaultServerMethods();
|
|
193
|
-
(0, utils_1.addManagedEventListener)(this.options.transport, 'disconnected',
|
|
194
|
-
// TODO should we catch possible promise rejection?
|
|
195
|
-
(peerDescriptor) => this.onNodeDisconnected(peerDescriptor), this.abortController.signal);
|
|
196
|
-
}
|
|
197
|
-
getDiagnosticInfo() {
|
|
198
|
-
return {
|
|
199
|
-
neighbors: this.neighbors.getAll().map((neighbor) => neighbor.getPeerDescriptor()),
|
|
200
|
-
};
|
|
201
|
-
}
|
|
202
|
-
stop() {
|
|
203
|
-
this.neighbors.getAll().forEach((remote) => {
|
|
204
|
-
this.options.connectionLocker.unlockConnection(remote.getPeerDescriptor(), SERVICE_ID);
|
|
205
|
-
remote.leaveStreamPartNotice(this.options.streamPartId, false);
|
|
206
|
-
});
|
|
207
|
-
this.neighbors.stop();
|
|
208
|
-
this.rpcCommunicator.destroy();
|
|
209
|
-
this.connections.clear();
|
|
210
|
-
this.abortController.abort();
|
|
211
|
-
}
|
|
212
|
-
}
|
|
213
|
-
exports.ProxyClient = ProxyClient;
|
|
214
|
-
//# sourceMappingURL=ProxyClient.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyClient.js","sourceRoot":"","sources":["../../../../src/content-delivery-layer/proxy/ProxyClient.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,34 +0,0 @@
|
|
|
1
|
-
import { ServerCallContext } from '@protobuf-ts/runtime-rpc';
|
|
2
|
-
import { DhtAddress, ListeningRpcCommunicator, PeerDescriptor } from '@streamr/dht';
|
|
3
|
-
import { StreamPartID, UserID } from '@streamr/utils';
|
|
4
|
-
import { EventEmitter } from 'eventemitter3';
|
|
5
|
-
import { ProxyConnectionRequest, ProxyConnectionResponse, ProxyDirection, StreamMessage } from '../../../generated/packages/trackerless-network/protos/NetworkRpc';
|
|
6
|
-
import { IProxyConnectionRpc } from '../../../generated/packages/trackerless-network/protos/NetworkRpc.server';
|
|
7
|
-
import { ContentDeliveryRpcRemote } from '../ContentDeliveryRpcRemote';
|
|
8
|
-
interface ProxyConnection {
|
|
9
|
-
direction: ProxyDirection;
|
|
10
|
-
userId: UserID;
|
|
11
|
-
remote: ContentDeliveryRpcRemote;
|
|
12
|
-
}
|
|
13
|
-
interface ProxyConnectionRpcLocalOptions {
|
|
14
|
-
localPeerDescriptor: PeerDescriptor;
|
|
15
|
-
streamPartId: StreamPartID;
|
|
16
|
-
rpcCommunicator: ListeningRpcCommunicator;
|
|
17
|
-
}
|
|
18
|
-
export interface Events {
|
|
19
|
-
newConnection: (nodeId: DhtAddress) => void;
|
|
20
|
-
}
|
|
21
|
-
export declare class ProxyConnectionRpcLocal extends EventEmitter<Events> implements IProxyConnectionRpc {
|
|
22
|
-
private readonly options;
|
|
23
|
-
private readonly connections;
|
|
24
|
-
constructor(options: ProxyConnectionRpcLocalOptions);
|
|
25
|
-
getConnection(nodeId: DhtAddress): ProxyConnection | undefined;
|
|
26
|
-
hasConnection(nodeId: DhtAddress): boolean;
|
|
27
|
-
removeConnection(nodeId: DhtAddress): void;
|
|
28
|
-
stop(): void;
|
|
29
|
-
getPropagationTargets(msg: StreamMessage): DhtAddress[];
|
|
30
|
-
private getNodeIdsForUserId;
|
|
31
|
-
private getSubscribers;
|
|
32
|
-
requestConnection(request: ProxyConnectionRequest, context: ServerCallContext): Promise<ProxyConnectionResponse>;
|
|
33
|
-
}
|
|
34
|
-
export {};
|
|
@@ -1,72 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ProxyConnectionRpcLocal = void 0;
|
|
4
|
-
const dht_1 = require("@streamr/dht");
|
|
5
|
-
const utils_1 = require("@streamr/utils");
|
|
6
|
-
const eventemitter3_1 = require("eventemitter3");
|
|
7
|
-
const NetworkRpc_1 = require("../../../generated/packages/trackerless-network/protos/NetworkRpc");
|
|
8
|
-
const NetworkRpc_client_1 = require("../../../generated/packages/trackerless-network/protos/NetworkRpc.client");
|
|
9
|
-
const ContentDeliveryRpcRemote_1 = require("../ContentDeliveryRpcRemote");
|
|
10
|
-
const logger = new utils_1.Logger(module);
|
|
11
|
-
class ProxyConnectionRpcLocal extends eventemitter3_1.EventEmitter {
|
|
12
|
-
options;
|
|
13
|
-
connections = new Map();
|
|
14
|
-
constructor(options) {
|
|
15
|
-
super();
|
|
16
|
-
this.options = options;
|
|
17
|
-
this.options.rpcCommunicator.registerRpcMethod(NetworkRpc_1.ProxyConnectionRequest, NetworkRpc_1.ProxyConnectionResponse, 'requestConnection', (msg, context) => this.requestConnection(msg, context));
|
|
18
|
-
}
|
|
19
|
-
getConnection(nodeId) {
|
|
20
|
-
return this.connections.get(nodeId);
|
|
21
|
-
}
|
|
22
|
-
hasConnection(nodeId) {
|
|
23
|
-
return this.connections.has(nodeId);
|
|
24
|
-
}
|
|
25
|
-
removeConnection(nodeId) {
|
|
26
|
-
this.connections.delete(nodeId);
|
|
27
|
-
}
|
|
28
|
-
stop() {
|
|
29
|
-
this.connections.forEach((connection) => connection.remote.leaveStreamPartNotice(this.options.streamPartId, false));
|
|
30
|
-
this.connections.clear();
|
|
31
|
-
this.removeAllListeners();
|
|
32
|
-
}
|
|
33
|
-
getPropagationTargets(msg) {
|
|
34
|
-
if (msg.body.oneofKind === 'groupKeyRequest') {
|
|
35
|
-
try {
|
|
36
|
-
const recipientId = msg.body.groupKeyRequest.recipientId;
|
|
37
|
-
return this.getNodeIdsForUserId((0, utils_1.toUserId)(recipientId));
|
|
38
|
-
}
|
|
39
|
-
catch (err) {
|
|
40
|
-
logger.trace(`Could not parse GroupKeyRequest`, { err });
|
|
41
|
-
return [];
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
else {
|
|
45
|
-
return this.getSubscribers();
|
|
46
|
-
}
|
|
47
|
-
}
|
|
48
|
-
getNodeIdsForUserId(userId) {
|
|
49
|
-
return Array.from(this.connections.keys()).filter((nodeId) => this.connections.get(nodeId).userId === userId);
|
|
50
|
-
}
|
|
51
|
-
getSubscribers() {
|
|
52
|
-
return Array.from(this.connections.keys()).filter((key) => this.connections.get(key).direction === NetworkRpc_1.ProxyDirection.SUBSCRIBE);
|
|
53
|
-
}
|
|
54
|
-
// IProxyConnectionRpc server method
|
|
55
|
-
async requestConnection(request, context) {
|
|
56
|
-
const senderPeerDescriptor = context.incomingSourceDescriptor;
|
|
57
|
-
const remoteNodeId = (0, dht_1.toNodeId)(senderPeerDescriptor);
|
|
58
|
-
this.connections.set(remoteNodeId, {
|
|
59
|
-
direction: request.direction,
|
|
60
|
-
userId: (0, utils_1.toUserId)(request.userId),
|
|
61
|
-
remote: new ContentDeliveryRpcRemote_1.ContentDeliveryRpcRemote(this.options.localPeerDescriptor, senderPeerDescriptor, this.options.rpcCommunicator, NetworkRpc_client_1.ContentDeliveryRpcClient)
|
|
62
|
-
});
|
|
63
|
-
const response = {
|
|
64
|
-
accepted: true
|
|
65
|
-
};
|
|
66
|
-
logger.trace(`Accepted connection request from ${remoteNodeId} to ${this.options.streamPartId}`);
|
|
67
|
-
this.emit('newConnection', remoteNodeId);
|
|
68
|
-
return response;
|
|
69
|
-
}
|
|
70
|
-
}
|
|
71
|
-
exports.ProxyConnectionRpcLocal = ProxyConnectionRpcLocal;
|
|
72
|
-
//# sourceMappingURL=ProxyConnectionRpcLocal.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyConnectionRpcLocal.js","sourceRoot":"","sources":["../../../../src/content-delivery-layer/proxy/ProxyConnectionRpcLocal.ts"],"names":[],"mappings":"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"}
|
|
@@ -1,7 +0,0 @@
|
|
|
1
|
-
import { RpcRemote } from '@streamr/dht';
|
|
2
|
-
import { UserID } from '@streamr/utils';
|
|
3
|
-
import { ProxyDirection } from '../../../generated/packages/trackerless-network/protos/NetworkRpc';
|
|
4
|
-
import { ProxyConnectionRpcClient } from '../../../generated/packages/trackerless-network/protos/NetworkRpc.client';
|
|
5
|
-
export declare class ProxyConnectionRpcRemote extends RpcRemote<ProxyConnectionRpcClient> {
|
|
6
|
-
requestConnection(direction: ProxyDirection, userId: UserID): Promise<boolean>;
|
|
7
|
-
}
|
|
@@ -1,27 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ProxyConnectionRpcRemote = void 0;
|
|
4
|
-
const dht_1 = require("@streamr/dht");
|
|
5
|
-
const utils_1 = require("@streamr/utils");
|
|
6
|
-
const logger = new utils_1.Logger(module);
|
|
7
|
-
class ProxyConnectionRpcRemote extends dht_1.RpcRemote {
|
|
8
|
-
async requestConnection(direction, userId) {
|
|
9
|
-
const request = {
|
|
10
|
-
direction,
|
|
11
|
-
userId: (0, utils_1.toUserIdRaw)(userId)
|
|
12
|
-
};
|
|
13
|
-
const options = this.formDhtRpcOptions({
|
|
14
|
-
timeout: dht_1.EXISTING_CONNECTION_TIMEOUT
|
|
15
|
-
});
|
|
16
|
-
try {
|
|
17
|
-
const res = await this.getClient().requestConnection(request, options);
|
|
18
|
-
return res.accepted;
|
|
19
|
-
}
|
|
20
|
-
catch (err) {
|
|
21
|
-
logger.debug(`ProxyConnectionRequest failed with error`, { err });
|
|
22
|
-
return false;
|
|
23
|
-
}
|
|
24
|
-
}
|
|
25
|
-
}
|
|
26
|
-
exports.ProxyConnectionRpcRemote = ProxyConnectionRpcRemote;
|
|
27
|
-
//# sourceMappingURL=ProxyConnectionRpcRemote.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ProxyConnectionRpcRemote.js","sourceRoot":"","sources":["../../../../src/content-delivery-layer/proxy/ProxyConnectionRpcRemote.ts"],"names":[],"mappings":";;;AAAA,sCAAqE;AACrE,0CAA4D;AAI5D,MAAM,MAAM,GAAG,IAAI,cAAM,CAAC,MAAM,CAAC,CAAA;AAEjC,MAAa,wBAAyB,SAAQ,eAAmC;IAE7E,KAAK,CAAC,iBAAiB,CAAC,SAAyB,EAAE,MAAc;QAC7D,MAAM,OAAO,GAA2B;YACpC,SAAS;YACT,MAAM,EAAE,IAAA,mBAAW,EAAC,MAAM,CAAC;SAC9B,CAAA;QACD,MAAM,OAAO,GAAG,IAAI,CAAC,iBAAiB,CAAC;YACnC,OAAO,EAAE,iCAA2B;SACvC,CAAC,CAAA;QACF,IAAI,CAAC;YACD,MAAM,GAAG,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,iBAAiB,CAAC,OAAO,EAAE,OAAO,CAAC,CAAA;YACtE,OAAO,GAAG,CAAC,QAAQ,CAAA;QACvB,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,0CAA0C,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;YACjE,OAAO,KAAK,CAAA;QAChB,CAAC;IACL,CAAC;CACJ;AAlBD,4DAkBC"}
|
package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.d.ts
DELETED
|
@@ -1,26 +0,0 @@
|
|
|
1
|
-
import { ServerCallContext } from '@protobuf-ts/runtime-rpc';
|
|
2
|
-
import { ConnectionLocker, DhtAddress, ListeningRpcCommunicator } from '@streamr/dht';
|
|
3
|
-
import { StreamPartID } from '@streamr/utils';
|
|
4
|
-
import { Empty } from '../../../generated/google/protobuf/empty';
|
|
5
|
-
import { PeerDescriptor } from '../../../generated/packages/dht/protos/DhtRpc';
|
|
6
|
-
import { CloseTemporaryConnection, TemporaryConnectionRequest, TemporaryConnectionResponse } from '../../../generated/packages/trackerless-network/protos/NetworkRpc';
|
|
7
|
-
import { ITemporaryConnectionRpc } from '../../../generated/packages/trackerless-network/protos/NetworkRpc.server';
|
|
8
|
-
import { NodeList } from '../NodeList';
|
|
9
|
-
interface TemporaryConnectionRpcLocalOptions {
|
|
10
|
-
rpcCommunicator: ListeningRpcCommunicator;
|
|
11
|
-
localPeerDescriptor: PeerDescriptor;
|
|
12
|
-
streamPartId: StreamPartID;
|
|
13
|
-
connectionLocker: ConnectionLocker;
|
|
14
|
-
}
|
|
15
|
-
export declare class TemporaryConnectionRpcLocal implements ITemporaryConnectionRpc {
|
|
16
|
-
private readonly options;
|
|
17
|
-
private readonly temporaryNodes;
|
|
18
|
-
private readonly lockId;
|
|
19
|
-
constructor(options: TemporaryConnectionRpcLocalOptions);
|
|
20
|
-
getNodes(): NodeList;
|
|
21
|
-
hasNode(node: DhtAddress): boolean;
|
|
22
|
-
removeNode(nodeId: DhtAddress): void;
|
|
23
|
-
openConnection(_request: TemporaryConnectionRequest, context: ServerCallContext): Promise<TemporaryConnectionResponse>;
|
|
24
|
-
closeConnection(_request: CloseTemporaryConnection, context: ServerCallContext): Promise<Empty>;
|
|
25
|
-
}
|
|
26
|
-
export {};
|
|
@@ -1,45 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TemporaryConnectionRpcLocal = void 0;
|
|
4
|
-
const dht_1 = require("@streamr/dht");
|
|
5
|
-
const NetworkRpc_client_1 = require("../../../generated/packages/trackerless-network/protos/NetworkRpc.client");
|
|
6
|
-
const ContentDeliveryRpcRemote_1 = require("../ContentDeliveryRpcRemote");
|
|
7
|
-
const NodeList_1 = require("../NodeList");
|
|
8
|
-
const LOCK_ID_BASE = 'system/content-delivery/temporary-connection/';
|
|
9
|
-
class TemporaryConnectionRpcLocal {
|
|
10
|
-
options;
|
|
11
|
-
temporaryNodes;
|
|
12
|
-
lockId;
|
|
13
|
-
constructor(options) {
|
|
14
|
-
this.options = options;
|
|
15
|
-
// TODO use options option or named constant?
|
|
16
|
-
this.temporaryNodes = new NodeList_1.NodeList((0, dht_1.toNodeId)(options.localPeerDescriptor), 10);
|
|
17
|
-
this.lockId = LOCK_ID_BASE + options.streamPartId;
|
|
18
|
-
}
|
|
19
|
-
getNodes() {
|
|
20
|
-
return this.temporaryNodes;
|
|
21
|
-
}
|
|
22
|
-
hasNode(node) {
|
|
23
|
-
return this.temporaryNodes.has(node);
|
|
24
|
-
}
|
|
25
|
-
removeNode(nodeId) {
|
|
26
|
-
this.temporaryNodes.remove(nodeId);
|
|
27
|
-
this.options.connectionLocker.weakUnlockConnection(nodeId, this.lockId);
|
|
28
|
-
}
|
|
29
|
-
async openConnection(_request, context) {
|
|
30
|
-
const sender = context.incomingSourceDescriptor;
|
|
31
|
-
const remote = new ContentDeliveryRpcRemote_1.ContentDeliveryRpcRemote(this.options.localPeerDescriptor, sender, this.options.rpcCommunicator, NetworkRpc_client_1.ContentDeliveryRpcClient);
|
|
32
|
-
this.temporaryNodes.add(remote);
|
|
33
|
-
this.options.connectionLocker.weakLockConnection((0, dht_1.toNodeId)(sender), this.lockId);
|
|
34
|
-
return {
|
|
35
|
-
accepted: true
|
|
36
|
-
};
|
|
37
|
-
}
|
|
38
|
-
async closeConnection(_request, context) {
|
|
39
|
-
const remoteNodeId = (0, dht_1.toNodeId)(context.incomingSourceDescriptor);
|
|
40
|
-
this.removeNode(remoteNodeId);
|
|
41
|
-
return {};
|
|
42
|
-
}
|
|
43
|
-
}
|
|
44
|
-
exports.TemporaryConnectionRpcLocal = TemporaryConnectionRpcLocal;
|
|
45
|
-
//# sourceMappingURL=TemporaryConnectionRpcLocal.js.map
|
package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TemporaryConnectionRpcLocal.js","sourceRoot":"","sources":["../../../../src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcLocal.ts"],"names":[],"mappings":";;;AACA,sCAA+G;AAS/G,gHAAmH;AAEnH,0EAAsE;AACtE,0CAAsC;AAStC,MAAM,YAAY,GAAG,+CAA+C,CAAA;AAEpE,MAAa,2BAA2B;IAEnB,OAAO,CAAoC;IAC3C,cAAc,CAAU;IACxB,MAAM,CAAQ;IAC/B,YAAY,OAA2C;QACnD,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;QACtB,6CAA6C;QAC7C,IAAI,CAAC,cAAc,GAAG,IAAI,mBAAQ,CAAC,IAAA,cAAQ,EAAC,OAAO,CAAC,mBAAmB,CAAC,EAAE,EAAE,CAAC,CAAA;QAC7E,IAAI,CAAC,MAAM,GAAG,YAAY,GAAG,OAAO,CAAC,YAAY,CAAA;IACrD,CAAC;IAED,QAAQ;QACJ,OAAO,IAAI,CAAC,cAAc,CAAA;IAC9B,CAAC;IAED,OAAO,CAAC,IAAgB;QACpB,OAAO,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,IAAI,CAAC,CAAA;IACxC,CAAC;IAED,UAAU,CAAC,MAAkB;QACzB,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,MAAM,CAAC,CAAA;QAClC,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,oBAAoB,CAAC,MAAM,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;IAC3E,CAAC;IAED,KAAK,CAAC,cAAc,CAChB,QAAoC,EACpC,OAA0B;QAE1B,MAAM,MAAM,GAAI,OAA0B,CAAC,wBAAyB,CAAA;QACpE,MAAM,MAAM,GAAG,IAAI,mDAAwB,CACvC,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAChC,MAAM,EACN,IAAI,CAAC,OAAO,CAAC,eAAe,EAC5B,4CAAwB,CAC3B,CAAA;QACD,IAAI,CAAC,cAAc,CAAC,GAAG,CAAC,MAAM,CAAC,CAAA;QAC/B,IAAI,CAAC,OAAO,CAAC,gBAAgB,CAAC,kBAAkB,CAAC,IAAA,cAAQ,EAAC,MAAM,CAAC,EAAE,IAAI,CAAC,MAAM,CAAC,CAAA;QAC/E,OAAO;YACH,QAAQ,EAAE,IAAI;SACjB,CAAA;IACL,CAAC;IAED,KAAK,CAAC,eAAe,CAAC,QAAkC,EAAE,OAA0B;QAChF,MAAM,YAAY,GAAG,IAAA,cAAQ,EAAE,OAA0B,CAAC,wBAAyB,CAAC,CAAA;QACpF,IAAI,CAAC,UAAU,CAAC,YAAY,CAAC,CAAA;QAC7B,OAAO,EAAE,CAAA;IACb,CAAC;CACJ;AAhDD,kEAgDC"}
|
package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.d.ts
DELETED
|
@@ -1,6 +0,0 @@
|
|
|
1
|
-
import { RpcRemote } from '@streamr/dht';
|
|
2
|
-
import { TemporaryConnectionRpcClient } from '../../../generated/packages/trackerless-network/protos/NetworkRpc.client';
|
|
3
|
-
export declare class TemporaryConnectionRpcRemote extends RpcRemote<TemporaryConnectionRpcClient> {
|
|
4
|
-
openConnection(): Promise<boolean>;
|
|
5
|
-
closeConnection(): Promise<void>;
|
|
6
|
-
}
|
package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.js
DELETED
|
@@ -1,31 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.TemporaryConnectionRpcRemote = void 0;
|
|
4
|
-
const dht_1 = require("@streamr/dht");
|
|
5
|
-
const utils_1 = require("@streamr/utils");
|
|
6
|
-
const logger = new utils_1.Logger(module);
|
|
7
|
-
class TemporaryConnectionRpcRemote extends dht_1.RpcRemote {
|
|
8
|
-
async openConnection() {
|
|
9
|
-
try {
|
|
10
|
-
const response = await this.getClient().openConnection({}, this.formDhtRpcOptions());
|
|
11
|
-
return response.accepted;
|
|
12
|
-
}
|
|
13
|
-
catch (err) {
|
|
14
|
-
logger.debug(`temporaryConnection to ${(0, dht_1.toNodeId)(this.getPeerDescriptor())} failed`, { err });
|
|
15
|
-
return false;
|
|
16
|
-
}
|
|
17
|
-
}
|
|
18
|
-
async closeConnection() {
|
|
19
|
-
try {
|
|
20
|
-
await this.getClient().closeConnection({}, this.formDhtRpcOptions({
|
|
21
|
-
connect: false,
|
|
22
|
-
notification: true
|
|
23
|
-
}));
|
|
24
|
-
}
|
|
25
|
-
catch (err) {
|
|
26
|
-
logger.trace(`closeConnection to ${(0, dht_1.toNodeId)(this.getPeerDescriptor())} failed`, { err });
|
|
27
|
-
}
|
|
28
|
-
}
|
|
29
|
-
}
|
|
30
|
-
exports.TemporaryConnectionRpcRemote = TemporaryConnectionRpcRemote;
|
|
31
|
-
//# sourceMappingURL=TemporaryConnectionRpcRemote.js.map
|
package/dist/src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.js.map
DELETED
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"TemporaryConnectionRpcRemote.js","sourceRoot":"","sources":["../../../../src/content-delivery-layer/temporary-connection/TemporaryConnectionRpcRemote.ts"],"names":[],"mappings":";;;AAAA,sCAAkD;AAClD,0CAAuC;AAGvC,MAAM,MAAM,GAAG,IAAI,cAAM,CAAC,MAAM,CAAC,CAAA;AAEjC,MAAa,4BAA6B,SAAQ,eAAuC;IAErF,KAAK,CAAC,cAAc;QAChB,IAAI,CAAC;YACD,MAAM,QAAQ,GAAG,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,cAAc,CAAC,EAAE,EAAE,IAAI,CAAC,iBAAiB,EAAE,CAAC,CAAA;YACpF,OAAO,QAAQ,CAAC,QAAQ,CAAA;QAC5B,CAAC;QAAC,OAAO,GAAQ,EAAE,CAAC;YAChB,MAAM,CAAC,KAAK,CAAC,0BAA0B,IAAA,cAAQ,EAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,SAAS,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;YAC5F,OAAO,KAAK,CAAA;QAChB,CAAC;IACL,CAAC;IAED,KAAK,CAAC,eAAe;QACjB,IAAI,CAAC;YACD,MAAM,IAAI,CAAC,SAAS,EAAE,CAAC,eAAe,CAAC,EAAE,EAAE,IAAI,CAAC,iBAAiB,CAAC;gBAC9D,OAAO,EAAE,KAAK;gBACd,YAAY,EAAE,IAAI;aACrB,CAAC,CAAC,CAAA;QACP,CAAC;QAAC,OAAO,GAAG,EAAE,CAAC;YACX,MAAM,CAAC,KAAK,CAAC,sBAAsB,IAAA,cAAQ,EAAC,IAAI,CAAC,iBAAiB,EAAE,CAAC,SAAS,EAAE,EAAE,GAAG,EAAE,CAAC,CAAA;QAC5F,CAAC;IACL,CAAC;CACJ;AAtBD,oEAsBC"}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { ConnectionsView, DataEntry, DhtAddress, ITransport, PeerDescriptor } from '@streamr/dht';
|
|
2
|
-
import { Any } from '../../generated/google/protobuf/any';
|
|
3
|
-
export interface ControlLayerNode extends ITransport {
|
|
4
|
-
joinDht(entryPointDescriptors: PeerDescriptor[]): Promise<void>;
|
|
5
|
-
hasJoined(): boolean;
|
|
6
|
-
getLocalPeerDescriptor(): PeerDescriptor;
|
|
7
|
-
fetchDataFromDht(key: DhtAddress): Promise<DataEntry[]>;
|
|
8
|
-
storeDataToDht(key: DhtAddress, data: Any): Promise<PeerDescriptor[]>;
|
|
9
|
-
deleteDataFromDht(key: DhtAddress, waitForCompletion: boolean): Promise<void>;
|
|
10
|
-
waitForNetworkConnectivity(): Promise<void>;
|
|
11
|
-
getTransport(): ITransport;
|
|
12
|
-
getNeighbors(): PeerDescriptor[];
|
|
13
|
-
getConnectionsView(): ConnectionsView;
|
|
14
|
-
start(): Promise<void>;
|
|
15
|
-
stop(): Promise<void>;
|
|
16
|
-
}
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ControlLayerNode.js","sourceRoot":"","sources":["../../../src/control-layer/ControlLayerNode.ts"],"names":[],"mappings":""}
|
|
@@ -1,16 +0,0 @@
|
|
|
1
|
-
import { IMessageType } from '@protobuf-ts/runtime';
|
|
2
|
-
import { ServerCallContext, ServiceInfo } from '@protobuf-ts/runtime-rpc';
|
|
3
|
-
import { ITransport } from '@streamr/dht';
|
|
4
|
-
import { ClassType, ClientTransport, ProtoRpcClient } from '@streamr/proto-rpc';
|
|
5
|
-
export declare const SERVICE_ID = "external-network-service";
|
|
6
|
-
export type ExternalRpcClient = ServiceInfo & ClassType;
|
|
7
|
-
export type ExternalRpcClientClass<T extends ExternalRpcClient> = {
|
|
8
|
-
new (clientTransport: ClientTransport): T;
|
|
9
|
-
};
|
|
10
|
-
export declare class ExternalNetworkRpc {
|
|
11
|
-
private readonly rpcCommunicator;
|
|
12
|
-
constructor(transport: ITransport);
|
|
13
|
-
registerRpcMethod<RequestClass extends IMessageType<RequestType>, ResponseClass extends IMessageType<ResponseType>, RequestType extends object, ResponseType extends object>(request: RequestClass, response: ResponseClass, name: string, fn: (req: RequestType, context: ServerCallContext) => Promise<ResponseType>): void;
|
|
14
|
-
createRpcClient<T extends ExternalRpcClient>(clientClass: ExternalRpcClientClass<T>): ProtoRpcClient<T>;
|
|
15
|
-
destroy(): void;
|
|
16
|
-
}
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
"use strict";
|
|
2
|
-
Object.defineProperty(exports, "__esModule", { value: true });
|
|
3
|
-
exports.ExternalNetworkRpc = exports.SERVICE_ID = void 0;
|
|
4
|
-
const dht_1 = require("@streamr/dht");
|
|
5
|
-
const proto_rpc_1 = require("@streamr/proto-rpc");
|
|
6
|
-
exports.SERVICE_ID = 'external-network-service';
|
|
7
|
-
class ExternalNetworkRpc {
|
|
8
|
-
rpcCommunicator;
|
|
9
|
-
constructor(transport) {
|
|
10
|
-
this.rpcCommunicator = new dht_1.ListeningRpcCommunicator(exports.SERVICE_ID, transport);
|
|
11
|
-
}
|
|
12
|
-
registerRpcMethod(request, response, name, fn) {
|
|
13
|
-
this.rpcCommunicator.registerRpcMethod(request, response, name, fn);
|
|
14
|
-
}
|
|
15
|
-
createRpcClient(clientClass) {
|
|
16
|
-
return (0, proto_rpc_1.toProtoRpcClient)(new clientClass(this.rpcCommunicator.getRpcClientTransport()));
|
|
17
|
-
}
|
|
18
|
-
destroy() {
|
|
19
|
-
this.rpcCommunicator.destroy();
|
|
20
|
-
}
|
|
21
|
-
}
|
|
22
|
-
exports.ExternalNetworkRpc = ExternalNetworkRpc;
|
|
23
|
-
//# sourceMappingURL=ExternalNetworkRpc.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"ExternalNetworkRpc.js","sourceRoot":"","sources":["../../../src/control-layer/ExternalNetworkRpc.ts"],"names":[],"mappings":";;;AAEA,sCAAmE;AACnE,kDAAiG;AAEpF,QAAA,UAAU,GAAG,0BAA0B,CAAA;AAMpD,MAAa,kBAAkB;IAEV,eAAe,CAA0B;IAE1D,YAAY,SAAqB;QAC7B,IAAI,CAAC,eAAe,GAAG,IAAI,8BAAwB,CAAC,kBAAU,EAAE,SAAS,CAAC,CAAA;IAC9E,CAAC;IAED,iBAAiB,CAMb,OAAqB,EACrB,QAAuB,EACvB,IAAY,EACZ,EAA2E;QAE3E,IAAI,CAAC,eAAe,CAAC,iBAAiB,CAAC,OAAO,EAAE,QAAQ,EAAE,IAAI,EAAE,EAAE,CAAC,CAAA;IACvE,CAAC;IAED,eAAe,CAA8B,WAAsC;QAC/E,OAAO,IAAA,4BAAgB,EAAC,IAAI,WAAW,CAAC,IAAI,CAAC,eAAe,CAAC,qBAAqB,EAAE,CAAC,CAAC,CAAA;IAC1F,CAAC;IAED,OAAO;QACH,IAAI,CAAC,eAAe,CAAC,OAAO,EAAE,CAAA;IAClC,CAAC;CAEJ;AA9BD,gDA8BC"}
|
|
@@ -1,28 +0,0 @@
|
|
|
1
|
-
import { DataEntry, DhtAddress, PeerDescriptor } from '@streamr/dht';
|
|
2
|
-
import { Any } from '../../generated/google/protobuf/any';
|
|
3
|
-
export declare const MAX_NODE_COUNT = 8;
|
|
4
|
-
interface PeerDescriptorStoreManagerOptions {
|
|
5
|
-
key: DhtAddress;
|
|
6
|
-
localPeerDescriptor: PeerDescriptor;
|
|
7
|
-
storeInterval?: number;
|
|
8
|
-
fetchDataFromDht: (key: DhtAddress) => Promise<DataEntry[]>;
|
|
9
|
-
storeDataToDht: (key: DhtAddress, data: Any) => Promise<PeerDescriptor[]>;
|
|
10
|
-
deleteDataFromDht: (key: DhtAddress, waitForCompletion: boolean) => Promise<void>;
|
|
11
|
-
}
|
|
12
|
-
/**
|
|
13
|
-
* For each key there is usually 0-MAX_NODE_COUNT PeerDescriptors stored in the DHT. If there are fewer node,
|
|
14
|
-
* the peer descriptor of the local node is stored to the DHT.
|
|
15
|
-
*/
|
|
16
|
-
export declare class PeerDescriptorStoreManager {
|
|
17
|
-
private readonly abortController;
|
|
18
|
-
private readonly options;
|
|
19
|
-
private isLocalNodeStored_;
|
|
20
|
-
constructor(options: PeerDescriptorStoreManagerOptions);
|
|
21
|
-
fetchNodes(): Promise<PeerDescriptor[]>;
|
|
22
|
-
storeAndKeepLocalNode(): Promise<void>;
|
|
23
|
-
private storeLocalNode;
|
|
24
|
-
private keepLocalNode;
|
|
25
|
-
isLocalNodeStored(): boolean;
|
|
26
|
-
destroy(): Promise<void>;
|
|
27
|
-
}
|
|
28
|
-
export {};
|