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

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 (496) 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 +7 -6
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +52 -14
  7. package/dest/client/interface.d.ts +43 -23
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +40 -42
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +157 -146
  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 +34 -3
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +23 -4
  21. package/dest/errors/tx-pool.error.d.ts +8 -0
  22. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  23. package/dest/errors/tx-pool.error.js +9 -0
  24. package/dest/index.d.ts +2 -1
  25. package/dest/index.d.ts.map +1 -1
  26. package/dest/index.js +1 -0
  27. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -88
  28. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  29. package/dest/mem_pools/attestation_pool/attestation_pool.js +441 -3
  30. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  31. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +373 -96
  33. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  34. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  35. package/dest/mem_pools/attestation_pool/index.js +1 -2
  36. package/dest/mem_pools/attestation_pool/mocks.d.ts +4 -2
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  38. package/dest/mem_pools/attestation_pool/mocks.js +8 -5
  39. package/dest/mem_pools/index.d.ts +3 -2
  40. package/dest/mem_pools/index.d.ts.map +1 -1
  41. package/dest/mem_pools/index.js +1 -1
  42. package/dest/mem_pools/instrumentation.d.ts +1 -1
  43. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  44. package/dest/mem_pools/instrumentation.js +2 -2
  45. package/dest/mem_pools/interface.d.ts +5 -5
  46. package/dest/mem_pools/interface.d.ts.map +1 -1
  47. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +15 -10
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +91 -50
  50. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +19 -5
  51. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -1
  52. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +59 -3
  53. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +79 -5
  54. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -1
  55. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +47 -0
  56. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  57. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  58. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  59. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +2 -2
  60. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -1
  61. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +3 -3
  62. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +4 -4
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -1
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +2 -0
  65. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +2 -2
  66. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -1
  67. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  68. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  69. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  70. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  71. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  72. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  73. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  74. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  75. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  76. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  77. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  78. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  79. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  80. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  81. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  82. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  83. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  84. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +93 -0
  85. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +95 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  90. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +174 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +74 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  105. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +73 -0
  106. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  107. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  108. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  109. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  110. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  111. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  112. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  113. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  114. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  115. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +209 -0
  116. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  117. package/dest/mem_pools/tx_pool_v2/interfaces.js +8 -0
  118. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +97 -0
  119. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  120. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +152 -0
  121. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  122. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  123. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  124. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  125. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  126. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +355 -0
  127. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +60 -0
  128. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  129. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +161 -0
  130. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +77 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +878 -0
  133. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +3 -3
  134. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  135. package/dest/msg_validators/attestation_validator/attestation_validator.js +41 -10
  136. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  137. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  138. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -6
  139. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  140. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  141. package/dest/msg_validators/clock_tolerance.js +37 -0
  142. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +3 -3
  143. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  144. package/dest/msg_validators/proposal_validator/proposal_validator.js +55 -31
  145. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +3 -3
  146. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -1
  147. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +93 -64
  148. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +3 -3
  149. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  150. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  151. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  152. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  153. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  154. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  155. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  156. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  157. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  158. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  159. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  160. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  161. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  162. package/dest/msg_validators/tx_validator/factory.d.ts +8 -3
  163. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  164. package/dest/msg_validators/tx_validator/factory.js +21 -11
  165. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  166. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  167. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  168. package/dest/msg_validators/tx_validator/gas_validator.d.ts +3 -2
  169. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  170. package/dest/msg_validators/tx_validator/gas_validator.js +11 -16
  171. package/dest/msg_validators/tx_validator/index.d.ts +2 -1
  172. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  173. package/dest/msg_validators/tx_validator/index.js +1 -0
  174. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  175. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  176. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  177. package/dest/msg_validators/tx_validator/phases_validator.d.ts +3 -2
  178. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  179. package/dest/msg_validators/tx_validator/phases_validator.js +3 -3
  180. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  181. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  182. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  183. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  184. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  185. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  186. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  187. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  188. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  189. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  190. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  191. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  192. package/dest/services/data_store.d.ts +1 -1
  193. package/dest/services/data_store.d.ts.map +1 -1
  194. package/dest/services/data_store.js +10 -6
  195. package/dest/services/discv5/discV5_service.js +1 -1
  196. package/dest/services/dummy_service.d.ts +24 -3
  197. package/dest/services/dummy_service.d.ts.map +1 -1
  198. package/dest/services/dummy_service.js +48 -0
  199. package/dest/services/encoding.d.ts +2 -2
  200. package/dest/services/encoding.d.ts.map +1 -1
  201. package/dest/services/encoding.js +6 -6
  202. package/dest/services/gossipsub/index.d.ts +3 -0
  203. package/dest/services/gossipsub/index.d.ts.map +1 -0
  204. package/dest/services/gossipsub/index.js +2 -0
  205. package/dest/services/gossipsub/scoring.d.ts +21 -3
  206. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  207. package/dest/services/gossipsub/scoring.js +24 -7
  208. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  209. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  210. package/dest/services/gossipsub/topic_score_params.js +346 -0
  211. package/dest/services/index.d.ts +2 -1
  212. package/dest/services/index.d.ts.map +1 -1
  213. package/dest/services/index.js +1 -0
  214. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  215. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  216. package/dest/services/libp2p/instrumentation.js +19 -8
  217. package/dest/services/libp2p/libp2p_service.d.ts +92 -36
  218. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  219. package/dest/services/libp2p/libp2p_service.js +413 -305
  220. package/dest/services/peer-manager/metrics.d.ts +2 -2
  221. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  222. package/dest/services/peer-manager/metrics.js +20 -5
  223. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  224. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  225. package/dest/services/peer-manager/peer_scoring.js +33 -4
  226. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +48 -0
  227. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  228. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +562 -0
  229. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  230. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  231. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  232. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +46 -0
  233. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  234. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  235. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +34 -0
  236. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  237. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +130 -0
  238. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  239. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  240. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  241. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  242. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  243. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  244. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  245. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  246. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  247. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  248. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  249. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  250. package/dest/services/reqresp/constants.d.ts +12 -0
  251. package/dest/services/reqresp/constants.d.ts.map +1 -0
  252. package/dest/services/reqresp/constants.js +7 -0
  253. package/dest/services/reqresp/interface.d.ts +12 -1
  254. package/dest/services/reqresp/interface.d.ts.map +1 -1
  255. package/dest/services/reqresp/interface.js +15 -1
  256. package/dest/services/reqresp/metrics.d.ts +6 -5
  257. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  258. package/dest/services/reqresp/metrics.js +17 -5
  259. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  260. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  261. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  262. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  263. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  264. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  265. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  266. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  267. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  268. package/dest/services/reqresp/protocols/status.d.ts +1 -1
  269. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  270. package/dest/services/reqresp/protocols/status.js +2 -1
  271. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  272. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  273. package/dest/services/reqresp/protocols/tx.js +20 -0
  274. package/dest/services/reqresp/reqresp.d.ts +6 -1
  275. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  276. package/dest/services/reqresp/reqresp.js +69 -26
  277. package/dest/services/service.d.ts +41 -2
  278. package/dest/services/service.d.ts.map +1 -1
  279. package/dest/services/tx_collection/config.d.ts +22 -1
  280. package/dest/services/tx_collection/config.d.ts.map +1 -1
  281. package/dest/services/tx_collection/config.js +55 -1
  282. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  283. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  284. package/dest/services/tx_collection/fast_tx_collection.js +71 -44
  285. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  286. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  287. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  288. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  289. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  290. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  291. package/dest/services/tx_collection/index.d.ts +3 -1
  292. package/dest/services/tx_collection/index.d.ts.map +1 -1
  293. package/dest/services/tx_collection/index.js +2 -0
  294. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  295. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  296. package/dest/services/tx_collection/instrumentation.js +10 -2
  297. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  298. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  299. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  300. package/dest/services/tx_collection/proposal_tx_collector.d.ts +49 -0
  301. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  302. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  303. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  304. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  305. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  306. package/dest/services/tx_collection/tx_collection.d.ts +29 -16
  307. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  308. package/dest/services/tx_collection/tx_collection.js +79 -7
  309. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  310. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  311. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  312. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  313. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  314. package/dest/services/tx_collection/tx_source.js +19 -2
  315. package/dest/services/tx_file_store/config.d.ts +16 -0
  316. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  317. package/dest/services/tx_file_store/config.js +22 -0
  318. package/dest/services/tx_file_store/index.d.ts +4 -0
  319. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  320. package/dest/services/tx_file_store/index.js +3 -0
  321. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  322. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  323. package/dest/services/tx_file_store/instrumentation.js +29 -0
  324. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  325. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  326. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  327. package/dest/services/tx_provider.d.ts +5 -5
  328. package/dest/services/tx_provider.d.ts.map +1 -1
  329. package/dest/services/tx_provider.js +5 -4
  330. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  331. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  332. package/dest/services/tx_provider_instrumentation.js +5 -5
  333. package/dest/test-helpers/index.d.ts +3 -1
  334. package/dest/test-helpers/index.d.ts.map +1 -1
  335. package/dest/test-helpers/index.js +2 -0
  336. package/dest/test-helpers/make-test-p2p-clients.d.ts +3 -3
  337. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  338. package/dest/test-helpers/mock-pubsub.d.ts +29 -2
  339. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  340. package/dest/test-helpers/mock-pubsub.js +103 -2
  341. package/dest/test-helpers/reqresp-nodes.d.ts +1 -1
  342. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  343. package/dest/test-helpers/reqresp-nodes.js +2 -1
  344. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  345. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  346. package/dest/test-helpers/test_tx_provider.js +41 -0
  347. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  348. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  349. package/dest/test-helpers/testbench-utils.js +366 -0
  350. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  351. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  352. package/dest/testbench/p2p_client_testbench_worker.js +215 -135
  353. package/dest/testbench/worker_client_manager.d.ts +51 -6
  354. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  355. package/dest/testbench/worker_client_manager.js +226 -44
  356. package/dest/util.d.ts +2 -2
  357. package/dest/util.d.ts.map +1 -1
  358. package/package.json +16 -16
  359. package/src/bootstrap/bootstrap.ts +7 -4
  360. package/src/client/factory.ts +95 -24
  361. package/src/client/interface.ts +59 -23
  362. package/src/client/p2p_client.ts +201 -172
  363. package/src/client/test/tx_proposal_collector/README.md +227 -0
  364. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +346 -0
  365. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  366. package/src/config.ts +48 -4
  367. package/src/errors/tx-pool.error.ts +12 -0
  368. package/src/index.ts +1 -0
  369. package/src/mem_pools/attestation_pool/attestation_pool.ts +496 -91
  370. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +460 -112
  371. package/src/mem_pools/attestation_pool/index.ts +9 -2
  372. package/src/mem_pools/attestation_pool/mocks.ts +7 -4
  373. package/src/mem_pools/index.ts +4 -1
  374. package/src/mem_pools/instrumentation.ts +2 -1
  375. package/src/mem_pools/interface.ts +4 -4
  376. package/src/mem_pools/tx_pool/README.md +29 -14
  377. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +130 -75
  378. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +66 -5
  379. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +119 -4
  380. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  381. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  382. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  383. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  384. package/src/mem_pools/tx_pool_v2/README.md +275 -0
  385. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  386. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  387. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  388. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  389. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  390. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +122 -0
  391. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  392. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +209 -0
  393. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  394. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  395. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +87 -0
  396. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +90 -0
  397. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  398. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  399. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  400. package/src/mem_pools/tx_pool_v2/interfaces.ts +239 -0
  401. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +242 -0
  402. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  403. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +444 -0
  404. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +223 -0
  405. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1052 -0
  406. package/src/msg_validators/attestation_validator/attestation_validator.ts +26 -14
  407. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  408. package/src/msg_validators/clock_tolerance.ts +51 -0
  409. package/src/msg_validators/proposal_validator/proposal_validator.ts +31 -31
  410. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +91 -67
  411. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +2 -2
  412. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  413. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  414. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  415. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  416. package/src/msg_validators/tx_validator/factory.ts +64 -23
  417. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  418. package/src/msg_validators/tx_validator/gas_validator.ts +17 -28
  419. package/src/msg_validators/tx_validator/index.ts +1 -0
  420. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  421. package/src/msg_validators/tx_validator/phases_validator.ts +5 -3
  422. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  423. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  424. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  425. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  426. package/src/services/data_store.ts +10 -7
  427. package/src/services/discv5/discV5_service.ts +1 -1
  428. package/src/services/dummy_service.ts +62 -1
  429. package/src/services/encoding.ts +6 -6
  430. package/src/services/gossipsub/README.md +641 -0
  431. package/src/services/gossipsub/index.ts +2 -0
  432. package/src/services/gossipsub/scoring.ts +29 -5
  433. package/src/services/gossipsub/topic_score_params.ts +487 -0
  434. package/src/services/index.ts +1 -0
  435. package/src/services/libp2p/instrumentation.ts +20 -7
  436. package/src/services/libp2p/libp2p_service.ts +442 -316
  437. package/src/services/peer-manager/metrics.ts +21 -4
  438. package/src/services/peer-manager/peer_scoring.ts +29 -1
  439. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  440. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  441. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  442. package/src/services/reqresp/batch-tx-requester/interface.ts +53 -0
  443. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +161 -0
  444. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  445. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  446. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  447. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  448. package/src/services/reqresp/constants.ts +14 -0
  449. package/src/services/reqresp/interface.ts +29 -1
  450. package/src/services/reqresp/metrics.ts +34 -9
  451. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  452. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  453. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  454. package/src/services/reqresp/protocols/status.ts +5 -3
  455. package/src/services/reqresp/protocols/tx.ts +22 -0
  456. package/src/services/reqresp/reqresp.ts +79 -22
  457. package/src/services/service.ts +54 -1
  458. package/src/services/tx_collection/config.ts +83 -1
  459. package/src/services/tx_collection/fast_tx_collection.ts +93 -47
  460. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  461. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  462. package/src/services/tx_collection/index.ts +6 -0
  463. package/src/services/tx_collection/instrumentation.ts +17 -2
  464. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  465. package/src/services/tx_collection/proposal_tx_collector.ts +113 -0
  466. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  467. package/src/services/tx_collection/tx_collection.ts +121 -24
  468. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  469. package/src/services/tx_collection/tx_source.ts +22 -3
  470. package/src/services/tx_file_store/config.ts +37 -0
  471. package/src/services/tx_file_store/index.ts +3 -0
  472. package/src/services/tx_file_store/instrumentation.ts +36 -0
  473. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  474. package/src/services/tx_provider.ts +10 -9
  475. package/src/services/tx_provider_instrumentation.ts +11 -5
  476. package/src/test-helpers/index.ts +2 -0
  477. package/src/test-helpers/make-test-p2p-clients.ts +3 -3
  478. package/src/test-helpers/mock-pubsub.ts +143 -3
  479. package/src/test-helpers/reqresp-nodes.ts +2 -1
  480. package/src/test-helpers/test_tx_provider.ts +64 -0
  481. package/src/test-helpers/testbench-utils.ts +430 -0
  482. package/src/testbench/p2p_client_testbench_worker.ts +332 -130
  483. package/src/testbench/worker_client_manager.ts +304 -47
  484. package/src/util.ts +7 -1
  485. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  486. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  487. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  488. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  489. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  490. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  491. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts +0 -15
  492. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.d.ts.map +0 -1
  493. package/dest/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.js +0 -88
  494. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  495. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  496. package/src/mem_pools/tx_pool/eviction/insufficient_fee_payer_balance_rule.ts +0 -108
