@aztec/p2p 0.0.1-commit.6d3c34e → 0.0.1-commit.7035c9bd6

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 (535) hide show
  1. package/README.md +129 -3
  2. package/dest/bootstrap/bootstrap.d.ts +4 -3
  3. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  4. package/dest/bootstrap/bootstrap.js +4 -4
  5. package/dest/client/factory.d.ts +11 -11
  6. package/dest/client/factory.d.ts.map +1 -1
  7. package/dest/client/factory.js +58 -18
  8. package/dest/client/interface.d.ts +46 -33
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +41 -51
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +169 -225
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +305 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  18. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  19. package/dest/config.d.ts +65 -16
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +108 -40
  22. package/dest/errors/tx-pool.error.d.ts +8 -0
  23. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  24. package/dest/errors/tx-pool.error.js +9 -0
  25. package/dest/index.d.ts +2 -1
  26. package/dest/index.d.ts.map +1 -1
  27. package/dest/index.js +1 -0
  28. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -88
  29. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  30. package/dest/mem_pools/attestation_pool/attestation_pool.js +445 -3
  31. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  33. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +373 -96
  34. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  35. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  36. package/dest/mem_pools/attestation_pool/index.js +1 -2
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts +4 -2
  38. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  39. package/dest/mem_pools/attestation_pool/mocks.js +8 -5
  40. package/dest/mem_pools/index.d.ts +3 -2
  41. package/dest/mem_pools/index.d.ts.map +1 -1
  42. package/dest/mem_pools/index.js +1 -1
  43. package/dest/mem_pools/instrumentation.d.ts +4 -2
  44. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  45. package/dest/mem_pools/instrumentation.js +18 -16
  46. package/dest/mem_pools/interface.d.ts +5 -5
  47. package/dest/mem_pools/interface.d.ts.map +1 -1
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +15 -10
  49. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  50. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +91 -50
  51. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +19 -5
  52. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -1
  53. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +59 -3
  54. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +79 -5
  55. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -1
  56. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +47 -0
  57. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  58. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  59. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +123 -0
  60. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +2 -2
  61. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -1
  62. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +3 -3
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +4 -4
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -1
  65. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +2 -0
  66. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +2 -2
  67. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -1
  68. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  69. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  70. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  71. package/dest/mem_pools/tx_pool/priority.d.ts +2 -2
  72. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  73. package/dest/mem_pools/tx_pool/priority.js +4 -4
  74. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  75. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  76. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +3 -1
  77. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  78. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  79. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  80. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  81. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  82. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  83. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  84. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  85. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  90. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +94 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  105. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  106. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  107. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  108. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  109. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  110. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  111. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  112. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  113. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  114. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  115. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  116. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  117. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  118. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  119. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  120. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  121. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  122. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +215 -0
  123. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  124. package/dest/mem_pools/tx_pool_v2/interfaces.js +10 -0
  125. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +134 -0
  126. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  127. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +216 -0
  128. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  129. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  130. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  133. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +337 -0
  134. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +62 -0
  135. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  136. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +167 -0
  137. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +78 -0
  138. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  139. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +923 -0
  140. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +3 -3
  141. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  142. package/dest/msg_validators/attestation_validator/attestation_validator.js +43 -11
  143. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  144. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  145. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -6
  146. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  147. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  148. package/dest/msg_validators/clock_tolerance.js +38 -0
  149. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +6 -4
  150. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  151. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  152. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +6 -4
  153. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  154. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  155. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -8
  156. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  157. package/dest/msg_validators/proposal_validator/proposal_validator.js +90 -54
  158. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  159. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  160. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  161. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  162. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  163. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  164. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  165. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  166. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  167. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  168. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  169. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  170. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  171. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  172. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  173. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  174. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  175. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  176. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  177. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  178. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  179. package/dest/msg_validators/tx_validator/factory.d.ts +137 -5
  180. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  181. package/dest/msg_validators/tx_validator/factory.js +249 -58
  182. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  183. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  184. package/dest/msg_validators/tx_validator/fee_payer_balance.js +24 -0
  185. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  186. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  187. package/dest/msg_validators/tx_validator/gas_validator.js +114 -52
  188. package/dest/msg_validators/tx_validator/index.d.ts +4 -1
  189. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  190. package/dest/msg_validators/tx_validator/index.js +3 -0
  191. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  192. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  193. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  194. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  195. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  196. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  197. package/dest/msg_validators/tx_validator/phases_validator.d.ts +24 -3
  198. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  199. package/dest/msg_validators/tx_validator/phases_validator.js +74 -26
  200. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  201. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  202. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  203. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  204. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  205. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  206. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  207. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  208. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  209. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  210. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  211. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  212. package/dest/services/data_store.d.ts +1 -1
  213. package/dest/services/data_store.d.ts.map +1 -1
  214. package/dest/services/data_store.js +10 -6
  215. package/dest/services/discv5/discV5_service.js +1 -1
  216. package/dest/services/dummy_service.d.ts +24 -4
  217. package/dest/services/dummy_service.d.ts.map +1 -1
  218. package/dest/services/dummy_service.js +46 -1
  219. package/dest/services/encoding.d.ts +7 -3
  220. package/dest/services/encoding.d.ts.map +1 -1
  221. package/dest/services/encoding.js +20 -14
  222. package/dest/services/gossipsub/index.d.ts +3 -0
  223. package/dest/services/gossipsub/index.d.ts.map +1 -0
  224. package/dest/services/gossipsub/index.js +2 -0
  225. package/dest/services/gossipsub/scoring.d.ts +21 -3
  226. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  227. package/dest/services/gossipsub/scoring.js +24 -7
  228. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  229. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  230. package/dest/services/gossipsub/topic_score_params.js +346 -0
  231. package/dest/services/index.d.ts +2 -1
  232. package/dest/services/index.d.ts.map +1 -1
  233. package/dest/services/index.js +1 -0
  234. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  235. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  236. package/dest/services/libp2p/instrumentation.js +19 -8
  237. package/dest/services/libp2p/libp2p_service.d.ts +97 -46
  238. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  239. package/dest/services/libp2p/libp2p_service.js +497 -392
  240. package/dest/services/peer-manager/metrics.d.ts +4 -2
  241. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  242. package/dest/services/peer-manager/metrics.js +26 -5
  243. package/dest/services/peer-manager/peer_manager.d.ts +1 -1
  244. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  245. package/dest/services/peer-manager/peer_manager.js +4 -3
  246. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  247. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  248. package/dest/services/peer-manager/peer_scoring.js +33 -4
  249. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +51 -0
  250. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  251. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +540 -0
  252. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  253. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  254. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  255. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +47 -0
  256. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  257. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  258. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +35 -0
  259. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  260. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +136 -0
  261. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +62 -0
  262. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  263. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +176 -0
  264. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  265. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  266. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  267. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  268. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  269. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  270. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  271. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  272. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  273. package/dest/services/reqresp/constants.d.ts +12 -0
  274. package/dest/services/reqresp/constants.d.ts.map +1 -0
  275. package/dest/services/reqresp/constants.js +7 -0
  276. package/dest/services/reqresp/interface.d.ts +12 -1
  277. package/dest/services/reqresp/interface.d.ts.map +1 -1
  278. package/dest/services/reqresp/interface.js +15 -1
  279. package/dest/services/reqresp/metrics.d.ts +6 -5
  280. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  281. package/dest/services/reqresp/metrics.js +17 -5
  282. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  283. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  284. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  285. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  286. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  287. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  288. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  289. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  290. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  291. package/dest/services/reqresp/protocols/status.d.ts +1 -1
  292. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  293. package/dest/services/reqresp/protocols/status.js +2 -1
  294. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  295. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  296. package/dest/services/reqresp/protocols/tx.js +20 -0
  297. package/dest/services/reqresp/reqresp.d.ts +6 -1
  298. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  299. package/dest/services/reqresp/reqresp.js +86 -34
  300. package/dest/services/service.d.ts +42 -3
  301. package/dest/services/service.d.ts.map +1 -1
  302. package/dest/services/tx_collection/config.d.ts +22 -1
  303. package/dest/services/tx_collection/config.d.ts.map +1 -1
  304. package/dest/services/tx_collection/config.js +55 -1
  305. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -7
  306. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  307. package/dest/services/tx_collection/fast_tx_collection.js +95 -84
  308. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  309. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  310. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  311. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  312. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  313. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  314. package/dest/services/tx_collection/index.d.ts +3 -1
  315. package/dest/services/tx_collection/index.d.ts.map +1 -1
  316. package/dest/services/tx_collection/index.js +2 -0
  317. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  318. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  319. package/dest/services/tx_collection/instrumentation.js +10 -2
  320. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  321. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  322. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  323. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  324. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  325. package/dest/services/tx_collection/request_tracker.js +84 -0
  326. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  327. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  328. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  329. package/dest/services/tx_collection/tx_collection.d.ts +29 -19
  330. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  331. package/dest/services/tx_collection/tx_collection.js +79 -7
  332. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  333. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  334. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  335. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  336. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  337. package/dest/services/tx_collection/tx_source.js +19 -2
  338. package/dest/services/tx_file_store/config.d.ts +16 -0
  339. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  340. package/dest/services/tx_file_store/config.js +22 -0
  341. package/dest/services/tx_file_store/index.d.ts +4 -0
  342. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  343. package/dest/services/tx_file_store/index.js +3 -0
  344. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  345. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  346. package/dest/services/tx_file_store/instrumentation.js +29 -0
  347. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  348. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  349. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  350. package/dest/services/tx_provider.d.ts +6 -6
  351. package/dest/services/tx_provider.d.ts.map +1 -1
  352. package/dest/services/tx_provider.js +9 -8
  353. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  354. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  355. package/dest/services/tx_provider_instrumentation.js +5 -5
  356. package/dest/test-helpers/index.d.ts +3 -1
  357. package/dest/test-helpers/index.d.ts.map +1 -1
  358. package/dest/test-helpers/index.js +2 -0
  359. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  360. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  361. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  362. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  363. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  364. package/dest/test-helpers/mock-pubsub.js +105 -4
  365. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  366. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  367. package/dest/test-helpers/reqresp-nodes.js +4 -3
  368. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  369. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  370. package/dest/test-helpers/test_tx_provider.js +41 -0
  371. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  372. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  373. package/dest/test-helpers/testbench-utils.js +385 -0
  374. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  375. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  376. package/dest/testbench/p2p_client_testbench_worker.js +222 -140
  377. package/dest/testbench/worker_client_manager.d.ts +53 -6
  378. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  379. package/dest/testbench/worker_client_manager.js +231 -45
  380. package/dest/util.d.ts +3 -3
  381. package/dest/util.d.ts.map +1 -1
  382. package/package.json +16 -16
  383. package/src/bootstrap/bootstrap.ts +7 -4
  384. package/src/client/factory.ts +108 -37
  385. package/src/client/interface.ts +56 -34
  386. package/src/client/p2p_client.ts +207 -274
  387. package/src/client/test/tx_proposal_collector/README.md +227 -0
  388. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +344 -0
  389. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  390. package/src/config.ts +172 -46
  391. package/src/errors/tx-pool.error.ts +12 -0
  392. package/src/index.ts +1 -0
  393. package/src/mem_pools/attestation_pool/attestation_pool.ts +497 -91
  394. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +460 -112
  395. package/src/mem_pools/attestation_pool/index.ts +9 -2
  396. package/src/mem_pools/attestation_pool/mocks.ts +7 -4
  397. package/src/mem_pools/index.ts +4 -1
  398. package/src/mem_pools/instrumentation.ts +19 -14
  399. package/src/mem_pools/interface.ts +4 -4
  400. package/src/mem_pools/tx_pool/README.md +29 -14
  401. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +130 -75
  402. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +66 -5
  403. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +119 -4
  404. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +163 -0
  405. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  406. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  407. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  408. package/src/mem_pools/tx_pool/priority.ts +4 -4
  409. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +3 -1
  410. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  411. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  412. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  413. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  414. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  415. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +122 -0
  416. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  417. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  418. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  419. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  420. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  421. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  422. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  423. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  424. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  425. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  426. package/src/mem_pools/tx_pool_v2/interfaces.ts +247 -0
  427. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +337 -0
  428. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  429. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  430. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +238 -0
  431. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1105 -0
  432. package/src/msg_validators/attestation_validator/README.md +49 -0
  433. package/src/msg_validators/attestation_validator/attestation_validator.ts +28 -15
  434. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  435. package/src/msg_validators/clock_tolerance.ts +52 -0
  436. package/src/msg_validators/proposal_validator/README.md +123 -0
  437. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +14 -4
  438. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +20 -7
  439. package/src/msg_validators/proposal_validator/proposal_validator.ts +89 -65
  440. package/src/msg_validators/tx_validator/README.md +119 -0
  441. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  442. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  443. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  444. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  445. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  446. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  447. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  448. package/src/msg_validators/tx_validator/factory.ts +406 -56
  449. package/src/msg_validators/tx_validator/fee_payer_balance.ts +44 -0
  450. package/src/msg_validators/tx_validator/gas_validator.ts +140 -55
  451. package/src/msg_validators/tx_validator/index.ts +3 -0
  452. package/src/msg_validators/tx_validator/metadata_validator.ts +18 -7
  453. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  454. package/src/msg_validators/tx_validator/phases_validator.ts +86 -29
  455. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  456. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  457. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  458. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  459. package/src/services/data_store.ts +10 -7
  460. package/src/services/discv5/discV5_service.ts +1 -1
  461. package/src/services/dummy_service.ts +59 -2
  462. package/src/services/encoding.ts +20 -13
  463. package/src/services/gossipsub/README.md +641 -0
  464. package/src/services/gossipsub/index.ts +2 -0
  465. package/src/services/gossipsub/scoring.ts +29 -5
  466. package/src/services/gossipsub/topic_score_params.ts +487 -0
  467. package/src/services/index.ts +1 -0
  468. package/src/services/libp2p/instrumentation.ts +20 -7
  469. package/src/services/libp2p/libp2p_service.ts +541 -420
  470. package/src/services/peer-manager/metrics.ts +28 -4
  471. package/src/services/peer-manager/peer_manager.ts +5 -3
  472. package/src/services/peer-manager/peer_scoring.ts +29 -1
  473. package/src/services/reqresp/README.md +229 -0
  474. package/src/services/reqresp/batch-tx-requester/README.md +344 -0
  475. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +670 -0
  476. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  477. package/src/services/reqresp/batch-tx-requester/interface.ts +54 -0
  478. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +168 -0
  479. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +249 -0
  480. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  481. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  482. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  483. package/src/services/reqresp/constants.ts +14 -0
  484. package/src/services/reqresp/interface.ts +29 -1
  485. package/src/services/reqresp/metrics.ts +34 -9
  486. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  487. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  488. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  489. package/src/services/reqresp/protocols/status.ts +5 -3
  490. package/src/services/reqresp/protocols/tx.ts +22 -0
  491. package/src/services/reqresp/reqresp.ts +99 -32
  492. package/src/services/service.ts +55 -2
  493. package/src/services/tx_collection/config.ts +83 -1
  494. package/src/services/tx_collection/fast_tx_collection.ts +111 -91
  495. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  496. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  497. package/src/services/tx_collection/index.ts +6 -0
  498. package/src/services/tx_collection/instrumentation.ts +17 -2
  499. package/src/services/tx_collection/proposal_tx_collector.ts +108 -0
  500. package/src/services/tx_collection/request_tracker.ts +127 -0
  501. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  502. package/src/services/tx_collection/tx_collection.ts +122 -27
  503. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  504. package/src/services/tx_collection/tx_source.ts +22 -3
  505. package/src/services/tx_file_store/config.ts +37 -0
  506. package/src/services/tx_file_store/index.ts +3 -0
  507. package/src/services/tx_file_store/instrumentation.ts +36 -0
  508. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  509. package/src/services/tx_provider.ts +12 -11
  510. package/src/services/tx_provider_instrumentation.ts +11 -5
  511. package/src/test-helpers/index.ts +2 -0
  512. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  513. package/src/test-helpers/mock-pubsub.ts +146 -9
  514. package/src/test-helpers/reqresp-nodes.ts +5 -7
  515. package/src/test-helpers/test_tx_provider.ts +64 -0
  516. package/src/test-helpers/testbench-utils.ts +456 -0
  517. package/src/testbench/p2p_client_testbench_worker.ts +334 -137
  518. package/src/testbench/worker_client_manager.ts +312 -47
  519. package/src/util.ts +8 -2
  520. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  521. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  522. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  523. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  524. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  525. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  526. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts +0 -15
  527. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts.map +0 -1
  528. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.js +0 -88
  529. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  530. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  531. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -183
  532. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  533. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  534. package/src/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.ts +0 -108
  535. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -206
