@aztec/p2p 0.0.0-test.0 → 0.0.1-commit.023c3e5

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 (512) hide show
  1. package/dest/bootstrap/bootstrap.d.ts +4 -3
  2. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  3. package/dest/bootstrap/bootstrap.js +26 -13
  4. package/dest/client/factory.d.ts +15 -5
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +61 -25
  7. package/dest/client/index.d.ts +2 -1
  8. package/dest/client/index.d.ts.map +1 -1
  9. package/dest/client/index.js +1 -0
  10. package/dest/client/interface.d.ts +170 -0
  11. package/dest/client/interface.d.ts.map +1 -0
  12. package/dest/client/interface.js +9 -0
  13. package/dest/client/p2p_client.d.ts +75 -193
  14. package/dest/client/p2p_client.d.ts.map +1 -1
  15. package/dest/client/p2p_client.js +765 -229
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  18. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +305 -0
  19. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  20. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  21. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  22. package/dest/config.d.ts +154 -125
  23. package/dest/config.d.ts.map +1 -1
  24. package/dest/config.js +182 -34
  25. package/dest/enr/generate-enr.d.ts +11 -3
  26. package/dest/enr/generate-enr.d.ts.map +1 -1
  27. package/dest/enr/generate-enr.js +27 -5
  28. package/dest/enr/index.d.ts +1 -1
  29. package/dest/errors/attestation-pool.error.d.ts +7 -0
  30. package/dest/errors/attestation-pool.error.d.ts.map +1 -0
  31. package/dest/errors/attestation-pool.error.js +12 -0
  32. package/dest/errors/reqresp.error.d.ts +1 -1
  33. package/dest/errors/reqresp.error.d.ts.map +1 -1
  34. package/dest/index.d.ts +4 -1
  35. package/dest/index.d.ts.map +1 -1
  36. package/dest/index.js +2 -0
  37. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -25
  38. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  39. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +1 -1
  40. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  41. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +299 -174
  42. package/dest/mem_pools/attestation_pool/index.d.ts +1 -1
  43. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +29 -11
  44. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
  45. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +168 -62
  46. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +24 -10
  47. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
  48. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +133 -82
  49. package/dest/mem_pools/attestation_pool/mocks.d.ts +234 -11
  50. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  51. package/dest/mem_pools/attestation_pool/mocks.js +19 -21
  52. package/dest/mem_pools/index.d.ts +1 -1
  53. package/dest/mem_pools/instrumentation.d.ts +16 -12
  54. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  55. package/dest/mem_pools/instrumentation.js +56 -41
  56. package/dest/mem_pools/interface.d.ts +3 -4
  57. package/dest/mem_pools/interface.d.ts.map +1 -1
  58. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +75 -16
  59. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  60. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +493 -142
  61. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  62. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  63. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  64. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  65. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  66. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
  67. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  68. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  69. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  70. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
  71. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  72. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  73. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  74. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  75. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  76. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  77. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  78. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  79. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  80. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  81. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  82. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  83. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  84. package/dest/mem_pools/tx_pool/index.js +0 -1
  85. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  86. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  87. package/dest/mem_pools/tx_pool/priority.js +7 -2
  88. package/dest/mem_pools/tx_pool/tx_pool.d.ts +72 -11
  89. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  90. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  91. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  92. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +276 -45
  93. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +7 -5
  94. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  95. package/dest/msg_validators/attestation_validator/attestation_validator.js +79 -10
  96. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +20 -0
  97. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -0
  98. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +76 -0
  99. package/dest/msg_validators/attestation_validator/index.d.ts +2 -1
  100. package/dest/msg_validators/attestation_validator/index.d.ts.map +1 -1
  101. package/dest/msg_validators/attestation_validator/index.js +1 -0
  102. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  103. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  104. package/dest/msg_validators/clock_tolerance.js +37 -0
  105. package/dest/msg_validators/index.d.ts +2 -2
  106. package/dest/msg_validators/index.d.ts.map +1 -1
  107. package/dest/msg_validators/index.js +1 -1
  108. package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts +10 -0
  109. package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts.map +1 -0
  110. package/dest/msg_validators/msg_seen_validator/msg_seen_validator.js +36 -0
  111. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +9 -0
  112. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  113. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +6 -0
  114. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +9 -0
  115. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  116. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +6 -0
  117. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  118. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  119. package/dest/msg_validators/proposal_validator/index.js +3 -0
  120. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -0
  121. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  122. package/dest/msg_validators/proposal_validator/proposal_validator.js +104 -0
  123. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +23 -0
  124. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -0
  125. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +212 -0
  126. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +1 -1
  127. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  128. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +3 -0
  129. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -0
  130. package/dest/msg_validators/tx_validator/allowed_public_setup.js +27 -0
  131. package/dest/msg_validators/tx_validator/archive_cache.d.ts +14 -0
  132. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -0
  133. package/dest/msg_validators/tx_validator/archive_cache.js +22 -0
  134. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +5 -4
  135. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  136. package/dest/msg_validators/tx_validator/block_header_validator.js +7 -6
  137. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  138. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  139. package/dest/msg_validators/tx_validator/data_validator.js +60 -87
  140. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +3 -4
  141. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  142. package/dest/msg_validators/tx_validator/double_spend_validator.js +24 -29
  143. package/dest/msg_validators/tx_validator/factory.d.ts +21 -0
  144. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -0
  145. package/dest/msg_validators/tx_validator/factory.js +84 -0
  146. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  147. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  148. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  149. package/dest/msg_validators/tx_validator/gas_validator.d.ts +12 -0
  150. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -0
  151. package/dest/msg_validators/tx_validator/gas_validator.js +110 -0
  152. package/dest/msg_validators/tx_validator/index.d.ts +9 -1
  153. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  154. package/dest/msg_validators/tx_validator/index.js +8 -0
  155. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +10 -5
  156. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  157. package/dest/msg_validators/tx_validator/metadata_validator.js +40 -21
  158. package/dest/msg_validators/tx_validator/phases_validator.d.ts +15 -0
  159. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -0
  160. package/dest/msg_validators/tx_validator/phases_validator.js +93 -0
  161. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  162. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  163. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  164. package/dest/msg_validators/tx_validator/test_utils.d.ts +17 -0
  165. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -0
  166. package/dest/msg_validators/tx_validator/test_utils.js +22 -0
  167. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +14 -0
  168. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -0
  169. package/dest/msg_validators/tx_validator/timestamp_validator.js +32 -0
  170. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +9 -0
  171. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -0
  172. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +24 -0
  173. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  174. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  175. package/dest/msg_validators/tx_validator/tx_proof_validator.js +8 -7
  176. package/dest/services/data_store.d.ts +1 -1
  177. package/dest/services/data_store.d.ts.map +1 -1
  178. package/dest/services/data_store.js +10 -6
  179. package/dest/services/discv5/discV5_service.d.ts +10 -9
  180. package/dest/services/discv5/discV5_service.d.ts.map +1 -1
  181. package/dest/services/discv5/discV5_service.js +64 -37
  182. package/dest/services/dummy_service.d.ts +66 -11
  183. package/dest/services/dummy_service.d.ts.map +1 -1
  184. package/dest/services/dummy_service.js +130 -5
  185. package/dest/services/encoding.d.ts +26 -7
  186. package/dest/services/encoding.d.ts.map +1 -1
  187. package/dest/services/encoding.js +75 -6
  188. package/dest/services/gossipsub/scoring.d.ts +1 -1
  189. package/dest/services/index.d.ts +5 -1
  190. package/dest/services/index.d.ts.map +1 -1
  191. package/dest/services/index.js +4 -0
  192. package/dest/services/libp2p/instrumentation.d.ts +20 -0
  193. package/dest/services/libp2p/instrumentation.d.ts.map +1 -0
  194. package/dest/services/libp2p/instrumentation.js +122 -0
  195. package/dest/services/libp2p/libp2p_service.d.ts +107 -95
  196. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  197. package/dest/services/libp2p/libp2p_service.js +1328 -313
  198. package/dest/services/peer-manager/interface.d.ts +23 -0
  199. package/dest/services/peer-manager/interface.d.ts.map +1 -0
  200. package/dest/services/peer-manager/interface.js +1 -0
  201. package/dest/services/peer-manager/metrics.d.ts +12 -3
  202. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  203. package/dest/services/peer-manager/metrics.js +44 -12
  204. package/dest/services/peer-manager/peer_manager.d.ts +103 -23
  205. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  206. package/dest/services/peer-manager/peer_manager.js +551 -82
  207. package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
  208. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  209. package/dest/services/peer-manager/peer_scoring.js +43 -2
  210. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +47 -0
  211. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  212. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +566 -0
  213. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  214. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  215. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  216. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +50 -0
  217. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  218. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  219. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +37 -0
  220. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  221. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +151 -0
  222. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  223. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  224. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  225. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  226. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  227. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  228. package/dest/services/reqresp/config.d.ts +11 -9
  229. package/dest/services/reqresp/config.d.ts.map +1 -1
  230. package/dest/services/reqresp/config.js +18 -4
  231. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +23 -4
  232. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  233. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +73 -10
  234. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +32 -17
  235. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  236. package/dest/services/reqresp/connection-sampler/connection_sampler.js +154 -84
  237. package/dest/services/reqresp/constants.d.ts +12 -0
  238. package/dest/services/reqresp/constants.d.ts.map +1 -0
  239. package/dest/services/reqresp/constants.js +7 -0
  240. package/dest/services/reqresp/index.d.ts +3 -2
  241. package/dest/services/reqresp/index.d.ts.map +1 -1
  242. package/dest/services/reqresp/index.js +2 -1
  243. package/dest/services/reqresp/interface.d.ts +75 -24
  244. package/dest/services/reqresp/interface.d.ts.map +1 -1
  245. package/dest/services/reqresp/interface.js +46 -27
  246. package/dest/services/reqresp/metrics.d.ts +6 -5
  247. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  248. package/dest/services/reqresp/metrics.js +17 -21
  249. package/dest/services/reqresp/protocols/auth.d.ts +43 -0
  250. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -0
  251. package/dest/services/reqresp/protocols/auth.js +71 -0
  252. package/dest/services/reqresp/protocols/block.d.ts +6 -1
  253. package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
  254. package/dest/services/reqresp/protocols/block.js +30 -6
  255. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +34 -0
  256. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -0
  257. package/dest/services/reqresp/protocols/block_txs/bitvector.js +87 -0
  258. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +11 -0
  259. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -0
  260. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +52 -0
  261. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +59 -0
  262. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -0
  263. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +105 -0
  264. package/dest/services/reqresp/protocols/block_txs/index.d.ts +4 -0
  265. package/dest/services/reqresp/protocols/block_txs/index.d.ts.map +1 -0
  266. package/dest/services/reqresp/protocols/block_txs/index.js +3 -0
  267. package/dest/services/reqresp/protocols/goodbye.d.ts +3 -5
  268. package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -1
  269. package/dest/services/reqresp/protocols/goodbye.js +7 -7
  270. package/dest/services/reqresp/protocols/index.d.ts +3 -1
  271. package/dest/services/reqresp/protocols/index.d.ts.map +1 -1
  272. package/dest/services/reqresp/protocols/index.js +2 -0
  273. package/dest/services/reqresp/protocols/ping.d.ts +1 -3
  274. package/dest/services/reqresp/protocols/ping.d.ts.map +1 -1
  275. package/dest/services/reqresp/protocols/status.d.ts +40 -7
  276. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  277. package/dest/services/reqresp/protocols/status.js +76 -5
  278. package/dest/services/reqresp/protocols/tx.d.ts +14 -4
  279. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  280. package/dest/services/reqresp/protocols/tx.js +34 -6
  281. package/dest/services/reqresp/rate-limiter/index.d.ts +1 -1
  282. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +6 -4
  283. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
  284. package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -2
  285. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
  286. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -1
  287. package/dest/services/reqresp/rate-limiter/rate_limits.js +21 -1
  288. package/dest/services/reqresp/reqresp.d.ts +29 -66
  289. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  290. package/dest/services/reqresp/reqresp.js +753 -248
  291. package/dest/services/reqresp/status.d.ts +10 -4
  292. package/dest/services/reqresp/status.d.ts.map +1 -1
  293. package/dest/services/reqresp/status.js +9 -2
  294. package/dest/services/service.d.ts +40 -20
  295. package/dest/services/service.d.ts.map +1 -1
  296. package/dest/services/tx_collection/config.d.ts +28 -0
  297. package/dest/services/tx_collection/config.d.ts.map +1 -0
  298. package/dest/services/tx_collection/config.js +66 -0
  299. package/dest/services/tx_collection/fast_tx_collection.d.ts +53 -0
  300. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -0
  301. package/dest/services/tx_collection/fast_tx_collection.js +311 -0
  302. package/dest/services/tx_collection/index.d.ts +4 -0
  303. package/dest/services/tx_collection/index.d.ts.map +1 -0
  304. package/dest/services/tx_collection/index.js +3 -0
  305. package/dest/services/tx_collection/instrumentation.d.ts +10 -0
  306. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -0
  307. package/dest/services/tx_collection/instrumentation.js +31 -0
  308. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  309. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  310. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  311. package/dest/services/tx_collection/slow_tx_collection.d.ts +53 -0
  312. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -0
  313. package/dest/services/tx_collection/slow_tx_collection.js +177 -0
  314. package/dest/services/tx_collection/tx_collection.d.ts +110 -0
  315. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -0
  316. package/dest/services/tx_collection/tx_collection.js +128 -0
  317. package/dest/services/tx_collection/tx_collection_sink.d.ts +30 -0
  318. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -0
  319. package/dest/services/tx_collection/tx_collection_sink.js +111 -0
  320. package/dest/services/tx_collection/tx_source.d.ts +18 -0
  321. package/dest/services/tx_collection/tx_source.d.ts.map +1 -0
  322. package/dest/services/tx_collection/tx_source.js +31 -0
  323. package/dest/services/tx_provider.d.ts +51 -0
  324. package/dest/services/tx_provider.d.ts.map +1 -0
  325. package/dest/services/tx_provider.js +219 -0
  326. package/dest/services/tx_provider_instrumentation.d.ts +16 -0
  327. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -0
  328. package/dest/services/tx_provider_instrumentation.js +34 -0
  329. package/dest/test-helpers/generate-peer-id-private-keys.d.ts +1 -1
  330. package/dest/test-helpers/get-ports.d.ts +1 -1
  331. package/dest/test-helpers/get-ports.d.ts.map +1 -1
  332. package/dest/test-helpers/index.d.ts +4 -1
  333. package/dest/test-helpers/index.d.ts.map +1 -1
  334. package/dest/test-helpers/index.js +3 -0
  335. package/dest/test-helpers/make-enrs.d.ts +1 -1
  336. package/dest/test-helpers/make-enrs.d.ts.map +1 -1
  337. package/dest/test-helpers/make-enrs.js +4 -5
  338. package/dest/test-helpers/make-test-p2p-clients.d.ts +33 -5
  339. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  340. package/dest/test-helpers/make-test-p2p-clients.js +86 -16
  341. package/dest/test-helpers/mock-pubsub.d.ts +59 -0
  342. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -0
  343. package/dest/test-helpers/mock-pubsub.js +130 -0
  344. package/dest/test-helpers/mock-tx-helpers.d.ts +12 -0
  345. package/dest/test-helpers/mock-tx-helpers.d.ts.map +1 -0
  346. package/dest/test-helpers/mock-tx-helpers.js +19 -0
  347. package/dest/test-helpers/reqresp-nodes.d.ts +15 -11
  348. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  349. package/dest/test-helpers/reqresp-nodes.js +62 -28
  350. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  351. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  352. package/dest/test-helpers/test_tx_provider.js +41 -0
  353. package/dest/test-helpers/testbench-utils.d.ts +158 -0
  354. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  355. package/dest/test-helpers/testbench-utils.js +297 -0
  356. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  357. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  358. package/dest/testbench/p2p_client_testbench_worker.js +259 -90
  359. package/dest/testbench/parse_log_file.d.ts +1 -1
  360. package/dest/testbench/parse_log_file.js +4 -4
  361. package/dest/testbench/testbench.d.ts +1 -1
  362. package/dest/testbench/testbench.js +4 -4
  363. package/dest/testbench/worker_client_manager.d.ts +51 -11
  364. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  365. package/dest/testbench/worker_client_manager.js +232 -53
  366. package/dest/types/index.d.ts +4 -2
  367. package/dest/types/index.d.ts.map +1 -1
  368. package/dest/types/index.js +2 -0
  369. package/dest/util.d.ts +24 -16
  370. package/dest/util.d.ts.map +1 -1
  371. package/dest/util.js +75 -69
  372. package/dest/versioning.d.ts +4 -4
  373. package/dest/versioning.d.ts.map +1 -1
  374. package/dest/versioning.js +8 -3
  375. package/package.json +32 -27
  376. package/src/bootstrap/bootstrap.ts +34 -15
  377. package/src/client/factory.ts +135 -53
  378. package/src/client/index.ts +1 -0
  379. package/src/client/interface.ts +213 -0
  380. package/src/client/p2p_client.ts +476 -383
  381. package/src/client/test/tx_proposal_collector/README.md +227 -0
  382. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +336 -0
  383. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  384. package/src/config.ts +304 -134
  385. package/src/enr/generate-enr.ts +39 -6
  386. package/src/errors/attestation-pool.error.ts +13 -0
  387. package/src/index.ts +4 -0
  388. package/src/mem_pools/attestation_pool/attestation_pool.ts +119 -24
  389. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +352 -201
  390. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +233 -72
  391. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +199 -96
  392. package/src/mem_pools/attestation_pool/mocks.ts +24 -17
  393. package/src/mem_pools/instrumentation.ts +72 -48
  394. package/src/mem_pools/interface.ts +2 -4
  395. package/src/mem_pools/tx_pool/README.md +270 -0
  396. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +580 -143
  397. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  398. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  399. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  400. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  401. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  402. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  403. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  404. package/src/mem_pools/tx_pool/index.ts +0 -1
  405. package/src/mem_pools/tx_pool/priority.ts +9 -2
  406. package/src/mem_pools/tx_pool/tx_pool.ts +75 -10
  407. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +225 -36
  408. package/src/msg_validators/attestation_validator/attestation_validator.ts +72 -14
  409. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +94 -0
  410. package/src/msg_validators/attestation_validator/index.ts +1 -0
  411. package/src/msg_validators/clock_tolerance.ts +51 -0
  412. package/src/msg_validators/index.ts +1 -1
  413. package/src/msg_validators/msg_seen_validator/msg_seen_validator.ts +36 -0
  414. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +10 -0
  415. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +13 -0
  416. package/src/msg_validators/proposal_validator/index.ts +3 -0
  417. package/src/msg_validators/proposal_validator/proposal_validator.ts +92 -0
  418. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +230 -0
  419. package/src/msg_validators/tx_validator/allowed_public_setup.ts +35 -0
  420. package/src/msg_validators/tx_validator/archive_cache.ts +28 -0
  421. package/src/msg_validators/tx_validator/block_header_validator.ts +10 -9
  422. package/src/msg_validators/tx_validator/data_validator.ts +95 -71
  423. package/src/msg_validators/tx_validator/double_spend_validator.ts +23 -20
  424. package/src/msg_validators/tx_validator/factory.ts +151 -0
  425. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  426. package/src/msg_validators/tx_validator/gas_validator.ts +123 -0
  427. package/src/msg_validators/tx_validator/index.ts +8 -0
  428. package/src/msg_validators/tx_validator/metadata_validator.ts +72 -24
  429. package/src/msg_validators/tx_validator/phases_validator.ts +118 -0
  430. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  431. package/src/msg_validators/tx_validator/test_utils.ts +43 -0
  432. package/src/msg_validators/tx_validator/timestamp_validator.ts +52 -0
  433. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +22 -0
  434. package/src/msg_validators/tx_validator/tx_proof_validator.ts +14 -8
  435. package/src/services/data_store.ts +10 -7
  436. package/src/services/discv5/discV5_service.ts +85 -39
  437. package/src/services/dummy_service.ts +198 -9
  438. package/src/services/encoding.ts +82 -6
  439. package/src/services/index.ts +4 -0
  440. package/src/services/libp2p/instrumentation.ts +126 -0
  441. package/src/services/libp2p/libp2p_service.ts +1170 -353
  442. package/src/services/peer-manager/interface.ts +29 -0
  443. package/src/services/peer-manager/metrics.ts +55 -12
  444. package/src/services/peer-manager/peer_manager.ts +657 -80
  445. package/src/services/peer-manager/peer_scoring.ts +45 -3
  446. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  447. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  448. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  449. package/src/services/reqresp/batch-tx-requester/interface.ts +57 -0
  450. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +209 -0
  451. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  452. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  453. package/src/services/reqresp/config.ts +26 -9
  454. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +77 -10
  455. package/src/services/reqresp/connection-sampler/connection_sampler.ts +166 -95
  456. package/src/services/reqresp/constants.ts +14 -0
  457. package/src/services/reqresp/index.ts +2 -0
  458. package/src/services/reqresp/interface.ts +95 -37
  459. package/src/services/reqresp/metrics.ts +40 -28
  460. package/src/services/reqresp/protocols/auth.ts +83 -0
  461. package/src/services/reqresp/protocols/block.ts +26 -4
  462. package/src/services/reqresp/protocols/block_txs/bitvector.ts +106 -0
  463. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +67 -0
  464. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +121 -0
  465. package/src/services/reqresp/protocols/block_txs/index.ts +3 -0
  466. package/src/services/reqresp/protocols/goodbye.ts +9 -7
  467. package/src/services/reqresp/protocols/index.ts +2 -0
  468. package/src/services/reqresp/protocols/status.ts +121 -5
  469. package/src/services/reqresp/protocols/tx.ts +36 -8
  470. package/src/services/reqresp/rate-limiter/rate_limiter.ts +12 -3
  471. package/src/services/reqresp/rate-limiter/rate_limits.ts +21 -1
  472. package/src/services/reqresp/reqresp.ts +449 -271
  473. package/src/services/reqresp/status.ts +12 -3
  474. package/src/services/service.ts +65 -22
  475. package/src/services/tx_collection/config.ts +98 -0
  476. package/src/services/tx_collection/fast_tx_collection.ts +364 -0
  477. package/src/services/tx_collection/index.ts +7 -0
  478. package/src/services/tx_collection/instrumentation.ts +35 -0
  479. package/src/services/tx_collection/proposal_tx_collector.ts +114 -0
  480. package/src/services/tx_collection/slow_tx_collection.ts +233 -0
  481. package/src/services/tx_collection/tx_collection.ts +216 -0
  482. package/src/services/tx_collection/tx_collection_sink.ts +129 -0
  483. package/src/services/tx_collection/tx_source.ts +37 -0
  484. package/src/services/tx_provider.ts +232 -0
  485. package/src/services/tx_provider_instrumentation.ts +54 -0
  486. package/src/test-helpers/index.ts +3 -0
  487. package/src/test-helpers/make-enrs.ts +4 -5
  488. package/src/test-helpers/make-test-p2p-clients.ts +111 -21
  489. package/src/test-helpers/mock-pubsub.ts +188 -0
  490. package/src/test-helpers/mock-tx-helpers.ts +24 -0
  491. package/src/test-helpers/reqresp-nodes.ts +87 -36
  492. package/src/test-helpers/test_tx_provider.ts +64 -0
  493. package/src/test-helpers/testbench-utils.ts +374 -0
  494. package/src/testbench/p2p_client_testbench_worker.ts +434 -89
  495. package/src/testbench/parse_log_file.ts +4 -4
  496. package/src/testbench/testbench.ts +4 -4
  497. package/src/testbench/worker_client_manager.ts +315 -59
  498. package/src/types/index.ts +2 -0
  499. package/src/util.ts +105 -91
  500. package/src/versioning.ts +11 -4
  501. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -56
  502. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  503. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -141
  504. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -8
  505. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  506. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -21
  507. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  508. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  509. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  510. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -174
  511. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -29
  512. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -18,11 +18,18 @@ import type { ConnectionSampler } from './connection_sampler.js';
