@aztec/p2p 0.0.1-commit.9b94fc1 → 0.0.1-commit.9ee6fcc6

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 (573) 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 -19
  8. package/dest/client/interface.d.ts +61 -35
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +52 -65
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +613 -336
  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 +304 -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 +68 -22
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +117 -52
  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 +111 -76
  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 +529 -289
  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 +11 -8
  38. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  39. package/dest/mem_pools/attestation_pool/mocks.js +17 -13
  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 +9 -1
  44. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  45. package/dest/mem_pools/instrumentation.js +33 -13
  46. package/dest/mem_pools/interface.d.ts +6 -7
  47. package/dest/mem_pools/interface.d.ts.map +1 -1
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +37 -27
  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 +314 -335
  51. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  52. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  53. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  54. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  55. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  56. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -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 +17 -0
  61. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  66. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  67. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  69. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  70. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  72. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  73. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  74. package/dest/mem_pools/tx_pool/index.js +0 -1
  75. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  76. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  77. package/dest/mem_pools/tx_pool/priority.js +8 -3
  78. package/dest/mem_pools/tx_pool/tx_pool.d.ts +11 -6
  79. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  80. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  81. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  82. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +33 -25
  83. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  84. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  85. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  86. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  87. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  88. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  89. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  90. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  91. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +94 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  105. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  106. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  107. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  108. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  109. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  110. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  111. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  112. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  113. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  114. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  115. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  116. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  117. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  118. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  119. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  120. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  121. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  122. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  123. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  124. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  125. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  126. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  127. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  128. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +215 -0
  129. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  130. package/dest/mem_pools/tx_pool_v2/interfaces.js +10 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +134 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  133. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +216 -0
  134. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  135. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  136. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  137. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  138. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  139. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +337 -0
  140. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +62 -0
  141. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  142. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +167 -0
  143. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +78 -0
  144. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  145. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +923 -0
  146. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +4 -4
  147. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  148. package/dest/msg_validators/attestation_validator/attestation_validator.js +54 -20
  149. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +7 -7
  150. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  151. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +22 -13
  152. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  153. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  154. package/dest/msg_validators/clock_tolerance.js +38 -0
  155. package/dest/msg_validators/index.d.ts +2 -2
  156. package/dest/msg_validators/index.d.ts.map +1 -1
  157. package/dest/msg_validators/index.js +1 -1
  158. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +11 -0
  159. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  160. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +14 -0
  161. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +11 -0
  162. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  163. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +20 -0
  164. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  165. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  166. package/dest/msg_validators/proposal_validator/index.js +3 -0
  167. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +18 -0
  168. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  169. package/dest/msg_validators/proposal_validator/proposal_validator.js +116 -0
  170. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  171. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  172. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  173. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  174. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  175. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  176. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  177. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  178. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  179. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  180. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  181. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  182. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  183. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  184. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  185. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  186. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  187. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  188. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  189. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  190. package/dest/msg_validators/tx_validator/data_validator.js +39 -3
  191. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  192. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  193. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  194. package/dest/msg_validators/tx_validator/factory.d.ts +139 -6
  195. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  196. package/dest/msg_validators/tx_validator/factory.js +255 -58
  197. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  198. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  199. package/dest/msg_validators/tx_validator/fee_payer_balance.js +24 -0
  200. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  201. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  202. package/dest/msg_validators/tx_validator/gas_validator.js +114 -52
  203. package/dest/msg_validators/tx_validator/index.d.ts +4 -1
  204. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  205. package/dest/msg_validators/tx_validator/index.js +3 -0
  206. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +4 -3
  207. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  208. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  209. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  210. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  211. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  212. package/dest/msg_validators/tx_validator/phases_validator.d.ts +24 -3
  213. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  214. package/dest/msg_validators/tx_validator/phases_validator.js +75 -27
  215. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  216. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  217. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  218. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  219. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  220. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +23 -5
  221. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  222. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  223. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  224. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  225. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  226. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  227. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  228. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  229. package/dest/services/data_store.d.ts +1 -1
  230. package/dest/services/data_store.d.ts.map +1 -1
  231. package/dest/services/data_store.js +10 -6
  232. package/dest/services/discv5/discV5_service.js +1 -1
  233. package/dest/services/dummy_service.d.ts +28 -4
  234. package/dest/services/dummy_service.d.ts.map +1 -1
  235. package/dest/services/dummy_service.js +49 -1
  236. package/dest/services/encoding.d.ts +7 -3
  237. package/dest/services/encoding.d.ts.map +1 -1
  238. package/dest/services/encoding.js +23 -15
  239. package/dest/services/gossipsub/index.d.ts +3 -0
  240. package/dest/services/gossipsub/index.d.ts.map +1 -0
  241. package/dest/services/gossipsub/index.js +2 -0
  242. package/dest/services/gossipsub/scoring.d.ts +21 -3
  243. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  244. package/dest/services/gossipsub/scoring.js +24 -7
  245. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  246. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  247. package/dest/services/gossipsub/topic_score_params.js +346 -0
  248. package/dest/services/index.d.ts +2 -1
  249. package/dest/services/index.d.ts.map +1 -1
  250. package/dest/services/index.js +1 -0
  251. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  252. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  253. package/dest/services/libp2p/instrumentation.js +30 -72
  254. package/dest/services/libp2p/libp2p_service.d.ts +111 -43
  255. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  256. package/dest/services/libp2p/libp2p_service.js +1047 -388
  257. package/dest/services/peer-manager/metrics.d.ts +9 -2
  258. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  259. package/dest/services/peer-manager/metrics.js +39 -21
  260. package/dest/services/peer-manager/peer_manager.d.ts +2 -2
  261. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  262. package/dest/services/peer-manager/peer_manager.js +10 -15
  263. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  264. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  265. package/dest/services/peer-manager/peer_scoring.js +32 -6
  266. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +51 -0
  267. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  268. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +540 -0
  269. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  270. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  271. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  272. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +47 -0
  273. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  274. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  275. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +35 -0
  276. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  277. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +136 -0
  278. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +62 -0
  279. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  280. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +176 -0
  281. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  282. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  283. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  284. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  285. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  286. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  287. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  288. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  289. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  290. package/dest/services/reqresp/constants.d.ts +12 -0
  291. package/dest/services/reqresp/constants.d.ts.map +1 -0
  292. package/dest/services/reqresp/constants.js +7 -0
  293. package/dest/services/reqresp/interface.d.ts +13 -2
  294. package/dest/services/reqresp/interface.d.ts.map +1 -1
  295. package/dest/services/reqresp/interface.js +16 -2
  296. package/dest/services/reqresp/metrics.d.ts +6 -5
  297. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  298. package/dest/services/reqresp/metrics.js +17 -21
  299. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  300. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  301. package/dest/services/reqresp/protocols/auth.js +2 -2
  302. package/dest/services/reqresp/protocols/block.d.ts +1 -1
  303. package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
  304. package/dest/services/reqresp/protocols/block.js +3 -2
  305. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  306. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  307. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  308. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  309. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  310. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  311. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +30 -7
  312. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  313. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +60 -14
  314. package/dest/services/reqresp/protocols/status.d.ts +5 -4
  315. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  316. package/dest/services/reqresp/protocols/status.js +7 -3
  317. package/dest/services/reqresp/protocols/tx.d.ts +8 -3
  318. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  319. package/dest/services/reqresp/protocols/tx.js +20 -0
  320. package/dest/services/reqresp/reqresp.d.ts +6 -1
  321. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  322. package/dest/services/reqresp/reqresp.js +488 -58
  323. package/dest/services/service.d.ts +56 -4
  324. package/dest/services/service.d.ts.map +1 -1
  325. package/dest/services/tx_collection/config.d.ts +22 -1
  326. package/dest/services/tx_collection/config.d.ts.map +1 -1
  327. package/dest/services/tx_collection/config.js +56 -2
  328. package/dest/services/tx_collection/fast_tx_collection.d.ts +10 -9
  329. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  330. package/dest/services/tx_collection/fast_tx_collection.js +95 -84
  331. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  332. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  333. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  334. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  335. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  336. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  337. package/dest/services/tx_collection/index.d.ts +3 -1
  338. package/dest/services/tx_collection/index.d.ts.map +1 -1
  339. package/dest/services/tx_collection/index.js +2 -0
  340. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  341. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  342. package/dest/services/tx_collection/instrumentation.js +11 -13
  343. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  344. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  345. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  346. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  347. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  348. package/dest/services/tx_collection/request_tracker.js +84 -0
  349. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -4
  350. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  351. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  352. package/dest/services/tx_collection/tx_collection.d.ts +31 -20
  353. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  354. package/dest/services/tx_collection/tx_collection.js +79 -7
  355. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  356. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  357. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  358. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  359. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  360. package/dest/services/tx_collection/tx_source.js +19 -2
  361. package/dest/services/tx_file_store/config.d.ts +16 -0
  362. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  363. package/dest/services/tx_file_store/config.js +22 -0
  364. package/dest/services/tx_file_store/index.d.ts +4 -0
  365. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  366. package/dest/services/tx_file_store/index.js +3 -0
  367. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  368. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  369. package/dest/services/tx_file_store/instrumentation.js +29 -0
  370. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  371. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  372. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  373. package/dest/services/tx_provider.d.ts +7 -5
  374. package/dest/services/tx_provider.d.ts.map +1 -1
  375. package/dest/services/tx_provider.js +20 -10
  376. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  377. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  378. package/dest/services/tx_provider_instrumentation.js +14 -14
  379. package/dest/test-helpers/index.d.ts +3 -1
  380. package/dest/test-helpers/index.d.ts.map +1 -1
  381. package/dest/test-helpers/index.js +2 -0
  382. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  383. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  384. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  385. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  386. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  387. package/dest/test-helpers/mock-pubsub.js +105 -4
  388. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  389. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  390. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  391. package/dest/test-helpers/reqresp-nodes.js +4 -3
  392. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  393. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  394. package/dest/test-helpers/test_tx_provider.js +41 -0
  395. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  396. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  397. package/dest/test-helpers/testbench-utils.js +385 -0
  398. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  399. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  400. package/dest/testbench/p2p_client_testbench_worker.js +226 -130
  401. package/dest/testbench/worker_client_manager.d.ts +53 -6
  402. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  403. package/dest/testbench/worker_client_manager.js +231 -40
  404. package/dest/util.d.ts +3 -3
  405. package/dest/util.d.ts.map +1 -1
  406. package/package.json +18 -18
  407. package/src/bootstrap/bootstrap.ts +7 -4
  408. package/src/client/factory.ts +110 -44
  409. package/src/client/interface.ts +73 -36
  410. package/src/client/p2p_client.ts +277 -397
  411. package/src/client/test/tx_proposal_collector/README.md +227 -0
  412. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +343 -0
  413. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  414. package/src/config.ts +182 -62
  415. package/src/errors/tx-pool.error.ts +12 -0
  416. package/src/index.ts +1 -0
  417. package/src/mem_pools/attestation_pool/attestation_pool.ts +511 -78
  418. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +614 -322
  419. package/src/mem_pools/attestation_pool/index.ts +9 -2
  420. package/src/mem_pools/attestation_pool/mocks.ts +22 -15
  421. package/src/mem_pools/index.ts +4 -1
  422. package/src/mem_pools/instrumentation.ts +43 -14
  423. package/src/mem_pools/interface.ts +5 -7
  424. package/src/mem_pools/tx_pool/README.md +270 -0
  425. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +367 -371
  426. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  427. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  428. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +163 -0
  429. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  430. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  431. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  432. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  433. package/src/mem_pools/tx_pool/index.ts +0 -1
  434. package/src/mem_pools/tx_pool/priority.ts +10 -3
  435. package/src/mem_pools/tx_pool/tx_pool.ts +11 -5
  436. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +26 -18
  437. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  438. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  439. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  440. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  441. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  442. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +122 -0
  443. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  444. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  445. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  446. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  447. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  448. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  449. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  450. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  451. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  452. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  453. package/src/mem_pools/tx_pool_v2/interfaces.ts +247 -0
  454. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +337 -0
  455. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  456. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  457. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +238 -0
  458. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1105 -0
  459. package/src/msg_validators/attestation_validator/README.md +49 -0
  460. package/src/msg_validators/attestation_validator/attestation_validator.ts +39 -23
  461. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +21 -18
  462. package/src/msg_validators/clock_tolerance.ts +52 -0
  463. package/src/msg_validators/index.ts +1 -1
  464. package/src/msg_validators/proposal_validator/README.md +123 -0
  465. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +20 -0
  466. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +26 -0
  467. package/src/msg_validators/proposal_validator/index.ts +3 -0
  468. package/src/msg_validators/proposal_validator/proposal_validator.ts +116 -0
  469. package/src/msg_validators/tx_validator/README.md +119 -0
  470. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  471. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  472. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  473. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  474. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  475. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  476. package/src/msg_validators/tx_validator/data_validator.ts +60 -7
  477. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  478. package/src/msg_validators/tx_validator/factory.ts +416 -58
  479. package/src/msg_validators/tx_validator/fee_payer_balance.ts +44 -0
  480. package/src/msg_validators/tx_validator/gas_validator.ts +140 -55
  481. package/src/msg_validators/tx_validator/index.ts +3 -0
  482. package/src/msg_validators/tx_validator/metadata_validator.ts +31 -12
  483. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  484. package/src/msg_validators/tx_validator/phases_validator.ts +87 -30
  485. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  486. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  487. package/src/msg_validators/tx_validator/timestamp_validator.ts +30 -19
  488. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  489. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  490. package/src/services/data_store.ts +10 -7
  491. package/src/services/discv5/discV5_service.ts +1 -1
  492. package/src/services/dummy_service.ts +65 -2
  493. package/src/services/encoding.ts +22 -13
  494. package/src/services/gossipsub/README.md +641 -0
  495. package/src/services/gossipsub/index.ts +2 -0
  496. package/src/services/gossipsub/scoring.ts +29 -5
  497. package/src/services/gossipsub/topic_score_params.ts +487 -0
  498. package/src/services/index.ts +1 -0
  499. package/src/services/libp2p/instrumentation.ts +32 -73
  500. package/src/services/libp2p/libp2p_service.ts +746 -406
  501. package/src/services/peer-manager/metrics.ts +46 -21
  502. package/src/services/peer-manager/peer_manager.ts +12 -7
  503. package/src/services/peer-manager/peer_scoring.ts +28 -4
  504. package/src/services/reqresp/README.md +229 -0
  505. package/src/services/reqresp/batch-tx-requester/README.md +344 -0
  506. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +670 -0
  507. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  508. package/src/services/reqresp/batch-tx-requester/interface.ts +54 -0
  509. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +168 -0
  510. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +249 -0
  511. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  512. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  513. package/src/services/reqresp/connection-sampler/connection_sampler.ts +19 -1
  514. package/src/services/reqresp/constants.ts +14 -0
  515. package/src/services/reqresp/interface.ts +30 -2
  516. package/src/services/reqresp/metrics.ts +36 -27
  517. package/src/services/reqresp/protocols/auth.ts +2 -2
  518. package/src/services/reqresp/protocols/block.ts +3 -2
  519. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  520. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  521. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +75 -10
  522. package/src/services/reqresp/protocols/status.ts +16 -12
  523. package/src/services/reqresp/protocols/tx.ts +23 -2
  524. package/src/services/reqresp/reqresp.ts +99 -32
  525. package/src/services/service.ts +73 -5
  526. package/src/services/tx_collection/config.ts +84 -2
  527. package/src/services/tx_collection/fast_tx_collection.ts +114 -93
  528. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  529. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  530. package/src/services/tx_collection/index.ts +6 -0
  531. package/src/services/tx_collection/instrumentation.ts +11 -13
  532. package/src/services/tx_collection/proposal_tx_collector.ts +108 -0
  533. package/src/services/tx_collection/request_tracker.ts +127 -0
  534. package/src/services/tx_collection/slow_tx_collection.ts +69 -36
  535. package/src/services/tx_collection/tx_collection.ts +123 -27
  536. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  537. package/src/services/tx_collection/tx_source.ts +22 -3
  538. package/src/services/tx_file_store/config.ts +37 -0
  539. package/src/services/tx_file_store/index.ts +3 -0
  540. package/src/services/tx_file_store/instrumentation.ts +36 -0
  541. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  542. package/src/services/tx_provider.ts +29 -12
  543. package/src/services/tx_provider_instrumentation.ts +24 -14
  544. package/src/test-helpers/index.ts +2 -0
  545. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  546. package/src/test-helpers/mock-pubsub.ts +147 -10
  547. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  548. package/src/test-helpers/reqresp-nodes.ts +6 -8
  549. package/src/test-helpers/test_tx_provider.ts +64 -0
  550. package/src/test-helpers/testbench-utils.ts +456 -0
  551. package/src/testbench/p2p_client_testbench_worker.ts +350 -129
  552. package/src/testbench/worker_client_manager.ts +312 -42
  553. package/src/util.ts +8 -2
  554. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -37
  555. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  556. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -213
  557. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -30
  558. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  559. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -219
  560. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -80
  561. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  562. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -238
  563. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  564. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  565. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -82
  566. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  567. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  568. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  569. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -298
  570. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -287
  571. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -283
  572. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -97
  573. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -0,0 +1,65 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { EvictionEvent } from './interfaces.js';