@@ -24,6 +24,7 @@ class KeyNotFoundError extends Error {
24
24
  }
25
25
 
26
26
  export class AztecDatastore implements Datastore {
27
+ #db: AztecAsyncKVStore;
27
28
  #memoryDatastore: Map<string, MemoryItem>;
28
29
  #dbDatastore: AztecAsyncMap<string, Uint8Array>;
29
30
 
@@ -32,9 +33,9 @@ export class AztecDatastore implements Datastore {
32
33
  private maxMemoryItems: number;
33
34
 
34
35
  constructor(db: AztecAsyncKVStore, { maxMemoryItems } = { maxMemoryItems: 50 }) {
36
+ this.#db = db;
35
37
  this.#memoryDatastore = new Map();
36
38
  this.#dbDatastore = db.openMap('p2p_datastore');
37
-
38
39
  this.maxMemoryItems = maxMemoryItems;
39
40
  }
40
41
 
@@ -106,13 +107,15 @@ export class AztecDatastore implements Datastore {
106
107
  });
107
108
  },
108
109
  commit: async () => {
109
- for (const op of this.#batchOps) {
110
- if (op.type === 'put' && op.value) {
111
- await this.put(op.key, op.value);
112
- } else if (op.type === 'del') {
113
- await this.delete(op.key);
110
+ await this.#db.transactionAsync(async () => {
111
+ for (const op of this.#batchOps) {
112
+ if (op.type === 'put' && op.value) {
113
+ await this.put(op.key, op.value);
114
+ } else if (op.type === 'del') {
115
+ await this.delete(op.key);
116
+ }
114
117
  }
115
- }
118
+ });
116
119
  this.#batchOps = []; // Clear operations after commit