@@ -1,5 +1,5 @@
1
1
  import { MAX_FR_CALLDATA_TO_ALL_ENQUEUED_CALLS } from '@aztec/constants';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import { computeCalldataHash } from '@aztec/stdlib/hash';
4
4
  import {
5
5
  TX_ERROR_CALLDATA_COUNT_MISMATCH,
@@ -16,7 +16,11 @@ import {
16
16
  } from '@aztec/stdlib/tx';
17
17
 
18
18
  export class DataTxValidator implements TxValidator<Tx> {
19
- #log = createLogger('p2p:tx_validator:tx_data');
19
+ #log: Logger;
20
+
21
+ constructor(bindings?: LoggerBindings) {
22
+ this.#log = createLogger('p2p:tx_validator:tx_data', bindings);
23
+ }
20
24
 
21
25
  async validateTx(tx: Tx): Promise<TxValidationResult> {
22
26
  const reason =
@@ -1,9 +1,8 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
3
  import {
3
- type AnyTx,
4
4
  TX_ERROR_DUPLICATE_NULLIFIER_IN_TX,
5
5
  TX_ERROR_EXISTING_NULLIFIER,
6
- Tx,
7
6
  type TxValidationResult,
8
7
  type TxValidator,
9
8
  } from '@aztec/stdlib/tx';
@@ -12,26 +11,33 @@ export interface NullifierSource {
12
11
  nullifiersExist: (nullifiers: Buffer[]) => Promise<boolean[]>;
13
12
  }
14
13
 
15
- export class DoubleSpendTxValidator<T extends AnyTx> implements TxValidator<T> {
16
- #log = createLogger('p2p:tx_validator:tx_double_spend');
14
+ /** Structural interface for double-spend validation. */
15
+ export interface HasNullifierData {
16
+ txHash: { toString(): string };
17
+ data: { getNonEmptyNullifiers(): Fr[] };
18
+ }
19
+
20
+ export class DoubleSpendTxValidator<T extends HasNullifierData> implements TxValidator<T> {
21
+ #log: Logger;
17
22
  #nullifierSource: NullifierSource;
18
23
 
19
- constructor(nullifierSource: NullifierSource) {
24
+ constructor(nullifierSource: NullifierSource, bindings?: LoggerBindings) {
20
25
  this.#nullifierSource = nullifierSource;
26
+ this.#log = createLogger('p2p:tx_validator:tx_double_spend', bindings);
21
27
  }
22
28
 
23
29
  async validateTx(tx: T): Promise<TxValidationResult> {
24
- const nullifiers = tx instanceof Tx ? tx.data.getNonEmptyNullifiers() : tx.txEffect.nullifiers;
30
+ const nullifiers = tx.data.getNonEmptyNullifiers();
25
31
 
26
32
  // Ditch this tx if it has repeated nullifiers
27
33
  const uniqueNullifiers = new Set(nullifiers.map(n => n.toBigInt()));
28
34
  if (uniqueNullifiers.size !== nullifiers.length) {
29
- this.#log.verbose(`Rejecting tx ${'txHash' in tx ? tx.txHash : tx.hash} for emitting duplicate nullifiers`);
35
+ this.#log.verbose(`Rejecting tx ${tx.txHash} for emitting duplicate nullifiers`);
30
36
  return { result: 'invalid', reason: [TX_ERROR_DUPLICATE_NULLIFIER_IN_TX] };
31
37
  }
32
38
 
33
39
  if ((await this.#nullifierSource.nullifiersExist(nullifiers.map(n => n.toBuffer()))).some(Boolean)) {
34
- this.#log.verbose(`Rejecting tx ${'txHash' in tx ? tx.txHash : tx.hash} for repeating a nullifier`);
40
+ this.#log.verbose(`Rejecting tx ${tx.txHash} for repeating a nullifier`);
35
41
  return { result: 'invalid', reason: [TX_ERROR_EXISTING_NULLIFIER] };
36
42
  }
37
43
 
@@ -1,7 +1,8 @@
1
1
  import { BlockNumber } from '@aztec/foundation/branded-types';
2
2
  import { Fr } from '@aztec/foundation/curves/bn254';
3
+ import type { LoggerBindings } from '@aztec/foundation/log';
3
4
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
4
- import { ProtocolContractAddress } from '@aztec/protocol-contracts';
5
+ import { ProtocolContractAddress, protocolContractsHash } from '@aztec/protocol-contracts';
5
6
  import type { ContractDataSource } from '@aztec/stdlib/contract';
6
7
  import type { GasFees } from '@aztec/stdlib/gas';
7
8
  import type {
@@ -11,9 +12,10 @@ import type {
11
12
  } from '@aztec/stdlib/interfaces/server';
12
13
  import { PeerErrorSeverity } from '@aztec/stdlib/p2p';
13
14
  import { DatabasePublicStateSource, MerkleTreeId } from '@aztec/stdlib/trees';
14
- import type { Tx, TxValidationResult } from '@aztec/stdlib/tx';
15
+ import type { Tx, TxValidationResult, TxValidator } from '@aztec/stdlib/tx';
15
16
  import type { UInt64 } from '@aztec/stdlib/types';
16
17
 
18
+ import { AggregateTxValidator } from './aggregate_tx_validator.js';
17
19
  import { ArchiveCache } from './archive_cache.js';
18
20
  import { BlockHeaderTxValidator } from './block_header_validator.js';
19
21
  import { DataTxValidator } from './data_validator.js';
@@ -21,6 +23,7 @@ import { DoubleSpendTxValidator } from './double_spend_validator.js';
21
23
  import { GasTxValidator } from './gas_validator.js';
22
24
  import { MetadataTxValidator } from './metadata_validator.js';
23
25
  import { PhasesTxValidator } from './phases_validator.js';
26
+ import { SizeTxValidator } from './size_validator.js';
24
27
  import { TimestampTxValidator } from './timestamp_validator.js';
25
28
  import { TxPermittedValidator } from './tx_permitted_validator.js';
26
29
  import { TxProofValidator } from './tx_proof_validator.js';
@@ -44,43 +47,53 @@ export function createTxMessageValidators(
44
47
  proofVerifier: ClientProtocolCircuitVerifier,
45
48
  txsPermitted: boolean,
46
49
  allowedInSetup: AllowedElement[] = [],
50
+ bindings?: LoggerBindings,
47
51
  ): Record<string, MessageValidator>[] {
48
52
  const merkleTree = worldStateSynchronizer.getCommitted();
49
53
 
50
54
  return [
51
55
  {
52
56
  txsPermittedValidator: {
53
- validator: new TxPermittedValidator(txsPermitted),
57
+ validator: new TxPermittedValidator(txsPermitted, bindings),
54
58
  severity: PeerErrorSeverity.MidToleranceError,
55
59
  },
56
60
  dataValidator: {
57
- validator: new DataTxValidator(),
61
+ validator: new DataTxValidator(bindings),
58
62
  severity: PeerErrorSeverity.HighToleranceError,
59
63
  },
60
64
  metadataValidator: {
61
- validator: new MetadataTxValidator({
62
- l1ChainId: new Fr(l1ChainId),
63
- rollupVersion: new Fr(rollupVersion),
64
- protocolContractsHash,
65
- vkTreeRoot: getVKTreeRoot(),
66
- }),
65
+ validator: new MetadataTxValidator(
66
+ {
67
+ l1ChainId: new Fr(l1ChainId),
68
+ rollupVersion: new Fr(rollupVersion),
69
+ protocolContractsHash,
70
+ vkTreeRoot: getVKTreeRoot(),
71
+ },
72
+ bindings,
73
+ ),
67
74
  severity: PeerErrorSeverity.HighToleranceError,
68
75
  },
69
76
  timestampValidator: {
70
- validator: new TimestampTxValidator<Tx>({
71
- timestamp,
72
- blockNumber,
73
- }),
77
+ validator: new TimestampTxValidator<Tx>(
78
+ {
79
+ timestamp,
80
+ blockNumber,
81
+ },
82
+ bindings,
83
+ ),
74
84
  severity: PeerErrorSeverity.MidToleranceError,
75
85
  },
76
86
  doubleSpendValidator: {
77
- validator: new DoubleSpendTxValidator({
78
- nullifiersExist: async (nullifiers: Buffer[]) => {
79
- const merkleTree = worldStateSynchronizer.getCommitted();
80
- const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
81
- return indices.map(index => index !== undefined);
87
+ validator: new DoubleSpendTxValidator(
88
+ {
89
+ nullifiersExist: async (nullifiers: Buffer[]) => {
90
+ const merkleTree = worldStateSynchronizer.getCommitted();
91
+ const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
92
+ return indices.map(index => index !== undefined);
93
+ },
82
94
  },
83
- }),
95
+ bindings,
96
+ ),
84
97
  severity: PeerErrorSeverity.HighToleranceError,
85
98
  },
86
99
  gasValidator: {
@@ -88,23 +101,51 @@ export function createTxMessageValidators(
88
101
  new DatabasePublicStateSource(merkleTree),
89
102
  ProtocolContractAddress.FeeJuice,
90
103
  gasFees,
104
+ bindings,
91
105
  ),
92
106
  severity: PeerErrorSeverity.HighToleranceError,
93
107
  },
94
108
  phasesValidator: {
95
- validator: new PhasesTxValidator(contractDataSource, allowedInSetup, timestamp),
109
+ validator: new PhasesTxValidator(contractDataSource, allowedInSetup, timestamp, bindings),
96
110
  severity: PeerErrorSeverity.MidToleranceError,
97
111
  },
98
112
  blockHeaderValidator: {
99
- validator: new BlockHeaderTxValidator(new ArchiveCache(merkleTree)),
113
+ validator: new BlockHeaderTxValidator(new ArchiveCache(merkleTree), bindings),
100
114
  severity: PeerErrorSeverity.HighToleranceError,
101
115
  },
102
116
  },
103
117
  {
104
118
  proofValidator: {
105
- validator: new TxProofValidator(proofVerifier),
119
+ validator: new TxProofValidator(proofVerifier, bindings),
106
120
  severity: PeerErrorSeverity.MidToleranceError,
107
121
  },
108
122
  },
109
123
  ];
110
124
  }
125
+
126
+ export function createTxReqRespValidator(
127
+ verifier: ClientProtocolCircuitVerifier,
128
+ {
129
+ l1ChainId,
130
+ rollupVersion,
131
+ }: {
132
+ l1ChainId: number;
133
+ rollupVersion: number;
134
+ },
135
+ bindings?: LoggerBindings,
136
+ ): TxValidator {
137
+ return new AggregateTxValidator(
138
+ new MetadataTxValidator(
139
+ {
140
+ l1ChainId: new Fr(l1ChainId),
141
+ rollupVersion: new Fr(rollupVersion),
142
+ protocolContractsHash,
143
+ vkTreeRoot: getVKTreeRoot(),
144
+ },
145
+ bindings,
146
+ ),
147
+ new SizeTxValidator(bindings),
148
+ new DataTxValidator(bindings),
149
+ new TxProofValidator(verifier, bindings),
150
+ );
151
+ }
@@ -0,0 +1,40 @@
1
+ import { getCallRequestsWithCalldataByPhase } from '@aztec/simulator/server';
2
+ import { FunctionSelector } from '@aztec/stdlib/abi';
3
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
4
+ import { type Tx, TxExecutionPhase } from '@aztec/stdlib/tx';
5
+
6
+ export type FeePayerBalanceDelta = {
7
+ feeLimit: bigint;
8
+ claimAmount: bigint;
9
+ };
10
+
11
+ const increasePublicBalanceSelectorPromise = FunctionSelector.fromSignature('_increase_public_balance((Field),u128)');
12
+
13
+ export function getTxFeeLimit(tx: Tx): bigint {
14
+ return tx.data.constants.txContext.gasSettings.getFeeLimit().toBigInt();
15
+ }
16
+
17
+ export async function getFeePayerClaimAmount(tx: Tx, feeJuiceAddress: AztecAddress): Promise<bigint> {
18
+ const setupFns = getCallRequestsWithCalldataByPhase(tx, TxExecutionPhase.SETUP);
19
+ const increasePublicBalanceSelector = await increasePublicBalanceSelectorPromise;
20
+ const feePayer = tx.data.feePayer;
21
+
22
+ const claimFunctionCall = setupFns.find(
23
+ fn =>
24
+ fn.request.contractAddress.equals(feeJuiceAddress) &&
25
+ fn.request.msgSender.equals(feeJuiceAddress) &&
26
+ fn.calldata.length > 2 &&
27
+ fn.functionSelector.equals(increasePublicBalanceSelector) &&
28
+ fn.args[0].equals(feePayer.toField()) &&
29
+ !fn.request.isStaticCall,
30
+ );
31
+
32
+ return claimFunctionCall ? claimFunctionCall.args[1].toBigInt() : 0n;
33
+ }
34
+
35
+ export async function getFeePayerBalanceDelta(tx: Tx, feeJuiceAddress: AztecAddress): Promise<FeePayerBalanceDelta> {
36
+ return {
37
+ feeLimit: getTxFeeLimit(tx),
38
+ claimAmount: await getFeePayerClaimAmount(tx, feeJuiceAddress),
39
+ };
40
+ }
@@ -1,8 +1,6 @@
1
1
  import { AVM_MAX_PROCESSABLE_L2_GAS, FIXED_DA_GAS, FIXED_L2_GAS } from '@aztec/constants';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import { computeFeePayerBalanceStorageSlot } from '@aztec/protocol-contracts/fee-juice';
4
- import { getCallRequestsWithCalldataByPhase } from '@aztec/simulator/server';
5
- import { FunctionSelector } from '@aztec/stdlib/abi';
6
4
  import type { AztecAddress } from '@aztec/stdlib/aztec-address';
7
5
  import { Gas, GasFees } from '@aztec/stdlib/gas';
8
6
  import type { PublicStateSource } from '@aztec/stdlib/trees';
@@ -12,18 +10,25 @@ import {
12
10
  TX_ERROR_INSUFFICIENT_FEE_PER_GAS,
13
11
  TX_ERROR_INSUFFICIENT_GAS_LIMIT,
14
12
  type Tx,
15
- TxExecutionPhase,
16
13
  type TxValidationResult,
17
14
  type TxValidator,
18
15
  } from '@aztec/stdlib/tx';
19
16
 
17
+ import { getFeePayerClaimAmount, getTxFeeLimit } from './fee_payer_balance.js';
18
+
20
19
  export class GasTxValidator implements TxValidator<Tx> {
21
- #log = createLogger('sequencer:tx_validator:tx_gas');
20
+ #log: Logger;
22
21
  #publicDataSource: PublicStateSource;
23
22
  #feeJuiceAddress: AztecAddress;
24
23
  #gasFees: GasFees;
25
24
 
26
- constructor(publicDataSource: PublicStateSource, feeJuiceAddress: AztecAddress, gasFees: GasFees) {
25
+ constructor(
26
+ publicDataSource: PublicStateSource,
27
+ feeJuiceAddress: AztecAddress,
28
+ gasFees: GasFees,
29
+ bindings?: LoggerBindings,
30
+ ) {
31
+ this.#log = createLogger('sequencer:tx_validator:tx_gas', bindings);
27
32
  this.#publicDataSource = publicDataSource;
28
33
  this.#feeJuiceAddress = feeJuiceAddress;
29
34
  this.#gasFees = gasFees;
@@ -93,7 +98,7 @@ export class GasTxValidator implements TxValidator<Tx> {
93
98
  const feePayer = tx.data.feePayer;
94
99
 
95
100
  // Compute the maximum fee that this tx may pay, based on its gasLimits and maxFeePerGas
96
- const feeLimit = tx.data.constants.txContext.gasSettings.getFeeLimit();
101
+ const feeLimit = getTxFeeLimit(tx);
97
102
 
98
103
  // Read current balance of the feePayer
99
104
  const initialBalance = await this.#publicDataSource.storageRead(
@@ -102,30 +107,14 @@ export class GasTxValidator implements TxValidator<Tx> {
102
107
  );
103
108
 
104
109
  // If there is a claim in this tx that increases the fee payer balance in Fee Juice, add it to balance
105
- const setupFns = getCallRequestsWithCalldataByPhase(tx, TxExecutionPhase.SETUP);
106
- const increasePublicBalanceSelector = await FunctionSelector.fromSignature(
107
- '_increase_public_balance((Field),u128)',
108
- );
109
-
110
- // Arguments of the claim function call:
111
- // - args[0]: Amount recipient.
112
- // - args[1]: Amount being claimed.
113
- const claimFunctionCall = setupFns.find(
114
- fn =>
115
- fn.request.contractAddress.equals(this.#feeJuiceAddress) &&
116
- fn.request.msgSender.equals(this.#feeJuiceAddress) &&
117
- fn.calldata.length > 2 &&
118
- fn.functionSelector.equals(increasePublicBalanceSelector) &&
119
- fn.args[0].equals(feePayer.toField()) &&
120
- !fn.request.isStaticCall,
121
- );
110
+ const claimAmount = await getFeePayerClaimAmount(tx, this.#feeJuiceAddress);
111
+ const balance = initialBalance.toBigInt() + claimAmount;
122
112
 
123
- const balance = claimFunctionCall ? initialBalance.add(claimFunctionCall.args[1]) : initialBalance;
124
- if (balance.lt(feeLimit)) {
113
+ if (balance < feeLimit) {
125
114
  this.#log.verbose(`Rejecting transaction due to not enough fee payer balance`, {
126
115
  feePayer,
127
- balance: balance.toBigInt(),
128
- feeLimit: feeLimit.toBigInt(),
116
+ balance,
117
+ feeLimit,
129
118
  });
130
119
  return { result: 'invalid', reason: [TX_ERROR_INSUFFICIENT_FEE_PAYER_BALANCE] };
131
120
  }
@@ -11,3 +11,4 @@ export * from './allowed_public_setup.js';
11
11
  export * from './archive_cache.js';
12
12
  export * from './tx_permitted_validator.js';
13
13
  export * from './timestamp_validator.js';
14
+ export * from './size_validator.js';
@@ -1,5 +1,5 @@
1
1
  import type { Fr } from '@aztec/foundation/curves/bn254';
2
- import { createLogger } from '@aztec/foundation/log';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
3
  import {
4
4
  type AnyTx,
5
5
  TX_ERROR_INCORRECT_L1_CHAIN_ID,
@@ -11,7 +11,7 @@ import {
11
11
  } from '@aztec/stdlib/tx';
12
12
 
13
13
  export class MetadataTxValidator<T extends AnyTx> implements TxValidator<T> {
14
- #log = createLogger('p2p:tx_validator:tx_metadata');
14
+ #log: Logger;
15
15
 
16
16
  constructor(
17
17
  private values: {
@@ -20,7 +20,10 @@ export class MetadataTxValidator<T extends AnyTx> implements TxValidator<T> {
20
20
  vkTreeRoot: Fr;
21
21
  protocolContractsHash: Fr;
22
22
  },
23
- ) {}
23
+ bindings?: LoggerBindings,
24
+ ) {
25
+ this.#log = createLogger('p2p:tx_validator:tx_metadata', bindings);
26
+ }
24
27
 
25
28
  validateTx(tx: T): Promise<TxValidationResult> {
26
29
  const errors = [];
@@ -1,4 +1,4 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import { PublicContractsDB, getCallRequestsWithCalldataByPhase } from '@aztec/simulator/server';
3
3
  import type { ContractDataSource } from '@aztec/stdlib/contract';
4
4
  import type { AllowedElement } from '@aztec/stdlib/interfaces/server';
@@ -14,15 +14,17 @@ import {
14
14
  import type { UInt64 } from '@aztec/stdlib/types';
15
15
 
16
16
  export class PhasesTxValidator implements TxValidator<Tx> {
17
- #log = createLogger('sequencer:tx_validator:tx_phases');
17
+ #log: Logger;
18
18
  private contractsDB: PublicContractsDB;
19
19
 
20
20
  constructor(
21
21
  contracts: ContractDataSource,
22
22
  private setupAllowList: AllowedElement[],
23
23
  private timestamp: UInt64,
24
+ bindings?: LoggerBindings,
24
25
  ) {
25
- this.contractsDB = new PublicContractsDB(contracts);
26
+ this.#log = createLogger('sequencer:tx_validator:tx_phases', bindings);
27
+ this.contractsDB = new PublicContractsDB(contracts, bindings);
26
28
  }
27
29
 
28
30
  async validateTx(tx: Tx): Promise<TxValidationResult> {
@@ -0,0 +1,22 @@
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
+ import { MAX_TX_SIZE_KB } from '@aztec/stdlib/p2p';
3
+ import { Tx, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
+
5
+ export class SizeTxValidator implements TxValidator<Tx> {
6
+ #log: Logger;
7
+
8
+ constructor(bindings?: LoggerBindings) {
9
+ this.#log = createLogger('p2p:tx_validator:tx_size', bindings);
10
+ }
11
+
12
+ validateTx(tx: Tx): Promise<TxValidationResult> {
13
+ const txSize = tx.getSize();
14
+ if (txSize > MAX_TX_SIZE_KB * 1024) {
15
+ this.#log.verbose(
16
+ `Rejecting transaction ${tx.getTxHash().toString()}. Reason: size above size limit. ${txSize}bytes > ${MAX_TX_SIZE_KB}Kb`,
17
+ );
18
+ return Promise.resolve({ result: 'invalid', reason: ['Transaction size above size limit'] });
19
+ }
20
+ return Promise.resolve({ result: 'valid' });
21
+ }
22
+ }
@@ -1,16 +1,25 @@
1
- import { BlockNumber } from '@aztec/foundation/branded-types';
2
- import { createLogger } from '@aztec/foundation/log';
3
- import {
4
- type AnyTx,
5
- TX_ERROR_INVALID_INCLUDE_BY_TIMESTAMP,
6
- type TxValidationResult,
7
- type TxValidator,
8
- getTxHash,
9
- } from '@aztec/stdlib/tx';
1
+ import type { BlockNumber } from '@aztec/foundation/branded-types';
2
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
3
+ import { TX_ERROR_INVALID_EXPIRATION_TIMESTAMP, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
10
4
  import type { UInt64 } from '@aztec/stdlib/types';
11
5
 
12
- export class TimestampTxValidator<T extends AnyTx> implements TxValidator<T> {
13
- #log = createLogger('p2p:tx_validator:timestamp');
6
+ /** Structural interface for timestamp validation. */
7
+ export interface HasTimestampData {
8
+ txHash: { toString(): string };
9
+ data: {
10
+ expirationTimestamp: bigint;
11
+ constants: {
12
+ anchorBlockHeader: {
13
+ globalVariables: {
14
+ blockNumber: BlockNumber;
15
+ };
16
+ };
17
+ };
18
+ };
19
+ }
20
+
21
+ export class TimestampTxValidator<T extends HasTimestampData> implements TxValidator<T> {
22
+ #log: Logger;
14
23
 
15
24
  constructor(
16
25
  private values: {
@@ -20,28 +29,27 @@ export class TimestampTxValidator<T extends AnyTx> implements TxValidator<T> {
20
29
  // Block number in which the tx is considered to be included.
21
30
  blockNumber: BlockNumber;
22
31
  },
23
- ) {}
32
+ bindings?: LoggerBindings,
33
+ ) {
34
+ this.#log = createLogger('p2p:tx_validator:timestamp', bindings);
35
+ }
24
36
 
25
37
  validateTx(tx: T): Promise<TxValidationResult> {
26
- const includeByTimestamp = tx.data.includeByTimestamp;
27
- // If building block 1, we skip the expiration check. For details on why see the `validate_include_by_timestamp`
38
+ const expirationTimestamp = tx.data.expirationTimestamp;
39
+ // If building block 1, we skip the expiration check. For details on why see the `validate_expiration_timestamp`
28
40
  // function in `noir-projects/noir-protocol-circuits/crates/rollup-lib/src/base/components/validation_requests.nr`.
29
41
  const buildingBlock1 = this.values.blockNumber === 1;
30
42
 
31
- if (!buildingBlock1 && includeByTimestamp < this.values.timestamp) {
43
+ if (!buildingBlock1 && expirationTimestamp < this.values.timestamp) {
32
44
  if (tx.data.constants.anchorBlockHeader.globalVariables.blockNumber === 0) {
33
45
  this.#log.warn(
34
46
  `A tx built against a genesis block failed to be included in block 1 which is the only block in which txs built against a genesis block are allowed to be included.`,
35
47
  );
36
48
  }
37
49
  this.#log.verbose(
38
- `Rejecting tx ${getTxHash(
39
- tx,
40
- )} for low expiration timestamp. Tx expiration timestamp: ${includeByTimestamp}, timestamp: ${
41
- this.values.timestamp
42
- }.`,
50
+ `Rejecting tx ${tx.txHash} for low expiration timestamp. Tx expiration timestamp: ${expirationTimestamp}, timestamp: ${this.values.timestamp}.`,
43
51
  );
44
- return Promise.resolve({ result: 'invalid', reason: [TX_ERROR_INVALID_INCLUDE_BY_TIMESTAMP] });
52
+ return Promise.resolve({ result: 'invalid', reason: [TX_ERROR_INVALID_EXPIRATION_TIMESTAMP] });
45
53
  } else {
46
54
  return Promise.resolve({ result: 'valid' });
47
55
  }
@@ -1,10 +1,15 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import type { Tx, TxValidationResult, TxValidator } from '@aztec/stdlib/tx';
3
3
 
4
4
  export class TxPermittedValidator implements TxValidator<Tx> {
5
- #log = createLogger('p2p:tx_validator:tx_permitted');
5
+ #log: Logger;
6
6
 
7
- constructor(private permitted: boolean) {}
7
+ constructor(
8
+ private permitted: boolean,
9
+ bindings?: LoggerBindings,
10
+ ) {
11
+ this.#log = createLogger('p2p:tx_validator:tx_permitted', bindings);
12
+ }
8
13
 
9
14
  validateTx(tx: Tx): Promise<TxValidationResult> {
10
15
  if (!this.permitted) {
@@ -1,11 +1,16 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import type { ClientProtocolCircuitVerifier } from '@aztec/stdlib/interfaces/server';
3
3
  import { TX_ERROR_INVALID_PROOF, Tx, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
4
 
5
5
  export class TxProofValidator implements TxValidator<Tx> {
6
- #log = createLogger('p2p:tx_validator:private_proof');
6
+ #log: Logger;
7
7
 
8
- constructor(private verifier: ClientProtocolCircuitVerifier) {}
8
+ constructor(
9
+ private verifier: ClientProtocolCircuitVerifier,
10
+ bindings?: LoggerBindings,
11
+ ) {
12
+ this.#log = createLogger('p2p:tx_validator:proof', bindings);
13
+ }
9
14
 
10
15
  async validateTx(tx: Tx): Promise<TxValidationResult> {
11
16
  const result = await this.verifier.verifyProof(tx);
@@ -24,6 +24,7 @@ class KeyNotFoundError extends Error {
24
24
  }
25
25
 
26
26
  export class AztecDatastore implements Datastore {
27
+ #db: AztecAsyncKVStore;
27
28
  #memoryDatastore: Map<string, MemoryItem>;
28
29
  #dbDatastore: AztecAsyncMap<string, Uint8Array>;
29
30
 
@@ -32,9 +33,9 @@ export class AztecDatastore implements Datastore {
32
33
  private maxMemoryItems: number;
33
34
 
34
35
  constructor(db: AztecAsyncKVStore, { maxMemoryItems } = { maxMemoryItems: 50 }) {
36
+ this.#db = db;
35
37
  this.#memoryDatastore = new Map();
36
38
  this.#dbDatastore = db.openMap('p2p_datastore');
37
-
38
39
  this.maxMemoryItems = maxMemoryItems;
39
40
  }
40
41
 
@@ -106,13 +107,15 @@ export class AztecDatastore implements Datastore {
106
107
  });
107
108
  },
108
109
  commit: async () => {
109
- for (const op of this.#batchOps) {
110
- if (op.type === 'put' && op.value) {
111
- await this.put(op.key, op.value);
112
- } else if (op.type === 'del') {
113
- await this.delete(op.key);
110
+ await this.#db.transactionAsync(async () => {
111
+ for (const op of this.#batchOps) {
112
+ if (op.type === 'put' && op.value) {
113
+ await this.put(op.key, op.value);
114
+ } else if (op.type === 'del') {
115
+ await this.delete(op.key);
116
+ }
114
117
  }
115
- }
118
+ });
116
119
  this.#batchOps = []; // Clear operations after commit
117
120
  },
118
121
  };
@@ -87,7 +87,7 @@ export class DiscV5Service extends EventEmitter implements PeerDiscoveryService
87
87
  this.packageVersion,
88
88
  ));
89
89
 
90
- const metricsRegistry = new OtelMetricsAdapter(telemetry);
90
+ const metricsRegistry = new OtelMetricsAdapter(telemetry, this.logger.getBindings());
91
91
  this.discv5 = Discv5.create({
92
92
  enr: this.enr,
93
93
  peerId,