3
+ /**
4
+ * Eviction rule that removes invalid transactions after a block is mined.
5
+ * Only triggers on BLOCK_MINED events.
6
+ *
7
+ * Eviction criteria includes:
8
+ * - Transactions with nullifiers that are already included in the mined block
9
+ * - Transactions with an expiration timestamp less than or equal to the mined block timestamp
10
+ */ export class InvalidTxsAfterMiningRule {
11
+ name = 'InvalidTxsAfterMining';
12
+ log = createLogger('p2p:tx_pool_v2:invalid_txs_after_mining_rule');
13
+ async evict(context, pool) {
14
+ if (context.event !== EvictionEvent.BLOCK_MINED) {
15
+ return {
16
+ reason: 'block_mined_invalid_txs',
17
+ success: true,
18
+ txsEvicted: []
19
+ };
20
+ }
21
+ try {
22
+ const { timestamp } = context.block.globalVariables;
23
+ const minedNullifiers = new Set(context.newNullifiers);
24
+ const txsToEvict = [];
25
+ const pendingTxs = pool.getPendingTxs();
26
+ for (const meta of pendingTxs){
27
+ // Evict pending txs that share nullifiers with mined txs
28
+ if (meta.nullifiers.some((nullifier)=>minedNullifiers.has(nullifier))) {
29
+ txsToEvict.push(meta.txHash);
30
+ continue;
31
+ }
32
+ // Evict pending txs with an expiration timestamp less than or equal to the mined block timestamp
33
+ if (meta.expirationTimestamp <= timestamp) {
34
+ this.log.verbose(`Evicting tx ${meta.txHash} from pool due to the tx being expired (expirationTimestamp: ${meta.expirationTimestamp}, mined block timestamp: ${timestamp})`);
35
+ txsToEvict.push(meta.txHash);
36
+ continue;
37
+ }
38
+ }
39
+ if (txsToEvict.length > 0) {
40
+ this.log.info(`Evicted ${txsToEvict.length} invalid txs after block mined`);
41
+ await pool.deleteTxs(txsToEvict, this.name);
42
+ }
43
+ this.log.debug(`Evicted ${txsToEvict.length} invalid txs after block mined`, {
44
+ txHashes: txsToEvict
45
+ });
46
+ return {
47
+ reason: 'block_mined_invalid_txs',
48
+ success: true,
49
+ txsEvicted: txsToEvict
50
+ };
51
+ } catch (err) {
52
+ this.log.error('Failed to evict invalid transactions after mining', {
53
+ err
54
+ });
55
+ return {
56
+ reason: 'block_mined_invalid_txs',
57
+ success: false,
58
+ txsEvicted: [],
59
+ error: new Error('Failed to evict invalid txs after mining', {
60
+ cause: err
61
+ })
62
+ };
63
+ }
64
+ }
65
+ }
@@ -0,0 +1,17 @@
1
+ import type { WorldStateSynchronizer } from '@aztec/stdlib/interfaces/server';
2
+ import type { EvictionContext, EvictionResult, EvictionRule, PoolOperations } from './interfaces.js';
3
+ /**
4
+ * Eviction rule that removes invalid transactions after a blockchain reorganization.
5
+ * Only triggers on CHAIN_PRUNED events.
6
+ *
7
+ * Eviction criteria includes:
8
+ * - Transactions that reference pruned block hashes (invalid by definition)
9
+ */
10
+ export declare class InvalidTxsAfterReorgRule implements EvictionRule {
11
+ private worldState;
12
+ readonly name = "InvalidTxsAfterReorg";
13
+ private log;
14
+ constructor(worldState: WorldStateSynchronizer);
15
+ evict(context: EvictionContext, pool: PoolOperations): Promise<EvictionResult>;
16
+ }
17
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW52YWxpZF90eHNfYWZ0ZXJfcmVvcmdfcnVsZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL21lbV9wb29scy90eF9wb29sX3YyL2V2aWN0aW9uL2ludmFsaWRfdHhzX2FmdGVyX3Jlb3JnX3J1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxLQUFLLEVBQUUsc0JBQXNCLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUc5RSxPQUFPLEtBQUssRUFBRSxlQUFlLEVBQUUsY0FBYyxFQUFFLFlBQVksRUFBRSxjQUFjLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUdyRzs7Ozs7O0dBTUc7QUFDSCxxQkFBYSx3QkFBeUIsWUFBVyxZQUFZO0lBSy9DLE9BQU8sQ0FBQyxVQUFVO0lBSjlCLFNBQWdCLElBQUksMEJBQTBCO0lBRTlDLE9BQU8sQ0FBQyxHQUFHLENBQStEO0lBRTFFLFlBQW9CLFVBQVUsRUFBRSxzQkFBc0IsRUFBSTtJQUVwRCxLQUFLLENBQUMsT0FBTyxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsY0FBYyxHQUFHLE9BQU8sQ0FBQyxjQUFjLENBQUMsQ0E2RW5GO0NBQ0YifQ==
@@ -0,0 +1 @@
1
+ {"version":3,"file":"invalid_txs_after_reorg_rule.d.ts","sourceRoot":"","sources":["../../../../src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,sBAAsB,EAAE,MAAM,iCAAiC,CAAC;AAG9E,OAAO,KAAK,EAAE,eAAe,EAAE,cAAc,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAGrG;;;;;;GAMG;AACH,qBAAa,wBAAyB,YAAW,YAAY;IAK/C,OAAO,CAAC,UAAU;IAJ9B,SAAgB,IAAI,0BAA0B;IAE9C,OAAO,CAAC,GAAG,CAA+D;IAE1E,YAAoB,UAAU,EAAE,sBAAsB,EAAI;IAEpD,KAAK,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC,CA6EnF;CACF"}
@@ -0,0 +1,93 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { createLogger } from '@aztec/foundation/log';
3
+ import { MerkleTreeId } from '@aztec/stdlib/trees';
4
+ import { EvictionEvent } from './interfaces.js';
5
+ /**
6
+ * Eviction rule that removes invalid transactions after a blockchain reorganization.
7
+ * Only triggers on CHAIN_PRUNED events.
8
+ *
9
+ * Eviction criteria includes:
10
+ * - Transactions that reference pruned block hashes (invalid by definition)
11
+ */ export class InvalidTxsAfterReorgRule {
12
+ worldState;
13
+ name;
14
+ log;
15
+ constructor(worldState){
16
+ this.worldState = worldState;
17
+ this.name = 'InvalidTxsAfterReorg';
18
+ this.log = createLogger('p2p:tx_pool_v2:invalid_txs_after_reorg_rule');
19
+ }
20
+ async evict(context, pool) {
21
+ if (context.event !== EvictionEvent.CHAIN_PRUNED) {
22
+ return {
23
+ reason: 'reorg_invalid_txs',
24
+ success: true,
25
+ txsEvicted: []
26
+ };
27
+ }
28
+ try {
29
+ const pendingTxs = pool.getPendingTxs();
30
+ // Deduplicate block hashes to reduce redundant DB lookups
31
+ const uniqueBlockHashes = new Map();
32
+ const txsByBlockHash = new Map();
33
+ for (const meta of pendingTxs){
34
+ const blockHashStr = meta.anchorBlockHeaderHash;
35
+ if (!txsByBlockHash.has(blockHashStr)) {
36
+ txsByBlockHash.set(blockHashStr, []);
37
+ uniqueBlockHashes.set(blockHashStr, Fr.fromHexString(blockHashStr));
38
+ }
39
+ txsByBlockHash.get(blockHashStr).push(meta.txHash);
40
+ }
41
+ // Sync without a block number to ensure the world state processes the prune event.
42
+ await this.worldState.syncImmediate();
43
+ const db = this.worldState.getSnapshot(context.blockNumber);
44
+ // Check which blocks exist in the archive
45
+ const blockHashArray = Array.from(uniqueBlockHashes.values());
46
+ const blocksFromDb = await db.findLeafIndices(MerkleTreeId.ARCHIVE, blockHashArray);
47
+ // Build set of pruned block hashes
48
+ const prunedBlockHashes = new Set();
49
+ let i = 0;
50
+ for (const [blockHashStr] of uniqueBlockHashes){
51
+ if (blocksFromDb[i] === undefined) {
52
+ prunedBlockHashes.add(blockHashStr);
53
+ }
54
+ i++;
55
+ }
56
+ // Identify txs whose anchor block was pruned
57
+ const txsToEvict = [];
58
+ for (const [blockHashStr, txHashes] of txsByBlockHash){
59
+ if (prunedBlockHashes.has(blockHashStr)) {
60
+ txsToEvict.push(...txHashes);
61
+ }
62
+ }
63
+ if (txsToEvict.length > 0) {
64
+ this.log.info(`Evicting ${txsToEvict.length} txs from pool due to referencing pruned blocks`);
65
+ await pool.deleteTxs(txsToEvict, this.name);
66
+ }
67
+ const keptCount = pendingTxs.length - txsToEvict.length;
68
+ if (keptCount > 0) {
69
+ this.log.verbose(`Kept ${keptCount} txs that did not reference pruned blocks`);
70
+ }
71
+ this.log.debug(`Evicted ${txsToEvict.length} invalid txs after reorg`, {
72
+ txHashes: txsToEvict
73
+ });
74
+ return {
75
+ reason: 'reorg_invalid_txs',
76
+ success: true,
77
+ txsEvicted: txsToEvict
78
+ };
79
+ } catch (err) {
80
+ this.log.error('Failed to evict invalid transactions after reorg', {
81
+ err
82
+ });
83
+ return {
84
+ reason: 'reorg_invalid_txs',
85
+ success: false,
86
+ txsEvicted: [],
87
+ error: new Error('Failed to evict invalid txs after reorg', {
88
+ cause: err
89
+ })
90
+ };
91
+ }
92
+ }
93
+ }
@@ -0,0 +1,16 @@
1
+ import type { EvictionConfig, EvictionContext, EvictionResult, EvictionRule, PoolOperations } from './interfaces.js';
2
+ /**
3
+ * Eviction rule that removes low-priority transactions when the pool exceeds configured limits.
4
+ * Triggers on TXS_ADDED and CHAIN_PRUNED events.
5
+ */
6
+ export declare class LowPriorityEvictionRule implements EvictionRule {
7
+ readonly name = "LowPriorityEviction";
8
+ private log;
9
+ private maxPoolSize;
10
+ constructor(config: {
11
+ maxPoolSize: number;
12
+ });
13
+ evict(context: EvictionContext, pool: PoolOperations): Promise<EvictionResult>;
14
+ updateConfig(config: EvictionConfig): void;
15
+ }
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG93X3ByaW9yaXR5X2V2aWN0aW9uX3J1bGUuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9tZW1fcG9vbHMvdHhfcG9vbF92Mi9ldmljdGlvbi9sb3dfcHJpb3JpdHlfZXZpY3Rpb25fcnVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEtBQUssRUFBRSxjQUFjLEVBQUUsZUFBZSxFQUFFLGNBQWMsRUFBRSxZQUFZLEVBQUUsY0FBYyxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFHckg7OztHQUdHO0FBQ0gscUJBQWEsdUJBQXdCLFlBQVcsWUFBWTtJQUMxRCxTQUFnQixJQUFJLHlCQUF5QjtJQUU3QyxPQUFPLENBQUMsR0FBRyxDQUE2RDtJQUN4RSxPQUFPLENBQUMsV0FBVyxDQUFTO0lBRTVCLFlBQVksTUFBTSxFQUFFO1FBQUUsV0FBVyxFQUFFLE1BQU0sQ0FBQTtLQUFFLEVBRTFDO0lBRUssS0FBSyxDQUFDLE9BQU8sRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLGNBQWMsR0FBRyxPQUFPLENBQUMsY0FBYyxDQUFDLENBZ0VuRjtJQUVELFlBQVksQ0FBQyxNQUFNLEVBQUUsY0FBYyxHQUFHLElBQUksQ0FJekM7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"low_priority_eviction_rule.d.ts","sourceRoot":"","sources":["../../../../src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,cAAc,EAAE,eAAe,EAAE,cAAc,EAAE,YAAY,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AAGrH;;;GAGG;AACH,qBAAa,uBAAwB,YAAW,YAAY;IAC1D,SAAgB,IAAI,yBAAyB;IAE7C,OAAO,CAAC,GAAG,CAA6D;IACxE,OAAO,CAAC,WAAW,CAAS;IAE5B,YAAY,MAAM,EAAE;QAAE,WAAW,EAAE,MAAM,CAAA;KAAE,EAE1C;IAEK,KAAK,CAAC,OAAO,EAAE,eAAe,EAAE,IAAI,EAAE,cAAc,GAAG,OAAO,CAAC,cAAc,CAAC,CAgEnF;IAED,YAAY,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI,CAIzC;CACF"}
@@ -0,0 +1,78 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { EvictionEvent } from './interfaces.js';
3
+ /**
4
+ * Eviction rule that removes low-priority transactions when the pool exceeds configured limits.
5
+ * Triggers on TXS_ADDED and CHAIN_PRUNED events.
6
+ */ export class LowPriorityEvictionRule {
7
+ name = 'LowPriorityEviction';
8
+ log = createLogger('p2p:tx_pool_v2:low_priority_eviction_rule');
9
+ maxPoolSize;
10
+ constructor(config){
11
+ this.maxPoolSize = config.maxPoolSize;
12
+ }
13
+ async evict(context, pool) {
14
+ if (context.event !== EvictionEvent.TXS_ADDED && context.event !== EvictionEvent.CHAIN_PRUNED) {
15
+ return {
16
+ reason: 'low_priority',
17
+ success: true,
18
+ txsEvicted: []
19
+ };
20
+ }
21
+ if (this.maxPoolSize === 0) {
22
+ return {
23
+ reason: 'low_priority',
24
+ success: true,
25
+ txsEvicted: []
26
+ };
27
+ }
28
+ try {
29
+ const currentTxCount = pool.getPendingTxCount();
30
+ if (currentTxCount <= this.maxPoolSize) {
31
+ this.log.trace(`Not evicting low priority txs. Pending tx count below limit ${currentTxCount} <= ${this.maxPoolSize}`);
32
+ return {
33
+ reason: 'low_priority',
34
+ success: true,
35
+ txsEvicted: []
36
+ };
37
+ }
38
+ this.log.info(`Evicting low priority txs. Pending tx count above limit: ${currentTxCount} > ${this.maxPoolSize}`);
39
+ const numberToEvict = currentTxCount - this.maxPoolSize;
40
+ const txsToEvict = pool.getLowestPriorityPending(numberToEvict);
41
+ if (txsToEvict.length > 0) {
42
+ if (context.event === EvictionEvent.TXS_ADDED) {
43
+ const toEvictSet = new Set(txsToEvict);
44
+ const numNewTxsEvicted = context.newTxHashes.filter((newTxHash)=>toEvictSet.has(newTxHash)).length;
45
+ this.log.info(`Evicted ${txsToEvict.length} low priority txs, including ${numNewTxsEvicted} newly added txs`);
46
+ } else {
47
+ this.log.info(`Evicted ${txsToEvict.length} low priority txs after chain prune`);
48
+ }
49
+ await pool.deleteTxs(txsToEvict, this.name);
50
+ }
51
+ this.log.debug(`Evicted ${txsToEvict.length} low priority txs`, {
52
+ txHashes: txsToEvict
53
+ });
54
+ return {
55
+ reason: 'low_priority',
56
+ success: true,
57
+ txsEvicted: txsToEvict
58
+ };
59
+ } catch (err) {
60
+ this.log.error('Failed to evict low priority transactions', {
61
+ err
62
+ });
63
+ return {
64
+ reason: 'low_priority',
65
+ success: false,
66
+ txsEvicted: [],
67
+ error: new Error('Failed to evict low priority txs', {
68
+ cause: err
69
+ })
70
+ };
71
+ }
72
+ }
73
+ updateConfig(config) {
74
+ if (config.maxPendingTxCount !== undefined) {
75
+ this.maxPoolSize = config.maxPendingTxCount;
76
+ }
77
+ }
78
+ }
@@ -0,0 +1,20 @@
1
+ import { type TxMetaData } from '../tx_metadata.js';
2
+ import { type EvictionConfig, type PreAddContext, type PreAddPoolAccess, type PreAddResult, type PreAddRule } from './interfaces.js';
3
+ /**
4
+ * Pre-add rule that checks if the pool is at capacity and handles low-priority eviction.
5
+ *
6
+ * When the pool is at capacity:
7
+ * - If incoming tx has higher priority than the lowest priority tx, evict the lowest and accept incoming
8
+ * - If incoming tx has equal or lower priority than the lowest, ignore incoming (it would be evicted anyway)
9
+ */
10
+ export declare class LowPriorityPreAddRule implements PreAddRule {
11
+ readonly name = "LowPriorityPreAdd";
12
+ private log;
13
+ private maxPoolSize;
14
+ constructor(config: {
15
+ maxPoolSize: number;
16
+ });
17
+ check(incomingMeta: TxMetaData, poolAccess: PreAddPoolAccess, context?: PreAddContext): Promise<PreAddResult>;
18
+ updateConfig(config: EvictionConfig): void;
19
+ }
20
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG93X3ByaW9yaXR5X3ByZV9hZGRfcnVsZS5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vc3JjL21lbV9wb29scy90eF9wb29sX3YyL2V2aWN0aW9uL2xvd19wcmlvcml0eV9wcmVfYWRkX3J1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBRUEsT0FBTyxFQUFFLEtBQUssVUFBVSxFQUEyQyxNQUFNLG1CQUFtQixDQUFDO0FBQzdGLE9BQU8sRUFDTCxLQUFLLGNBQWMsRUFDbkIsS0FBSyxhQUFhLEVBQ2xCLEtBQUssZ0JBQWdCLEVBQ3JCLEtBQUssWUFBWSxFQUNqQixLQUFLLFVBQVUsRUFFaEIsTUFBTSxpQkFBaUIsQ0FBQztBQUV6Qjs7Ozs7O0dBTUc7QUFDSCxxQkFBYSxxQkFBc0IsWUFBVyxVQUFVO0lBQ3RELFNBQWdCLElBQUksdUJBQXVCO0lBRTNDLE9BQU8sQ0FBQyxHQUFHLENBQTREO0lBQ3ZFLE9BQU8sQ0FBQyxXQUFXLENBQVM7SUFFNUIsWUFBWSxNQUFNLEVBQUU7UUFBRSxXQUFXLEVBQUUsTUFBTSxDQUFBO0tBQUUsRUFFMUM7SUFFRCxLQUFLLENBQUMsWUFBWSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsZ0JBQWdCLEVBQUUsT0FBTyxDQUFDLEVBQUUsYUFBYSxHQUFHLE9BQU8sQ0FBQyxZQUFZLENBQUMsQ0E4RDVHO0lBRUQsWUFBWSxDQUFDLE1BQU0sRUFBRSxjQUFjLEdBQUcsSUFBSSxDQUl6QztDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"low_priority_pre_add_rule.d.ts","sourceRoot":"","sources":["../../../../src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,UAAU,EAA2C,MAAM,mBAAmB,CAAC;AAC7F,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,aAAa,EAClB,KAAK,gBAAgB,EACrB,KAAK,YAAY,EACjB,KAAK,UAAU,EAEhB,MAAM,iBAAiB,CAAC;AAEzB;;;;;;GAMG;AACH,qBAAa,qBAAsB,YAAW,UAAU;IACtD,SAAgB,IAAI,uBAAuB;IAE3C,OAAO,CAAC,GAAG,CAA4D;IACvE,OAAO,CAAC,WAAW,CAAS;IAE5B,YAAY,MAAM,EAAE;QAAE,WAAW,EAAE,MAAM,CAAA;KAAE,EAE1C;IAED,KAAK,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,gBAAgB,EAAE,OAAO,CAAC,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC,CA8D5G;IAED,YAAY,CAAC,MAAM,EAAE,cAAc,GAAG,IAAI,CAIzC;CACF"}
@@ -0,0 +1,75 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { comparePriority, getMinimumPriceBumpFee } from '../tx_metadata.js';
3
+ import { TxPoolRejectionCode } from './interfaces.js';
4
+ /**
5
+ * Pre-add rule that checks if the pool is at capacity and handles low-priority eviction.
6
+ *
7
+ * When the pool is at capacity:
8
+ * - If incoming tx has higher priority than the lowest priority tx, evict the lowest and accept incoming
9
+ * - If incoming tx has equal or lower priority than the lowest, ignore incoming (it would be evicted anyway)
10
+ */ export class LowPriorityPreAddRule {
11
+ name = 'LowPriorityPreAdd';
12
+ log = createLogger('p2p:tx_pool_v2:low_priority_pre_add_rule');
13
+ maxPoolSize;
14
+ constructor(config){
15
+ this.maxPoolSize = config.maxPoolSize;
16
+ }
17
+ check(incomingMeta, poolAccess, context) {
18
+ // Skip if max pool size is disabled (0 = unlimited)
19
+ if (this.maxPoolSize === 0) {
20
+ return Promise.resolve({
21
+ shouldIgnore: false,
22
+ txHashesToEvict: []
23
+ });
24
+ }
25
+ const currentCount = poolAccess.getPendingTxCount();
26
+ // If pool is not at capacity, accept the tx
27
+ if (currentCount < this.maxPoolSize) {
28
+ return Promise.resolve({
29
+ shouldIgnore: false,
30
+ txHashesToEvict: []
31
+ });
32
+ }
33
+ // Pool is at capacity - need to compare priorities
34
+ const lowestPriorityMeta = poolAccess.getLowestPriorityPendingTx();
35
+ if (!lowestPriorityMeta) {
36
+ // No pending txs (shouldn't happen if count > 0, but handle gracefully)
37
+ return Promise.resolve({
38
+ shouldIgnore: false,
39
+ txHashesToEvict: []
40
+ });
41
+ }
42
+ // Compare incoming tx against lowest priority tx.
43
+ // feeOnly mode (RPC): use strict fee comparison only — avoids churn from hash ordering.
44
+ // When price bump is also set, require the bumped fee threshold.
45
+ // Default (gossip): use full comparePriority (fee + tx hash tiebreaker) for determinism.
46
+ const isHigherPriority = context?.feeComparisonOnly ? context.priceBumpPercentage !== undefined ? incomingMeta.priorityFee >= getMinimumPriceBumpFee(lowestPriorityMeta.priorityFee, context.priceBumpPercentage) : incomingMeta.priorityFee > lowestPriorityMeta.priorityFee : comparePriority(incomingMeta, lowestPriorityMeta) > 0;
47
+ if (isHigherPriority) {
48
+ this.log.debug(`Pool at capacity (${currentCount}/${this.maxPoolSize}), evicting ${lowestPriorityMeta.txHash} ` + `(priority ${lowestPriorityMeta.priorityFee}) for ${incomingMeta.txHash} (priority ${incomingMeta.priorityFee})`);
49
+ return Promise.resolve({
50
+ shouldIgnore: false,
51
+ txHashesToEvict: [
52
+ lowestPriorityMeta.txHash
53
+ ]
54
+ });
55
+ }
56
+ // Incoming tx has equal or lower priority - ignore it (it would be evicted anyway)
57
+ const minimumFee = context?.feeComparisonOnly && context.priceBumpPercentage !== undefined ? getMinimumPriceBumpFee(lowestPriorityMeta.priorityFee, context.priceBumpPercentage) : lowestPriorityMeta.priorityFee + 1n;
58
+ this.log.debug(`Pool at capacity (${currentCount}/${this.maxPoolSize}), ignoring ${incomingMeta.txHash} ` + `(priority ${incomingMeta.priorityFee}) - lower than existing minimum (priority ${lowestPriorityMeta.priorityFee})`);
59
+ return Promise.resolve({
60
+ shouldIgnore: true,
61
+ txHashesToEvict: [],
62
+ reason: {
63
+ code: TxPoolRejectionCode.LOW_PRIORITY_FEE,
64
+ message: `Tx does not meet minimum priority fee. Required: ${minimumFee}, got: ${incomingMeta.priorityFee}`,
65
+ minimumPriorityFee: minimumFee,
66
+ txPriorityFee: incomingMeta.priorityFee
67
+ }
68
+ });
69
+ }
70
+ updateConfig(config) {
71
+ if (config.maxPendingTxCount !== undefined) {
72
+ this.maxPoolSize = config.maxPendingTxCount;
73
+ }
74
+ }
75
+ }
@@ -0,0 +1,15 @@
1
+ import { type TxMetaData } from '../tx_metadata.js';
2
+ import type { PreAddContext, PreAddPoolAccess, PreAddResult, PreAddRule } from './interfaces.js';
3
+ /**
4
+ * Pre-add rule that checks for nullifier conflicts between incoming and existing transactions.
5
+ *
6
+ * When an incoming tx shares nullifiers with existing pending txs:
7
+ * - If the incoming tx has strictly higher priority, evict all conflicting txs
8
+ * - If any conflicting tx has equal or higher priority, ignore the incoming tx
9
+ */
10
+ export declare class NullifierConflictRule implements PreAddRule {
11
+ readonly name = "NullifierConflict";
12
+ private log;
13
+ check(incomingMeta: TxMetaData, poolAccess: PreAddPoolAccess, context?: PreAddContext): Promise<PreAddResult>;
14
+ }
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibnVsbGlmaWVyX2NvbmZsaWN0X3J1bGUuZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9tZW1fcG9vbHMvdHhfcG9vbF92Mi9ldmljdGlvbi9udWxsaWZpZXJfY29uZmxpY3RfcnVsZS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFQSxPQUFPLEVBQUUsS0FBSyxVQUFVLEVBQTBCLE1BQU0sbUJBQW1CLENBQUM7QUFDNUUsT0FBTyxLQUFLLEVBQUUsYUFBYSxFQUFFLGdCQUFnQixFQUFFLFlBQVksRUFBRSxVQUFVLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUVqRzs7Ozs7O0dBTUc7QUFDSCxxQkFBYSxxQkFBc0IsWUFBVyxVQUFVO0lBQ3RELFNBQWdCLElBQUksdUJBQXVCO0lBRTNDLE9BQU8sQ0FBQyxHQUFHLENBQTBEO0lBRXJFLEtBQUssQ0FBQyxZQUFZLEVBQUUsVUFBVSxFQUFFLFVBQVUsRUFBRSxnQkFBZ0IsRUFBRSxPQUFPLENBQUMsRUFBRSxhQUFhLEdBQUcsT0FBTyxDQUFDLFlBQVksQ0FBQyxDQWE1RztDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"nullifier_conflict_rule.d.ts","sourceRoot":"","sources":["../../../../src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts"],"names":[],"mappings":"AAEA,OAAO,EAAE,KAAK,UAAU,EAA0B,MAAM,mBAAmB,CAAC;AAC5E,OAAO,KAAK,EAAE,aAAa,EAAE,gBAAgB,EAAE,YAAY,EAAE,UAAU,EAAE,MAAM,iBAAiB,CAAC;AAEjG;;;;;;GAMG;AACH,qBAAa,qBAAsB,YAAW,UAAU;IACtD,SAAgB,IAAI,uBAAuB;IAE3C,OAAO,CAAC,GAAG,CAA0D;IAErE,KAAK,CAAC,YAAY,EAAE,UAAU,EAAE,UAAU,EAAE,gBAAgB,EAAE,OAAO,CAAC,EAAE,aAAa,GAAG,OAAO,CAAC,YAAY,CAAC,CAa5G;CACF"}
@@ -0,0 +1,19 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { checkNullifierConflict } from '../tx_metadata.js';
3
+ /**
4
+ * Pre-add rule that checks for nullifier conflicts between incoming and existing transactions.
5
+ *
6
+ * When an incoming tx shares nullifiers with existing pending txs:
7
+ * - If the incoming tx has strictly higher priority, evict all conflicting txs
8
+ * - If any conflicting tx has equal or higher priority, ignore the incoming tx
9
+ */ export class NullifierConflictRule {
10
+ name = 'NullifierConflict';
11
+ log = createLogger('p2p:tx_pool_v2:nullifier_conflict_rule');
12
+ check(incomingMeta, poolAccess, context) {
13
+ const result = checkNullifierConflict(incomingMeta, (nullifier)=>poolAccess.getTxHashByNullifier(nullifier), (txHash)=>poolAccess.getMetadata(txHash), context?.priceBumpPercentage);
14
+ if (result.shouldIgnore) {
15
+ this.log.debug(`Ignoring tx ${incomingMeta.txHash}: ${result.reason?.message}`);
16
+ }
17
+ return Promise.resolve(result);
18
+ }
19
+ }
@@ -0,0 +1,6 @@
1
+ export { AztecKVTxPoolV2 } from './tx_pool_v2.js';
2
+ export { type TxPoolV2, type TxPoolV2Config, type TxPoolV2Events, type AddTxsResult, type PoolReadAccess, DEFAULT_TX_POOL_V2_CONFIG, } from './interfaces.js';
3
+ export { type TxMetaData, type TxState, buildTxMetaData, comparePriority, stubTxMetaData } from './tx_metadata.js';
4
+ export { TxArchive } from './archive/index.js';
5
+ export { DeletedPool } from './deleted_pool.js';
6
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tZW1fcG9vbHMvdHhfcG9vbF92Mi9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsZUFBZSxFQUFFLE1BQU0saUJBQWlCLENBQUM7QUFDbEQsT0FBTyxFQUNMLEtBQUssUUFBUSxFQUNiLEtBQUssY0FBYyxFQUNuQixLQUFLLGNBQWMsRUFDbkIsS0FBSyxZQUFZLEVBQ2pCLEtBQUssY0FBYyxFQUNuQix5QkFBeUIsR0FDMUIsTUFBTSxpQkFBaUIsQ0FBQztBQUN6QixPQUFPLEVBQUUsS0FBSyxVQUFVLEVBQUUsS0FBSyxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxjQUFjLEVBQUUsTUFBTSxrQkFBa0IsQ0FBQztBQUNuSCxPQUFPLEVBQUUsU0FBUyxFQUFFLE1BQU0sb0JBQW9CLENBQUM7QUFDL0MsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLG1CQUFtQixDQUFDIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/mem_pools/tx_pool_v2/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,eAAe,EAAE,MAAM,iBAAiB,CAAC;AAClD,OAAO,EACL,KAAK,QAAQ,EACb,KAAK,cAAc,EACnB,KAAK,cAAc,EACnB,KAAK,YAAY,EACjB,KAAK,cAAc,EACnB,yBAAyB,GAC1B,MAAM,iBAAiB,CAAC;AACzB,OAAO,EAAE,KAAK,UAAU,EAAE,KAAK,OAAO,EAAE,eAAe,EAAE,eAAe,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAC;AACnH,OAAO,EAAE,SAAS,EAAE,MAAM,oBAAoB,CAAC;AAC/C,OAAO,EAAE,WAAW,EAAE,MAAM,mBAAmB,CAAC"}
@@ -0,0 +1,5 @@
1
+ export { AztecKVTxPoolV2 } from './tx_pool_v2.js';
2
+ export { DEFAULT_TX_POOL_V2_CONFIG } from './interfaces.js';
3
+ export { buildTxMetaData, comparePriority, stubTxMetaData } from './tx_metadata.js';
4
+ export { TxArchive } from './archive/index.js';
5
+ export { DeletedPool } from './deleted_pool.js';
@@ -0,0 +1,15 @@
1
+ import { type TelemetryClient } from '@aztec/telemetry-client';
2
+ /** Callback that returns the current estimated metadata memory in bytes. */
3
+ export type MetadataMemoryCallback = () => number;
4
+ /** Instrumentation for TxPoolV2Impl internal operations. */
5
+ export declare class TxPoolV2Instrumentation {
6
+ #private;
7
+ constructor(telemetry: TelemetryClient, metadataMemoryCallback: MetadataMemoryCallback);
8
+ recordEvictions(count: number, reason: string): void;
9
+ recordIgnored(count: number): void;
10
+ recordRejected(count: number): void;
11
+ recordSoftDeletedHits(count: number): void;
12
+ recordMissingOnProtect(count: number): void;
13
+ recordMissingPreviouslyEvicted(count: number): void;
14
+ }
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5zdHJ1bWVudGF0aW9uLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbWVtX3Bvb2xzL3R4X3Bvb2xfdjIvaW5zdHJ1bWVudGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFNTCxLQUFLLGVBQWUsRUFHckIsTUFBTSx5QkFBeUIsQ0FBQztBQUVqQyw0RUFBNEU7QUFDNUUsTUFBTSxNQUFNLHNCQUFzQixHQUFHLE1BQU0sTUFBTSxDQUFDO0FBRWxELDREQUE0RDtBQUM1RCxxQkFBYSx1QkFBdUI7O0lBU2xDLFlBQVksU0FBUyxFQUFFLGVBQWUsRUFBRSxzQkFBc0IsRUFBRSxzQkFBc0IsRUFtQnJGO0lBRUQsZUFBZSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFFNUM7SUFFRCxhQUFhLENBQUMsS0FBSyxFQUFFLE1BQU0sUUFFMUI7SUFFRCxjQUFjLENBQUMsS0FBSyxFQUFFLE1BQU0sUUFFM0I7SUFFRCxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxRQUVsQztJQUVELHNCQUFzQixDQUFDLEtBQUssRUFBRSxNQUFNLFFBRW5DO0lBRUQsOEJBQThCLENBQUMsS0FBSyxFQUFFLE1BQU0sUUFFM0M7Q0FDRiJ9
@@ -0,0 +1 @@
1
+ {"version":3,"file":"instrumentation.d.ts","sourceRoot":"","sources":["../../../src/mem_pools/tx_pool_v2/instrumentation.ts"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,eAAe,EAGrB,MAAM,yBAAyB,CAAC;AAEjC,4EAA4E;AAC5E,MAAM,MAAM,sBAAsB,GAAG,MAAM,MAAM,CAAC;AAElD,4DAA4D;AAC5D,qBAAa,uBAAuB;;IASlC,YAAY,SAAS,EAAE,eAAe,EAAE,sBAAsB,EAAE,sBAAsB,EAmBrF;IAED,eAAe,CAAC,KAAK,EAAE,MAAM,EAAE,MAAM,EAAE,MAAM,QAE5C;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,QAE1B;IAED,cAAc,CAAC,KAAK,EAAE,MAAM,QAE3B;IAED,qBAAqB,CAAC,KAAK,EAAE,MAAM,QAElC;IAED,sBAAsB,CAAC,KAAK,EAAE,MAAM,QAEnC;IAED,8BAA8B,CAAC,KAAK,EAAE,MAAM,QAE3C;CACF"}
@@ -0,0 +1,43 @@
1
+ import { Attributes, Metrics, createUpDownCounterWithDefault } from '@aztec/telemetry-client';
2
+ /** Instrumentation for TxPoolV2Impl internal operations. */ export class TxPoolV2Instrumentation {
3
+ #evictedCounter;
4
+ #ignoredCounter;
5
+ #rejectedCounter;
6
+ #softDeletedHitsCounter;
7
+ #missingOnProtectCounter;
8
+ #missingPreviouslyEvictedCounter;
9
+ #metadataMemoryGauge;
10
+ constructor(telemetry, metadataMemoryCallback){
11
+ const meter = telemetry.getMeter('TxPoolV2Impl');
12
+ this.#evictedCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_EVICTED_COUNT);
13
+ this.#ignoredCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_IGNORED_COUNT);
14
+ this.#rejectedCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_REJECTED_COUNT);
15
+ this.#softDeletedHitsCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_SOFT_DELETED_HITS);
16
+ this.#missingOnProtectCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_MISSING_ON_PROTECT);
17
+ this.#missingPreviouslyEvictedCounter = createUpDownCounterWithDefault(meter, Metrics.MEMPOOL_TX_POOL_V2_MISSING_PREVIOUSLY_EVICTED);
18
+ this.#metadataMemoryGauge = meter.createObservableGauge(Metrics.MEMPOOL_TX_POOL_V2_METADATA_MEMORY);
19
+ this.#metadataMemoryGauge.addCallback((result)=>{
20
+ result.observe(metadataMemoryCallback());
21
+ });
22
+ }
23
+ recordEvictions(count, reason) {
24
+ this.#evictedCounter.add(count, {
25
+ [Attributes.TX_POOL_EVICTION_REASON]: reason
26
+ });
27
+ }
28
+ recordIgnored(count) {
29
+ this.#ignoredCounter.add(count);
30
+ }
31
+ recordRejected(count) {
32
+ this.#rejectedCounter.add(count);
33
+ }
34
+ recordSoftDeletedHits(count) {
35
+ this.#softDeletedHitsCounter.add(count);
36
+ }
37
+ recordMissingOnProtect(count) {
38
+ this.#missingOnProtectCounter.add(count);
39
+ }
40
+ recordMissingPreviouslyEvicted(count) {
41
+ this.#missingPreviouslyEvictedCounter.add(count);
42
+ }
43
+ }