@streamr/trackerless-network 102.0.0-beta.0 → 102.0.0-beta.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (231) hide show
  1. package/dist/generated/google/protobuf/any.js.map +1 -0
  2. package/dist/generated/google/protobuf/empty.js.map +1 -0
  3. package/dist/generated/google/protobuf/timestamp.js.map +1 -0
  4. package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.client.d.ts +9 -0
  5. package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.client.js +7 -0
  6. package/dist/generated/packages/dht/protos/DhtRpc.client.js.map +1 -0
  7. package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.d.ts +32 -8
  8. package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.js +23 -7
  9. package/dist/generated/packages/dht/protos/DhtRpc.js.map +1 -0
  10. package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.server.d.ts +5 -0
  11. package/dist/generated/packages/dht/protos/DhtRpc.server.js.map +1 -0
  12. package/dist/generated/packages/proto-rpc/protos/ProtoRpc.js.map +1 -0
  13. package/dist/generated/packages/trackerless-network/protos/NetworkRpc.client.js.map +1 -0
  14. package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.d.ts +3 -3
  15. package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.js +1 -1
  16. package/dist/generated/packages/trackerless-network/protos/NetworkRpc.js.map +1 -0
  17. package/dist/generated/packages/trackerless-network/protos/NetworkRpc.server.js.map +1 -0
  18. package/dist/package.json +9 -10
  19. package/dist/src/NetworkNode.d.ts +4 -3
  20. package/dist/src/NetworkNode.js.map +1 -1
  21. package/dist/src/NetworkStack.d.ts +2 -2
  22. package/dist/src/NetworkStack.js +4 -4
  23. package/dist/src/NetworkStack.js.map +1 -1
  24. package/dist/src/exports.d.ts +3 -2
  25. package/dist/src/exports.js +3 -2
  26. package/dist/src/exports.js.map +1 -1
  27. package/dist/src/logic/ContentDeliveryLayerNode.d.ts +2 -1
  28. package/dist/src/logic/ContentDeliveryLayerNode.js +5 -5
  29. package/dist/src/logic/ContentDeliveryLayerNode.js.map +1 -1
  30. package/dist/src/logic/ContentDeliveryManager.d.ts +2 -1
  31. package/dist/src/logic/ContentDeliveryManager.js +2 -1
  32. package/dist/src/logic/ContentDeliveryManager.js.map +1 -1
  33. package/dist/src/logic/ContentDeliveryRpcLocal.d.ts +3 -3
  34. package/dist/src/logic/ContentDeliveryRpcLocal.js +1 -1
  35. package/dist/src/logic/ContentDeliveryRpcLocal.js.map +1 -1
  36. package/dist/src/logic/ContentDeliveryRpcRemote.d.ts +2 -2
  37. package/dist/src/logic/ControlLayerNode.d.ts +1 -1
  38. package/dist/src/logic/DiscoveryLayerNode.d.ts +3 -3
  39. package/dist/src/logic/DuplicateMessageDetector.js +1 -1
  40. package/dist/src/logic/DuplicateMessageDetector.js.map +1 -1
  41. package/dist/src/logic/PeerDescriptorStoreManager.d.ts +1 -1
  42. package/dist/src/logic/PeerDescriptorStoreManager.js +1 -1
  43. package/dist/src/logic/PeerDescriptorStoreManager.js.map +1 -1
  44. package/dist/src/logic/inspect/InspectSession.d.ts +2 -2
  45. package/dist/src/logic/inspect/InspectSession.js +2 -2
  46. package/dist/src/logic/inspect/InspectSession.js.map +1 -1
  47. package/dist/src/logic/inspect/Inspector.d.ts +1 -1
  48. package/dist/src/logic/inspect/Inspector.js +1 -1
  49. package/dist/src/logic/inspect/Inspector.js.map +1 -1
  50. package/dist/src/logic/neighbor-discovery/HandshakeRpcLocal.d.ts +2 -2
  51. package/dist/src/logic/neighbor-discovery/HandshakeRpcRemote.d.ts +2 -2
  52. package/dist/src/logic/neighbor-discovery/Handshaker.js +2 -2
  53. package/dist/src/logic/neighbor-discovery/Handshaker.js.map +1 -1
  54. package/dist/src/logic/neighbor-discovery/NeighborUpdateManager.js +2 -2
  55. package/dist/src/logic/neighbor-discovery/NeighborUpdateManager.js.map +1 -1
  56. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.d.ts +2 -2
  57. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.js +1 -1
  58. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.js.map +1 -1
  59. package/dist/src/logic/neighbor-discovery/NeighborUpdateRpcRemote.d.ts +1 -1
  60. package/dist/src/logic/node-info/NodeInfoClient.d.ts +1 -1
  61. package/dist/src/logic/node-info/NodeInfoClient.js +1 -1
  62. package/dist/src/logic/node-info/NodeInfoClient.js.map +1 -1
  63. package/dist/src/logic/node-info/NodeInfoRpcLocal.d.ts +2 -2
  64. package/dist/src/logic/node-info/NodeInfoRpcLocal.js +1 -1
  65. package/dist/src/logic/node-info/NodeInfoRpcLocal.js.map +1 -1
  66. package/dist/src/logic/node-info/NodeInfoRpcRemote.d.ts +2 -2
  67. package/dist/src/logic/propagation/Propagation.d.ts +1 -1
  68. package/dist/src/logic/propagation/PropagationTaskStore.d.ts +1 -1
  69. package/dist/src/logic/proxy/ProxyClient.d.ts +1 -2
  70. package/dist/src/logic/proxy/ProxyClient.js +2 -3
  71. package/dist/src/logic/proxy/ProxyClient.js.map +1 -1
  72. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.d.ts +2 -2
  73. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.js +4 -4
  74. package/dist/src/logic/proxy/ProxyConnectionRpcLocal.js.map +1 -1
  75. package/dist/src/logic/proxy/ProxyConnectionRpcRemote.d.ts +2 -2
  76. package/dist/src/logic/proxy/ProxyConnectionRpcRemote.js +1 -1
  77. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.d.ts +4 -4
  78. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.js +1 -1
  79. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcLocal.js.map +1 -1
  80. package/dist/src/logic/temporary-connection/TemporaryConnectionRpcRemote.d.ts +1 -1
  81. package/dist/src/logic/utils.d.ts +1 -1
  82. package/dist/src/logic/utils.js +2 -2
  83. package/dist/src/logic/utils.js.map +1 -1
  84. package/dist/src/types.d.ts +6 -0
  85. package/dist/src/types.js +3 -0
  86. package/dist/src/types.js.map +1 -0
  87. package/dist/test/benchmark/first-message.js +2 -2
  88. package/dist/test/benchmark/first-message.js.map +1 -1
  89. package/dist/test/utils/utils.d.ts +2 -2
  90. package/dist/test/utils/utils.js +5 -4
  91. package/dist/test/utils/utils.js.map +1 -1
  92. package/jest.config.ts +13 -0
  93. package/package.json +9 -10
  94. package/proto.sh +2 -2
  95. package/protos/NetworkRpc.proto +2 -3
  96. package/.eslintignore +0 -7
  97. package/.eslintrc +0 -3
  98. package/dist/src/proto/google/protobuf/any.js.map +0 -1
  99. package/dist/src/proto/google/protobuf/empty.js.map +0 -1
  100. package/dist/src/proto/google/protobuf/timestamp.js.map +0 -1
  101. package/dist/src/proto/packages/dht/protos/DhtRpc.client.js.map +0 -1
  102. package/dist/src/proto/packages/dht/protos/DhtRpc.js.map +0 -1
  103. package/dist/src/proto/packages/dht/protos/DhtRpc.server.js.map +0 -1
  104. package/dist/src/proto/packages/proto-rpc/protos/ProtoRpc.js.map +0 -1
  105. package/dist/src/proto/packages/trackerless-network/protos/NetworkRpc.client.js.map +0 -1
  106. package/dist/src/proto/packages/trackerless-network/protos/NetworkRpc.js.map +0 -1
  107. package/dist/src/proto/packages/trackerless-network/protos/NetworkRpc.server.js.map +0 -1
  108. package/jest.config.js +0 -8
  109. package/src/NetworkNode.ts +0 -141
  110. package/src/NetworkStack.ts +0 -198
  111. package/src/exports.ts +0 -16
  112. package/src/logic/ContentDeliveryLayerNode.ts +0 -424
  113. package/src/logic/ContentDeliveryManager.ts +0 -399
  114. package/src/logic/ContentDeliveryRpcLocal.ts +0 -48
  115. package/src/logic/ContentDeliveryRpcRemote.ts +0 -44
  116. package/src/logic/ControlLayerNode.ts +0 -17
  117. package/src/logic/DiscoveryLayerNode.ts +0 -30
  118. package/src/logic/DuplicateMessageDetector.ts +0 -167
  119. package/src/logic/ExternalNetworkRpc.ts +0 -42
  120. package/src/logic/NodeList.ts +0 -114
  121. package/src/logic/PeerDescriptorStoreManager.ts +0 -96
  122. package/src/logic/StreamPartNetworkSplitAvoidance.ts +0 -90
  123. package/src/logic/StreamPartReconnect.ts +0 -38
  124. package/src/logic/createContentDeliveryLayerNode.ts +0 -130
  125. package/src/logic/formStreamPartDeliveryServiceId.ts +0 -7
  126. package/src/logic/inspect/InspectSession.ts +0 -54
  127. package/src/logic/inspect/Inspector.ts +0 -100
  128. package/src/logic/neighbor-discovery/HandshakeRpcLocal.ts +0 -138
  129. package/src/logic/neighbor-discovery/HandshakeRpcRemote.ts +0 -66
  130. package/src/logic/neighbor-discovery/Handshaker.ts +0 -215
  131. package/src/logic/neighbor-discovery/NeighborFinder.ts +0 -77
  132. package/src/logic/neighbor-discovery/NeighborUpdateManager.ts +0 -69
  133. package/src/logic/neighbor-discovery/NeighborUpdateRpcLocal.ts +0 -75
  134. package/src/logic/neighbor-discovery/NeighborUpdateRpcRemote.ts +0 -35
  135. package/src/logic/node-info/NodeInfoClient.ts +0 -23
  136. package/src/logic/node-info/NodeInfoRpcLocal.ts +0 -28
  137. package/src/logic/node-info/NodeInfoRpcRemote.ts +0 -11
  138. package/src/logic/propagation/FifoMapWithTTL.ts +0 -116
  139. package/src/logic/propagation/Propagation.ts +0 -84
  140. package/src/logic/propagation/PropagationTaskStore.ts +0 -41
  141. package/src/logic/proxy/ProxyClient.ts +0 -287
  142. package/src/logic/proxy/ProxyConnectionRpcLocal.ts +0 -106
  143. package/src/logic/proxy/ProxyConnectionRpcRemote.ts +0 -26
  144. package/src/logic/temporary-connection/TemporaryConnectionRpcLocal.ts +0 -73
  145. package/src/logic/temporary-connection/TemporaryConnectionRpcRemote.ts +0 -29
  146. package/src/logic/utils.ts +0 -18
  147. package/src/proto/google/protobuf/any.ts +0 -326
  148. package/src/proto/google/protobuf/empty.ts +0 -81
  149. package/src/proto/google/protobuf/timestamp.ts +0 -287
  150. package/src/proto/packages/dht/protos/DhtRpc.client.ts +0 -407
  151. package/src/proto/packages/dht/protos/DhtRpc.server.ts +0 -160
  152. package/src/proto/packages/dht/protos/DhtRpc.ts +0 -1244
  153. package/src/proto/packages/proto-rpc/protos/ProtoRpc.ts +0 -108
  154. package/src/proto/packages/trackerless-network/protos/NetworkRpc.client.ts +0 -218
  155. package/src/proto/packages/trackerless-network/protos/NetworkRpc.server.ts +0 -85
  156. package/src/proto/packages/trackerless-network/protos/NetworkRpc.ts +0 -783
  157. package/test/benchmark/StreamPartIdDataKeyDistribution.test.ts +0 -60
  158. package/test/benchmark/first-message.ts +0 -169
  159. package/test/end-to-end/content-delivery-layer-node-with-real-connections.test.ts +0 -160
  160. package/test/end-to-end/external-network-rpc.test.ts +0 -67
  161. package/test/end-to-end/inspect.test.ts +0 -124
  162. package/test/end-to-end/proxy-and-full-node.test.ts +0 -143
  163. package/test/end-to-end/proxy-connections.test.ts +0 -228
  164. package/test/end-to-end/proxy-key-exchange.test.ts +0 -126
  165. package/test/end-to-end/webrtc-full-node-network.test.ts +0 -85
  166. package/test/end-to-end/websocket-full-node-network.test.ts +0 -84
  167. package/test/integration/ContentDeliveryLayerNode-Layer1Node-Latencies.test.ts +0 -139
  168. package/test/integration/ContentDeliveryLayerNode-Layer1Node.test.ts +0 -162
  169. package/test/integration/ContentDeliveryManager.test.ts +0 -157
  170. package/test/integration/ContentDeliveryRpcRemote.test.ts +0 -100
  171. package/test/integration/HandshakeRpcRemote.test.ts +0 -79
  172. package/test/integration/Handshakes.test.ts +0 -176
  173. package/test/integration/Inspect.test.ts +0 -89
  174. package/test/integration/NeighborUpdateRpcRemote.test.ts +0 -82
  175. package/test/integration/NetworkNode.test.ts +0 -115
  176. package/test/integration/NetworkRpc.test.ts +0 -52
  177. package/test/integration/NetworkStack.test.ts +0 -72
  178. package/test/integration/NodeInfoRpc.test.ts +0 -109
  179. package/test/integration/Propagation.test.ts +0 -76
  180. package/test/integration/joining-streams-on-offline-peers.test.ts +0 -82
  181. package/test/integration/stream-without-default-entrypoints.test.ts +0 -128
  182. package/test/integration/streamEntryPointReplacing.test.ts +0 -97
  183. package/test/types/global.d.ts +0 -2
  184. package/test/unit/ContentDeliveryLayerNode.test.ts +0 -112
  185. package/test/unit/ContentDeliveryManager.test.ts +0 -95
  186. package/test/unit/ContentDeliveryRpcLocal.test.ts +0 -60
  187. package/test/unit/DuplicateMessageDetector.test.ts +0 -192
  188. package/test/unit/ExternalNetworkRpc.test.ts +0 -48
  189. package/test/unit/FifoMapWithTtl.test.ts +0 -253
  190. package/test/unit/HandshakeRpcLocal.test.ts +0 -168
  191. package/test/unit/Handshaker.test.ts +0 -69
  192. package/test/unit/InspectSession.test.ts +0 -80
  193. package/test/unit/Inspector.test.ts +0 -51
  194. package/test/unit/NeighborFinder.test.ts +0 -51
  195. package/test/unit/NeighborUpdateRpcLocal.test.ts +0 -139
  196. package/test/unit/NetworkNode.test.ts +0 -42
  197. package/test/unit/NodeList.test.ts +0 -164
  198. package/test/unit/NumberPair.test.ts +0 -22
  199. package/test/unit/PeerDescriptorStoreManager.test.ts +0 -103
  200. package/test/unit/Propagation.test.ts +0 -151
  201. package/test/unit/ProxyConnectionRpcRemote.test.ts +0 -39
  202. package/test/unit/StreamPartIDDataKey.test.ts +0 -12
  203. package/test/unit/StreamPartNetworkSplitAvoidance.test.ts +0 -31
  204. package/test/unit/StreamPartReconnect.test.ts +0 -30
  205. package/test/unit/TemporaryConnectionRpcLocal.test.ts +0 -38
  206. package/test/utils/fake/FakePeerDescriptorStoreManager.ts +0 -29
  207. package/test/utils/mock/MockConnectionsView.ts +0 -18
  208. package/test/utils/mock/MockControlLayerNode.ts +0 -78
  209. package/test/utils/mock/MockDiscoveryLayerNode.ts +0 -60
  210. package/test/utils/mock/MockHandshaker.ts +0 -17
  211. package/test/utils/mock/MockNeighborFinder.ts +0 -20
  212. package/test/utils/mock/MockNeighborUpdateManager.ts +0 -21
  213. package/test/utils/mock/MockTransport.ts +0 -30
  214. package/test/utils/utils.ts +0 -143
  215. package/tsconfig.browser.json +0 -12
  216. package/tsconfig.jest.json +0 -16
  217. package/tsconfig.json +0 -3
  218. package/tsconfig.node.json +0 -16
  219. /package/dist/{src/proto → generated}/google/protobuf/any.d.ts +0 -0
  220. /package/dist/{src/proto → generated}/google/protobuf/any.js +0 -0
  221. /package/dist/{src/proto → generated}/google/protobuf/empty.d.ts +0 -0
  222. /package/dist/{src/proto → generated}/google/protobuf/empty.js +0 -0
  223. /package/dist/{src/proto → generated}/google/protobuf/timestamp.d.ts +0 -0
  224. /package/dist/{src/proto → generated}/google/protobuf/timestamp.js +0 -0
  225. /package/dist/{src/proto → generated}/packages/dht/protos/DhtRpc.server.js +0 -0
  226. /package/dist/{src/proto → generated}/packages/proto-rpc/protos/ProtoRpc.d.ts +0 -0
  227. /package/dist/{src/proto → generated}/packages/proto-rpc/protos/ProtoRpc.js +0 -0
  228. /package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.client.d.ts +0 -0
  229. /package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.client.js +0 -0
  230. /package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.server.d.ts +0 -0
  231. /package/dist/{src/proto → generated}/packages/trackerless-network/protos/NetworkRpc.server.js +0 -0
