@aztec/p2p 0.0.1-commit.3469e52 → 0.0.1-commit.381b1a9

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 (508) 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 +10 -10
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +50 -18
  7. package/dest/client/interface.d.ts +46 -33
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +41 -51
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +162 -224
  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 +304 -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 +60 -11
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +101 -33
  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 +353 -87
  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 +2 -2
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  38. package/dest/mem_pools/attestation_pool/mocks.js +2 -2
  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 +3 -3
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +3 -2
  50. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -1
  51. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +3 -2
  52. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -1
  53. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +3 -3
  54. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -1
  55. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +8 -1
  56. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +3 -3
  57. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +3 -3
  58. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -1
  59. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +2 -0
  60. package/dest/mem_pools/tx_pool/priority.d.ts +2 -2
  61. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  62. package/dest/mem_pools/tx_pool/priority.js +4 -4
  63. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  64. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  65. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +3 -1
  66. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  67. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  69. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  70. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  72. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  73. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  75. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  76. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  77. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  78. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  79. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  80. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +93 -0
  81. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  82. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  83. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  84. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  85. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  90. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  105. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  106. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  107. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  108. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  109. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  110. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  111. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +211 -0
  112. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  113. package/dest/mem_pools/tx_pool_v2/interfaces.js +9 -0
  114. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +128 -0
  115. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  116. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +210 -0
  117. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  118. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  119. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  120. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  121. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  122. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +354 -0
  123. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +60 -0
  124. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  125. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +161 -0
  126. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +77 -0
  127. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  128. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +899 -0
  129. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +3 -3
  130. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  131. package/dest/msg_validators/attestation_validator/attestation_validator.js +40 -9
  132. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  133. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  134. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -6
  135. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  136. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  137. package/dest/msg_validators/clock_tolerance.js +37 -0
  138. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +6 -4
  139. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  140. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  141. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +6 -4
  142. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  143. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  144. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -8
  145. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  146. package/dest/msg_validators/proposal_validator/proposal_validator.js +81 -38
  147. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  148. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  149. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  150. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  151. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  152. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  153. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  154. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  155. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  156. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  157. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  158. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  159. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  160. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  161. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  162. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  163. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  164. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  165. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  166. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  167. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  168. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  169. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  170. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  171. package/dest/msg_validators/tx_validator/factory.d.ts +129 -5
  172. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  173. package/dest/msg_validators/tx_validator/factory.js +241 -57
  174. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
  175. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
  176. package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
  177. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  178. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  179. package/dest/msg_validators/tx_validator/gas_validator.js +106 -38
  180. package/dest/msg_validators/tx_validator/index.d.ts +3 -1
  181. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  182. package/dest/msg_validators/tx_validator/index.js +2 -0
  183. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  184. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  185. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  186. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  187. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  188. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  189. package/dest/msg_validators/tx_validator/phases_validator.d.ts +4 -3
  190. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  191. package/dest/msg_validators/tx_validator/phases_validator.js +47 -26
  192. package/dest/msg_validators/tx_validator/size_validator.d.ts +3 -1
  193. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -1
  194. package/dest/msg_validators/tx_validator/size_validator.js +4 -1
  195. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  196. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  197. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  198. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  199. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  200. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  201. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  202. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  203. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  204. package/dest/services/data_store.d.ts +1 -1
  205. package/dest/services/data_store.d.ts.map +1 -1
  206. package/dest/services/data_store.js +10 -6
  207. package/dest/services/discv5/discV5_service.js +1 -1
  208. package/dest/services/dummy_service.d.ts +24 -4
  209. package/dest/services/dummy_service.d.ts.map +1 -1
  210. package/dest/services/dummy_service.js +46 -1
  211. package/dest/services/encoding.d.ts +3 -3
  212. package/dest/services/encoding.d.ts.map +1 -1
  213. package/dest/services/encoding.js +11 -10
  214. package/dest/services/gossipsub/index.d.ts +3 -0
  215. package/dest/services/gossipsub/index.d.ts.map +1 -0
  216. package/dest/services/gossipsub/index.js +2 -0
  217. package/dest/services/gossipsub/scoring.d.ts +21 -3
  218. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  219. package/dest/services/gossipsub/scoring.js +24 -7
  220. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  221. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  222. package/dest/services/gossipsub/topic_score_params.js +346 -0
  223. package/dest/services/index.d.ts +2 -1
  224. package/dest/services/index.d.ts.map +1 -1
  225. package/dest/services/index.js +1 -0
  226. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  227. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  228. package/dest/services/libp2p/instrumentation.js +14 -3
  229. package/dest/services/libp2p/libp2p_service.d.ts +101 -43
  230. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  231. package/dest/services/libp2p/libp2p_service.js +478 -375
  232. package/dest/services/peer-manager/metrics.d.ts +2 -2
  233. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  234. package/dest/services/peer-manager/metrics.js +20 -5
  235. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  236. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  237. package/dest/services/peer-manager/peer_scoring.js +33 -4
  238. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +48 -0
  239. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  240. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +562 -0
  241. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  242. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  243. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  244. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +46 -0
  245. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  246. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  247. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +34 -0
  248. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  249. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +130 -0
  250. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  251. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  252. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  253. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  254. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  255. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  256. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  257. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  258. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  259. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  260. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  261. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  262. package/dest/services/reqresp/interface.d.ts +14 -3
  263. package/dest/services/reqresp/interface.d.ts.map +1 -1
  264. package/dest/services/reqresp/interface.js +17 -3
  265. package/dest/services/reqresp/metrics.d.ts +6 -5
  266. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  267. package/dest/services/reqresp/metrics.js +17 -5
  268. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  269. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  270. package/dest/services/reqresp/protocols/block_txs/bitvector.js +5 -0
  271. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  272. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  273. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  274. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  275. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  276. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  277. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  278. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  279. package/dest/services/reqresp/protocols/tx.js +20 -0
  280. package/dest/services/reqresp/reqresp.d.ts +6 -1
  281. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  282. package/dest/services/reqresp/reqresp.js +69 -26
  283. package/dest/services/service.d.ts +42 -3
  284. package/dest/services/service.d.ts.map +1 -1
  285. package/dest/services/tx_collection/config.d.ts +22 -1
  286. package/dest/services/tx_collection/config.d.ts.map +1 -1
  287. package/dest/services/tx_collection/config.js +55 -1
  288. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  289. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  290. package/dest/services/tx_collection/fast_tx_collection.js +71 -44
  291. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  292. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  293. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  294. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  295. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  296. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  297. package/dest/services/tx_collection/index.d.ts +3 -1
  298. package/dest/services/tx_collection/index.d.ts.map +1 -1
  299. package/dest/services/tx_collection/index.js +2 -0
  300. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  301. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  302. package/dest/services/tx_collection/instrumentation.js +10 -2
  303. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  304. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  305. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  306. package/dest/services/tx_collection/proposal_tx_collector.d.ts +49 -0
  307. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  308. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  309. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  310. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  311. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  312. package/dest/services/tx_collection/tx_collection.d.ts +29 -16
  313. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  314. package/dest/services/tx_collection/tx_collection.js +79 -7
  315. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  316. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  317. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  318. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  319. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  320. package/dest/services/tx_collection/tx_source.js +19 -2
  321. package/dest/services/tx_file_store/config.d.ts +16 -0
  322. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  323. package/dest/services/tx_file_store/config.js +22 -0
  324. package/dest/services/tx_file_store/index.d.ts +4 -0
  325. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  326. package/dest/services/tx_file_store/index.js +3 -0
  327. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  328. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  329. package/dest/services/tx_file_store/instrumentation.js +29 -0
  330. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  331. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  332. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  333. package/dest/services/tx_provider.d.ts +6 -6
  334. package/dest/services/tx_provider.d.ts.map +1 -1
  335. package/dest/services/tx_provider.js +9 -8
  336. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  337. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  338. package/dest/services/tx_provider_instrumentation.js +5 -5
  339. package/dest/test-helpers/index.d.ts +3 -1
  340. package/dest/test-helpers/index.d.ts.map +1 -1
  341. package/dest/test-helpers/index.js +2 -0
  342. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  343. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  344. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  345. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  346. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  347. package/dest/test-helpers/mock-pubsub.js +105 -4
  348. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  349. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  350. package/dest/test-helpers/reqresp-nodes.js +4 -3
  351. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  352. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  353. package/dest/test-helpers/test_tx_provider.js +41 -0
  354. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  355. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  356. package/dest/test-helpers/testbench-utils.js +367 -0
  357. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  358. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  359. package/dest/testbench/p2p_client_testbench_worker.js +221 -138
  360. package/dest/testbench/worker_client_manager.d.ts +53 -6
  361. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  362. package/dest/testbench/worker_client_manager.js +230 -45
  363. package/dest/util.d.ts +2 -2
  364. package/dest/util.d.ts.map +1 -1
  365. package/package.json +14 -14
  366. package/src/bootstrap/bootstrap.ts +7 -4
  367. package/src/client/factory.ts +89 -36
  368. package/src/client/interface.ts +56 -34
  369. package/src/client/p2p_client.ts +197 -273
  370. package/src/client/test/tx_proposal_collector/README.md +227 -0
  371. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +345 -0
  372. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  373. package/src/config.ts +160 -34
  374. package/src/errors/tx-pool.error.ts +12 -0
  375. package/src/index.ts +1 -0
  376. package/src/mem_pools/attestation_pool/attestation_pool.ts +496 -91
  377. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +442 -102
  378. package/src/mem_pools/attestation_pool/index.ts +9 -2
  379. package/src/mem_pools/attestation_pool/mocks.ts +2 -1
  380. package/src/mem_pools/index.ts +4 -1
  381. package/src/mem_pools/instrumentation.ts +2 -1
  382. package/src/mem_pools/interface.ts +4 -4
  383. package/src/mem_pools/tx_pool/README.md +1 -1
  384. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +2 -2
  385. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +2 -1
  386. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +2 -1
  387. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +10 -7
  388. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  389. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  390. package/src/mem_pools/tx_pool/priority.ts +4 -4
  391. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +3 -1
  392. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  393. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  394. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  395. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  396. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  397. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  398. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  399. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  400. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  401. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  402. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  403. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  404. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  405. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  406. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  407. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  408. package/src/mem_pools/tx_pool_v2/interfaces.ts +242 -0
  409. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +327 -0
  410. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  411. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +444 -0
  412. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +223 -0
  413. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1079 -0
  414. package/src/msg_validators/attestation_validator/attestation_validator.ts +25 -13
  415. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  416. package/src/msg_validators/clock_tolerance.ts +51 -0
  417. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +14 -4
  418. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +20 -7
  419. package/src/msg_validators/proposal_validator/proposal_validator.ts +78 -48
  420. package/src/msg_validators/tx_validator/README.md +115 -0
  421. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  422. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  423. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  424. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  425. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  426. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  427. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  428. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  429. package/src/msg_validators/tx_validator/factory.ts +392 -55
  430. package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
  431. package/src/msg_validators/tx_validator/gas_validator.ts +132 -30
  432. package/src/msg_validators/tx_validator/index.ts +2 -0
  433. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  434. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  435. package/src/msg_validators/tx_validator/phases_validator.ts +56 -29
  436. package/src/msg_validators/tx_validator/size_validator.ts +6 -2
  437. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  438. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  439. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  440. package/src/services/data_store.ts +10 -7
  441. package/src/services/discv5/discV5_service.ts +1 -1
  442. package/src/services/dummy_service.ts +59 -2
  443. package/src/services/encoding.ts +9 -9
  444. package/src/services/gossipsub/README.md +641 -0
  445. package/src/services/gossipsub/index.ts +2 -0
  446. package/src/services/gossipsub/scoring.ts +29 -5
  447. package/src/services/gossipsub/topic_score_params.ts +487 -0
  448. package/src/services/index.ts +1 -0
  449. package/src/services/libp2p/instrumentation.ts +15 -2
  450. package/src/services/libp2p/libp2p_service.ts +531 -407
  451. package/src/services/peer-manager/metrics.ts +21 -4
  452. package/src/services/peer-manager/peer_scoring.ts +29 -1
  453. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  454. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  455. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  456. package/src/services/reqresp/batch-tx-requester/interface.ts +53 -0
  457. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +161 -0
  458. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  459. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  460. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  461. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  462. package/src/services/reqresp/interface.ts +31 -3
  463. package/src/services/reqresp/metrics.ts +34 -9
  464. package/src/services/reqresp/protocols/block_txs/bitvector.ts +7 -0
  465. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  466. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  467. package/src/services/reqresp/protocols/tx.ts +22 -0
  468. package/src/services/reqresp/reqresp.ts +79 -22
  469. package/src/services/service.ts +55 -2
  470. package/src/services/tx_collection/config.ts +83 -1
  471. package/src/services/tx_collection/fast_tx_collection.ts +93 -47
  472. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  473. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  474. package/src/services/tx_collection/index.ts +6 -0
  475. package/src/services/tx_collection/instrumentation.ts +17 -2
  476. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  477. package/src/services/tx_collection/proposal_tx_collector.ts +113 -0
  478. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  479. package/src/services/tx_collection/tx_collection.ts +121 -24
  480. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  481. package/src/services/tx_collection/tx_source.ts +22 -3
  482. package/src/services/tx_file_store/config.ts +37 -0
  483. package/src/services/tx_file_store/index.ts +3 -0
  484. package/src/services/tx_file_store/instrumentation.ts +36 -0
  485. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  486. package/src/services/tx_provider.ts +12 -11
  487. package/src/services/tx_provider_instrumentation.ts +11 -5
  488. package/src/test-helpers/index.ts +2 -0
  489. package/src/test-helpers/make-test-p2p-clients.ts +3 -5
  490. package/src/test-helpers/mock-pubsub.ts +146 -9
  491. package/src/test-helpers/reqresp-nodes.ts +4 -6
  492. package/src/test-helpers/test_tx_provider.ts +64 -0
  493. package/src/test-helpers/testbench-utils.ts +431 -0
  494. package/src/testbench/p2p_client_testbench_worker.ts +334 -131
  495. package/src/testbench/worker_client_manager.ts +311 -47
  496. package/src/util.ts +7 -1
  497. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  498. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  499. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  500. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  501. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  502. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  503. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  504. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  505. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -157
  506. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  507. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  508. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -191
