@aztec/p2p 0.0.1-commit.6d3c34e → 0.0.1-commit.7cf39cb55

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 (475) 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 +4 -4
  4. package/dest/client/factory.d.ts +5 -5
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +50 -13
  7. package/dest/client/interface.d.ts +37 -15
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +37 -36
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +126 -139
  12. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +305 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  18. package/dest/config.d.ts +33 -3
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +23 -4
  21. package/dest/index.d.ts +2 -1
  22. package/dest/index.d.ts.map +1 -1
  23. package/dest/index.js +1 -0
  24. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -88
  25. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  26. package/dest/mem_pools/attestation_pool/attestation_pool.js +441 -3
  27. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  28. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  29. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +373 -96
  30. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  31. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  32. package/dest/mem_pools/attestation_pool/index.js +1 -2
  33. package/dest/mem_pools/attestation_pool/mocks.d.ts +4 -2
  34. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  35. package/dest/mem_pools/attestation_pool/mocks.js +8 -5
  36. package/dest/mem_pools/index.d.ts +3 -2
  37. package/dest/mem_pools/index.d.ts.map +1 -1
  38. package/dest/mem_pools/index.js +1 -1
  39. package/dest/mem_pools/instrumentation.d.ts +1 -1
  40. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  41. package/dest/mem_pools/instrumentation.js +2 -2
  42. package/dest/mem_pools/interface.d.ts +5 -5
  43. package/dest/mem_pools/interface.d.ts.map +1 -1
  44. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +15 -10
  45. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  46. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +91 -50
  47. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +19 -5
  48. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +59 -3
  50. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +79 -5
  51. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -1
  52. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +47 -0
  53. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  54. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  55. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  56. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +2 -2
  57. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -1
  58. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +4 -4
  59. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -1
  60. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +2 -0
  61. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +2 -2
  62. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -1
  63. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  64. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  66. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  67. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  69. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  70. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  72. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +102 -0
  73. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +242 -0
  75. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  76. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  77. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +119 -0
  78. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  79. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  80. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +93 -0
  81. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  82. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  83. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +89 -0
  84. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  85. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +131 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +17 -0
  90. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +72 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +63 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  105. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  106. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  107. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  108. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +201 -0
  109. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  110. package/dest/mem_pools/tx_pool_v2/interfaces.js +7 -0
  111. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +95 -0
  112. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  113. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +128 -0
  114. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  115. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  116. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  117. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +105 -0
  118. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  119. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +345 -0
  120. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +57 -0
  121. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  122. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +160 -0
  123. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +71 -0
  124. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  125. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +780 -0
  126. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +3 -3
  127. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  128. package/dest/msg_validators/attestation_validator/attestation_validator.js +41 -10
  129. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  130. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  131. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -6
  132. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  133. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  134. package/dest/msg_validators/clock_tolerance.js +37 -0
  135. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +3 -3
  136. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  137. package/dest/msg_validators/proposal_validator/proposal_validator.js +55 -31
  138. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +3 -3
  139. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -1
  140. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +93 -64
  141. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +3 -3
  142. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  143. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  144. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  145. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  146. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  147. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  148. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  149. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  150. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  151. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  152. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  153. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  154. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  155. package/dest/msg_validators/tx_validator/factory.d.ts +8 -3
  156. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  157. package/dest/msg_validators/tx_validator/factory.js +21 -11
  158. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  159. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  160. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  161. package/dest/msg_validators/tx_validator/gas_validator.d.ts +3 -2
  162. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  163. package/dest/msg_validators/tx_validator/gas_validator.js +11 -16
  164. package/dest/msg_validators/tx_validator/index.d.ts +2 -1
  165. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  166. package/dest/msg_validators/tx_validator/index.js +1 -0
  167. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  168. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  169. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  170. package/dest/msg_validators/tx_validator/phases_validator.d.ts +3 -2
  171. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  172. package/dest/msg_validators/tx_validator/phases_validator.js +3 -3
  173. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  174. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  175. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  176. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  177. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  178. package/dest/msg_validators/tx_validator/timestamp_validator.js +4 -4
  179. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  180. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  181. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  182. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  183. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  184. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  185. package/dest/services/data_store.d.ts +1 -1
  186. package/dest/services/data_store.d.ts.map +1 -1
  187. package/dest/services/data_store.js +10 -6
  188. package/dest/services/discv5/discV5_service.js +1 -1
  189. package/dest/services/dummy_service.d.ts +22 -2
  190. package/dest/services/dummy_service.d.ts.map +1 -1
  191. package/dest/services/dummy_service.js +45 -0
  192. package/dest/services/encoding.d.ts +2 -2
  193. package/dest/services/encoding.d.ts.map +1 -1
  194. package/dest/services/encoding.js +4 -5
  195. package/dest/services/gossipsub/index.d.ts +3 -0
  196. package/dest/services/gossipsub/index.d.ts.map +1 -0
  197. package/dest/services/gossipsub/index.js +2 -0
  198. package/dest/services/gossipsub/scoring.d.ts +21 -3
  199. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  200. package/dest/services/gossipsub/scoring.js +24 -7
  201. package/dest/services/gossipsub/topic_score_params.d.ts +161 -0
  202. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  203. package/dest/services/gossipsub/topic_score_params.js +324 -0
  204. package/dest/services/index.d.ts +2 -1
  205. package/dest/services/index.d.ts.map +1 -1
  206. package/dest/services/index.js +1 -0
  207. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  208. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  209. package/dest/services/libp2p/instrumentation.js +19 -8
  210. package/dest/services/libp2p/libp2p_service.d.ts +91 -36
  211. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  212. package/dest/services/libp2p/libp2p_service.js +407 -303
  213. package/dest/services/peer-manager/metrics.d.ts +2 -2
  214. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  215. package/dest/services/peer-manager/metrics.js +20 -5
  216. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  217. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  218. package/dest/services/peer-manager/peer_scoring.js +33 -4
  219. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +47 -0
  220. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  221. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +566 -0
  222. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  223. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  224. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  225. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +50 -0
  226. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  227. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  228. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +37 -0
  229. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  230. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +151 -0
  231. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  232. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  233. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  234. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  235. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  236. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  237. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  238. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  239. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  240. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  241. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  242. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  243. package/dest/services/reqresp/constants.d.ts +12 -0
  244. package/dest/services/reqresp/constants.d.ts.map +1 -0
  245. package/dest/services/reqresp/constants.js +7 -0
  246. package/dest/services/reqresp/interface.d.ts +12 -1
  247. package/dest/services/reqresp/interface.d.ts.map +1 -1
  248. package/dest/services/reqresp/interface.js +15 -1
  249. package/dest/services/reqresp/metrics.d.ts +6 -5
  250. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  251. package/dest/services/reqresp/metrics.js +17 -5
  252. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  253. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  254. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  255. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  256. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  257. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  258. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  259. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  260. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  261. package/dest/services/reqresp/protocols/status.d.ts +1 -1
  262. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  263. package/dest/services/reqresp/protocols/status.js +2 -1
  264. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  265. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  266. package/dest/services/reqresp/protocols/tx.js +20 -0
  267. package/dest/services/reqresp/reqresp.d.ts +6 -1
  268. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  269. package/dest/services/reqresp/reqresp.js +69 -26
  270. package/dest/services/service.d.ts +38 -1
  271. package/dest/services/service.d.ts.map +1 -1
  272. package/dest/services/tx_collection/config.d.ts +22 -1
  273. package/dest/services/tx_collection/config.d.ts.map +1 -1
  274. package/dest/services/tx_collection/config.js +55 -1
  275. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  276. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  277. package/dest/services/tx_collection/fast_tx_collection.js +34 -13
  278. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  279. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  280. package/dest/services/tx_collection/file_store_tx_collection.js +165 -0
  281. package/dest/services/tx_collection/file_store_tx_source.d.ts +28 -0
  282. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  283. package/dest/services/tx_collection/file_store_tx_source.js +59 -0
  284. package/dest/services/tx_collection/index.d.ts +3 -1
  285. package/dest/services/tx_collection/index.d.ts.map +1 -1
  286. package/dest/services/tx_collection/index.js +2 -0
  287. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  288. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  289. package/dest/services/tx_collection/instrumentation.js +9 -2
  290. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  291. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  292. package/dest/services/tx_collection/proposal_tx_collector.js +49 -0
  293. package/dest/services/tx_collection/slow_tx_collection.d.ts +8 -4
  294. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  295. package/dest/services/tx_collection/slow_tx_collection.js +55 -23
  296. package/dest/services/tx_collection/tx_collection.d.ts +25 -13
  297. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  298. package/dest/services/tx_collection/tx_collection.js +79 -7
  299. package/dest/services/tx_collection/tx_collection_sink.d.ts +15 -6
  300. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  301. package/dest/services/tx_collection/tx_collection_sink.js +13 -7
  302. package/dest/services/tx_file_store/config.d.ts +16 -0
  303. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  304. package/dest/services/tx_file_store/config.js +22 -0
  305. package/dest/services/tx_file_store/index.d.ts +4 -0
  306. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  307. package/dest/services/tx_file_store/index.js +3 -0
  308. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  309. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  310. package/dest/services/tx_file_store/instrumentation.js +29 -0
  311. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  312. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  313. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  314. package/dest/services/tx_provider.d.ts +5 -5
  315. package/dest/services/tx_provider.d.ts.map +1 -1
  316. package/dest/services/tx_provider.js +5 -4
  317. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  318. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  319. package/dest/services/tx_provider_instrumentation.js +5 -5
  320. package/dest/test-helpers/index.d.ts +3 -1
  321. package/dest/test-helpers/index.d.ts.map +1 -1
  322. package/dest/test-helpers/index.js +2 -0
  323. package/dest/test-helpers/make-test-p2p-clients.d.ts +3 -3
  324. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  325. package/dest/test-helpers/mock-pubsub.d.ts +27 -1
  326. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  327. package/dest/test-helpers/mock-pubsub.js +97 -2
  328. package/dest/test-helpers/reqresp-nodes.d.ts +1 -1
  329. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  330. package/dest/test-helpers/reqresp-nodes.js +2 -1
  331. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  332. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  333. package/dest/test-helpers/test_tx_provider.js +41 -0
  334. package/dest/test-helpers/testbench-utils.d.ts +160 -0
  335. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  336. package/dest/test-helpers/testbench-utils.js +366 -0
  337. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  338. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  339. package/dest/testbench/p2p_client_testbench_worker.js +213 -133
  340. package/dest/testbench/worker_client_manager.d.ts +51 -6
  341. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  342. package/dest/testbench/worker_client_manager.js +226 -44
  343. package/package.json +16 -16
  344. package/src/bootstrap/bootstrap.ts +7 -4
  345. package/src/client/factory.ts +90 -22
  346. package/src/client/interface.ts +45 -14
  347. package/src/client/p2p_client.ts +168 -166
  348. package/src/client/test/tx_proposal_collector/README.md +227 -0
  349. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +336 -0
  350. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  351. package/src/config.ts +48 -4
  352. package/src/index.ts +1 -0
  353. package/src/mem_pools/attestation_pool/attestation_pool.ts +496 -91
  354. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +460 -112
  355. package/src/mem_pools/attestation_pool/index.ts +9 -2
  356. package/src/mem_pools/attestation_pool/mocks.ts +6 -4
  357. package/src/mem_pools/index.ts +4 -1
  358. package/src/mem_pools/instrumentation.ts +2 -1
  359. package/src/mem_pools/interface.ts +4 -4
  360. package/src/mem_pools/tx_pool/README.md +28 -13
  361. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +130 -75
  362. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +66 -5
  363. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +119 -4
  364. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  365. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  366. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  367. package/src/mem_pools/tx_pool_v2/README.md +275 -0
  368. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  369. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  370. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +310 -0
  371. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +147 -0
  372. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  373. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +111 -0
  374. package/src/mem_pools/tx_pool_v2/eviction/index.ts +23 -0
  375. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +164 -0
  376. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  377. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  378. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +88 -0
  379. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +72 -0
  380. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  381. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  382. package/src/mem_pools/tx_pool_v2/interfaces.ts +233 -0
  383. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +211 -0
  384. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  385. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +433 -0
  386. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +218 -0
  387. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +924 -0
  388. package/src/msg_validators/attestation_validator/attestation_validator.ts +26 -14
  389. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  390. package/src/msg_validators/clock_tolerance.ts +51 -0
  391. package/src/msg_validators/proposal_validator/proposal_validator.ts +31 -31
  392. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +91 -67
  393. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +2 -2
  394. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  395. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  396. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  397. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  398. package/src/msg_validators/tx_validator/factory.ts +64 -23
  399. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  400. package/src/msg_validators/tx_validator/gas_validator.ts +17 -28
  401. package/src/msg_validators/tx_validator/index.ts +1 -0
  402. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  403. package/src/msg_validators/tx_validator/phases_validator.ts +5 -3
  404. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  405. package/src/msg_validators/tx_validator/timestamp_validator.ts +25 -17
  406. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  407. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  408. package/src/services/data_store.ts +10 -7
  409. package/src/services/discv5/discV5_service.ts +1 -1
  410. package/src/services/dummy_service.ts +57 -0
  411. package/src/services/encoding.ts +4 -5
  412. package/src/services/gossipsub/README.md +626 -0
  413. package/src/services/gossipsub/index.ts +2 -0
  414. package/src/services/gossipsub/scoring.ts +29 -5
  415. package/src/services/gossipsub/topic_score_params.ts +451 -0
  416. package/src/services/index.ts +1 -0
  417. package/src/services/libp2p/instrumentation.ts +20 -7
  418. package/src/services/libp2p/libp2p_service.ts +435 -314
  419. package/src/services/peer-manager/metrics.ts +21 -4
  420. package/src/services/peer-manager/peer_scoring.ts +29 -1
  421. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  422. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  423. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  424. package/src/services/reqresp/batch-tx-requester/interface.ts +57 -0
  425. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +209 -0
  426. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  427. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  428. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  429. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  430. package/src/services/reqresp/constants.ts +14 -0
  431. package/src/services/reqresp/interface.ts +29 -1
  432. package/src/services/reqresp/metrics.ts +34 -9
  433. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  434. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  435. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  436. package/src/services/reqresp/protocols/status.ts +5 -3
  437. package/src/services/reqresp/protocols/tx.ts +22 -0
  438. package/src/services/reqresp/reqresp.ts +79 -22
  439. package/src/services/service.ts +44 -0
  440. package/src/services/tx_collection/config.ts +83 -1
  441. package/src/services/tx_collection/fast_tx_collection.ts +44 -19
  442. package/src/services/tx_collection/file_store_tx_collection.ts +198 -0
  443. package/src/services/tx_collection/file_store_tx_source.ts +73 -0
  444. package/src/services/tx_collection/index.ts +6 -0
  445. package/src/services/tx_collection/instrumentation.ts +11 -2
  446. package/src/services/tx_collection/proposal_tx_collector.ts +112 -0
  447. package/src/services/tx_collection/slow_tx_collection.ts +66 -32
  448. package/src/services/tx_collection/tx_collection.ts +117 -21
  449. package/src/services/tx_collection/tx_collection_sink.ts +17 -7
  450. package/src/services/tx_file_store/config.ts +37 -0
  451. package/src/services/tx_file_store/index.ts +3 -0
  452. package/src/services/tx_file_store/instrumentation.ts +36 -0
  453. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  454. package/src/services/tx_provider.ts +10 -9
  455. package/src/services/tx_provider_instrumentation.ts +11 -5
  456. package/src/test-helpers/index.ts +2 -0
  457. package/src/test-helpers/make-test-p2p-clients.ts +3 -3
  458. package/src/test-helpers/mock-pubsub.ts +133 -3
  459. package/src/test-helpers/reqresp-nodes.ts +2 -1
  460. package/src/test-helpers/test_tx_provider.ts +64 -0
  461. package/src/test-helpers/testbench-utils.ts +430 -0
  462. package/src/testbench/p2p_client_testbench_worker.ts +322 -127
  463. package/src/testbench/worker_client_manager.ts +304 -47
  464. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  465. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  466. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  467. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  468. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  469. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  470. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts +0 -15
  471. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts.map +0 -1
  472. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.js +0 -88
  473. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  474. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  475. package/src/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.ts +0 -108