@@ -1,424 +0,0 @@
1
- import {
2
- ConnectionLocker,
3
- DhtAddress,
4
- ITransport,
5
- ListeningRpcCommunicator,
6
- PeerDescriptor,
7
- toNodeId,
8
- } from '@streamr/dht'
9
- import { Logger, StreamPartID, addManagedEventListener } from '@streamr/utils'
10
- import { EventEmitter } from 'eventemitter3'
11
- import {
12
- CloseTemporaryConnection,
13
- ContentDeliveryLayerNeighborInfo,
14
- LeaveStreamPartNotice,
15
- MessageID,
16
- MessageRef,
17
- StreamMessage,
18
- TemporaryConnectionRequest,
19
- TemporaryConnectionResponse,
20
- } from '../proto/packages/trackerless-network/protos/NetworkRpc'
21
- import { ContentDeliveryRpcClient } from '../proto/packages/trackerless-network/protos/NetworkRpc.client'
22
- import { ContentDeliveryRpcLocal } from './ContentDeliveryRpcLocal'
23
- import { ContentDeliveryRpcRemote } from './ContentDeliveryRpcRemote'
24
- import { DiscoveryLayerNode } from './DiscoveryLayerNode'
25
- import { DuplicateMessageDetector } from './DuplicateMessageDetector'
26
- import { NodeList } from './NodeList'
27
- import { Inspector } from './inspect/Inspector'
28
- import { Handshaker } from './neighbor-discovery/Handshaker'
29
- import { NeighborFinder } from './neighbor-discovery/NeighborFinder'
30
- import { NeighborUpdateManager } from './neighbor-discovery/NeighborUpdateManager'
31
- import { Propagation } from './propagation/Propagation'
32
- import { ProxyConnectionRpcLocal } from './proxy/ProxyConnectionRpcLocal'
33
- import { TemporaryConnectionRpcLocal } from './temporary-connection/TemporaryConnectionRpcLocal'
34
- import { markAndCheckDuplicate } from './utils'
35
-
36
- export interface Events {
37
- message: (message: StreamMessage) => void
38
- neighborConnected: (nodeId: DhtAddress) => void
39
- entryPointLeaveDetected: () => void
40
- }
41
-
42
- export interface StrictContentDeliveryLayerNodeOptions {
43
- streamPartId: StreamPartID
44
- discoveryLayerNode: DiscoveryLayerNode
45
- transport: ITransport
46
- connectionLocker: ConnectionLocker
47
- localPeerDescriptor: PeerDescriptor
48
- nodeViewSize: number
49
- nearbyNodeView: NodeList
50
- randomNodeView: NodeList
51
- leftNodeView: NodeList
52
- rightNodeView: NodeList
53
- neighbors: NodeList
54
- handshaker: Handshaker
55
- neighborFinder: NeighborFinder
56
- neighborUpdateManager: NeighborUpdateManager
57
- propagation: Propagation
58
- rpcCommunicator: ListeningRpcCommunicator
59
- neighborTargetCount: number
60
- inspector: Inspector
61
- temporaryConnectionRpcLocal: TemporaryConnectionRpcLocal
62
- isLocalNodeEntryPoint: () => boolean
63
-
64
- proxyConnectionRpcLocal?: ProxyConnectionRpcLocal
65
- rpcRequestTimeout?: number
66
- }
67
-
68
- const RANDOM_NODE_VIEW_SIZE = 20
69
-
70
- const logger = new Logger(module)
71
-
72
- export class ContentDeliveryLayerNode extends EventEmitter<Events> {
73
-
74
- private started = false
75
- private readonly duplicateDetectors: Map<string, DuplicateMessageDetector>
76
- private options: StrictContentDeliveryLayerNodeOptions
77
- private readonly contentDeliveryRpcLocal: ContentDeliveryRpcLocal
78
- private abortController: AbortController = new AbortController()
79
- private messagesPropagated = 0
80
-
81
- constructor(options: StrictContentDeliveryLayerNodeOptions) {
82
- super()
83
- this.options = options
84
- this.duplicateDetectors = new Map()
85
- this.contentDeliveryRpcLocal = new ContentDeliveryRpcLocal({
86
- localPeerDescriptor: this.options.localPeerDescriptor,
87
- streamPartId: this.options.streamPartId,
88
- rpcCommunicator: this.options.rpcCommunicator,
89
- markAndCheckDuplicate: (msg: MessageID, prev?: MessageRef) => markAndCheckDuplicate(this.duplicateDetectors, msg, prev),
90
- broadcast: (message: StreamMessage, previousNode?: DhtAddress) => this.broadcast(message, previousNode),
91
- onLeaveNotice: (remoteNodeId: DhtAddress, sourceIsStreamEntryPoint: boolean) => {
92
- if (this.abortController.signal.aborted) {
93
- return
94
- }
95
- const contact = this.options.nearbyNodeView.get(remoteNodeId)
96
- || this.options.randomNodeView.get(remoteNodeId)
97
- || this.options.neighbors.get(remoteNodeId)
98
- || this.options.proxyConnectionRpcLocal?.getConnection(remoteNodeId)?.remote
99
- // TODO: check integrity of notifier?
100
- if (contact) {
101
- this.options.discoveryLayerNode.removeContact(remoteNodeId)
102
- this.options.neighbors.remove(remoteNodeId)
103
- this.options.nearbyNodeView.remove(remoteNodeId)
104
- this.options.randomNodeView.remove(remoteNodeId)
105
- this.options.leftNodeView.remove(remoteNodeId)
106
- this.options.rightNodeView.remove(remoteNodeId)
107
- this.options.neighborFinder.start([remoteNodeId])
108
- this.options.proxyConnectionRpcLocal?.removeConnection(remoteNodeId)
109
- }
110
- if (sourceIsStreamEntryPoint) {
111
- this.emit('entryPointLeaveDetected')
112
- }
113
- },
114
- markForInspection: (remoteNodeId: DhtAddress, messageId: MessageID) => this.options.inspector.markMessage(remoteNodeId, messageId)
115
- })
116
- }
117
-
118
- async start(): Promise<void> {
119
- this.started = true
120
- this.registerDefaultServerMethods()
121
- addManagedEventListener(
122
- this.options.discoveryLayerNode,
123
- 'nearbyContactAdded',
124
- () => this.onNearbyContactAdded(),
125
- this.abortController.signal
126
- )
127
- addManagedEventListener(
128
- this.options.discoveryLayerNode,
129
- 'nearbyContactRemoved',
130
- () => this.onNearbyContactRemoved(),
131
- this.abortController.signal
132
- )
133
- addManagedEventListener(
134
- this.options.discoveryLayerNode,
135
- 'randomContactAdded',
136
- () => this.onRandomContactAdded(),
137
- this.abortController.signal
138
- )
139
- addManagedEventListener(
140
- this.options.discoveryLayerNode,
141
- 'randomContactRemoved',
142
- () => this.onRandomContactRemoved(),
143
- this.abortController.signal
144
- )
145
- addManagedEventListener(
146
- this.options.discoveryLayerNode,
147
- 'ringContactAdded',
148
- () => this.onRingContactsUpdated(),
149
- this.abortController.signal
150
- )
151
- addManagedEventListener(
152
- this.options.discoveryLayerNode,
153
- 'ringContactRemoved',
154
- () => this.onRingContactsUpdated(),
155
- this.abortController.signal
156
- )
157
- addManagedEventListener(
158
- this.options.transport,
159
- 'disconnected',
160
- (peerDescriptor: PeerDescriptor) => this.onNodeDisconnected(peerDescriptor),
161
- this.abortController.signal
162
- )
163
- addManagedEventListener(
164
- this.options.neighbors,
165
- 'nodeAdded',
166
- (id, remote) => {
167
- this.options.propagation.onNeighborJoined(id)
168
- this.options.connectionLocker.weakLockConnection(
169
- toNodeId(remote.getPeerDescriptor()),
170
- this.options.streamPartId
171
- )
172
- this.emit('neighborConnected', id)
173
- },
174
- this.abortController.signal
175
- )
176
- addManagedEventListener(
177
- this.options.neighbors,
178
- 'nodeRemoved',
179
- (_id, remote) => {
180
- this.options.connectionLocker.weakUnlockConnection(
181
- toNodeId(remote.getPeerDescriptor()),
182
- this.options.streamPartId
183
- )
184
- },
185
- this.abortController.signal
186
- )
187
- if (this.options.proxyConnectionRpcLocal !== undefined) {
188
- addManagedEventListener(
189
- this.options.proxyConnectionRpcLocal,
190
- 'newConnection',
191
- (id: DhtAddress) => this.options.propagation.onNeighborJoined(id),
192
- this.abortController.signal
193
- )
194
- }
195
- this.options.neighborFinder.start()
196
- await this.options.neighborUpdateManager.start()
197
- }
198
-
199
- private registerDefaultServerMethods(): void {
200
- this.options.rpcCommunicator.registerRpcNotification(StreamMessage, 'sendStreamMessage',
201
- (msg: StreamMessage, context) => this.contentDeliveryRpcLocal.sendStreamMessage(msg, context))
202
- this.options.rpcCommunicator.registerRpcNotification(LeaveStreamPartNotice, 'leaveStreamPartNotice',
203
- (req: LeaveStreamPartNotice, context) => this.contentDeliveryRpcLocal.leaveStreamPartNotice(req, context))
204
- this.options.rpcCommunicator.registerRpcMethod(TemporaryConnectionRequest, TemporaryConnectionResponse, 'openConnection',
205
- (req: TemporaryConnectionRequest, context) => this.options.temporaryConnectionRpcLocal.openConnection(req, context))
206
- this.options.rpcCommunicator.registerRpcNotification(CloseTemporaryConnection, 'closeConnection',
207
- (req: TemporaryConnectionRequest, context) => this.options.temporaryConnectionRpcLocal.closeConnection(req, context))
208
- }
209
-
210
- private onRingContactsUpdated(): void {
211
- logger.trace('onRingContactsUpdated')
212
- if (this.isStopped()) {
213
- return
214
- }
215
- const contacts = this.options.discoveryLayerNode.getRingContacts()
216
- this.options.leftNodeView.replaceAll(contacts.left.map((peer) =>
217
- new ContentDeliveryRpcRemote(
218
- this.options.localPeerDescriptor,
219
- peer,
220
- this.options.rpcCommunicator,
221
- ContentDeliveryRpcClient,
222
- this.options.rpcRequestTimeout
223
- )
224
- ))
225
- this.options.rightNodeView.replaceAll(contacts.right.map((peer) =>
226
- new ContentDeliveryRpcRemote(
227
- this.options.localPeerDescriptor,
228
- peer,
229
- this.options.rpcCommunicator,
230
- ContentDeliveryRpcClient,
231
- this.options.rpcRequestTimeout
232
- )
233
- ))
234
- }
235
-
236
- private onNearbyContactAdded(): void {
237
- logger.trace(`New nearby contact found`)
238
- if (this.isStopped()) {
239
- return
240
- }
241
- const closestContacts = this.options.discoveryLayerNode.getClosestContacts()
242
- this.updateNearbyNodeView(closestContacts)
243
- if (this.options.neighbors.size() < this.options.neighborTargetCount) {
244
- this.options.neighborFinder.start()
245
- }
246
- }
247
-
248
- private onNearbyContactRemoved(): void {
249
- logger.trace(`Nearby contact removed`)
250
- if (this.isStopped()) {
251
- return
252
- }
253
- const closestContacts = this.options.discoveryLayerNode.getClosestContacts()
254
- this.updateNearbyNodeView(closestContacts)
255
- }
256
-
257
- private updateNearbyNodeView(nodes: PeerDescriptor[]) {
258
- this.options.nearbyNodeView.replaceAll(Array.from(nodes).map((descriptor) =>
259
- new ContentDeliveryRpcRemote(
260
- this.options.localPeerDescriptor,
261
- descriptor,
262
- this.options.rpcCommunicator,
263
- ContentDeliveryRpcClient,
264
- this.options.rpcRequestTimeout
265
- )
266
- ))
267
- for (const descriptor of this.options.discoveryLayerNode.getNeighbors()) {
268
- if (this.options.nearbyNodeView.size() >= this.options.nodeViewSize) {
269
- break
270
- }
271
- this.options.nearbyNodeView.add(
272
- new ContentDeliveryRpcRemote(
273
- this.options.localPeerDescriptor,
274
- descriptor,
275
- this.options.rpcCommunicator,
276
- ContentDeliveryRpcClient,
277
- this.options.rpcRequestTimeout
278
- )
279
- )
280
- }
281
- }
282
-
283
- private onRandomContactAdded(): void {
284
- if (this.isStopped()) {
285
- return
286
- }
287
- const randomContacts = this.options.discoveryLayerNode.getRandomContacts(RANDOM_NODE_VIEW_SIZE)
288
- this.options.randomNodeView.replaceAll(randomContacts.map((descriptor) =>
289
- new ContentDeliveryRpcRemote(
290
- this.options.localPeerDescriptor,
291
- descriptor,
292
- this.options.rpcCommunicator,
293
- ContentDeliveryRpcClient,
294
- this.options.rpcRequestTimeout
295
- )
296
- ))
297
- if (this.options.neighbors.size() < this.options.neighborTargetCount) {
298
- this.options.neighborFinder.start()
299
- }
300
- }
301
-
302
- private onRandomContactRemoved(): void {
303
- logger.trace(`New random contact removed`)
304
- if (this.isStopped()) {
305
- return
306
- }
307
- const randomContacts = this.options.discoveryLayerNode.getRandomContacts(RANDOM_NODE_VIEW_SIZE)
308
- this.options.randomNodeView.replaceAll(randomContacts.map((descriptor) =>
309
- new ContentDeliveryRpcRemote(
310
- this.options.localPeerDescriptor,
311
- descriptor,
312
- this.options.rpcCommunicator,
313
- ContentDeliveryRpcClient,
314
- this.options.rpcRequestTimeout
315
- )
316
- ))
317
- }
318
-
319
- private onNodeDisconnected(peerDescriptor: PeerDescriptor): void {
320
- const nodeId = toNodeId(peerDescriptor)
321
- if (this.options.neighbors.has(nodeId)) {
322
- this.options.neighbors.remove(nodeId)
323
- this.options.neighborFinder.start([nodeId])
324
- this.options.temporaryConnectionRpcLocal.removeNode(nodeId)
325
- }
326
- }
327
-
328
- hasProxyConnection(nodeId: DhtAddress): boolean {
329
- if (this.options.proxyConnectionRpcLocal) {
330
- return this.options.proxyConnectionRpcLocal.hasConnection(nodeId)
331
- }
332
- return false
333
- }
334
-
335
- stop(): void {
336
- if (!this.started) {
337
- return
338
- }
339
- this.abortController.abort()
340
- this.options.proxyConnectionRpcLocal?.stop()
341
- this.options.neighbors.getAll().map((remote) => {
342
- remote.leaveStreamPartNotice(this.options.streamPartId, this.options.isLocalNodeEntryPoint())
343
- this.options.connectionLocker.weakUnlockConnection(
344
- toNodeId(remote.getPeerDescriptor()),
345
- this.options.streamPartId
346
- )
347
- })
348
- this.options.rpcCommunicator.destroy()
349
- this.removeAllListeners()
350
- this.options.nearbyNodeView.stop()
351
- this.options.neighbors.stop()
352
- this.options.randomNodeView.stop()
353
- this.options.neighborFinder.stop()
354
- this.options.neighborUpdateManager.stop()
355
- this.options.inspector.stop()
356
- }
357
-
358
- broadcast(msg: StreamMessage, previousNode?: DhtAddress): void {
359
- if (!previousNode) {
360
- markAndCheckDuplicate(this.duplicateDetectors, msg.messageId!, msg.previousMessageRef)
361
- }
362
- this.emit('message', msg)
363
- const skipBackPropagation = previousNode !== undefined && !this.options.temporaryConnectionRpcLocal.hasNode(previousNode)
364
- this.options.propagation.feedUnseenMessage(msg, this.getPropagationTargets(msg), skipBackPropagation ? previousNode : null)
365
- this.messagesPropagated += 1
366
- }
367
-
368
- inspect(peerDescriptor: PeerDescriptor): Promise<boolean> {
369
- return this.options.inspector.inspect(peerDescriptor)
370
- }
371
-
372
- private getPropagationTargets(msg: StreamMessage): DhtAddress[] {
373
- let propagationTargets = this.options.neighbors.getIds()
374
- if (this.options.proxyConnectionRpcLocal) {
375
- propagationTargets = propagationTargets.concat(this.options.proxyConnectionRpcLocal.getPropagationTargets(msg))
376
- }
377
- propagationTargets = propagationTargets.concat(this.options.temporaryConnectionRpcLocal.getNodes().getIds())
378
- return propagationTargets
379
- }
380
-
381
- getOwnNodeId(): DhtAddress {
382
- return toNodeId(this.options.localPeerDescriptor)
383
- }
384
-
385
- getOutgoingHandshakeCount(): number {
386
- return this.options.handshaker.getOngoingHandshakes().size
387
- }
388
-
389
- getNeighbors(): PeerDescriptor[] {
390
- if (!this.started && this.isStopped()) {
391
- return []
392
- }
393
- return this.options.neighbors.getAll().map((n) => n.getPeerDescriptor())
394
- }
395
-
396
- getInfos(): ContentDeliveryLayerNeighborInfo[] {
397
- return this.options.neighbors.getAll().map((n) => {
398
- return {
399
- peerDescriptor: n.getPeerDescriptor(),
400
- rtt: n.getRtt()
401
- }
402
- })
403
- }
404
-
405
- getNearbyNodeView(): NodeList {
406
- return this.options.nearbyNodeView
407
- }
408
-
409
- public getDiagnosticInfo(): Record<string, unknown> {
410
- return {
411
- neighborCount: this.options.neighbors.size(),
412
- nearbyNodeViewCount: this.options.nearbyNodeView.size(),
413
- randomNodeViewCount: this.options.randomNodeView.size(),
414
- leftNodeViewCount: this.options.leftNodeView.size(),
415
- rightNodeViewCount: this.options.rightNodeView.size(),
416
- messagesPropagated: this.messagesPropagated
417
- }
418
- }
419
-
420
- private isStopped() {
421
- return this.abortController.signal.aborted
422
- }
423
-
424
- }