@@ -0,0 +1,31 @@
1
+ import type { Fr } from '@aztec/foundation/curves/bn254';
2
+ import { FunctionSelector, countArgumentsSize, getAllFunctionAbis } from '@aztec/stdlib/abi';
3
+ import type { ContractArtifact } from '@aztec/stdlib/abi';
4
+ import type { AztecAddress } from '@aztec/stdlib/aztec-address';
5
+ import type { AllowedElement } from '@aztec/stdlib/interfaces/server';
6
+
7
+ /**
8
+ * Builds an AllowedElement from a contract artifact, deriving both the function selector
9
+ * and calldata length from the artifact instead of hardcoding signature strings.
10
+ */
11
+ export async function buildAllowedElement(
12
+ artifact: ContractArtifact,
13
+ target: { address: AztecAddress } | { classId: Fr },
14
+ functionName: string,
15
+ opts?: { onlySelf?: boolean; rejectNullMsgSender?: boolean },
16
+ ): Promise<AllowedElement> {
17
+ const allFunctions = getAllFunctionAbis(artifact);
18
+ const fn = allFunctions.find(f => f.name === functionName);
19
+ if (!fn) {
20
+ throw new Error(`Unknown function ${functionName} in artifact ${artifact.name}`);
21
+ }
22
+ const selector = await FunctionSelector.fromNameAndParameters(fn.name, fn.parameters);
23
+ const calldataLength = 1 + countArgumentsSize(fn);
24
+ return {
25
+ ...target,
26
+ selector,
27
+ calldataLength,
28
+ ...(opts?.onlySelf ? { onlySelf: true } : {}),
29
+ ...(opts?.rejectNullMsgSender ? { rejectNullMsgSender: true } : {}),
30
+ } as AllowedElement;
31
+ }
@@ -1,5 +1,5 @@
1
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
1
  import type { ArchiveSource } from '@aztec/p2p';
