@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.
Files changed (303) hide show
  1. package/dist/exports-browser.cjs +7636 -0
  2. package/dist/exports-browser.cjs.map +1 -0
  3. package/dist/exports-browser.d.ts +1321 -0
  4. package/dist/exports-browser.js +7611 -0
  5. package/dist/exports-browser.js.map +1 -0
  6. package/dist/exports-nodejs.cjs +7833 -0
  7. package/dist/exports-nodejs.cjs.map +1 -0
  8. package/dist/exports-nodejs.d.ts +1321 -0
  9. package/dist/exports-nodejs.js +7808 -0
  10. package/dist/exports-nodejs.js.map +1 -0
  11. package/package.json +41 -25
  12. package/dist/generated/google/protobuf/any.d.ts +0 -180
  13. package/dist/generated/google/protobuf/any.js +0 -155
  14. package/dist/generated/google/protobuf/any.js.map +0 -1
  15. package/dist/generated/google/protobuf/empty.d.ts +0 -31
  16. package/dist/generated/google/protobuf/empty.js +0 -45
  17. package/dist/generated/google/protobuf/empty.js.map +0 -1
  18. package/dist/generated/google/protobuf/timestamp.d.ts +0 -156
  19. package/dist/generated/google/protobuf/timestamp.js +0 -136
  20. package/dist/generated/google/protobuf/timestamp.js.map +0 -1
  21. package/dist/generated/packages/dht/protos/DhtRpc.client.d.ts +0 -371
  22. package/dist/generated/packages/dht/protos/DhtRpc.client.js +0 -292
  23. package/dist/generated/packages/dht/protos/DhtRpc.client.js.map +0 -1
  24. package/dist/generated/packages/dht/protos/DhtRpc.d.ts +0 -1031
  25. package/dist/generated/packages/dht/protos/DhtRpc.js +0 -702
  26. package/dist/generated/packages/dht/protos/DhtRpc.js.map +0 -1
  27. package/dist/generated/packages/dht/protos/DhtRpc.server.d.ts +0 -168
  28. package/dist/generated/packages/dht/protos/DhtRpc.server.js +0 -3
  29. package/dist/generated/packages/dht/protos/DhtRpc.server.js.map +0 -1
  30. package/dist/generated/packages/proto-rpc/protos/ProtoRpc.d.ts +0 -87
  31. package/dist/generated/packages/proto-rpc/protos/ProtoRpc.js +0 -66
  32. package/dist/generated/packages/proto-rpc/protos/ProtoRpc.js.map +0 -1
  33. package/dist/package.json +0 -61
  34. package/dist/src/connection/Connection.d.ts +0 -12
  35. package/dist/src/connection/Connection.js +0 -30
  36. package/dist/src/connection/Connection.js.map +0 -1
  37. package/dist/src/connection/ConnectionLockRpcLocal.d.ts +0 -22
  38. package/dist/src/connection/ConnectionLockRpcLocal.js +0 -54
  39. package/dist/src/connection/ConnectionLockRpcLocal.js.map +0 -1
  40. package/dist/src/connection/ConnectionLockRpcRemote.d.ts +0 -10
  41. package/dist/src/connection/ConnectionLockRpcRemote.js +0 -61
  42. package/dist/src/connection/ConnectionLockRpcRemote.js.map +0 -1
  43. package/dist/src/connection/ConnectionLockStates.d.ts +0 -27
  44. package/dist/src/connection/ConnectionLockStates.js +0 -114
  45. package/dist/src/connection/ConnectionLockStates.js.map +0 -1
  46. package/dist/src/connection/ConnectionManager.d.ts +0 -85
  47. package/dist/src/connection/ConnectionManager.js +0 -569
  48. package/dist/src/connection/ConnectionManager.js.map +0 -1
  49. package/dist/src/connection/ConnectionsView.d.ts +0 -7
  50. package/dist/src/connection/ConnectionsView.js +0 -3
  51. package/dist/src/connection/ConnectionsView.js.map +0 -1
  52. package/dist/src/connection/ConnectorFacade.d.ts +0 -58
  53. package/dist/src/connection/ConnectorFacade.js +0 -154
  54. package/dist/src/connection/ConnectorFacade.js.map +0 -1
  55. package/dist/src/connection/Handshaker.d.ts +0 -27
  56. package/dist/src/connection/Handshaker.js +0 -179
  57. package/dist/src/connection/Handshaker.js.map +0 -1
  58. package/dist/src/connection/IConnection.d.ts +0 -32
  59. package/dist/src/connection/IConnection.js +0 -12
  60. package/dist/src/connection/IConnection.js.map +0 -1
  61. package/dist/src/connection/ManagedConnection.d.ts +0 -30
  62. package/dist/src/connection/ManagedConnection.js +0 -129
  63. package/dist/src/connection/ManagedConnection.js.map +0 -1
  64. package/dist/src/connection/OutputBuffer.d.ts +0 -9
  65. package/dist/src/connection/OutputBuffer.js +0 -26
  66. package/dist/src/connection/OutputBuffer.js.map +0 -1
  67. package/dist/src/connection/PendingConnection.d.ts +0 -19
  68. package/dist/src/connection/PendingConnection.js +0 -59
  69. package/dist/src/connection/PendingConnection.js.map +0 -1
  70. package/dist/src/connection/connectivityChecker.d.ts +0 -9
  71. package/dist/src/connection/connectivityChecker.js +0 -138
  72. package/dist/src/connection/connectivityChecker.js.map +0 -1
  73. package/dist/src/connection/connectivityRequestHandler.d.ts +0 -4
  74. package/dist/src/connection/connectivityRequestHandler.js +0 -108
  75. package/dist/src/connection/connectivityRequestHandler.js.map +0 -1
  76. package/dist/src/connection/simulator/Simulator.d.ts +0 -36
  77. package/dist/src/connection/simulator/Simulator.js +0 -290
  78. package/dist/src/connection/simulator/Simulator.js.map +0 -1
  79. package/dist/src/connection/simulator/SimulatorConnection.d.ts +0 -18
  80. package/dist/src/connection/simulator/SimulatorConnection.js +0 -123
  81. package/dist/src/connection/simulator/SimulatorConnection.js.map +0 -1
  82. package/dist/src/connection/simulator/SimulatorConnector.d.ts +0 -16
  83. package/dist/src/connection/simulator/SimulatorConnector.js +0 -80
  84. package/dist/src/connection/simulator/SimulatorConnector.js.map +0 -1
  85. package/dist/src/connection/simulator/SimulatorTransport.d.ts +0 -6
  86. package/dist/src/connection/simulator/SimulatorTransport.js +0 -17
  87. package/dist/src/connection/simulator/SimulatorTransport.js.map +0 -1
  88. package/dist/src/connection/simulator/pings.d.ts +0 -21
  89. package/dist/src/connection/simulator/pings.js +0 -61
  90. package/dist/src/connection/simulator/pings.js.map +0 -1
  91. package/dist/src/connection/webrtc/BrowserWebrtcConnection.d.ts +0 -37
  92. package/dist/src/connection/webrtc/BrowserWebrtcConnection.js +0 -229
  93. package/dist/src/connection/webrtc/BrowserWebrtcConnection.js.map +0 -1
  94. package/dist/src/connection/webrtc/IWebrtcConnection.d.ts +0 -21
  95. package/dist/src/connection/webrtc/IWebrtcConnection.js +0 -9
  96. package/dist/src/connection/webrtc/IWebrtcConnection.js.map +0 -1
  97. package/dist/src/connection/webrtc/NodeWebrtcConnection.d.ts +0 -45
  98. package/dist/src/connection/webrtc/NodeWebrtcConnection.js +0 -229
  99. package/dist/src/connection/webrtc/NodeWebrtcConnection.js.map +0 -1
  100. package/dist/src/connection/webrtc/WebrtcConnector.d.ts +0 -43
  101. package/dist/src/connection/webrtc/WebrtcConnector.js +0 -208
  102. package/dist/src/connection/webrtc/WebrtcConnector.js.map +0 -1
  103. package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.d.ts +0 -26
  104. package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.js +0 -82
  105. package/dist/src/connection/webrtc/WebrtcConnectorRpcLocal.js.map +0 -1
  106. package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.d.ts +0 -8
  107. package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.js +0 -50
  108. package/dist/src/connection/webrtc/WebrtcConnectorRpcRemote.js.map +0 -1
  109. package/dist/src/connection/webrtc/iceServerAsString.d.ts +0 -2
  110. package/dist/src/connection/webrtc/iceServerAsString.js +0 -17
  111. package/dist/src/connection/webrtc/iceServerAsString.js.map +0 -1
  112. package/dist/src/connection/websocket/AbstractWebsocketClientConnection.d.ts +0 -27
  113. package/dist/src/connection/websocket/AbstractWebsocketClientConnection.js +0 -107
  114. package/dist/src/connection/websocket/AbstractWebsocketClientConnection.js.map +0 -1
  115. package/dist/src/connection/websocket/AutoCertifierClientFacade.d.ts +0 -26
  116. package/dist/src/connection/websocket/AutoCertifierClientFacade.js +0 -39
  117. package/dist/src/connection/websocket/AutoCertifierClientFacade.js.map +0 -1
  118. package/dist/src/connection/websocket/BrowserWebsocketClientConnection.d.ts +0 -7
  119. package/dist/src/connection/websocket/BrowserWebsocketClientConnection.js +0 -44
  120. package/dist/src/connection/websocket/BrowserWebsocketClientConnection.js.map +0 -1
  121. package/dist/src/connection/websocket/NodeWebsocketClientConnection.d.ts +0 -7
  122. package/dist/src/connection/websocket/NodeWebsocketClientConnection.js +0 -39
  123. package/dist/src/connection/websocket/NodeWebsocketClientConnection.js.map +0 -1
  124. package/dist/src/connection/websocket/WebsocketClientConnector.d.ts +0 -26
  125. package/dist/src/connection/websocket/WebsocketClientConnector.js +0 -86
  126. package/dist/src/connection/websocket/WebsocketClientConnector.js.map +0 -1
  127. package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.d.ts +0 -18
  128. package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.js +0 -23
  129. package/dist/src/connection/websocket/WebsocketClientConnectorRpcLocal.js.map +0 -1
  130. package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.d.ts +0 -5
  131. package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.js +0 -17
  132. package/dist/src/connection/websocket/WebsocketClientConnectorRpcRemote.js.map +0 -1
  133. package/dist/src/connection/websocket/WebsocketServer.d.ts +0 -25
  134. package/dist/src/connection/websocket/WebsocketServer.js +0 -146
  135. package/dist/src/connection/websocket/WebsocketServer.js.map +0 -1
  136. package/dist/src/connection/websocket/WebsocketServerConnection.d.ts +0 -22
  137. package/dist/src/connection/websocket/WebsocketServerConnection.js +0 -101
  138. package/dist/src/connection/websocket/WebsocketServerConnection.js.map +0 -1
  139. package/dist/src/connection/websocket/WebsocketServerConnector.d.ts +0 -44
  140. package/dist/src/connection/websocket/WebsocketServerConnector.js +0 -279
  141. package/dist/src/connection/websocket/WebsocketServerConnector.js.map +0 -1
  142. package/dist/src/dht/DhtNode.d.ts +0 -119
  143. package/dist/src/dht/DhtNode.js +0 -500
  144. package/dist/src/dht/DhtNode.js.map +0 -1
  145. package/dist/src/dht/DhtNodeRpcLocal.d.ts +0 -23
  146. package/dist/src/dht/DhtNodeRpcLocal.js +0 -54
  147. package/dist/src/dht/DhtNodeRpcLocal.js.map +0 -1
  148. package/dist/src/dht/DhtNodeRpcRemote.d.ts +0 -25
  149. package/dist/src/dht/DhtNodeRpcRemote.js +0 -83
  150. package/dist/src/dht/DhtNodeRpcRemote.js.map +0 -1
  151. package/dist/src/dht/ExternalApiRpcLocal.d.ts +0 -18
  152. package/dist/src/dht/ExternalApiRpcLocal.js +0 -32
  153. package/dist/src/dht/ExternalApiRpcLocal.js.map +0 -1
  154. package/dist/src/dht/ExternalApiRpcRemote.d.ts +0 -10
  155. package/dist/src/dht/ExternalApiRpcRemote.js +0 -58
  156. package/dist/src/dht/ExternalApiRpcRemote.js.map +0 -1
  157. package/dist/src/dht/PeerManager.d.ts +0 -63
  158. package/dist/src/dht/PeerManager.js +0 -251
  159. package/dist/src/dht/PeerManager.js.map +0 -1
  160. package/dist/src/dht/contact/Contact.d.ts +0 -8
  161. package/dist/src/dht/contact/Contact.js +0 -18
  162. package/dist/src/dht/contact/Contact.js.map +0 -1
  163. package/dist/src/dht/contact/ContactList.d.ts +0 -19
  164. package/dist/src/dht/contact/ContactList.js +0 -35
  165. package/dist/src/dht/contact/ContactList.js.map +0 -1
  166. package/dist/src/dht/contact/RandomContactList.d.ts +0 -11
  167. package/dist/src/dht/contact/RandomContactList.js +0 -47
  168. package/dist/src/dht/contact/RandomContactList.js.map +0 -1
  169. package/dist/src/dht/contact/RingContactList.d.ts +0 -28
  170. package/dist/src/dht/contact/RingContactList.js +0 -126
  171. package/dist/src/dht/contact/RingContactList.js.map +0 -1
  172. package/dist/src/dht/contact/RpcRemote.d.ts +0 -19
  173. package/dist/src/dht/contact/RpcRemote.js +0 -61
  174. package/dist/src/dht/contact/RpcRemote.js.map +0 -1
  175. package/dist/src/dht/contact/SortedContactList.d.ts +0 -37
  176. package/dist/src/dht/contact/SortedContactList.js +0 -134
  177. package/dist/src/dht/contact/SortedContactList.js.map +0 -1
  178. package/dist/src/dht/contact/getClosestNodes.d.ts +0 -6
  179. package/dist/src/dht/contact/getClosestNodes.js +0 -19
  180. package/dist/src/dht/contact/getClosestNodes.js.map +0 -1
  181. package/dist/src/dht/contact/ringIdentifiers.d.ts +0 -16
  182. package/dist/src/dht/contact/ringIdentifiers.js +0 -54
  183. package/dist/src/dht/contact/ringIdentifiers.js.map +0 -1
  184. package/dist/src/dht/discovery/DiscoverySession.d.ts +0 -29
  185. package/dist/src/dht/discovery/DiscoverySession.js +0 -102
  186. package/dist/src/dht/discovery/DiscoverySession.js.map +0 -1
  187. package/dist/src/dht/discovery/PeerDiscovery.d.ts +0 -42
  188. package/dist/src/dht/discovery/PeerDiscovery.js +0 -193
  189. package/dist/src/dht/discovery/PeerDiscovery.js.map +0 -1
  190. package/dist/src/dht/discovery/RingDiscoverySession.d.ts +0 -28
  191. package/dist/src/dht/discovery/RingDiscoverySession.js +0 -116
  192. package/dist/src/dht/discovery/RingDiscoverySession.js.map +0 -1
  193. package/dist/src/dht/recursive-operation/RecursiveOperationManager.d.ts +0 -38
  194. package/dist/src/dht/recursive-operation/RecursiveOperationManager.js +0 -165
  195. package/dist/src/dht/recursive-operation/RecursiveOperationManager.js.map +0 -1
  196. package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.d.ts +0 -14
  197. package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.js +0 -26
  198. package/dist/src/dht/recursive-operation/RecursiveOperationRpcLocal.js.map +0 -1
  199. package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.d.ts +0 -6
  200. package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.js +0 -44
  201. package/dist/src/dht/recursive-operation/RecursiveOperationRpcRemote.js.map +0 -1
  202. package/dist/src/dht/recursive-operation/RecursiveOperationSession.d.ts +0 -45
  203. package/dist/src/dht/recursive-operation/RecursiveOperationSession.js +0 -185
  204. package/dist/src/dht/recursive-operation/RecursiveOperationSession.js.map +0 -1
  205. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.d.ts +0 -14
  206. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.js +0 -20
  207. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcLocal.js.map +0 -1
  208. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.d.ts +0 -6
  209. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.js +0 -21
  210. package/dist/src/dht/recursive-operation/RecursiveOperationSessionRpcRemote.js.map +0 -1
  211. package/dist/src/dht/routing/DuplicateDetector.d.ts +0 -10
  212. package/dist/src/dht/routing/DuplicateDetector.js +0 -31
  213. package/dist/src/dht/routing/DuplicateDetector.js.map +0 -1
  214. package/dist/src/dht/routing/Router.d.ts +0 -35
  215. package/dist/src/dht/routing/Router.js +0 -204
  216. package/dist/src/dht/routing/Router.js.map +0 -1
  217. package/dist/src/dht/routing/RouterRpcLocal.d.ts +0 -20
  218. package/dist/src/dht/routing/RouterRpcLocal.js +0 -67
  219. package/dist/src/dht/routing/RouterRpcLocal.js.map +0 -1
  220. package/dist/src/dht/routing/RouterRpcRemote.d.ts +0 -8
  221. package/dist/src/dht/routing/RouterRpcRemote.js +0 -81
  222. package/dist/src/dht/routing/RouterRpcRemote.js.map +0 -1
  223. package/dist/src/dht/routing/RoutingSession.d.ts +0 -56
  224. package/dist/src/dht/routing/RoutingSession.js +0 -201
  225. package/dist/src/dht/routing/RoutingSession.js.map +0 -1
  226. package/dist/src/dht/routing/RoutingTablesCache.d.ts +0 -24
  227. package/dist/src/dht/routing/RoutingTablesCache.js +0 -46
  228. package/dist/src/dht/routing/RoutingTablesCache.js.map +0 -1
  229. package/dist/src/dht/routing/getPreviousPeer.d.ts +0 -2
  230. package/dist/src/dht/routing/getPreviousPeer.js +0 -12
  231. package/dist/src/dht/routing/getPreviousPeer.js.map +0 -1
  232. package/dist/src/dht/store/LocalDataStore.d.ts +0 -14
  233. package/dist/src/dht/store/LocalDataStore.js +0 -78
  234. package/dist/src/dht/store/LocalDataStore.js.map +0 -1
  235. package/dist/src/dht/store/StoreManager.d.ts +0 -32
  236. package/dist/src/dht/store/StoreManager.js +0 -126
  237. package/dist/src/dht/store/StoreManager.js.map +0 -1
  238. package/dist/src/dht/store/StoreRpcLocal.d.ts +0 -21
  239. package/dist/src/dht/store/StoreRpcLocal.js +0 -65
  240. package/dist/src/dht/store/StoreRpcLocal.js.map +0 -1
  241. package/dist/src/dht/store/StoreRpcRemote.d.ts +0 -7
  242. package/dist/src/dht/store/StoreRpcRemote.js +0 -29
  243. package/dist/src/dht/store/StoreRpcRemote.js.map +0 -1
  244. package/dist/src/exports.d.ts +0 -25
  245. package/dist/src/exports.js +0 -48
  246. package/dist/src/exports.js.map +0 -1
  247. package/dist/src/helpers/AddressTools.d.ts +0 -2
  248. package/dist/src/helpers/AddressTools.js +0 -32
  249. package/dist/src/helpers/AddressTools.js.map +0 -1
  250. package/dist/src/helpers/Connectivity.d.ts +0 -4
  251. package/dist/src/helpers/Connectivity.js +0 -24
  252. package/dist/src/helpers/Connectivity.js.map +0 -1
  253. package/dist/src/helpers/browser/isBrowserEnvironment.d.ts +0 -1
  254. package/dist/src/helpers/browser/isBrowserEnvironment.js +0 -6
  255. package/dist/src/helpers/browser/isBrowserEnvironment.js.map +0 -1
  256. package/dist/src/helpers/browser/isBrowserEnvironment_override.d.ts +0 -1
  257. package/dist/src/helpers/browser/isBrowserEnvironment_override.js +0 -7
  258. package/dist/src/helpers/browser/isBrowserEnvironment_override.js.map +0 -1
  259. package/dist/src/helpers/createPeerDescriptor.d.ts +0 -3
  260. package/dist/src/helpers/createPeerDescriptor.js +0 -58
  261. package/dist/src/helpers/createPeerDescriptor.js.map +0 -1
  262. package/dist/src/helpers/createPeerDescriptorSignaturePayload.d.ts +0 -2
  263. package/dist/src/helpers/createPeerDescriptorSignaturePayload.js +0 -30
  264. package/dist/src/helpers/createPeerDescriptorSignaturePayload.js.map +0 -1
  265. package/dist/src/helpers/debugHelpers.d.ts +0 -3
  266. package/dist/src/helpers/debugHelpers.js +0 -11
  267. package/dist/src/helpers/debugHelpers.js.map +0 -1
  268. package/dist/src/helpers/errors.d.ts +0 -72
  269. package/dist/src/helpers/errors.js +0 -97
  270. package/dist/src/helpers/errors.js.map +0 -1
  271. package/dist/src/helpers/offering.d.ts +0 -4
  272. package/dist/src/helpers/offering.js +0 -18
  273. package/dist/src/helpers/offering.js.map +0 -1
  274. package/dist/src/helpers/protoClasses.d.ts +0 -2
  275. package/dist/src/helpers/protoClasses.js +0 -32
  276. package/dist/src/helpers/protoClasses.js.map +0 -1
  277. package/dist/src/helpers/protoToString.d.ts +0 -2
  278. package/dist/src/helpers/protoToString.js +0 -19
  279. package/dist/src/helpers/protoToString.js.map +0 -1
  280. package/dist/src/helpers/version.d.ts +0 -6
  281. package/dist/src/helpers/version.js +0 -38
  282. package/dist/src/helpers/version.js.map +0 -1
  283. package/dist/src/identifiers.d.ts +0 -10
  284. package/dist/src/identifiers.js +0 -31
  285. package/dist/src/identifiers.js.map +0 -1
  286. package/dist/src/rpc-protocol/DhtCallContext.d.ts +0 -12
  287. package/dist/src/rpc-protocol/DhtCallContext.js +0 -17
  288. package/dist/src/rpc-protocol/DhtCallContext.js.map +0 -1
  289. package/dist/src/rpc-protocol/DhtRpcOptions.d.ts +0 -10
  290. package/dist/src/rpc-protocol/DhtRpcOptions.js +0 -3
  291. package/dist/src/rpc-protocol/DhtRpcOptions.js.map +0 -1
  292. package/dist/src/transport/ITransport.d.ts +0 -31
  293. package/dist/src/transport/ITransport.js +0 -9
  294. package/dist/src/transport/ITransport.js.map +0 -1
  295. package/dist/src/transport/ListeningRpcCommunicator.d.ts +0 -11
  296. package/dist/src/transport/ListeningRpcCommunicator.js +0 -31
  297. package/dist/src/transport/ListeningRpcCommunicator.js.map +0 -1
  298. package/dist/src/transport/RoutingRpcCommunicator.d.ts +0 -10
  299. package/dist/src/transport/RoutingRpcCommunicator.js +0 -60
  300. package/dist/src/transport/RoutingRpcCommunicator.js.map +0 -1
  301. package/dist/src/types/ServiceID.d.ts +0 -1
  302. package/dist/src/types/ServiceID.js +0 -3
  303. package/dist/src/types/ServiceID.js.map +0 -1