@@ -374,6 +374,7 @@ var _dec, _dec1, _initProto;
374
374
  import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/constants';
375
375
  import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
376
376
  import { createLogger } from '@aztec/foundation/log';
377
+ import { RunningPromise } from '@aztec/foundation/promise';
377
378
  import { DateProvider } from '@aztec/foundation/timer';
378
379
  import { L2TipsKVStore } from '@aztec/kv-store/stores';
379
380
  import { L2BlockStream } from '@aztec/stdlib/block';
@@ -401,6 +402,8 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
401
402
  l2BlockSource;
402
403
  p2pService;
403
404
  txCollection;
405
+ txFileStore;
406
+ epochCache;
404
407
  _dateProvider;
405
408
  telemetry;
406
409
  log;
@@ -433,15 +436,10 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
433
436
  blockStream;
434
437
  txProvider;
435
438
  validatorAddresses;
436
- /**
437
- * In-memory P2P client constructor.
438
- * @param store - The client's instance of the KV store.
439
- * @param l2BlockSource - P2P client's source for fetching existing blocks.
440
- * @param txPool - The client's instance of a transaction pool. Defaults to in-memory implementation.
441
- * @param p2pService - The concrete instance of p2p networking to use.
442
- * @param log - A logger.
443
- */ constructor(_clientType, store, l2BlockSource, mempools, p2pService, txCollection, config = {}, _dateProvider = new DateProvider(), telemetry = getTelemetryClient(), log = createLogger('p2p')){
444
- super(telemetry, 'P2PClient'), this.store = store, this.l2BlockSource = l2BlockSource, this.p2pService = p2pService, this.txCollection = txCollection, this._dateProvider = _dateProvider, this.telemetry = telemetry, this.log = log, this.currentState = (_initProto(this), P2PClientState.IDLE), this.syncPromise = Promise.resolve(), this.syncResolve = undefined, this.latestBlockNumberAtStart = -1, this.provenBlockNumberAtStart = -1, this.finalizedBlockNumberAtStart = -1, this.validatorAddresses = [];
439
+ /** Tracks the last slot for which we called prepareForSlot */ lastSlotProcessed;
440
+ /** Polls for slot changes and calls prepareForSlot on the tx pool */ slotMonitor;
441
+ constructor(_clientType, store, l2BlockSource, mempools, p2pService, txCollection, txFileStore, epochCache, config = {}, _dateProvider = new DateProvider(), telemetry = getTelemetryClient(), log = createLogger('p2p')){
442
+ super(telemetry, 'P2PClient'), this.store = store, this.l2BlockSource = l2BlockSource, this.p2pService = p2pService, this.txCollection = txCollection, this.txFileStore = txFileStore, this.epochCache = epochCache, this._dateProvider = _dateProvider, this.telemetry = telemetry, this.log = log, this.currentState = (_initProto(this), P2PClientState.IDLE), this.syncPromise = Promise.resolve(), this.syncResolve = undefined, this.latestBlockNumberAtStart = -1, this.provenBlockNumberAtStart = -1, this.finalizedBlockNumberAtStart = -1, this.validatorAddresses = [], this.lastSlotProcessed = SlotNumber.ZERO;
445
443
  this.config = {
446
444
  ...getP2PDefaultConfig(),
447
445
  ...config
@@ -496,10 +494,9 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
496
494
  getL2BlockHash(number) {
497
495
  return this.l2Tips.getL2BlockHash(number);
498
496
  }
499
- updateP2PConfig(config) {
500
- this.txPool.updateConfig(config);
497
+ async updateP2PConfig(config) {
498
+ await this.txPool.updateConfig(config);
501
499
  this.p2pService.updateConfig(config);
502
- return Promise.resolve();
503
500
  }
504
501
  getL2Tips() {
505
502
  return this.l2Tips.getL2Tips();
@@ -517,7 +514,7 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
517
514
  const limit = event.block.number - from + 1;
518
515
  if (limit > 0) {
519
516
  const oldBlocks = await this.l2BlockSource.getBlocks(from, limit);
520
- await this.handleFinalizedL2Blocks(oldBlocks.map((b)=>b.toL2Block()));
517
+ await this.handleFinalizedL2Blocks(oldBlocks);
521
518
  }
522
519
  break;
523
520
  }
@@ -526,7 +523,7 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
526
523
  break;
527
524
  case 'chain-pruned':
528
525
  this.txCollection.stopCollectingForBlocksAfter(event.block.number);
529
- await this.handlePruneL2Blocks(event.block.number);
526
+ await this.handlePruneL2Blocks(event.block);
530
527
  break;
531
528
  case 'chain-checkpointed':
532
529
  break;
@@ -541,7 +538,6 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
541
538
  await this.startServiceIfSynched();
542
539
  }
543
540
  #assertIsReady() {
544
- // this.log.info('Checking if p2p client is ready, current state: ', this.currentState);
545
541
  if (!this.isReady()) {
546
542
  throw new Error('P2P client not ready');
547
543
  }
@@ -556,6 +552,8 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
556
552
  if (this.currentState !== P2PClientState.IDLE) {
557
553
  return this.syncPromise;
558
554
  }
555
+ // Start the tx pool first, as it needs to hydrate state from persistence
556
+ await this.txPool.start();
559
557
  // get the current latest block numbers
560
558
  const latestBlockNumbers = await this.l2BlockSource.getL2Tips();
561
559
  this.latestBlockNumberAtStart = latestBlockNumbers.proposed.number;
@@ -598,6 +596,10 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
598
596
  }
599
597
  this.blockStream.start();
600
598
  await this.txCollection.start();
599
+ this.txFileStore?.start();
600
+ // Start slot monitor to call prepareForSlot when the slot changes
601
+ this.slotMonitor = new RunningPromise(()=>this.maybeCallPrepareForSlot(), this.log, this.config.slotCheckIntervalMS);
602
+ this.slotMonitor.start();
601
603
  return this.syncPromise;
602
604
  }
603
605
  addReqRespSubProtocol(subProtocol, handler, validator) {
@@ -618,12 +620,18 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
618
620
  * 'ready' will now return 'false' and the running promise that keeps the client synced is interrupted.
619
621
  */ async stop() {
620
622
  this.log.debug('Stopping p2p client...');
623
+ await this.slotMonitor?.stop();
624
+ this.log.debug('Stopped slot monitor');
621
625
  await tryStop(this.txCollection);
622
626
  this.log.debug('Stopped tx collection service');
627
+ await this.txFileStore?.stop();
628
+ this.log.debug('Stopped tx file store');
623
629
  await this.p2pService.stop();
624
630
  this.log.debug('Stopped p2p service');
625
631
  await this.blockStream?.stop();
626
632
  this.log.debug('Stopped block downloader');
633
+ await this.txPool.stop();
634
+ this.log.debug('Stopped tx pool');
627
635
  await this.runningPromise;
628
636
  this.setCurrentState(P2PClientState.STOPPED);
629
637
  this.log.info('P2P client stopped');
@@ -632,12 +640,30 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
632
640
  this.initBlockStream();
633
641
  await this.blockStream.sync();
634
642
  }
635
- broadcastProposal(proposal) {
643
+ async broadcastProposal(proposal) {
636
644
  this.log.verbose(`Broadcasting proposal for slot ${proposal.slotNumber} to peers`);
645
+ // Store our own proposal so we can respond to req/resp requests for it
646
+ const { count } = await this.attestationPool.tryAddBlockProposal(proposal);
647
+ if (count > 1) {
648
+ if (this.config.broadcastEquivocatedProposals) {
649
+ this.log.warn(`Broadcasting equivocated block proposal for slot ${proposal.slotNumber}`, {
650
+ slot: proposal.slotNumber,
651
+ archive: proposal.archive.toString(),
652
+ count
653
+ });
654
+ } else {
655
+ throw new Error(`Attempted to broadcast a duplicate block proposal for slot ${proposal.slotNumber}`);
656
+ }
657
+ }
637
658
  return this.p2pService.propagate(proposal);
638
659
  }
639
- broadcastCheckpointProposal(proposal) {
660
+ async broadcastCheckpointProposal(proposal) {
640
661
  this.log.verbose(`Broadcasting checkpoint proposal for slot ${proposal.slotNumber} to peers`);
662
+ const blockProposal = proposal.getBlockProposal();
663
+ if (blockProposal) {
664
+ // Store our own last-block proposal so we can respond to req/resp requests for it.
665
+ await this.attestationPool.tryAddBlockProposal(blockProposal);
666
+ }
641
667
  return this.p2pService.propagate(proposal);
642
668
  }
643
669
  async broadcastCheckpointAttestations(attestations) {
@@ -647,8 +673,11 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
647
673
  async getCheckpointAttestationsForSlot(slot, proposalId) {
648
674
  return await (proposalId ? this.attestationPool.getCheckpointAttestationsForSlotAndProposal(slot, proposalId) : this.attestationPool.getCheckpointAttestationsForSlot(slot));
649
675
  }
650
- addCheckpointAttestations(attestations) {
651
- return this.attestationPool.addCheckpointAttestations(attestations);
676
+ addOwnCheckpointAttestations(attestations) {
677
+ return this.attestationPool.addOwnCheckpointAttestations(attestations);
678
+ }
679
+ hasBlockProposalsForSlot(slot) {
680
+ return this.attestationPool.hasBlockProposalsForSlot(slot);
652
681
  }
653
682
  // REVIEW: https://github.com/AztecProtocol/aztec-packages/issues/7963
654
683
  // ^ This pattern is not my favorite (md)
@@ -658,6 +687,12 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
658
687
  registerCheckpointProposalHandler(handler) {
659
688
  this.p2pService.registerCheckpointReceivedCallback(handler);
660
689
  }
690
+ registerDuplicateProposalCallback(callback) {
691
+ this.p2pService.registerDuplicateProposalCallback(callback);
692
+ }
693
+ registerDuplicateAttestationCallback(callback) {
694
+ this.p2pService.registerDuplicateAttestationCallback(callback);
695
+ }
661
696
  /**
662
697
  * Uses the batched Request Response protocol to request a set of transactions from the network.
663
698
  */ async requestTxsByHash(txHashes, pinnedPeerId) {
@@ -668,15 +703,30 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
668
703
  const txBatches = await this.p2pService.sendBatchRequest(ReqRespSubProtocol.TX, requests, pinnedPeerId, timeoutMs, maxPeers, maxRetryAttempts);
669
704
  const txs = txBatches.flat();
670
705
  if (txs.length > 0) {
671
- await this.txPool.addTxs(txs);
706
+ await this.txPool.addPendingTxs(txs);
672
707
  }
673
708
  const txHashesStr = txHashes.map((tx)=>tx.toString()).join(', ');
674
709
  this.log.debug(`Requested txs ${txHashesStr} (${txs.length} / ${txHashes.length}) from peers`);
675
710
  // We return all transactions, even the not found ones to the caller, such they can handle missing items themselves.
676
711
  return txs;
677
712
  }
678
- getPendingTxs(limit, after) {
679
- return this.getTxs('pending', limit, after);
713
+ async getPendingTxs(limit, after) {
714
+ if (limit !== undefined && limit <= 0) {
715
+ throw new TypeError('limit must be greater than 0');
716
+ }
717
+ let txHashes = await this.txPool.getPendingTxHashes();
718
+ let startIndex = 0;
719
+ if (after) {
720
+ startIndex = txHashes.findIndex((txHash)=>after.equals(txHash));
721
+ if (startIndex === -1) {
722
+ return [];
723
+ }
724
+ startIndex++;
725
+ }
726
+ const endIndex = limit !== undefined ? startIndex + limit : undefined;
727
+ txHashes = txHashes.slice(startIndex, endIndex);
728
+ const maybeTxs = await Promise.all(txHashes.map((txHash)=>this.txPool.getTxByHash(txHash)));
729
+ return maybeTxs.filter((tx)=>!!tx);
680
730
  }
681
731
  getPendingTxCount() {
682
732
  return this.txPool.getPendingTxCount();
@@ -689,52 +739,13 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
689
739
  }
690
740
  }
691
741
  }
692
- /**
693
- * Returns all transactions in the transaction pool.
694
- * @param filter - The type of txs to return
695
- * @param limit - How many txs to return
696
- * @param after - If paginating, the last known tx hash. Will return txs after this hash
697
- * @returns An array of Txs.
698
- */ async getTxs(filter, limit, after) {
699
- if (limit !== undefined && limit <= 0) {
700
- throw new TypeError('limit must be greater than 0');
701
- }
702
- let txs = undefined;
703
- let txHashes;
704
- if (filter === 'all') {
705
- txs = await this.txPool.getAllTxs();
706
- txHashes = await Promise.all(txs.map((tx)=>tx.getTxHash()));
707
- } else if (filter === 'mined') {
708
- const minedTxHashes = await this.txPool.getMinedTxHashes();
709
- txHashes = minedTxHashes.map(([txHash])=>txHash);
710
- } else if (filter === 'pending') {
711
- txHashes = await this.txPool.getPendingTxHashes();
712
- } else {
713
- const _ = filter;
714
- throw new Error(`Unknown filter ${filter}`);
715
- }
716
- let startIndex = 0;
717
- let endIndex = undefined;
718
- if (after) {
719
- startIndex = txHashes.findIndex((txHash)=>after.equals(txHash));
720
- // if we can't find the last tx in our set then return an empty array as pagination is no longer valid.
721
- if (startIndex === -1) {
722
- return [];
742
+ async *iterateEligiblePendingTxs() {
743
+ for (const txHash of (await this.txPool.getEligiblePendingTxHashes())){
744
+ const tx = await this.txPool.getTxByHash(txHash);
745
+ if (tx) {
746
+ yield tx;
723
747
  }
724
- // increment by one because we don't want to return the same tx again
725
- startIndex++;
726
- }
727
- if (limit !== undefined) {
728
- endIndex = startIndex + limit;
729
748
  }
730
- txHashes = txHashes.slice(startIndex, endIndex);
731
- if (txs) {
732
- txs = txs.slice(startIndex, endIndex);
733
- } else {
734
- const maybeTxs = await Promise.all(txHashes.map((txHash)=>this.txPool.getTxByHash(txHash)));
735
- txs = maybeTxs.filter((tx)=>!!tx);
736
- }
737
- return txs;
738
749
  }
739
750
  /**
740
751
  * Returns a transaction in the transaction pool by its hash.
@@ -797,16 +808,18 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
797
808
  return this.txPool.getArchivedTxByHash(txHash);
798
809
  }
799
810
  /**
800
- * Verifies the 'tx' and, if valid, adds it to local tx pool and forwards it to other peers.
801
- * @param tx - The tx to verify.
811
+ * Accepts a transaction, adds it to local tx pool and forwards it to other peers.
812
+ * @param tx - The tx to send.
802
813
  * @returns Empty promise.
803
814
  **/ async sendTx(tx) {
804
- const addedCount = await this.addTxsToPool([
815
+ this.#assertIsReady();
816
+ const result = await this.txPool.addPendingTxs([
805
817
  tx
806
818
  ]);
807
- const txAddedSuccessfully = addedCount === 1;
808
- if (txAddedSuccessfully) {
819
+ if (result.accepted.length === 1) {
809
820
  await this.p2pService.propagate(tx);
821
+ } else {
822
+ this.log.warn(`Tx ${tx.getTxHash()} not propagated: accepted=${result.accepted.length} ignored=${result.ignored.length} rejected=${result.rejected.length}`);
810
823
  }
811
824
  }
812
825
  /**
@@ -814,14 +827,15 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
814
827
  * @param txs - The transactions.
815
828
  **/ async addTxsToPool(txs) {
816
829
  this.#assertIsReady();
817
- return await this.txPool.addTxs(txs);
830
+ return (await this.txPool.addPendingTxs(txs)).accepted.length;
818
831
  }
819
832
  /**
820
833
  * Returns whether the given tx hash is flagged as pending or mined.
821
834
  * @param txHash - Hash of the tx to query.
822
835
  * @returns Pending or mined depending on its status, or undefined if not found.
823
- */ getTxStatus(txHash) {
824
- return this.txPool.getTxStatus(txHash);
836
+ */ async getTxStatus(txHash) {
837
+ const status = await this.txPool.getTxStatus(txHash);
838
+ return status === 'protected' ? 'pending' : status;
825
839
  }
826
840
  getEnr() {
827
841
  return this.p2pService.getEnr();
@@ -830,13 +844,11 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
830
844
  return Promise.resolve(this.p2pService.getEnr()?.encodeTxt());
831
845
  }
832
846
  /**
833
- * Deletes the 'txs' from the pool.
834
- * NOT used if we use sendTx as reconcileTxPool will handle this.
835
- * @param txHashes - Hashes of the transactions to delete.
836
- * @returns Empty promise.
837
- **/ async deleteTxs(txHashes) {
847
+ * Handles failed transaction execution by removing txs from the pool.
848
+ * @param txHashes - Hashes of the transactions that failed execution.
849
+ **/ async handleFailedExecution(txHashes) {
838
850
  this.#assertIsReady();
839
- await this.txPool.deleteTxs(txHashes);
851
+ await this.txPool.handleFailedExecution(txHashes);
840
852
  }
841
853
  /**
842
854
  * Public function to check if the p2p client is fully synced and ready to receive txs.
@@ -880,13 +892,12 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
880
892
  };
881
893
  }
882
894
  /**
883
- * Mark all txs from these blocks as mined.
895
+ * Handles mined blocks by marking the txs in them as mined.
884
896
  * @param blocks - A list of existing blocks with txs that the P2P client needs to ensure the tx pool is reconciled with.
885
897
  * @returns Empty promise.
886
- */ async markTxsAsMinedFromBlocks(blocks) {
898
+ */ async handleMinedBlocks(blocks) {
887
899
  for (const block of blocks){
888
- const txHashes = block.body.txEffects.map((txEffect)=>txEffect.txHash);
889
- await this.txPool.markAsMined(txHashes, block.header);
900
+ await this.txPool.handleMinedBlock(block);
890
901
  }
891
902
  }
892
903
  /**
@@ -895,14 +906,13 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
895
906
  * @returns Empty promise.
896
907
  */ async handleLatestL2Blocks(blocks) {
897
908
  if (!blocks.length) {
898
- return Promise.resolve();
909
+ return;
899
910
  }
900
- await this.markTxsAsMinedFromBlocks(blocks);
901
- await this.txPool.clearNonEvictableTxs();
911
+ await this.handleMinedBlocks(blocks);
912
+ await this.maybeCallPrepareForSlot();
902
913
  await this.startCollectingMissingTxs(blocks);
903
914
  const lastBlock = blocks.at(-1);
904
915
  await this.synchedLatestSlot.set(BigInt(lastBlock.header.getSlot()));
905
- this.log.verbose(`Synched to latest block ${lastBlock.number}`);
906
916
  }
907
917
  /** Request txs for unproven blocks so the prover node has more chances to get them. */ async startCollectingMissingTxs(blocks) {
908
918
  try {
@@ -936,59 +946,26 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
936
946
  * @returns Empty promise.
937
947
  */ async handleFinalizedL2Blocks(blocks) {
938
948
  if (!blocks.length) {
939
- return Promise.resolve();
949
+ return;
940
950
  }
941
- this.log.debug(`Handling finalized blocks ${blocks.length} up to ${blocks.at(-1)?.number}`);
942
- const lastBlockNum = blocks[blocks.length - 1].number;
943
- const lastBlockSlot = blocks[blocks.length - 1].header.getSlot();
944
- const txHashes = blocks.flatMap((block)=>block.body.txEffects.map((txEffect)=>txEffect.txHash));
945
- this.log.debug(`Deleting ${txHashes.length} txs from pool from finalized blocks up to ${lastBlockNum}`);
946
- await this.txPool.deleteTxs(txHashes, {
947
- permanently: true
948
- });
949
- await this.txPool.cleanupDeletedMinedTxs(lastBlockNum);
950
- await this.attestationPool.deleteCheckpointAttestationsOlderThan(lastBlockSlot);
951
- this.log.debug(`Synched to finalized block ${lastBlockNum} at slot ${lastBlockSlot}`);
951
+ // Finalization is monotonic, so we only need to call with the last block
952
+ const lastBlock = blocks.at(-1);
953
+ await this.txPool.handleFinalizedBlock(lastBlock.header);
954
+ await this.attestationPool.deleteOlderThan(lastBlock.header.getSlot());
952
955
  }
953
956
  /**
954
957
  * Updates the tx pool after a chain prune.
955
- * @param latestBlock - The block number the chain was pruned to.
958
+ * @param latestBlock - The block ID the chain was pruned to.
956
959
  */ async handlePruneL2Blocks(latestBlock) {
957
- const txsToDelete = new Map();
958
- const minedTxs = await this.txPool.getMinedTxHashes();
959
- // Find transactions that reference pruned blocks in their historical header
960
- for (const tx of (await this.txPool.getAllTxs())){
961
- // every tx that's been generated against a block that has now been pruned is no longer valid
962
- if (tx.data.constants.anchorBlockHeader.globalVariables.blockNumber > latestBlock) {
963
- const txHash = tx.getTxHash();
964
- txsToDelete.set(txHash.toString(), txHash);
965
- }
966
- }
967
- this.log.info(`Detected chain prune. Removing ${txsToDelete.size} txs built against pruned blocks.`, {
968
- newLatestBlock: latestBlock,
969
- previousLatestBlock: await this.getSyncedLatestBlockNum(),
970
- txsToDelete: Array.from(txsToDelete.keys())
971
- });
972
- // delete invalid txs (both pending and mined)
973
- await this.txPool.deleteTxs(Array.from(txsToDelete.values()));
974
- // everything left in the mined set was built against a block on the proven chain so its still valid
975
- // move back to pending the txs that were reorged out of the chain, unless txPoolDeleteTxsAfterReorg is set,
976
- // in which case we clean them up to avoid potential reorg loops
977
- // NOTE: we can't move _all_ txs back to pending because the tx pool could keep hold of mined txs for longer
978
- // (see this.keepProvenTxsFor)
979
- const minedTxsFromReorg = [];
980
- for (const [txHash, blockNumber] of minedTxs){
981
- // We keep the txsToDelete out of this list as they have already been deleted above
982
- if (blockNumber > latestBlock && !txsToDelete.has(txHash.toString())) {
983
- minedTxsFromReorg.push(txHash);
984
- }
985
- }
986
- if (this.config.txPoolDeleteTxsAfterReorg) {
987
- this.log.info(`Deleting ${minedTxsFromReorg.length} mined txs from reorg`);
988
- await this.txPool.deleteTxs(minedTxsFromReorg);
989
- } else {
990
- await this.txPool.markMinedAsPending(minedTxsFromReorg, latestBlock);
960
+ await this.txPool.handlePrunedBlocks(latestBlock);
961
+ }
962
+ /** Checks if the slot has changed and calls prepareForSlot if so. */ async maybeCallPrepareForSlot() {
963
+ const { currentSlot } = this.epochCache.getCurrentAndNextSlot();
964
+ if (currentSlot <= this.lastSlotProcessed) {
965
+ return;
991
966
  }
967
+ this.lastSlotProcessed = currentSlot;
968
+ await this.txPool.prepareForSlot(currentSlot);
992
969
  }
993
970
  async startServiceIfSynched() {
994
971
  if (this.currentState !== P2PClientState.SYNCHING) {
@@ -1023,10 +1000,20 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
1023
1000
  return this.p2pService.validate(txs);
1024
1001
  }
1025
1002
  /**
1026
- * Marks transactions as non-evictable in the pool.
1027
- * @param txHashes - Hashes of the transactions to mark as non-evictable.
1028
- */ markTxsAsNonEvictable(txHashes) {
1029
- return this.txPool.markTxsAsNonEvictable(txHashes);
1003
+ * Protects existing transactions by hash for a given slot.
1004
+ * Returns hashes of transactions that weren't found in the pool.
1005
+ * @param txHashes - Hashes of the transactions to protect.
1006
+ * @param blockHeader - The block header providing slot context.
1007
+ * @returns Hashes of transactions not found in the pool.
1008
+ */ protectTxs(txHashes, blockHeader) {
1009
+ return this.txPool.protectTxs(txHashes, blockHeader);
1010
+ }
1011
+ /**
1012
+ * Prepares the pool for a new slot.
1013
+ * Unprotects transactions from earlier slots and validates them.
1014
+ * @param slotNumber - The slot number to prepare for
1015
+ */ async prepareForSlot(slotNumber) {
1016
+ await this.txPool.prepareForSlot(slotNumber);
1030
1017
  }
1031
1018
  handleAuthRequestFromPeer(authRequest, peerId) {
1032
1019
  return this.p2pService.handleAuthRequestFromPeer(authRequest, peerId);
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHJvcG9zYWxfdHhfY29sbGVjdG9yX3dvcmtlci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL2NsaWVudC90ZXN0L3R4X3Byb3Bvc2FsX2NvbGxlY3Rvci9wcm9wb3NhbF90eF9jb2xsZWN0b3Jfd29ya2VyLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiIifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"proposal_tx_collector_worker.d.ts","sourceRoot":"","sources":["../../../../src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts"],"names":[],"mappings":""}