2
+ import type { BlockHash } from '@aztec/stdlib/block';
3
3
  import type { MerkleTreeReadOperations } from '@aztec/stdlib/interfaces/server';
4
4
  import { MerkleTreeId } from '@aztec/stdlib/trees';
5
5
 
@@ -14,8 +14,8 @@ export class ArchiveCache implements ArchiveSource {
14
14
  this.archives = new Map<string, bigint>();
15
15
  }
16
16
 
17
- public async getArchiveIndices(archives: Fr[]): Promise<(bigint | undefined)[]> {
18
- const toCheckDb = archives.filter(n => !this.archives.has(n.toString()));
17
+ public async getArchiveIndices(archives: BlockHash[]): Promise<(bigint | undefined)[]> {
18
+ const toCheckDb = archives.filter(n => !this.archives.has(n.toString())).map(n => n.toFr());
19
19
  const dbHits = await this.db.findLeafIndices(MerkleTreeId.ARCHIVE, toCheckDb);
20
20
  dbHits.forEach((x, index) => {
21
21
  if (x !== undefined) {
@@ -1,23 +1,36 @@
1
- import type { Fr } from '@aztec/foundation/curves/bn254';
2
- import { createLogger } from '@aztec/foundation/log';
3
- import { type AnyTx, TX_ERROR_BLOCK_HEADER, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
+ import type { BlockHash } from '@aztec/stdlib/block';
3
+ import { TX_ERROR_BLOCK_HEADER, type TxValidationResult, type TxValidator } from '@aztec/stdlib/tx';
4
4
 
5
5
  export interface ArchiveSource {
6
- getArchiveIndices: (archives: Fr[]) => Promise<(bigint | undefined)[]>;
6
+ getArchiveIndices: (archives: BlockHash[]) => Promise<(bigint | undefined)[]>;
7
7
  }
8
8
 
9
- export class BlockHeaderTxValidator<T extends AnyTx> implements TxValidator<T> {
10
- #log = createLogger('p2p:tx_validator:tx_block_header');
9
+ /** Structural interface for block header validation. */
10
+ export interface HasBlockHeaderData {
11
+ txHash: { toString(): string };
12
+ data: {
13
+ constants: {
14
+ anchorBlockHeader: {
15
+ hash(): Promise<BlockHash>;
16
+ };
17
+ };
18
+ };
19
+ }
20
+
21
+ export class BlockHeaderTxValidator<T extends HasBlockHeaderData> implements TxValidator<T> {
22
+ #log: Logger;
11
23
  #archiveSource: ArchiveSource;
12
24
 
13
- constructor(archiveSource: ArchiveSource) {
25
+ constructor(archiveSource: ArchiveSource, bindings?: LoggerBindings) {
14
26
  this.#archiveSource = archiveSource;
27
+ this.#log = createLogger('p2p:tx_validator:tx_block_header', bindings);
15
28
  }
16
29
 
17
30
  async validateTx(tx: T): Promise<TxValidationResult> {
18
31
  const [index] = await this.#archiveSource.getArchiveIndices([await tx.data.constants.anchorBlockHeader.hash()]);
19
32
  if (index === undefined) {
20
- this.#log.verbose(`Rejecting tx ${'txHash' in tx ? tx.txHash : tx.hash} for referencing an unknown block header`);
33
+ this.#log.verbose(`Rejecting tx ${tx.txHash} for referencing an unknown block header`);
21
34
  return { result: 'invalid', reason: [TX_ERROR_BLOCK_HEADER] };
22
35
  }
23
36
  return { result: 'valid' };
@@ -0,0 +1,56 @@
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
+ import { ContractInstancePublishedEvent } from '@aztec/protocol-contracts/instance-registry';
3
+ import { computeContractAddressFromInstance } from '@aztec/stdlib/contract';
4
+ import {
5
+ TX_ERROR_INCORRECT_CONTRACT_ADDRESS,
6
+ TX_ERROR_MALFORMED_CONTRACT_INSTANCE_LOG,
7
+ type Tx,
8
+ type TxValidationResult,
9
+ type TxValidator,
10
+ } from '@aztec/stdlib/tx';
11
+
12
+ /** Validates that contract instance deployment logs contain correct addresses. */
13
+ export class ContractInstanceTxValidator implements TxValidator<Tx> {
14
+ #log: Logger;
15
+
16
+ constructor(bindings?: LoggerBindings) {
17
+ this.#log = createLogger('p2p:tx_validator:contract_instance', bindings);
18
+ }
19
+
20
+ async validateTx(tx: Tx): Promise<TxValidationResult> {
21
+ const reason = await this.#hasCorrectContractInstanceAddresses(tx);
22
+ return reason ? { result: 'invalid', reason: [reason] } : { result: 'valid' };
23
+ }
24
+
25
+ async #hasCorrectContractInstanceAddresses(tx: Tx): Promise<string | undefined> {
26
+ const privateLogs = tx.data.getNonEmptyPrivateLogs();
27
+ for (const log of privateLogs) {
28
+ if (!ContractInstancePublishedEvent.isContractInstancePublishedEvent(log)) {
29
+ continue;
30
+ }
31
+
32
+ let event;
33
+ try {
34
+ event = ContractInstancePublishedEvent.fromLog(log);
35
+ } catch (e) {
36
+ this.#log.warn(`Rejecting tx ${tx.getTxHash()}: failed to parse contract instance event: ${e}`);
37
+ return TX_ERROR_MALFORMED_CONTRACT_INSTANCE_LOG;
38
+ }
39
+
40
+ try {
41
+ const instance = event.toContractInstance();
42
+ const computedAddress = await computeContractAddressFromInstance(instance);
43
+ if (!computedAddress.equals(instance.address)) {
44
+ this.#log.warn(
45
+ `Rejecting tx ${tx.getTxHash()}: contract instance address mismatch. Claimed ${instance.address}, computed ${computedAddress}`,
46
+ );
47
+ return TX_ERROR_INCORRECT_CONTRACT_ADDRESS;
48
+ }
49
+ } catch (e) {
50
+ this.#log.warn(`Rejecting tx ${tx.getTxHash()}: failed to compute contract instance address: ${e}`);
51
+ return TX_ERROR_MALFORMED_CONTRACT_INSTANCE_LOG;
52
+ }
53
+ }
54
+ return undefined;
55
+ }
56
+ }
@@ -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