117
120
  },
118
121
  };
@@ -87,7 +87,7 @@ export class DiscV5Service extends EventEmitter implements PeerDiscoveryService
87
87
  this.packageVersion,
88
88
  ));
89
89
 
90
- const metricsRegistry = new OtelMetricsAdapter(telemetry);
90
+ const metricsRegistry = new OtelMetricsAdapter(telemetry, this.logger.getBindings());
91
91
  this.discv5 = Discv5.create({
92
92
  enr: this.enr,
93
93
  peerId,
@@ -1,6 +1,6 @@
1
1
  import type { EthAddress } from '@aztec/foundation/eth-address';
2
2
  import type { PeerInfo } from '@aztec/stdlib/interfaces/server';
3
- import type { Gossipable, PeerErrorSeverity } from '@aztec/stdlib/p2p';
3
+ import type { Gossipable, PeerErrorSeverity, TopicType } from '@aztec/stdlib/p2p';
4
4
  import { Tx, TxHash } from '@aztec/stdlib/tx';
5
5
 
6
6
  import type { PeerId } from '@libp2p/interface';
@@ -8,7 +8,9 @@ import type { ENR } from '@nethermindeth/enr';
8
8
  import EventEmitter from 'events';
9
9
 
10
10
  import type { PeerManagerInterface } from './peer-manager/interface.js';
11
+ import type { BatchTxRequesterLibP2PService } from './reqresp/batch-tx-requester/interface.js';
11
12
  import type { P2PReqRespConfig } from './reqresp/config.js';
13
+ import type { ConnectionSampler } from './reqresp/connection-sampler/connection_sampler.js';
12
14
  import { type AuthRequest, StatusMessage } from './reqresp/index.js';
13
15
  import type {
14
16
  ReqRespInterface,
@@ -24,6 +26,8 @@ import { ReqRespStatus } from './reqresp/status.js';
24
26
  import {
25
27
  type P2PBlockReceivedCallback,
26
28
  type P2PCheckpointReceivedCallback,
29
+ type P2PDuplicateAttestationCallback,
30
+ type P2PDuplicateProposalCallback,
27
31
  type P2PService,
28
32
  type PeerDiscoveryService,
29
33
  PeerDiscoveryState,
@@ -40,6 +44,10 @@ export class DummyP2PService implements P2PService {
40
44
  return [];
41
45
  }
42
46
 
47
+ getGossipMeshPeerCount(_topicType: TopicType): number {
48
+ return 0;
49
+ }
50
+
43
51
  /**
44
52
  * Starts the dummy implementation.
45
53
  * @returns A resolved promise.
@@ -80,6 +88,16 @@ export class DummyP2PService implements P2PService {
80
88
  */
81
89
  public registerCheckpointReceivedCallback(_callback: P2PCheckpointReceivedCallback) {}
82
90
 
91
+ /**
92
+ * Register a callback for when a duplicate proposal is detected
93
+ */
94
+ public registerDuplicateProposalCallback(_callback: P2PDuplicateProposalCallback): void {}
95
+
96
+ /**
97
+ * Register a callback for when a duplicate attestation is detected
98
+ */
99
+ public registerDuplicateAttestationCallback(_callback: P2PDuplicateAttestationCallback): void {}
100
+
83
101
  /**
84
102
  * Sends a request to a peer.
85
103
  * @param _protocol - The protocol to send the request on.
@@ -106,6 +124,15 @@ export class DummyP2PService implements P2PService {
106
124
  return Promise.resolve([]);
107
125
  }
108
126
 
127
+ public sendRequestToPeer(
128
+ _peerId: PeerId,
129
+ _subProtocol: ReqRespSubProtocol,
130
+ _payload: Buffer,
131
+ _dialTimeout?: number,
132
+ ): Promise<ReqRespResponse> {
133
+ return Promise.resolve({ status: ReqRespStatus.SUCCESS, data: Buffer.from([]) });
134
+ }
135
+
109
136
  /**
110
137
  * Returns the ENR of the peer.
111
138
  * @returns The ENR of the peer, otherwise undefined.
@@ -114,7 +141,7 @@ export class DummyP2PService implements P2PService {
114
141
  return undefined;
115
142
  }
116
143
 
117
- validate(_txs: Tx[]): Promise<void> {
144
+ validateTxsReceivedInBlockProposal(_txs: Tx[]): Promise<void> {
118
145
  return Promise.resolve();
119
146
  }
120
147
 
@@ -132,6 +159,27 @@ export class DummyP2PService implements P2PService {
132
159
 
133
160
  //this is no-op
134
161
  registerThisValidatorAddresses(_address: EthAddress[]): void {}
162
+
163
+ /**
164
+ * Get dummy BatchTxRequesterLibP2PService for testing
165
+ */
166
+ getBatchTxRequesterService(): BatchTxRequesterLibP2PService {
167
+ return {
168
+ reqResp: this, // The dummy service implements ReqRespInterface
169
+ connectionSampler: new DummyReqResp().getConnectionSampler(),
170
+ txValidatorConfig: {
171
+ l1ChainId: 1,
172
+ rollupVersion: 1,
173
+ proofVerifier: {
174
+ verifyProof: () => Promise.resolve({ valid: true, durationMs: 0, totalDurationMs: 0 }),
175
+ stop: () => Promise.resolve(),
176
+ },
177
+ },
178
+ peerScoring: {
179
+ penalizePeer: (_peerId, _penalty) => {},
180
+ },
181
+ };
182
+ }
135
183
  }
136
184
 
137
185
  /**
@@ -268,6 +316,15 @@ export class DummyReqResp implements ReqRespInterface {
268
316
  return Promise.resolve({ status: ReqRespStatus.SUCCESS, data: Buffer.from([]) });
269
317
  }
270
318
 
319
+ /**
320
+ * Get dummy connection sampler for testing
321
+ */
322
+ getConnectionSampler(): Pick<ConnectionSampler, 'getPeerListSortedByConnectionCountAsc'> {
323
+ return {
324
+ getPeerListSortedByConnectionCountAsc: () => [],
325
+ };
326
+ }
327
+
271
328
  addSubProtocol(
272
329
  _subProtocol: ReqRespSubProtocol,
273
330
  _handler: ReqRespSubProtocolHandler,
@@ -1,14 +1,22 @@
1
1
  // Taken from lodestar: https://github.com/ChainSafe/lodestar
2
- import { sha256 } from '@aztec/foundation/crypto/sha256';
3
2
  import { createLogger } from '@aztec/foundation/log';
4
- import { TopicType, getTopicFromString } from '@aztec/stdlib/p2p';
3
+ import { MAX_TX_SIZE_KB, TopicType, getTopicFromString } from '@aztec/stdlib/p2p';
5
4
 
6
5
  import type { RPC } from '@chainsafe/libp2p-gossipsub/message';
7
6
  import type { DataTransform } from '@chainsafe/libp2p-gossipsub/types';
8
7
  import type { Message } from '@libp2p/interface';
8
+ import { webcrypto } from 'node:crypto';
9
9
  import { compressSync, uncompressSync } from 'snappy';
10
10
  import xxhashFactory from 'xxhash-wasm';
11
11
 
12
+ /** Thrown when a Snappy-compressed response exceeds the allowed decompressed size. */
13
+ export class OversizedSnappyResponseError extends Error {
14
+ constructor(decompressedSize: number, maxSizeKb: number) {
15
+ super(`Decompressed size ${decompressedSize} exceeds maximum allowed size of ${maxSizeKb}kb`);
16
+ this.name = 'OversizedSnappyResponseError';
17
+ }
18
+ }
19
+
12
20
  // Load WASM
13
21
  const xxhash = await xxhashFactory();
14
22
 
@@ -44,22 +52,21 @@ export function msgIdToStrFn(msgId: Uint8Array): string {
44
52
  * @param message - The libp2p message
45
53
  * @returns The message identifier
46
54
  */
47
- export function getMsgIdFn(message: Message) {
48
- const { topic } = message;
49
-
50
- const vec = [Buffer.from(topic), message.data];
51
- return sha256(Buffer.concat(vec)).subarray(0, 20);
55
+ export async function getMsgIdFn({ topic, data }: Message): Promise<Uint8Array> {
56
+ const buffer = Buffer.concat([Buffer.from(topic), data]);
57
+ const hash = await webcrypto.subtle.digest('SHA-256', buffer);
58
+ return Buffer.from(hash.slice(0, 20));
52
59
  }
53
60
 
54
61
  const DefaultMaxSizesKb: Record<TopicType, number> = {
55
- // Tx effects should not exceed 128kb, so 512kb for the full tx obj should be sufficient
56
- [TopicType.tx]: 512,
62
+ [TopicType.tx]: MAX_TX_SIZE_KB,
57
63
  // An attestation has roughly 30 fields, which is 1kb, so 5x is plenty
58
64
  [TopicType.checkpoint_attestation]: 5,
59
65
  // Proposals may carry some tx objects, so we allow a larger size capped at 10mb
60
66
  // Note this may not be enough for carrying all tx objects in a block
61
67
  [TopicType.block_proposal]: 1024 * 10,
62
- // TODO(palla/mbps): Check size for checkpoint proposal
68
+ // Checkpoint proposals carry almost the same data as a block proposal (see the lastBlockProposal)
69
+ // Only diff is an additional header, which is pretty small compared to the 10mb limit
63
70
  [TopicType.checkpoint_proposal]: 1024 * 10,
64
71
  };
65
72
 
@@ -79,15 +86,15 @@ export class SnappyTransform implements DataTransform {
79
86
  return this.inboundTransformData(Buffer.from(data), topic);
80
87
  }
81
88
 
82
- public inboundTransformData(data: Buffer, topic?: TopicType): Buffer {
89
+ public inboundTransformData(data: Buffer, topic?: TopicType, maxSizeKbOverride?: number): Buffer {
83
90
  if (data.length === 0) {
84
91
  return data;
85
92
  }
86
- const maxSizeKb = this.maxSizesKb[topic!] ?? this.defaultMaxSizeKb;
93
+ const maxSizeKb = maxSizeKbOverride ?? this.maxSizesKb[topic!] ?? this.defaultMaxSizeKb;
87
94
  const { decompressedSize } = readSnappyPreamble(data);
88
95
  if (decompressedSize > maxSizeKb * 1024) {
89
96
  this.logger.warn(`Decompressed size ${decompressedSize} exceeds maximum allowed size of ${maxSizeKb}kb`);
90
- throw new Error(`Decompressed size ${decompressedSize} exceeds maximum allowed size of ${maxSizeKb}kb`);
97
+ throw new OversizedSnappyResponseError(decompressedSize, maxSizeKb);
91
98
  }
92
99
 
93
100
  return Buffer.from(uncompressSync(data, { asBuffer: true }));