@@ -1,31 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.DuplicateDetector = void 0;
4
- class DuplicateDetector {
5
- values = new Set();
6
- queue = [];
7
- maxItemCount;
8
- constructor(maxItemCount) {
9
- this.maxItemCount = maxItemCount;
10
- }
11
- add(value) {
12
- this.values.add(value);
13
- this.queue.push(value);
14
- if (this.queue.length > this.maxItemCount) {
15
- const removed = this.queue.shift();
16
- this.values.delete(removed);
17
- }
18
- }
19
- isMostLikelyDuplicate(value) {
20
- return this.values.has(value);
21
- }
22
- size() {
23
- return this.values.size;
24
- }
25
- clear() {
26
- this.values.clear();
27
- this.queue = [];
28
- }
29
- }
30
- exports.DuplicateDetector = DuplicateDetector;
31
- //# sourceMappingURL=DuplicateDetector.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"DuplicateDetector.js","sourceRoot":"","sources":["../../../../src/dht/routing/DuplicateDetector.ts"],"names":[],"mappings":";;;AAAA,MAAa,iBAAiB;IAElB,MAAM,GAAgB,IAAI,GAAG,EAAE,CAAA;IAC/B,KAAK,GAAa,EAAE,CAAA;IACpB,YAAY,CAAQ;IAE5B,YACI,YAAoB;QAEpB,IAAI,CAAC,YAAY,GAAG,YAAY,CAAA;IACpC,CAAC;IAEM,GAAG,CAAC,KAAa;QACpB,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;QACtB,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAA;QACtB,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,IAAI,CAAC,YAAY,EAAE,CAAC;YACxC,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,KAAK,EAAG,CAAA;YACnC,IAAI,CAAC,MAAM,CAAC,MAAM,CAAC,OAAO,CAAC,CAAA;QAC/B,CAAC;IACL,CAAC;IAEM,qBAAqB,CAAC,KAAa;QACtC,OAAO,IAAI,CAAC,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,CAAA;IACjC,CAAC;IAEM,IAAI;QACP,OAAO,IAAI,CAAC,MAAM,CAAC,IAAI,CAAA;IAC3B,CAAC;IAEM,KAAK;QACR,IAAI,CAAC,MAAM,CAAC,KAAK,EAAE,CAAA;QACnB,IAAI,CAAC,KAAK,GAAG,EAAE,CAAA;IACnB,CAAC;CACJ;AAjCD,8CAiCC"}
@@ -1,35 +0,0 @@
1
- import { Message, PeerDescriptor, RouteMessageAck, RouteMessageWrapper } from '../../../generated/packages/dht/protos/DhtRpc';
2
- import { RoutingMode, RoutingSession } from './RoutingSession';
3
- import { RoutingRpcCommunicator } from '../../transport/RoutingRpcCommunicator';
4
- import { DhtAddress } from '../../identifiers';
5
- export interface RouterOptions {
6
- rpcCommunicator: RoutingRpcCommunicator;
7
- localPeerDescriptor: PeerDescriptor;
8
- handleMessage: (message: Message) => void;
9
- getConnections: () => PeerDescriptor[];
10
- }
11
- export declare class Router {
12
- private readonly forwardingTable;
13
- private readonly routingTablesCache;
14
- private ongoingRoutingSessions;
15
- private readonly duplicateRequestDetector;
16
- private stopped;
17
- private readonly options;
18
- private messagesRouted;
19
- private messagesSent;
20
- constructor(options: RouterOptions);
21
- private registerLocalRpcMethods;
22
- send(msg: Message, reachableThrough: PeerDescriptor[]): void;
23
- doRouteMessage(routedMessage: RouteMessageWrapper, mode?: RoutingMode, excludedPeer?: DhtAddress): RouteMessageAck;
24
- private createRoutingSession;
25
- isMostLikelyDuplicate(requestId: string): boolean;
26
- addToDuplicateDetector(requestId: string): void;
27
- addRoutingSession(session: RoutingSession): void;
28
- removeRoutingSession(sessionId: string): void;
29
- onNodeConnected(peerDescriptor: PeerDescriptor): void;
30
- onNodeDisconnected(peerDescriptor: PeerDescriptor): void;
31
- resetCache(): void;
32
- stop(): void;
33
- getDiagnosticInfo(): Record<string, unknown>;
34
- private setForwardingEntries;
35
- }
@@ -1,204 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.Router = void 0;
4
- const DhtRpc_1 = require("../../../generated/packages/dht/protos/DhtRpc");
5
- const RoutingSession_1 = require("./RoutingSession");
6
- const utils_1 = require("@streamr/utils");
7
- const DuplicateDetector_1 = require("./DuplicateDetector");
8
- const uuid_1 = require("uuid");
9
- const RouterRpcLocal_1 = require("./RouterRpcLocal");
10
- const identifiers_1 = require("../../identifiers");
11
- const RoutingTablesCache_1 = require("./RoutingTablesCache");
12
- const logger = new utils_1.Logger(module);
13
- class Router {
14
- forwardingTable = new Map();
15
- routingTablesCache = new RoutingTablesCache_1.RoutingTablesCache();
16
- ongoingRoutingSessions = new Map();
17
- // TODO use options option or named constant?
18
- duplicateRequestDetector = new DuplicateDetector_1.DuplicateDetector(10000);
19
- stopped = false;
20
- options;
21
- messagesRouted = 0;
22
- messagesSent = 0;
23
- constructor(options) {
24
- this.options = options;
25
- this.registerLocalRpcMethods();
26
- }
27
- registerLocalRpcMethods() {
28
- const rpcLocal = new RouterRpcLocal_1.RouterRpcLocal({
29
- doRouteMessage: (routedMessage, mode) => this.doRouteMessage(routedMessage, mode),
30
- setForwardingEntries: (routedMessage) => this.setForwardingEntries(routedMessage),
31
- duplicateRequestDetector: this.duplicateRequestDetector,
32
- localPeerDescriptor: this.options.localPeerDescriptor,
33
- handleMessage: this.options.handleMessage
34
- });
35
- this.options.rpcCommunicator.registerRpcMethod(DhtRpc_1.RouteMessageWrapper, DhtRpc_1.RouteMessageAck, 'routeMessage', async (routedMessage) => {
36
- if (this.stopped) {
37
- return (0, RouterRpcLocal_1.createRouteMessageAck)(routedMessage, DhtRpc_1.RouteMessageError.STOPPED);
38
- }
39
- return rpcLocal.routeMessage(routedMessage);
40
- });
41
- this.options.rpcCommunicator.registerRpcMethod(DhtRpc_1.RouteMessageWrapper, DhtRpc_1.RouteMessageAck, 'forwardMessage', async (forwardMessage) => {
42
- if (this.stopped) {
43
- return (0, RouterRpcLocal_1.createRouteMessageAck)(forwardMessage, DhtRpc_1.RouteMessageError.STOPPED);
44
- }
45
- return rpcLocal.forwardMessage(forwardMessage);
46
- });
47
- }
48
- send(msg, reachableThrough) {
49
- msg.sourceDescriptor = this.options.localPeerDescriptor;
50
- const targetPeerDescriptor = msg.targetDescriptor;
51
- const forwardingEntry = this.forwardingTable.get((0, identifiers_1.toNodeId)(targetPeerDescriptor));
52
- if (forwardingEntry && forwardingEntry.peerDescriptors.length > 0) {
53
- const forwardedMessage = {
54
- message: msg,
55
- requestId: (0, uuid_1.v4)(),
56
- target: forwardingEntry.peerDescriptors[0].nodeId,
57
- sourcePeer: this.options.localPeerDescriptor,
58
- reachableThrough,
59
- routingPath: [],
60
- parallelRootNodeIds: []
61
- };
62
- const ack = this.doRouteMessage(forwardedMessage, RoutingSession_1.RoutingMode.FORWARD);
63
- if (ack.error !== undefined) {
64
- const error = 'Could not forward message with error ' + ack.error;
65
- logger.debug(error);
66
- throw new Error(error);
67
- }
68
- }
69
- else {
70
- const routedMessage = {
71
- message: msg,
72
- requestId: (0, uuid_1.v4)(),
73
- target: targetPeerDescriptor.nodeId,
74
- sourcePeer: this.options.localPeerDescriptor,
75
- reachableThrough,
76
- routingPath: [],
77
- parallelRootNodeIds: []
78
- };
79
- const ack = this.doRouteMessage(routedMessage, RoutingSession_1.RoutingMode.ROUTE);
80
- if (ack.error !== undefined) {
81
- const error = 'Could not route message with error ' + ack.error;
82
- logger.debug(error);
83
- throw new Error(error);
84
- }
85
- }
86
- this.messagesSent += 1;
87
- }
88
- doRouteMessage(routedMessage, mode = RoutingSession_1.RoutingMode.ROUTE, excludedPeer) {
89
- if (this.stopped) {
90
- return (0, RouterRpcLocal_1.createRouteMessageAck)(routedMessage, DhtRpc_1.RouteMessageError.STOPPED);
91
- }
92
- logger.trace(`Routing message ${routedMessage.requestId} from ${(0, identifiers_1.toNodeId)(routedMessage.sourcePeer)} `
93
- + `to ${(0, identifiers_1.toDhtAddress)(routedMessage.target)}`);
94
- const session = this.createRoutingSession(routedMessage, mode, excludedPeer);
95
- const contacts = session.updateAndGetRoutablePeers();
96
- if (contacts.length > 0) {
97
- this.addRoutingSession(session);
98
- logger.trace('starting to raceForEvent from routingSession: ' + session.sessionId);
99
- const eventReceived = (0, utils_1.raceForEvent)(session, ['routingSucceeded', 'partialSuccess', 'routingFailed', 'stopped'], 10000 // TODO use options option or named constant?
100
- );
101
- setImmediate(async () => {
102
- try {
103
- await eventReceived;
104
- logger.trace('raceForEvent ended from routingSession: ' + session.sessionId);
105
- }
106
- catch {
107
- logger.trace('raceForEvent timed out for routingSession ' + session.sessionId);
108
- }
109
- session.stop();
110
- this.removeRoutingSession(session.sessionId);
111
- });
112
- session.sendMoreRequests(contacts);
113
- this.messagesRouted += 1;
114
- return (0, RouterRpcLocal_1.createRouteMessageAck)(routedMessage);
115
- }
116
- else {
117
- logger.trace('no targets', { sessionId: session.sessionId });
118
- return (0, RouterRpcLocal_1.createRouteMessageAck)(routedMessage, DhtRpc_1.RouteMessageError.NO_TARGETS);
119
- }
120
- }
121
- createRoutingSession(routedMessage, mode, excludedNode) {
122
- const excludedNodeIds = new Set(routedMessage.routingPath.map((descriptor) => (0, identifiers_1.toNodeId)(descriptor)));
123
- if (excludedNode) {
124
- excludedNodeIds.add(excludedNode);
125
- }
126
- routedMessage.parallelRootNodeIds.forEach((nodeId) => {
127
- excludedNodeIds.add(nodeId);
128
- });
129
- return new RoutingSession_1.RoutingSession({
130
- rpcCommunicator: this.options.rpcCommunicator,
131
- localPeerDescriptor: this.options.localPeerDescriptor,
132
- routedMessage,
133
- // TODO use options option or named constant?
134
- parallelism: (0, identifiers_1.areEqualPeerDescriptors)(this.options.localPeerDescriptor, routedMessage.sourcePeer) ? 2 : 1,
135
- mode,
136
- excludedNodeIds,
137
- routingTablesCache: this.routingTablesCache,
138
- getConnections: this.options.getConnections
139
- });
140
- }
141
- isMostLikelyDuplicate(requestId) {
142
- return this.duplicateRequestDetector.isMostLikelyDuplicate(requestId);
143
- }
144
- addToDuplicateDetector(requestId) {
145
- this.duplicateRequestDetector.add(requestId);
146
- }
147
- addRoutingSession(session) {
148
- this.ongoingRoutingSessions.set(session.sessionId, session);
149
- }
150
- removeRoutingSession(sessionId) {
151
- this.ongoingRoutingSessions.delete(sessionId);
152
- }
153
- onNodeConnected(peerDescriptor) {
154
- const remote = new RoutingSession_1.RoutingRemoteContact(peerDescriptor, this.options.localPeerDescriptor, this.options.rpcCommunicator);
155
- this.routingTablesCache.onNodeConnected(remote);
156
- }
157
- onNodeDisconnected(peerDescriptor) {
158
- this.routingTablesCache.onNodeDisconnected((0, identifiers_1.toNodeId)(peerDescriptor));
159
- }
160
- resetCache() {
161
- this.routingTablesCache.reset();
162
- }
163
- stop() {
164
- this.stopped = true;
165
- this.ongoingRoutingSessions.forEach((session, _id) => {
166
- session.stop();
167
- });
168
- this.ongoingRoutingSessions.clear();
169
- this.forwardingTable.forEach((entry) => {
170
- clearTimeout(entry.timeout);
171
- });
172
- this.forwardingTable.clear();
173
- this.duplicateRequestDetector.clear();
174
- this.routingTablesCache.reset();
175
- }
176
- getDiagnosticInfo() {
177
- return {
178
- messagesRouted: this.messagesRouted,
179
- messagesSent: this.messagesSent
180
- };
181
- }
182
- setForwardingEntries(routedMessage) {
183
- const reachableThroughWithoutSelf = routedMessage.reachableThrough.filter((peer) => {
184
- return !(0, identifiers_1.areEqualPeerDescriptors)(peer, this.options.localPeerDescriptor);
185
- });
186
- if (reachableThroughWithoutSelf.length > 0) {
187
- const sourceNodeId = (0, identifiers_1.toNodeId)(routedMessage.sourcePeer);
188
- if (this.forwardingTable.has(sourceNodeId)) {
189
- const oldEntry = this.forwardingTable.get(sourceNodeId);
190
- clearTimeout(oldEntry.timeout);
191
- this.forwardingTable.delete(sourceNodeId);
192
- }
193
- const forwardingEntry = {
194
- peerDescriptors: reachableThroughWithoutSelf,
195
- timeout: setTimeout(() => {
196
- this.forwardingTable.delete(sourceNodeId);
197
- }, 10000) // TODO use options option or named constant?
198
- };
199
- this.forwardingTable.set(sourceNodeId, forwardingEntry);
200
- }
201
- }
202
- }
203
- exports.Router = Router;
204
- //# sourceMappingURL=Router.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Router.js","sourceRoot":"","sources":["../../../../src/dht/routing/Router.ts"],"names":[],"mappings":"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"}
@@ -1,20 +0,0 @@
1
- import { Message, PeerDescriptor, RouteMessageAck, RouteMessageError, RouteMessageWrapper } from '../../../generated/packages/dht/protos/DhtRpc';
2
- import { IRouterRpc } from '../../../generated/packages/dht/protos/DhtRpc.server';
3
- import { DuplicateDetector } from './DuplicateDetector';
4
- import { RoutingMode } from './RoutingSession';
5
- interface RouterRpcLocalOptions {
6
- doRouteMessage: (routedMessage: RouteMessageWrapper, mode?: RoutingMode) => RouteMessageAck;
7
- setForwardingEntries: (routedMessage: RouteMessageWrapper) => void;
8
- handleMessage: (message: Message) => void;
9
- duplicateRequestDetector: DuplicateDetector;
10
- localPeerDescriptor: PeerDescriptor;
11
- }
12
- export declare const createRouteMessageAck: (routedMessage: RouteMessageWrapper, error?: RouteMessageError) => RouteMessageAck;
13
- export declare class RouterRpcLocal implements IRouterRpc {
14
- private readonly options;
15
- constructor(options: RouterRpcLocalOptions);
16
- routeMessage(routedMessage: RouteMessageWrapper): Promise<RouteMessageAck>;
17
- forwardMessage(forwardMessage: RouteMessageWrapper): Promise<RouteMessageAck>;
18
- private forwardToDestination;
19
- }
20
- export {};
@@ -1,67 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RouterRpcLocal = exports.createRouteMessageAck = void 0;
4
- const utils_1 = require("@streamr/utils");
5
- const DhtRpc_1 = require("../../../generated/packages/dht/protos/DhtRpc");
6
- const RoutingSession_1 = require("./RoutingSession");
7
- const identifiers_1 = require("../../identifiers");
8
- const uuid_1 = require("uuid");
9
- const logger = new utils_1.Logger(module);
10
- const createRouteMessageAck = (routedMessage, error) => {
11
- const ack = {
12
- requestId: routedMessage.requestId,
13
- error
14
- };
15
- return ack;
16
- };
17
- exports.createRouteMessageAck = createRouteMessageAck;
18
- class RouterRpcLocal {
19
- options;
20
- constructor(options) {
21
- this.options = options;
22
- }
23
- async routeMessage(routedMessage) {
24
- if (this.options.duplicateRequestDetector.isMostLikelyDuplicate(routedMessage.requestId)) {
25
- logger.trace(`Routing message ${routedMessage.requestId} from ${(0, identifiers_1.toNodeId)(routedMessage.sourcePeer)} `
26
- + `to ${(0, identifiers_1.toDhtAddress)(routedMessage.target)} is likely a duplicate`);
27
- return (0, exports.createRouteMessageAck)(routedMessage, DhtRpc_1.RouteMessageError.DUPLICATE);
28
- }
29
- logger.trace(`Processing received routeMessage ${routedMessage.requestId}`);
30
- this.options.duplicateRequestDetector.add(routedMessage.requestId);
31
- if ((0, utils_1.areEqualBinaries)(this.options.localPeerDescriptor.nodeId, routedMessage.target)) {
32
- logger.trace(`routing message targeted to self ${routedMessage.requestId}`);
33
- this.options.setForwardingEntries(routedMessage);
34
- this.options.handleMessage(routedMessage.message);
35
- return (0, exports.createRouteMessageAck)(routedMessage);
36
- }
37
- else {
38
- return this.options.doRouteMessage(routedMessage);
39
- }
40
- }
41
- async forwardMessage(forwardMessage) {
42
- if (this.options.duplicateRequestDetector.isMostLikelyDuplicate(forwardMessage.requestId)) {
43
- logger.trace(`Forwarding message ${forwardMessage.requestId} from ${(0, identifiers_1.toNodeId)(forwardMessage.sourcePeer)} `
44
- + `to ${(0, identifiers_1.toDhtAddress)(forwardMessage.target)} is likely a duplicate`);
45
- return (0, exports.createRouteMessageAck)(forwardMessage, DhtRpc_1.RouteMessageError.DUPLICATE);
46
- }
47
- logger.trace(`Processing received forward routeMessage ${forwardMessage.requestId}`);
48
- this.options.duplicateRequestDetector.add(forwardMessage.requestId);
49
- if ((0, utils_1.areEqualBinaries)(this.options.localPeerDescriptor.nodeId, forwardMessage.target)) {
50
- return this.forwardToDestination(forwardMessage);
51
- }
52
- else {
53
- return this.options.doRouteMessage(forwardMessage, RoutingSession_1.RoutingMode.FORWARD);
54
- }
55
- }
56
- forwardToDestination(routedMessage) {
57
- logger.trace(`Forwarding found message targeted to self ${routedMessage.requestId}`);
58
- const forwardedMessage = routedMessage.message;
59
- if ((0, identifiers_1.areEqualPeerDescriptors)(this.options.localPeerDescriptor, forwardedMessage.targetDescriptor)) {
60
- this.options.handleMessage(forwardedMessage);
61
- return (0, exports.createRouteMessageAck)(routedMessage);
62
- }
63
- return this.options.doRouteMessage({ ...routedMessage, requestId: (0, uuid_1.v4)(), target: forwardedMessage.targetDescriptor.nodeId });
64
- }
65
- }
66
- exports.RouterRpcLocal = RouterRpcLocal;
67
- //# sourceMappingURL=RouterRpcLocal.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RouterRpcLocal.js","sourceRoot":"","sources":["../../../../src/dht/routing/RouterRpcLocal.ts"],"names":[],"mappings":";;;AAAA,0CAAyD;AACzD,0EAAgJ;AAGhJ,qDAA8C;AAC9C,mDAAmF;AACnF,+BAAyB;AAUzB,MAAM,MAAM,GAAG,IAAI,cAAM,CAAC,MAAM,CAAC,CAAA;AAE1B,MAAM,qBAAqB,GAAG,CAAC,aAAkC,EAAE,KAAyB,EAAmB,EAAE;IACpH,MAAM,GAAG,GAAoB;QACzB,SAAS,EAAE,aAAa,CAAC,SAAS;QAClC,KAAK;KACR,CAAA;IACD,OAAO,GAAG,CAAA;AACd,CAAC,CAAA;AANY,QAAA,qBAAqB,yBAMjC;AAED,MAAa,cAAc;IAEN,OAAO,CAAuB;IAE/C,YAAY,OAA8B;QACtC,IAAI,CAAC,OAAO,GAAG,OAAO,CAAA;IAC1B,CAAC;IAED,KAAK,CAAC,YAAY,CAAC,aAAkC;QACjD,IAAI,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,aAAa,CAAC,SAAS,CAAC,EAAE,CAAC;YACvF,MAAM,CAAC,KAAK,CAAC,mBAAmB,aAAa,CAAC,SAAS,SAAS,IAAA,sBAAQ,EAAC,aAAa,CAAC,UAAW,CAAC,GAAG;kBAChG,MAAM,IAAA,0BAAY,EAAC,aAAa,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAA;YACvE,OAAO,IAAA,6BAAqB,EAAC,aAAa,EAAE,0BAAiB,CAAC,SAAS,CAAC,CAAA;QAC5E,CAAC;QACD,MAAM,CAAC,KAAK,CAAC,oCAAoC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAA;QAC3E,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC,CAAA;QAClE,IAAI,IAAA,wBAAgB,EAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,MAAM,EAAE,aAAa,CAAC,MAAM,CAAC,EAAE,CAAC;YAClF,MAAM,CAAC,KAAK,CAAC,oCAAoC,aAAa,CAAC,SAAS,EAAE,CAAC,CAAA;YAC3E,IAAI,CAAC,OAAO,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAA;YAChD,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,aAAa,CAAC,OAAQ,CAAC,CAAA;YAClD,OAAO,IAAA,6BAAqB,EAAC,aAAa,CAAC,CAAA;QAC/C,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,aAAa,CAAC,CAAA;QACrD,CAAC;IACL,CAAC;IAED,KAAK,CAAC,cAAc,CAAC,cAAmC;QACpD,IAAI,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,qBAAqB,CAAC,cAAc,CAAC,SAAS,CAAC,EAAE,CAAC;YACxF,MAAM,CAAC,KAAK,CAAC,sBAAsB,cAAc,CAAC,SAAS,SAAS,IAAA,sBAAQ,EAAC,cAAc,CAAC,UAAW,CAAC,GAAG;kBACrG,MAAM,IAAA,0BAAY,EAAC,cAAc,CAAC,MAAM,CAAC,wBAAwB,CAAC,CAAA;YACxE,OAAO,IAAA,6BAAqB,EAAC,cAAc,EAAE,0BAAiB,CAAC,SAAS,CAAC,CAAA;QAC7E,CAAC;QACD,MAAM,CAAC,KAAK,CAAC,4CAA4C,cAAc,CAAC,SAAS,EAAE,CAAC,CAAA;QACpF,IAAI,CAAC,OAAO,CAAC,wBAAwB,CAAC,GAAG,CAAC,cAAc,CAAC,SAAS,CAAC,CAAA;QACnE,IAAI,IAAA,wBAAgB,EAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,CAAC,MAAM,EAAE,cAAc,CAAC,MAAM,CAAC,EAAE,CAAC;YACnF,OAAO,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,CAAA;QACpD,CAAC;aAAM,CAAC;YACJ,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,cAAc,EAAE,4BAAW,CAAC,OAAO,CAAC,CAAA;QAC3E,CAAC;IACL,CAAC;IAEO,oBAAoB,CAAC,aAAkC;QAC3D,MAAM,CAAC,KAAK,CAAC,6CAA6C,aAAa,CAAC,SAAS,EAAE,CAAC,CAAA;QACpF,MAAM,gBAAgB,GAAG,aAAa,CAAC,OAAQ,CAAA;QAC/C,IAAI,IAAA,qCAAuB,EAAC,IAAI,CAAC,OAAO,CAAC,mBAAmB,EAAE,gBAAgB,CAAC,gBAAiB,CAAC,EAAE,CAAC;YAChG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,gBAAgB,CAAC,CAAA;YAC5C,OAAO,IAAA,6BAAqB,EAAC,aAAa,CAAC,CAAA;QAC/C,CAAC;QACD,OAAO,IAAI,CAAC,OAAO,CAAC,cAAc,CAAC,EAAE,GAAG,aAAa,EAAE,SAAS,EAAE,IAAA,SAAE,GAAE,EAAE,MAAM,EAAE,gBAAgB,CAAC,gBAAiB,CAAC,MAAM,EAAE,CAAC,CAAA;IAChI,CAAC;CAEJ;AAnDD,wCAmDC"}
@@ -1,8 +0,0 @@
1
- import { RouteMessageWrapper } from '../../../generated/packages/dht/protos/DhtRpc';
2
- import { RouterRpcClient } from '../../../generated/packages/dht/protos/DhtRpc.client';
3
- import { RpcRemote } from '../contact/RpcRemote';
4
- export declare const ROUTING_TIMEOUT = 2000;
5
- export declare class RouterRpcRemote extends RpcRemote<RouterRpcClient> {
6
- routeMessage(params: RouteMessageWrapper): Promise<boolean>;
7
- forwardMessage(params: RouteMessageWrapper): Promise<boolean>;
8
- }
@@ -1,81 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.RouterRpcRemote = exports.ROUTING_TIMEOUT = void 0;
4
- const utils_1 = require("@streamr/utils");
5
- const uuid_1 = require("uuid");
6
- const DhtRpc_1 = require("../../../generated/packages/dht/protos/DhtRpc");
7
- const RpcRemote_1 = require("../contact/RpcRemote");
8
- const getPreviousPeer_1 = require("./getPreviousPeer");
9
- const identifiers_1 = require("../../identifiers");
10
- const logger = new utils_1.Logger(module);
11
- // default timeout
12
- exports.ROUTING_TIMEOUT = 2000;
13
- class RouterRpcRemote extends RpcRemote_1.RpcRemote {
14
- async routeMessage(params) {
15
- const message = {
16
- target: params.target,
17
- sourcePeer: params.sourcePeer,
18
- message: params.message,
19
- requestId: params.requestId ?? (0, uuid_1.v4)(),
20
- reachableThrough: params.reachableThrough ?? [],
21
- routingPath: params.routingPath,
22
- parallelRootNodeIds: params.parallelRootNodeIds
23
- };
24
- const options = this.formDhtRpcOptions({
25
- connect: false
26
- });
27
- try {
28
- const ack = await this.getClient().routeMessage(message, options);
29
- // Success signal if sent to destination and error includes duplicate
30
- if (ack.error === DhtRpc_1.RouteMessageError.DUPLICATE
31
- && (0, utils_1.areEqualBinaries)(params.target, this.getPeerDescriptor().nodeId)) {
32
- return true;
33
- }
34
- else if (ack.error !== undefined) {
35
- return false;
36
- }
37
- }
38
- catch (err) {
39
- const previousPeer = (0, getPreviousPeer_1.getPreviousPeer)(params);
40
- const fromNode = previousPeer
41
- ? (0, identifiers_1.toNodeId)(previousPeer)
42
- : (0, identifiers_1.toNodeId)(params.sourcePeer);
43
- const toNode = (0, identifiers_1.toNodeId)(this.getPeerDescriptor());
44
- logger.trace(`Failed to send routeMessage from ${fromNode} to ${toNode}`, { err });
45
- return false;
46
- }
47
- return true;
48
- }
49
- async forwardMessage(params) {
50
- const message = {
51
- target: params.target,
52
- sourcePeer: params.sourcePeer,
53
- message: params.message,
54
- requestId: params.requestId ?? (0, uuid_1.v4)(),
55
- reachableThrough: params.reachableThrough ?? [],
56
- routingPath: params.routingPath,
57
- parallelRootNodeIds: params.parallelRootNodeIds
58
- };
59
- const options = this.formDhtRpcOptions({
60
- connect: false
61
- });
62
- try {
63
- const ack = await this.getClient().forwardMessage(message, options);
64
- if (ack.error !== undefined) {
65
- return false;
66
- }
67
- }
68
- catch (err) {
69
- const previousPeer = (0, getPreviousPeer_1.getPreviousPeer)(params);
70
- const fromNode = previousPeer
71
- ? (0, identifiers_1.toNodeId)(previousPeer)
72
- : (0, identifiers_1.toNodeId)(params.sourcePeer);
73
- const toNode = (0, identifiers_1.toNodeId)(this.getPeerDescriptor());
74
- logger.trace(`Failed to send forwardMessage from ${fromNode} to ${toNode}`, { err });
75
- return false;
76
- }
77
- return true;
78
- }
79
- }
80
- exports.RouterRpcRemote = RouterRpcRemote;
81
- //# sourceMappingURL=RouterRpcRemote.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"RouterRpcRemote.js","sourceRoot":"","sources":["../../../../src/dht/routing/RouterRpcRemote.ts"],"names":[],"mappings":"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"}
@@ -1,56 +0,0 @@
1
- import EventEmitter from 'eventemitter3';
2
- import { PeerDescriptor, RouteMessageWrapper } from '../../../generated/packages/dht/protos/DhtRpc';
3
- import { RouterRpcRemote } from './RouterRpcRemote';
4
- import { RoutingRpcCommunicator } from '../../transport/RoutingRpcCommunicator';
5
- import { Contact } from '../contact/Contact';
6
- import { RecursiveOperationRpcRemote } from '../recursive-operation/RecursiveOperationRpcRemote';
7
- import { DhtAddress } from '../../identifiers';
8
- import { RoutingTablesCache } from './RoutingTablesCache';
9
- export declare class RoutingRemoteContact extends Contact {
10
- private routerRpcRemote;
11
- private recursiveOperationRpcRemote;
12
- constructor(peer: PeerDescriptor, localPeerDescriptor: PeerDescriptor, rpcCommunicator: RoutingRpcCommunicator);
13
- getRouterRpcRemote(): RouterRpcRemote;
14
- getRecursiveOperationRpcRemote(): RecursiveOperationRpcRemote;
15
- }
16
- export interface RoutingSessionEvents {
17
- routingSucceeded: () => void;
18
- partialSuccess: () => void;
19
- routingFailed: () => void;
20
- stopped: () => void;
21
- }
22
- export declare enum RoutingMode {
23
- ROUTE = 0,
24
- FORWARD = 1,
25
- RECURSIVE = 2
26
- }
27
- interface RoutingSessionOptions {
28
- rpcCommunicator: RoutingRpcCommunicator;
29
- localPeerDescriptor: PeerDescriptor;
30
- routedMessage: RouteMessageWrapper;
31
- parallelism: number;
32
- mode: RoutingMode;
33
- excludedNodeIds: Set<DhtAddress>;
34
- routingTablesCache: RoutingTablesCache;
35
- getConnections: () => PeerDescriptor[];
36
- }
37
- export declare class RoutingSession extends EventEmitter<RoutingSessionEvents> {
38
- readonly sessionId: string;
39
- private ongoingRequests;
40
- private contactedPeers;
41
- private failedHopCounter;
42
- private successfulHopCounter;
43
- private stopped;
44
- private readonly options;
45
- constructor(options: RoutingSessionOptions);
46
- private onRequestFailed;
47
- private emitFailure;
48
- private onRequestSucceeded;
49
- private sendRouteMessageRequest;
50
- updateAndGetRoutablePeers(): RoutingRemoteContact[];
51
- sendMoreRequests(uncontacted: RoutingRemoteContact[]): void;
52
- private addParallelRootIfSource;
53
- private deleteParallelRootIfSource;
54
- stop(): void;
55
- }
56
- export {};