18
18
  * If a peer fails, it is replaced while maintaining the same bucket.
19
19
  */
20
20
  export class BatchConnectionSampler {
21
- private readonly logger = createLogger('p2p:reqresp:batch-connection-sampler');
22
21
  private readonly batch: PeerId[] = [];
23
22
  private readonly requestsPerPeer: number;
23
+ /** Tracks peer-index combinations that returned empty/invalid responses */
24
+ private readonly failedPeerIndices: Map<string, Set<number>> = new Map();
24
25
 
25
- constructor(private readonly connectionSampler: ConnectionSampler, batchSize: number, maxPeers: number) {
26
+ constructor(
27
+ private readonly connectionSampler: ConnectionSampler,
28
+ batchSize: number,
29
+ maxPeers: number,
30
+ exclude?: PeerId[],
31
+ private readonly logger = createLogger('p2p:reqresp:batch-connection-sampler'),
32
+ ) {
26
33
  if (maxPeers <= 0) {
27
34
  throw new Error('Max peers cannot be 0');
28
35
  }
@@ -34,14 +41,17 @@ export class BatchConnectionSampler {
34
41
  this.requestsPerPeer = Math.max(1, Math.floor(batchSize / maxPeers));
35
42
 
36
43
  // Sample initial peers
37
- this.batch = this.connectionSampler.samplePeersBatch(maxPeers);
44
+ const excluding = exclude && new Map(exclude.map(peerId => [peerId.toString(), true] as const));
45
+ this.batch = this.connectionSampler.samplePeersBatch(maxPeers, excluding);
38
46
  }
39
47
 
40
48
  /**
41
- * Gets the peer responsible for handling a specific request index
49
+ * Gets the peer responsible for handling a specific request index.
50
+ * If the primary peer has previously failed for this index, tries other peers.
51
+ * If all batch peers have failed, attempts to sample a new peer.
42
52
  *
43
53
  * @param index - The request index
44
- * @returns The peer assigned to handle this request
54
+ * @returns The peer assigned to handle this request, or undefined if no peer available
45
55
  */
46
56
  getPeerForRequest(index: number): PeerId | undefined {
47
57
  if (this.batch.length === 0) {
@@ -49,8 +59,65 @@ export class BatchConnectionSampler {
49
59
  }
50
60
 
51
61
  // Calculate which peer bucket this index belongs to
52
- const peerIndex = Math.floor(index / this.requestsPerPeer) % this.batch.length;
53
- return this.batch[peerIndex];
62
+ const primaryPeerIndex = Math.floor(index / this.requestsPerPeer) % this.batch.length;
63
+
64
+ // Try peers starting from primary, wrapping around
65
+ for (let offset = 0; offset < this.batch.length; offset++) {
66
+ const peerIndex = (primaryPeerIndex + offset) % this.batch.length;
67
+ const peer = this.batch[peerIndex];
68
+ const peerKey = peer.toString();
69
+
70
+ const failedIndices = this.failedPeerIndices.get(peerKey);
71
+ if (!failedIndices || !failedIndices.has(index)) {
72
+ return peer;
73
+ }
74
+ }
75
+
76
+ // All batch peers have failed for this index - try to sample a new peer
77
+ const newPeer = this.sampleNewPeer();
78
+ if (newPeer) {
79
+ return newPeer;
80
+ }
81
+
82
+ return undefined;
83
+ }
84
+
85
+ /**
86
+ * Attempts to sample a new peer that isn't already in the batch.
87
+ * If successful, adds the peer to the batch.
88
+ *
89
+ * @returns The new peer if one was sampled, undefined otherwise
90
+ */
91
+ private sampleNewPeer(): PeerId | undefined {
92
+ // Exclude all current batch peers
93
+ const excluding = new Map(this.batch.map(p => [p.toString(), true] as const));
94
+ const newPeer = this.connectionSampler.getPeer(excluding);
95
+
96
+ if (newPeer) {
97
+ this.batch.push(newPeer);
98
+ this.logger.trace('Sampled new peer for exhausted index', { newPeer: newPeer.toString() });
99
+ return newPeer;
100
+ }
101
+
102
+ return undefined;
103
+ }
104
+
105
+ /**
106
+ * Marks that a peer returned an empty/invalid response for a specific request index.
107
+ * The peer will not be assigned this index again.
108
+ *
109
+ * @param peerId - The peer that failed
110
+ * @param index - The request index that failed
111
+ */
112
+ markPeerFailedForIndex(peerId: PeerId, index: number): void {
113
+ const peerKey = peerId.toString();
114
+ let failedIndices = this.failedPeerIndices.get(peerKey);
115
+ if (!failedIndices) {
116
+ failedIndices = new Set();
117
+ this.failedPeerIndices.set(peerKey, failedIndices);
118
+ }
119
+ failedIndices.add(index);
120
+ this.logger.trace('Marked peer failed for index', { peerId: peerKey, index });
54
121
  }
55
122
 
56
123
  /**
@@ -66,15 +133,15 @@ export class BatchConnectionSampler {
66
133
  }
67
134
 
68
135
  const excluding = new Map([[peerId.toString(), true]]);
69
- const newPeer = this.connectionSampler.getPeer(excluding);
136
+ const newPeer = this.connectionSampler.getPeer(excluding); // Q: Shouldn't we accumulate all excluded peers? Otherwise the sampler could return us a previously excluded peer?
70
137
 
71
138
  if (newPeer) {
72
139
  this.batch[index] = newPeer;
73
- this.logger.trace(`Replaced peer ${peerId} with ${newPeer}`, { peerId, newPeer });
140
+ this.logger.trace('Replaced peer', { peerId, newPeer });
74
141
  } else {
75
142
  // If we couldn't get a replacement, remove the peer and compact the array
76
143
  this.batch.splice(index, 1);
77
- this.logger.trace(`Removed peer ${peerId}`, { peerId });
144
+ this.logger.trace('Removed peer', { peerId });
78
145
  }
79
146
  }
80
147
 
@@ -1,15 +1,10 @@
1
+ import { AbortError } from '@aztec/foundation/error';
1
2
  import { createLogger } from '@aztec/foundation/log';
2
- import { SerialQueue } from '@aztec/foundation/queue';
3
3
 
4
4
  import type { Libp2p, PeerId, Stream } from '@libp2p/interface';
5
5
 
6
6
  const MAX_SAMPLE_ATTEMPTS = 4;
7
7
 
8
- interface StreamAndPeerId {
9
- stream: Stream;
10
- peerId: PeerId;
11
- }
12
-
13
8
  export class RandomSampler {
14
9
  random(max: number) {
15
10
  return Math.floor(Math.random() * max);
@@ -17,31 +12,33 @@ export class RandomSampler {
17
12
  }
18
13
 
19
14
  /**
20
- * A class that samples peers from the libp2p node and returns a peer that we don't already have a connection open to.
15
+ * A class that samples peers from the libp2p node and returns a peer that we don't already have a reqresp connection open to.
21
16
  * If we already have a connection open, we try to sample a different peer.
22
17
  * We do this MAX_SAMPLE_ATTEMPTS times, if we still don't find a peer we just go for it.
23
18
  *
24
19
  * @dev Close must always be called on connections, else memory leak
25
20
  */
26
21
  export class ConnectionSampler {
27
- private readonly logger = createLogger('p2p:reqresp:connection-sampler');
28
22
  private cleanupInterval: NodeJS.Timeout;
29
- private abortController: AbortController = new AbortController();
30
23
 
31
- private readonly activeConnectionsCount: Map<PeerId, number> = new Map();
32
- private readonly streams: Map<string, StreamAndPeerId> = new Map();
24
+ // Map from stringified peer id to number of active connections
25
+ protected readonly activeConnectionsCount: Map<string, number> = new Map();
26
+
27
+ // eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
28
+ protected readonly streams: Set<Stream> = new Set();
33
29
 
34
- // Serial queue to ensure that we only dial one peer at a time
35
- private dialQueue: SerialQueue = new SerialQueue();
30
+ private abortOnStop: AbortController = new AbortController();
36
31
 
37
32
  constructor(
38
33
  private readonly libp2p: Libp2p,
39
- private readonly cleanupIntervalMs: number = 60000, // Default to 1 minute
40
- private readonly sampler: RandomSampler = new RandomSampler(), // Allow randomness to be mocked for testing
34
+ private readonly sampler: RandomSampler,
35
+ private readonly logger = createLogger('p2p:reqresp:connection-sampler'),
36
+ private readonly opts: { cleanupIntervalMs?: number; p2pOptimisticNegotiation?: boolean } = {},
41
37
  ) {
42
- this.cleanupInterval = setInterval(() => void this.cleanupStaleConnections(), this.cleanupIntervalMs);
43
-
44
- this.dialQueue.start();
38
+ this.cleanupInterval = setInterval(
39
+ () => void this.cleanupStaleConnections(),
40
+ this.opts.cleanupIntervalMs ?? 60_000,
41
+ );
45
42
  }
46
43
 
47
44
  /**
@@ -49,13 +46,11 @@ export class ConnectionSampler {
49
46
  */
50
47
  async stop() {
51
48
  this.logger.info('Stopping connection sampler');
49
+ this.abortOnStop.abort(new AbortError('Connection sampler stopped'));
52
50
  clearInterval(this.cleanupInterval);
53
51
 
54
- this.abortController.abort();
55
- await this.dialQueue.end();
56
-
57
52
  // Close all active streams
58
- const closePromises = Array.from(this.streams.keys()).map(streamId => this.close(streamId));
53
+ const closePromises = Array.from(this.streams.values()).map(stream => this.close(stream));
59
54
  await Promise.all(closePromises);
60
55
  this.logger.info('Connection sampler stopped');
61
56
  }
@@ -69,70 +64,128 @@ export class ConnectionSampler {
69
64
  getPeer(excluding?: Map<string, boolean>): PeerId | undefined {
70
65
  // In libp2p getPeers performs a shallow copy, so this array can be sliced from safetly
71
66
  const peers = this.libp2p.getPeers();
67
+ const { peer } = this.getPeerFromList(peers, excluding);
68
+ return peer;
69
+ }
72
70
 
71
+ /**
72
+ * Samples a peer from a list of peers, excluding those that have active (reqresp) connections or are in the exclusion list
73
+ *
74
+ * @param peers - The list of peers to sample from
75
+ * @param excluding - The peers to exclude from the sampling
76
+ * @returns - A peer from the list, or undefined if no peers are available,
77
+ * - a boolean indicating if the peer has active connections, and
78
+ * - all sampled peers - to enable optional resampling
79
+ *
80
+ * @dev The provided list peers, should be mutated by this function. This allows batch sampling
81
+ * to be performed without making extra copies of the list.
82
+ */
83
+ getPeerFromList(
84
+ peers: PeerId[],
85
+ excluding?: Map<string, boolean>,
86
+ ): {
87
+ peer: PeerId | undefined;
88
+ sampledPeers: PeerId[];
89
+ } {
73
90
  if (peers.length === 0) {
74
- return undefined;
91
+ return { peer: undefined, sampledPeers: [] };
75
92
  }
76
93
 
77
- let randomIndex = this.sampler.random(peers.length);
78
- let attempts = 0;
79
-
80
- // Keep sampling while:
81
- // - we haven't exceeded max attempts AND
82
- // - either the peer has active connections OR is in the exclusion list
83
- while (
84
- attempts < MAX_SAMPLE_ATTEMPTS &&
85
- ((this.activeConnectionsCount.get(peers[randomIndex]) ?? 0) > 0 ||
86
- (excluding?.get(peers[randomIndex]?.toString()) ?? false))
87
- ) {
94
+ const sampledPeers: PeerId[] = [];
95
+ // Try to find a peer that has no active connections and is not in the exclusion list
96
+ for (let attempts = 0; attempts < MAX_SAMPLE_ATTEMPTS && peers.length > 0; attempts++) {
97
+ const randomIndex = this.sampler.random(peers.length);
98
+ const peer = peers[randomIndex];
99
+ const hasActiveConnections = (this.activeConnectionsCount.get(peer.toString()) ?? 0) > 0;
100
+ const isExcluded = excluding?.get(peer.toString()) ?? false;
101
+
102
+ // Remove this peer from consideration
88
103
  peers.splice(randomIndex, 1);
89
- randomIndex = this.sampler.random(peers.length);
90
- attempts++;
104
+
105
+ // If peer is suitable (no active connections and not excluded), return it
106
+ if (!hasActiveConnections && !isExcluded) {
107
+ this.logger.trace('Sampled peer', {
108
+ attempts,
109
+ peer,
110
+ });
111
+ return { peer, sampledPeers };
112
+ }
113
+
114
+ // Keep track of peers that have active reqresp channels, batch sampling will use these to resample
115
+ sampledPeers.push(peer);
91
116
  }
92
117
 
93
- this.logger.trace(`Sampled peer in ${attempts} attempts`, {
94
- attempts,
95
- peer: peers[randomIndex]?.toString(),
118
+ // If we've exhausted our attempts or peers list is empty, return the last peer if available
119
+ const lastPeer = peers.length > 0 ? peers[this.sampler.random(peers.length)] : undefined;
120
+
121
+ this.logger.trace('Sampled peer', {
122
+ attempts: MAX_SAMPLE_ATTEMPTS,
123
+ peer: lastPeer?.toString(),
96
124
  });
97
- return peers[randomIndex];
125
+ return { peer: lastPeer, sampledPeers };
126
+ }
127
+
128
+ /*
129
+ * Returns all peers sorted by connection count ascending,
130
+ * meaning that the peers with the least number of active connections are earlier in an array
131
+ *
132
+ * @param: excluding - peers to exclude
133
+ * @return: list of peer ids
134
+ * */
135
+ public getPeerListSortedByConnectionCountAsc(excluding?: Set<string>): PeerId[] {
136
+ return this.libp2p
137
+ .getPeers()
138
+ .filter(id => !excluding?.has(id.toString()))
139
+ .map(id => ({ id, count: this.activeConnectionsCount.get(id.toString()) ?? 0 }))
140
+ .sort((a, b) => a.count - b.count)
141
+ .map(p => p.id);
98
142
  }
99
143
 
100
144
  /**
101
145
  * Samples a batch of unique peers from the libp2p node, prioritizing peers without active connections
102
146
  *
103
147
  * @param numberToSample - The number of peers to sample
148
+ * @param excluding - The peers to exclude from the sampling
104
149
  * @returns Array of unique sampled peers, prioritizing those without active connections
105
150
  */
106
- samplePeersBatch(numberToSample: number): PeerId[] {
151
+ samplePeersBatch(numberToSample: number, excluding?: Map<string, boolean>): PeerId[] {
107
152
  const peers = this.libp2p.getPeers();
108
- const sampledPeers: PeerId[] = [];
109
- const peersWithConnections: PeerId[] = []; // Hold onto peers with active connections incase we need to sample more
110
-
111
- for (const peer of peers) {
112
- const activeConnections = this.activeConnectionsCount.get(peer) ?? 0;
113
- if (activeConnections === 0) {
114
- if (sampledPeers.push(peer) === numberToSample) {
115
- return sampledPeers;
116
- }
117
- } else {
118
- peersWithConnections.push(peer);
153
+ this.logger.debug('Sampling peers batch', { numberToSample, peers });
154
+
155
+ // Only sample as many peers as we have available
156
+ numberToSample = Math.min(numberToSample, peers.length);
157
+
158
+ const batch: PeerId[] = [];
159
+ // eslint-disable-next-line aztec-custom/no-non-primitive-in-collections
160
+ const withActiveConnections: Set<PeerId> = new Set();
161
+ for (let i = 0; i < numberToSample; i++) {
162
+ const { peer, sampledPeers } = this.getPeerFromList(peers, excluding);
163
+ if (peer) {
164
+ batch.push(peer);
165
+ }
166
+ if (sampledPeers.length > 0) {
167
+ sampledPeers.forEach(peer => withActiveConnections.add(peer));
119
168
  }
120
169
  }
170
+ const lengthWithoutConnections = batch.length;
121
171
 
122
172
  // If we still need more peers, sample from those with connections
123
- while (sampledPeers.length < numberToSample && peersWithConnections.length > 0) {
124
- const randomIndex = this.sampler.random(peersWithConnections.length);
125
- const [peer] = peersWithConnections.splice(randomIndex, 1);
126
- sampledPeers.push(peer);
173
+ while (batch.length < numberToSample && withActiveConnections.size > 0) {
174
+ const randomIndex = this.sampler.random(withActiveConnections.size);
175
+
176
+ const peer = Array.from(withActiveConnections)[randomIndex];
177
+ withActiveConnections.delete(peer);
178
+ batch.push(peer);
127
179
  }
128
180
 
129
- this.logger.trace(`Batch sampled ${sampledPeers.length} unique peers`, {
130
- peers: sampledPeers,
131
- withoutConnections: sampledPeers.length - peersWithConnections.length,
132
- withConnections: peersWithConnections.length,
181
+ this.logger.trace('Batch sampled peers', {
182
+ length: batch.length,
183
+ peers: batch,
184
+ withoutConnections: lengthWithoutConnections,
185
+ withConnections: numberToSample - lengthWithoutConnections,
133
186
  });
134
187
 
135
- return sampledPeers;
188
+ return batch;
136
189
  }
137
190
 
138
191
  // Set of passthrough functions to keep track of active connections
@@ -142,22 +195,27 @@ export class ConnectionSampler {
142
195
  *
143
196
  * @param peerId - The peer id
144
197
  * @param protocol - The protocol
198
+ * @param timeout - Abort connection if it takes too long
145
199
  * @returns The stream
146
200
  */
147
- async dialProtocol(peerId: PeerId, protocol: string): Promise<Stream> {
148
- // Dialling at the same time can cause race conditions where two different streams
149
- // end up with the same id, hence a serial queue
150
- const stream = await this.dialQueue.put(() =>
151
- this.libp2p.dialProtocol(peerId, protocol, { signal: this.abortController.signal }),
152
- );
201
+ async dialProtocol(peerId: PeerId, protocol: string, timeout?: number): Promise<Stream> {
202
+ const stream = await this.libp2p.dialProtocol(peerId, protocol, {
203
+ signal: AbortSignal.any(
204
+ timeout ? [this.abortOnStop.signal, AbortSignal.timeout(timeout!)] : [this.abortOnStop.signal],
205
+ ),
206
+ negotiateFully: !this.opts.p2pOptimisticNegotiation,
207
+ });
208
+ stream.metadata.peerId = peerId;
209
+ this.streams.add(stream);
153
210
 
154
- this.streams.set(stream.id, { stream, peerId });
155
- const updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerId) ?? 0) + 1;
156
- this.activeConnectionsCount.set(peerId, updatedActiveConnectionsCount);
211
+ const peerIdString = peerId.toString();
212
+ const updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerIdString) ?? 0) + 1;
213
+ this.activeConnectionsCount.set(peerIdString, updatedActiveConnectionsCount);
157
214
 
158
- this.logger.trace(`Dialed protocol ${protocol} with peer ${peerId.toString()}`, {
215
+ this.logger.trace('Dialed protocol', {
159
216
  streamId: stream.id,
160
- peerId: peerId.toString(),
217
+ protocol,
218
+ peerId: peerIdString,
161
219
  activeConnectionsCount: updatedActiveConnectionsCount,
162
220
  });
163
221
  return stream;
@@ -165,34 +223,39 @@ export class ConnectionSampler {
165
223
 
166
224
  /**
167
225
  * Closes a stream and updates the active connections count
168
- *
169
- * @param streamId - The stream id
170
226
  */
171
- async close(streamId: string): Promise<void> {
172
- try {
173
- const streamAndPeerId = this.streams.get(streamId);
174
- if (!streamAndPeerId) {
175
- this.logger.warn(`Stream ${streamId} not found`);
176
- return;
177
- }
227
+ async close(stream: Stream): Promise<void> {
228
+ let peerId: PeerId | undefined = undefined;
178
229
 
179
- const { stream, peerId } = streamAndPeerId;
230
+ try {
231
+ peerId = stream.metadata.peerId;
232
+ let updatedActiveConnectionsCount = undefined;
180
233
 
181
- const updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerId) ?? 1) - 1;
182
- this.activeConnectionsCount.set(peerId, updatedActiveConnectionsCount);
234
+ if (!peerId) {
235
+ this.logger.warn(`Stream ${stream.id} does not have a peerId set`);
236
+ } else {
237
+ updatedActiveConnectionsCount = (this.activeConnectionsCount.get(peerId.toString()) ?? 1) - 1;
238
+ this.activeConnectionsCount.set(peerId.toString(), updatedActiveConnectionsCount);
239
+ }
183
240
 
184
- this.logger.trace(`Closing connection to peer ${peerId.toString()}`, {
185
- streamId,
186
- peerId: peerId.toString(),
241
+ this.logger.trace('Closing connection', {
242
+ streamId: stream.id,
243
+ peerId: peerId?.toString(),
187
244
  protocol: stream.protocol,
188
245
  activeConnectionsCount: updatedActiveConnectionsCount,
189
246
  });
190
247
 
191
- await stream?.close();
248
+ if (!this.streams.has(stream)) {
249
+ this.logger.debug(`Stream ${stream.id} is not in the active streams set`);
250
+ }
251
+
252
+ await stream.close();
192
253
  } catch (error) {
193
- this.logger.error(`Failed to close connection to peer with stream id ${streamId}`, error);
254
+ this.logger.error(`Failed to close connection to peer ${peerId ?? 'unknown'} with stream id ${stream.id}`, error);
255
+ // graceful close failed, abort the stream
256
+ stream.abort(new AbortError('Failed to close stream gracefully'));
194
257
  } finally {
195
- this.streams.delete(streamId);
258
+ this.streams.delete(stream);
196
259
  }
197
260
  }
198
261
 
@@ -202,15 +265,23 @@ export class ConnectionSampler {
202
265
  private async cleanupStaleConnections() {
203
266
  // Look for streams without anything in the activeConnectionsCount
204
267
  // If we find anything, close the stream
205
- for (const [streamId, { peerId }] of this.streams.entries()) {
268
+ for (const stream of this.streams.values()) {
206
269
  try {
207
270
  // Check if we have lost track of accounting
208
- if (this.activeConnectionsCount.get(peerId) === 0) {
209
- await this.close(streamId);
210
- this.logger.debug(`Cleaned up stale connection ${streamId} to peer ${peerId.toString()}`);
271
+ const peerId: PeerId = stream.metadata.peerId;
272
+ if (!peerId) {
273
+ this.logger.warn(`Stream ${stream.id} does not have a peerId set`);
274
+ } else if (this.activeConnectionsCount.get(peerId.toString()) === 0) {
275
+ await this.close(stream);
276
+ this.logger.debug('Cleaned up stale connection', { streamId: stream.id, peerId: peerId.toString() });
211
277
  }
212
278
  } catch (error) {
213
- this.logger.error(`Error cleaning up stale connection ${streamId}`, { error });
279
+ this.logger.error(
280
+ `Error cleaning up stale connection to peer ${stream.metadata.peerId?.toString() ?? 'unknown'} stream ${
281
+ stream.id
282
+ }`,
283
+ { error },
284
+ );
214
285
  }
215
286
  }
216
287
  }
@@ -0,0 +1,14 @@
1
+ /**
2
+ * Constants for P2P message deserialization bounds checking.
3
+ * These constants define maximum allowed sizes during deserialization
4
+ * to prevent DoS attacks via maliciously crafted messages.
5
+ */
6
+
7
+ /** Max transactions per block for deserialization validation (~300x default of 32) */
8
+ export { MAX_TXS_PER_BLOCK } from '@aztec/stdlib/deserialization';
9
+
10
+ /** Max version string length (e.g., "1.0.0-alpha.123") */
11
+ export const MAX_VERSION_STRING_LENGTH = 64;
12
+
13
+ /** Max block hash string length (hex: 0x + 64 chars, with generous headroom) */
14
+ export const MAX_BLOCK_HASH_STRING_LENGTH = 128;
@@ -2,3 +2,5 @@
2
2
  * Request Response protocol allows nodes to ask their peers for data
3
3
  * that they missed via the traditional gossip protocol.
4
4
  */
5
+ export * from './protocols/index.js';
6
+ export * from './interface.js';