@aztec/p2p 0.0.1-commit.dbf9cec → 0.0.1-commit.ddcf04837

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 (339) hide show
  1. package/README.md +129 -3
  2. package/dest/client/factory.d.ts +2 -2
  3. package/dest/client/factory.d.ts.map +1 -1
  4. package/dest/client/factory.js +25 -11
  5. package/dest/client/interface.d.ts +9 -2
  6. package/dest/client/interface.d.ts.map +1 -1
  7. package/dest/client/p2p_client.d.ts +3 -2
  8. package/dest/client/p2p_client.d.ts.map +1 -1
  9. package/dest/client/p2p_client.js +46 -38
  10. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +17 -6
  11. package/dest/config.d.ts +125 -100
  12. package/dest/config.d.ts.map +1 -1
  13. package/dest/config.js +92 -33
  14. package/dest/errors/p2p-service.error.d.ts +9 -0
  15. package/dest/errors/p2p-service.error.d.ts.map +1 -0
  16. package/dest/errors/p2p-service.error.js +10 -0
  17. package/dest/index.d.ts +1 -2
  18. package/dest/index.d.ts.map +1 -1
  19. package/dest/index.js +0 -1
  20. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +7 -5
  21. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  22. package/dest/mem_pools/attestation_pool/attestation_pool.js +16 -9
  23. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +6 -6
  24. package/dest/mem_pools/index.d.ts +1 -2
  25. package/dest/mem_pools/index.d.ts.map +1 -1
  26. package/dest/mem_pools/instrumentation.d.ts +4 -2
  27. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  28. package/dest/mem_pools/instrumentation.js +16 -14
  29. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +1 -1
  30. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -1
  31. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +2 -1
  32. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +7 -1
  33. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -1
  34. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +2 -2
  35. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +1 -1
  36. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -1
  37. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +8 -6
  38. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +2 -2
  39. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -1
  40. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +2 -2
  41. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +9 -5
  42. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -1
  43. package/dest/mem_pools/tx_pool_v2/interfaces.js +2 -1
  44. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +25 -10
  45. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -1
  46. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +39 -12
  47. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +1 -1
  48. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +26 -43
  50. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +4 -2
  51. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -1
  52. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +6 -0
  53. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +2 -1
  54. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -1
  55. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +24 -6
  56. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +5 -2
  57. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  58. package/dest/msg_validators/attestation_validator/attestation_validator.js +20 -11
  59. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +4 -2
  60. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  61. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +2 -2
  62. package/dest/msg_validators/clock_tolerance.d.ts +12 -1
  63. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -1
  64. package/dest/msg_validators/clock_tolerance.js +54 -3
  65. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +7 -4
  66. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  67. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  68. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +7 -4
  69. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  70. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  71. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +15 -8
  72. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  73. package/dest/msg_validators/proposal_validator/proposal_validator.js +67 -47
  74. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  75. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  76. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  77. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  78. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  79. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  80. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  81. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  82. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  83. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  84. package/dest/msg_validators/tx_validator/data_validator.d.ts +1 -1
  85. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  86. package/dest/msg_validators/tx_validator/data_validator.js +35 -2
  87. package/dest/msg_validators/tx_validator/factory.d.ts +23 -4
  88. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  89. package/dest/msg_validators/tx_validator/factory.js +36 -10
  90. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
  91. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
  92. package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
  93. package/dest/msg_validators/tx_validator/gas_validator.d.ts +13 -4
  94. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  95. package/dest/msg_validators/tx_validator/gas_validator.js +49 -17
  96. package/dest/msg_validators/tx_validator/index.d.ts +2 -1
  97. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  98. package/dest/msg_validators/tx_validator/index.js +1 -0
  99. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +1 -1
  100. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  101. package/dest/msg_validators/tx_validator/metadata_validator.js +4 -4
  102. package/dest/msg_validators/tx_validator/phases_validator.d.ts +22 -2
  103. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  104. package/dest/msg_validators/tx_validator/phases_validator.js +72 -24
  105. package/dest/services/data_store.d.ts +1 -1
  106. package/dest/services/data_store.d.ts.map +1 -1
  107. package/dest/services/data_store.js +5 -5
  108. package/dest/services/dummy_service.d.ts +6 -3
  109. package/dest/services/dummy_service.d.ts.map +1 -1
  110. package/dest/services/dummy_service.js +6 -1
  111. package/dest/services/encoding.d.ts +5 -1
  112. package/dest/services/encoding.d.ts.map +1 -1
  113. package/dest/services/encoding.js +7 -1
  114. package/dest/services/gossipsub/topic_score_params.d.ts +13 -2
  115. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -1
  116. package/dest/services/gossipsub/topic_score_params.js +21 -4
  117. package/dest/services/libp2p/libp2p_service.d.ts +15 -25
  118. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  119. package/dest/services/libp2p/libp2p_service.js +165 -126
  120. package/dest/services/peer-manager/metrics.d.ts +3 -1
  121. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  122. package/dest/services/peer-manager/metrics.js +6 -0
  123. package/dest/services/peer-manager/peer_manager.d.ts +6 -2
  124. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  125. package/dest/services/peer-manager/peer_manager.js +39 -11
  126. package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
  127. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  128. package/dest/services/peer-manager/peer_scoring.js +32 -10
  129. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +11 -8
  130. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -1
  131. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +69 -65
  132. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +3 -2
  133. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -1
  134. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +5 -4
  135. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -1
  136. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +13 -7
  137. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +3 -1
  138. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -1
  139. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +3 -0
  140. package/dest/services/reqresp/config.d.ts +3 -3
  141. package/dest/services/reqresp/config.d.ts.map +1 -1
  142. package/dest/services/reqresp/interface.d.ts +14 -9
  143. package/dest/services/reqresp/interface.d.ts.map +1 -1
  144. package/dest/services/reqresp/interface.js +10 -11
  145. package/dest/services/reqresp/metrics.d.ts +1 -1
  146. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  147. package/dest/services/reqresp/metrics.js +0 -1
  148. package/dest/services/reqresp/protocols/index.d.ts +1 -2
  149. package/dest/services/reqresp/protocols/index.d.ts.map +1 -1
  150. package/dest/services/reqresp/protocols/index.js +0 -1
  151. package/dest/services/reqresp/protocols/tx.d.ts +1 -1
  152. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  153. package/dest/services/reqresp/protocols/tx.js +1 -3
  154. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +5 -4
  155. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
  156. package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -8
  157. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
  158. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -1
  159. package/dest/services/reqresp/rate-limiter/rate_limits.js +0 -10
  160. package/dest/services/reqresp/reqresp.d.ts +4 -2
  161. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  162. package/dest/services/reqresp/reqresp.js +28 -11
  163. package/dest/services/service.d.ts +5 -2
  164. package/dest/services/service.d.ts.map +1 -1
  165. package/dest/services/tx_collection/fast_tx_collection.d.ts +1 -4
  166. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  167. package/dest/services/tx_collection/fast_tx_collection.js +57 -73
  168. package/dest/services/tx_collection/file_store_tx_source.d.ts +5 -4
  169. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -1
  170. package/dest/services/tx_collection/file_store_tx_source.js +39 -29
  171. package/dest/services/tx_collection/proposal_tx_collector.d.ts +6 -7
  172. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -1
  173. package/dest/services/tx_collection/proposal_tx_collector.js +4 -4
  174. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  175. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  176. package/dest/services/tx_collection/request_tracker.js +84 -0
  177. package/dest/services/tx_collection/slow_tx_collection.js +1 -1
  178. package/dest/services/tx_collection/tx_collection.d.ts +3 -6
  179. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  180. package/dest/services/tx_collection/tx_source.d.ts +6 -5
  181. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  182. package/dest/services/tx_collection/tx_source.js +9 -7
  183. package/dest/test-helpers/make-test-p2p-clients.d.ts +1 -1
  184. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  185. package/dest/test-helpers/mock-pubsub.d.ts +11 -3
  186. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  187. package/dest/test-helpers/mock-pubsub.js +35 -10
  188. package/dest/test-helpers/reqresp-nodes.d.ts +1 -1
  189. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  190. package/dest/test-helpers/reqresp-nodes.js +1 -2
  191. package/dest/test-helpers/testbench-utils.d.ts +1 -1
  192. package/dest/test-helpers/testbench-utils.d.ts.map +1 -1
  193. package/dest/test-helpers/testbench-utils.js +23 -3
  194. package/dest/testbench/p2p_client_testbench_worker.js +68 -16
  195. package/dest/testbench/worker_client_manager.d.ts +10 -1
  196. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  197. package/dest/testbench/worker_client_manager.js +55 -3
  198. package/dest/util.d.ts +1 -1
  199. package/package.json +14 -14
  200. package/src/client/factory.ts +43 -14
  201. package/src/client/interface.ts +9 -1
  202. package/src/client/p2p_client.ts +50 -39
  203. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +19 -9
  204. package/src/config.ts +137 -35
  205. package/src/errors/p2p-service.error.ts +11 -0
  206. package/src/index.ts +0 -1
  207. package/src/mem_pools/attestation_pool/attestation_pool.ts +17 -12
  208. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +6 -6
  209. package/src/mem_pools/index.ts +0 -3
  210. package/src/mem_pools/instrumentation.ts +17 -13
  211. package/src/mem_pools/tx_pool_v2/README.md +9 -1
  212. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +2 -1
  213. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +11 -1
  214. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +3 -3
  215. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +15 -6
  216. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +2 -1
  217. package/src/mem_pools/tx_pool_v2/interfaces.ts +9 -4
  218. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +60 -14
  219. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +29 -43
  220. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +16 -1
  221. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +28 -6
  222. package/src/msg_validators/attestation_validator/README.md +49 -0
  223. package/src/msg_validators/attestation_validator/attestation_validator.ts +21 -9
  224. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +4 -1
  225. package/src/msg_validators/clock_tolerance.ts +72 -3
  226. package/src/msg_validators/proposal_validator/README.md +123 -0
  227. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +17 -4
  228. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +23 -7
  229. package/src/msg_validators/proposal_validator/proposal_validator.ts +79 -49
  230. package/src/msg_validators/tx_validator/README.md +5 -1
  231. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  232. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  233. package/src/msg_validators/tx_validator/archive_cache.ts +1 -1
  234. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  235. package/src/msg_validators/tx_validator/data_validator.ts +42 -1
  236. package/src/msg_validators/tx_validator/factory.ts +43 -3
  237. package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
  238. package/src/msg_validators/tx_validator/gas_validator.ts +65 -16
  239. package/src/msg_validators/tx_validator/index.ts +1 -0
  240. package/src/msg_validators/tx_validator/metadata_validator.ts +12 -4
  241. package/src/msg_validators/tx_validator/phases_validator.ts +82 -27
  242. package/src/services/data_store.ts +5 -13
  243. package/src/services/dummy_service.ts +8 -2
  244. package/src/services/encoding.ts +9 -1
  245. package/src/services/gossipsub/topic_score_params.ts +36 -4
  246. package/src/services/libp2p/libp2p_service.ts +164 -139
  247. package/src/services/peer-manager/metrics.ts +7 -0
  248. package/src/services/peer-manager/peer_manager.ts +45 -11
  249. package/src/services/peer-manager/peer_scoring.ts +27 -5
  250. package/src/services/reqresp/README.md +229 -0
  251. package/src/services/reqresp/batch-tx-requester/README.md +46 -7
  252. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +64 -69
  253. package/src/services/reqresp/batch-tx-requester/interface.ts +2 -1
  254. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +13 -6
  255. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +5 -0
  256. package/src/services/reqresp/config.ts +2 -2
  257. package/src/services/reqresp/interface.ts +21 -11
  258. package/src/services/reqresp/metrics.ts +0 -1
  259. package/src/services/reqresp/protocols/index.ts +0 -1
  260. package/src/services/reqresp/protocols/tx.ts +1 -3
  261. package/src/services/reqresp/rate-limiter/rate_limiter.ts +13 -9
  262. package/src/services/reqresp/rate-limiter/rate_limits.ts +0 -10
  263. package/src/services/reqresp/reqresp.ts +37 -12
  264. package/src/services/service.ts +6 -1
  265. package/src/services/tx_collection/fast_tx_collection.ts +57 -83
  266. package/src/services/tx_collection/file_store_tx_source.ts +43 -31
  267. package/src/services/tx_collection/proposal_tx_collector.ts +8 -13
  268. package/src/services/tx_collection/request_tracker.ts +127 -0
  269. package/src/services/tx_collection/slow_tx_collection.ts +1 -1
  270. package/src/services/tx_collection/tx_collection.ts +3 -5
  271. package/src/services/tx_collection/tx_source.ts +8 -7
  272. package/src/test-helpers/make-test-p2p-clients.ts +1 -1
  273. package/src/test-helpers/mock-pubsub.ts +31 -5
  274. package/src/test-helpers/reqresp-nodes.ts +3 -3
  275. package/src/test-helpers/testbench-utils.ts +30 -3
  276. package/src/testbench/p2p_client_testbench_worker.ts +72 -15
  277. package/src/testbench/worker_client_manager.ts +68 -6
  278. package/src/util.ts +1 -1
  279. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +0 -125
  280. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +0 -1
  281. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +0 -596
  282. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +0 -32
  283. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +0 -1
  284. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +0 -112
  285. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +0 -157
  286. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +0 -1
  287. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +0 -52
  288. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +0 -16
  289. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +0 -1
  290. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +0 -122
  291. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +0 -17
  292. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +0 -1
  293. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +0 -84
  294. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +0 -19
  295. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +0 -1
  296. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +0 -78
  297. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +0 -26
  298. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +0 -1
  299. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +0 -84
  300. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +0 -25
  301. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +0 -1
  302. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +0 -57
  303. package/dest/mem_pools/tx_pool/index.d.ts +0 -3
  304. package/dest/mem_pools/tx_pool/index.d.ts.map +0 -1
  305. package/dest/mem_pools/tx_pool/index.js +0 -2
  306. package/dest/mem_pools/tx_pool/priority.d.ts +0 -12
  307. package/dest/mem_pools/tx_pool/priority.d.ts.map +0 -1
  308. package/dest/mem_pools/tx_pool/priority.js +0 -15
  309. package/dest/mem_pools/tx_pool/tx_pool.d.ts +0 -127
  310. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +0 -1
  311. package/dest/mem_pools/tx_pool/tx_pool.js +0 -3
  312. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +0 -7
  313. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +0 -1
  314. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +0 -400
  315. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  316. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  317. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -212
  318. package/dest/services/reqresp/protocols/block.d.ts +0 -9
  319. package/dest/services/reqresp/protocols/block.d.ts.map +0 -1
  320. package/dest/services/reqresp/protocols/block.js +0 -32
  321. package/dest/services/tx_collection/missing_txs_tracker.d.ts +0 -32
  322. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +0 -1
  323. package/dest/services/tx_collection/missing_txs_tracker.js +0 -27
  324. package/src/mem_pools/tx_pool/README.md +0 -270
  325. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +0 -746
  326. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +0 -132
  327. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +0 -208
  328. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +0 -162
  329. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +0 -104
  330. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +0 -93
  331. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +0 -106
  332. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +0 -75
  333. package/src/mem_pools/tx_pool/index.ts +0 -2
  334. package/src/mem_pools/tx_pool/priority.ts +0 -20
  335. package/src/mem_pools/tx_pool/tx_pool.ts +0 -141
  336. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +0 -319
  337. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -230
  338. package/src/services/reqresp/protocols/block.ts +0 -37
  339. package/src/services/tx_collection/missing_txs_tracker.ts +0 -52
@@ -230,7 +230,7 @@ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.j
230
230
  /**
231
231
  * Creates a mock EpochCache for testing.
232
232
  */ export function createMockEpochCache() {
233
- return {
233
+ const cache = {
234
234
  getCommittee: ()=>Promise.resolve({
235
235
  committee: [],
236
236
  seed: 1n,
@@ -238,27 +238,45 @@ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.j
238
238
  isEscapeHatchOpen: false
239
239
  }),
240
240
  getProposerIndexEncoding: ()=>'0x',
241
+ getSlotNow: ()=>SlotNumber.ZERO,
242
+ getTargetSlot: ()=>SlotNumber.ZERO,
243
+ getEpochNow: ()=>EpochNumber.ZERO,
244
+ getTargetEpoch: ()=>EpochNumber.ZERO,
241
245
  getEpochAndSlotNow: ()=>({
242
246
  epoch: EpochNumber.ZERO,
243
247
  slot: SlotNumber.ZERO,
244
248
  ts: 0n,
245
249
  nowMs: 0n
246
250
  }),
251
+ isProposerPipeliningEnabled: ()=>false,
252
+ pipeliningOffset: ()=>0,
247
253
  computeProposerIndex: ()=>0n,
248
254
  getCurrentAndNextSlot: ()=>({
249
255
  currentSlot: SlotNumber.ZERO,
250
256
  nextSlot: SlotNumber.ZERO
251
257
  }),
258
+ getTargetAndNextSlot: ()=>({
259
+ targetSlot: SlotNumber.ZERO,
260
+ nextSlot: SlotNumber.ZERO
261
+ }),
252
262
  getProposerAttesterAddressInSlot: ()=>Promise.resolve(undefined),
253
263
  getEpochAndSlotInNextL1Slot: ()=>({
254
264
  epoch: EpochNumber.ZERO,
255
265
  slot: SlotNumber.ZERO,
256
266
  ts: 0n,
257
- now: 0n
267
+ nowSeconds: 0n
268
+ }),
269
+ getTargetEpochAndSlotInNextL1Slot: ()=>({
270
+ epoch: EpochNumber.ZERO,
271
+ slot: SlotNumber.ZERO,
272
+ ts: 0n,
273
+ nowSeconds: 0n
258
274
  }),
259
275
  isInCommittee: ()=>Promise.resolve(false),
260
276
  getRegisteredValidators: ()=>Promise.resolve([]),
261
277
  filterInCommittee: ()=>Promise.resolve([]),
278
+ isEscapeHatchOpen: ()=>Promise.resolve(false),
279
+ isEscapeHatchOpenAtSlot: ()=>Promise.resolve(false),
262
280
  getL1Constants: ()=>({
263
281
  l1StartBlock: 0n,
264
282
  l1GenesisTime: 0n,
@@ -266,9 +284,11 @@ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.j
266
284
  slotDuration: 1,
267
285
  ethereumSlotDuration: 1,
268
286
  proofSubmissionEpochs: 1,
269
- targetCommitteeSize: 48
287
+ targetCommitteeSize: 48,
288
+ rollupManaLimit: Number.MAX_SAFE_INTEGER
270
289
  })
271
290
  };
291
+ return cache;
272
292
  }
273
293
  /**
274
294
  * Creates a mock WorldStateSynchronizer for testing.
@@ -23,7 +23,7 @@ import { peerIdFromString } from '@libp2p/peer-id';
23
23
  import { createP2PClient } from '../index.js';
24
24
  import { BatchTxRequesterCollector, LibP2PService, SendBatchRequestCollector } from '../services/index.js';
25
25
  import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.js';
26
- import { MissingTxsTracker } from '../services/tx_collection/missing_txs_tracker.js';
26
+ import { RequestTracker } from '../services/tx_collection/request_tracker.js';
27
27
  import { AlwaysTrueCircuitVerifier } from '../test-helpers/index.js';
28
28
  import { BENCHMARK_CONSTANTS, InMemoryAttestationPool, InMemoryTxPool, UNLIMITED_RATE_LIMIT_QUOTA, createMockEpochCache, createMockWorldStateSynchronizer, filterTxsByDistribution } from '../test-helpers/index.js';
29
29
  export { COLLECTOR_DISPLAY_NAMES } from '../test-helpers/testbench-utils.js';
@@ -110,6 +110,21 @@ function installUnlimitedRateLimits(client) {
110
110
  rateLimiter.getRateLimits = ()=>UNLIMITED_RATE_LIMIT_QUOTA;
111
111
  rateLimiter.allow = ()=>RateLimitStatus.Allowed;
112
112
  }
113
+ /** Resets peer scores to prevent cross-case contamination in benchmarks. */ function resetPeerScores(client) {
114
+ const peerManager = client.p2pService.peerManager;
115
+ const peerScoring = peerManager?.peerScoring;
116
+ if (peerScoring?.resetAllScores) {
117
+ peerScoring.resetAllScores();
118
+ }
119
+ }
120
+ /** Returns the number of connected peers for connectivity checks. */ function getConnectedPeerCount(client) {
121
+ const p2pService = client.p2pService;
122
+ const connectionSampler = p2pService?.reqresp?.getConnectionSampler?.();
123
+ if (connectionSampler?.getPeerListSortedByConnectionCountAsc) {
124
+ return connectionSampler.getPeerListSortedByConnectionCountAsc().length;
125
+ }
126
+ return 0;
127
+ }
113
128
  async function runAggregatorBenchmark(client, blockProposal, collectorType, timeoutMs, pinnedPeerId, pinnedPeerIndex, logger, expectedPeerCount) {
114
129
  let timer = new Timer();
115
130
  try {
@@ -154,7 +169,7 @@ async function runAggregatorBenchmark(client, blockProposal, collectorType, time
154
169
  timer = new Timer();
155
170
  if (collectorType === 'batch-requester') {
156
171
  const collector = new BatchTxRequesterCollector(batchTxRequesterService, logger, new DateProvider(), noopTxValidator);
157
- const fetchedTxs = await collector.collectTxs(MissingTxsTracker.fromArray(txHashes), blockProposal, pinnedPeer, timeoutMs);
172
+ const fetchedTxs = await collector.collectTxs(RequestTracker.create(txHashes, new Date(Date.now() + timeoutMs)), blockProposal, pinnedPeer);
158
173
  const durationMs = timer.ms();
159
174
  return {
160
175
  type: 'BENCH_RESULT',
@@ -164,7 +179,7 @@ async function runAggregatorBenchmark(client, blockProposal, collectorType, time
164
179
  };
165
180
  }
166
181
  const collector = new SendBatchRequestCollector(batchTxRequesterService, BENCHMARK_CONSTANTS.FIXED_MAX_PEERS, BENCHMARK_CONSTANTS.FIXED_MAX_RETRY_ATTEMPTS);
167
- const fetchedTxs = await collector.collectTxs(MissingTxsTracker.fromArray(txHashes), blockProposal, pinnedPeer, timeoutMs);
182
+ const fetchedTxs = await collector.collectTxs(RequestTracker.create(txHashes, new Date(Date.now() + timeoutMs)), blockProposal, pinnedPeer);
168
183
  const durationMs = timer.ms();
169
184
  return {
170
185
  type: 'BENCH_RESULT',
@@ -188,6 +203,35 @@ let workerAttestationPool = null;
188
203
  let workerConfig = null;
189
204
  let workerLogger = null;
190
205
  let kvStore = null;
206
+ async function stopWorker() {
207
+ try {
208
+ if (workerClient) {
209
+ await workerClient.stop();
210
+ workerClient = null;
211
+ }
212
+ } catch (e) {
213
+ workerLogger?.error('Error stopping worker client', e);
214
+ }
215
+ try {
216
+ if (kvStore?.close) {
217
+ await kvStore.close();
218
+ kvStore = null;
219
+ }
220
+ } catch (e) {
221
+ workerLogger?.error('Error closing kv store', e);
222
+ }
223
+ }
224
+ function gracefulExit(code = 0) {
225
+ try {
226
+ if (process.connected) {
227
+ process.disconnect();
228
+ }
229
+ } catch {
230
+ // IPC channel already closed
231
+ }
232
+ // Safety fallback if lingering handles prevent the event loop from draining
233
+ setTimeout(()=>process.exit(code), 5000).unref();
234
+ }
191
235
  // eslint-disable-next-line @typescript-eslint/no-misused-promises
192
236
  process.on('message', async (msg)=>{
193
237
  const { type, config: rawConfig, clientIndex } = msg;
@@ -195,7 +239,8 @@ process.on('message', async (msg)=>{
195
239
  if (type === 'START') {
196
240
  const config = {
197
241
  ...rawConfig,
198
- peerIdPrivateKey: rawConfig.peerIdPrivateKey ? new SecretValue(rawConfig.peerIdPrivateKey) : undefined
242
+ peerIdPrivateKey: rawConfig.peerIdPrivateKey ? new SecretValue(rawConfig.peerIdPrivateKey) : undefined,
243
+ priceBumpPercentage: 10n
199
244
  };
200
245
  workerConfig = config;
201
246
  workerTxPool = new InMemoryTxPool();
@@ -237,13 +282,8 @@ process.on('message', async (msg)=>{
237
282
  const cmd = msg;
238
283
  switch(cmd.type){
239
284
  case 'STOP':
240
- if (workerClient) {
241
- await workerClient.stop();
242
- }
243
- if (kvStore?.close) {
244
- await kvStore.close();
245
- }
246
- process.exit(0);
285
+ await stopWorker();
286
+ gracefulExit(0);
247
287
  break;
248
288
  case 'SEND_TX':
249
289
  if (workerClient) {
@@ -253,6 +293,12 @@ process.on('message', async (msg)=>{
253
293
  });
254
294
  }
255
295
  break;
296
+ case 'GET_PEER_COUNT':
297
+ process.send({
298
+ type: 'PEER_COUNT',
299
+ count: workerClient ? getConnectedPeerCount(workerClient) : 0
300
+ });
301
+ break;
256
302
  case 'BENCH_REQRESP':
257
303
  {
258
304
  const benchCmd = cmd;
@@ -269,6 +315,7 @@ process.on('message', async (msg)=>{
269
315
  // Reset state before each benchmark run to avoid cross-run contamination
270
316
  workerTxPool.resetState();
271
317
  workerAttestationPool.resetState();
318
+ resetPeerScores(workerClient);
272
319
  installUnlimitedRateLimits(workerClient);
273
320
  const allTxs = await generateDeterministicTxs(benchCmd.txCount, benchCmd.seed, workerConfig);
274
321
  const txHashes = allTxs.map((tx)=>tx.getTxHash());
@@ -292,10 +339,15 @@ process.on('message', async (msg)=>{
292
339
  }
293
340
  }
294
341
  } catch (err) {
295
- process.send({
296
- type: 'ERROR',
297
- error: err.message
298
- });
299
- process.exit(1);
342
+ try {
343
+ process.send({
344
+ type: 'ERROR',
345
+ error: err.message
346
+ });
347
+ } catch {
348
+ // IPC channel may be closed
349
+ }
350
+ await stopWorker();
351
+ gracefulExit(1);
300
352
  }
301
353
  });
@@ -38,6 +38,8 @@ declare class WorkerClientManager {
38
38
  * Note: We send the raw peerIdPrivateKey string instead of SecretValue
39
39
  * because SecretValue.toJSON() returns '[Redacted]', losing the value.
40
40
  * The worker must re-wrap it in SecretValue.
41
+ * We also omit priceBumpPercentage since it's a bigint and can't be
42
+ * serialized over IPC (which uses JSON under the hood).
41
43
  */
42
44
  private createClientConfig;
43
45
  /**
@@ -76,6 +78,13 @@ declare class WorkerClientManager {
76
78
  * Cleans up all worker processes with timeout and force kill if needed
77
79
  */
78
80
  cleanup(): Promise<void>;
81
+ /**
82
+ * Checks that the aggregator (client 0) has sufficient peer connections before running a benchmark.
83
+ * This prevents benchmark cases from starting with degraded connectivity after a previous case
84
+ * caused connection failures.
85
+ */
86
+ waitForConnectivity(minPeers: number, timeoutMs?: number): Promise<number>;
87
+ private getPeerCount;
79
88
  /**
80
89
  * Run a req/resp benchmark across all worker clients.
81
90
  *
@@ -93,4 +102,4 @@ declare class WorkerClientManager {
93
102
  export { WorkerClientManager, testChainConfig };
94
103
  export type { DistributionPattern, CollectorType } from './p2p_client_testbench_worker.js';
95
104
  export { COLLECTOR_DISPLAY_NAMES } from './p2p_client_testbench_worker.js';
96
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2VyX2NsaWVudF9tYW5hZ2VyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGJlbmNoL3dvcmtlcl9jbGllbnRfbWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVwRCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsS0FBSyxZQUFZLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFLeEQsT0FBTyxFQUFFLEtBQUssU0FBUyxFQUF1QixNQUFNLGNBQWMsQ0FBQztBQUtuRSxPQUFPLEtBQUssRUFHVixhQUFhLEVBQ2IsbUJBQW1CLEVBQ3BCLE1BQU0sa0NBQWtDLENBQUM7QUFRMUMsUUFBQSxNQUFNLGVBQWUsRUFBRSxXQU10QixDQUFDO0FBRUYsTUFBTSxXQUFXLHNCQUFzQjtJQUNyQyxPQUFPLEVBQUUsTUFBTSxDQUFDO0lBQ2hCLFlBQVksRUFBRSxtQkFBbUIsQ0FBQztJQUNsQyxhQUFhLEVBQUUsYUFBYSxDQUFDO0lBQzdCLFNBQVMsRUFBRSxNQUFNLENBQUM7SUFDbEIsZUFBZSxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ3pCLFdBQVcsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUNyQixJQUFJLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDZjtBQUVELE1BQU0sV0FBVyxzQkFBc0I7SUFDckMsT0FBTyxFQUFFLE1BQU0sQ0FBQztJQUNoQixZQUFZLEVBQUUsbUJBQW1CLENBQUM7SUFDbEMsU0FBUyxFQUFFLGFBQWEsQ0FBQztJQUN6QixVQUFVLEVBQUUsTUFBTSxDQUFDO0lBQ25CLFlBQVksRUFBRSxNQUFNLENBQUM7SUFDckIsT0FBTyxFQUFFLE9BQU8sQ0FBQztJQUNqQixLQUFLLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDaEI7QUFFRCxjQUFNLG1CQUFtQjtJQUNoQixTQUFTLEVBQUUsWUFBWSxFQUFFLENBQU07SUFDL0IsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLENBQU07SUFDakMsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFNO0lBQ3hCLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBTTtJQUNyQixPQUFPLEVBQUUsTUFBTSxFQUFFLENBQU07SUFDOUIsT0FBTyxDQUFDLFNBQVMsQ0FBcUI7SUFDdEMsT0FBTyxDQUFDLE1BQU0sQ0FBUztJQUN2QixPQUFPLENBQUMsdUJBQXVCLENBQWdCO0lBRS9DLFlBQVksTUFBTSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUd4RDtJQUVELE9BQU8sU0FLTjtJQUVEOzs7OztPQUtHO0lBQ0gsT0FBTyxDQUFDLGtCQUFrQjtJQWlCMUI7OztPQUdHO0lBQ0gsT0FBTyxDQUFDLGtCQUFrQjtJQWdHMUI7Ozs7Ozs7T0FPRztJQUNHLGlCQUFpQixDQUNyQixlQUFlLEVBQUUsTUFBTSxFQUN2QixPQUFPLEdBQUU7UUFDUCxhQUFhLENBQUMsRUFBRSxRQUFRLEdBQUcsS0FBSyxDQUFDO1FBQ2pDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sQ0FBQztRQUN2QixTQUFTLENBQUMsRUFBRSxNQUFNLENBQUM7UUFDbkIsWUFBWSxDQUFDLEVBQUUsTUFBTSxDQUFDO0tBQ2xCLHFCQStEUDtJQUVELDRCQUE0QixTQUUzQjtJQUVELGtDQUFrQyxXQUVqQztJQUVEOzs7OztPQUtHO0lBQ0csVUFBVSxDQUFDLFdBQVcsRUFBRSxNQUFNLEVBQUUsT0FBTyxFQUFFLE1BQU0saUJBOENwRDtJQUVEOztPQUVHO0lBQ0gsT0FBTyxDQUFDLGdCQUFnQjtJQXFDeEI7O09BRUc7SUFDRyxPQUFPLGtCQWdDWjtJQUVEOzs7Ozs7Ozs7T0FTRztJQUNHLG1CQUFtQixDQUFDLE1BQU0sRUFBRSxzQkFBc0IsR0FBRyxPQUFPLENBQUMsc0JBQXNCLENBQUMsQ0FzRXpGO0lBRUQsT0FBTyxDQUFDLGlCQUFpQjtJQWtDekIsT0FBTyxDQUFDLGtCQUFrQjtDQWlDM0I7QUFFRCxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsZUFBZSxFQUFFLENBQUM7QUFDaEQsWUFBWSxFQUFFLG1CQUFtQixFQUFFLGFBQWEsRUFBRSxNQUFNLGtDQUFrQyxDQUFDO0FBQzNGLE9BQU8sRUFBRSx1QkFBdUIsRUFBRSxNQUFNLGtDQUFrQyxDQUFDIn0=
105
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoid29ya2VyX2NsaWVudF9tYW5hZ2VyLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdGJlbmNoL3dvcmtlcl9jbGllbnRfbWFuYWdlci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUVwRCxPQUFPLEtBQUssRUFBRSxXQUFXLEVBQUUsTUFBTSxzQkFBc0IsQ0FBQztBQUV4RCxPQUFPLEVBQUUsS0FBSyxZQUFZLEVBQVEsTUFBTSxlQUFlLENBQUM7QUFLeEQsT0FBTyxFQUFFLEtBQUssU0FBUyxFQUF1QixNQUFNLGNBQWMsQ0FBQztBQUtuRSxPQUFPLEtBQUssRUFHVixhQUFhLEVBQ2IsbUJBQW1CLEVBQ3BCLE1BQU0sa0NBQWtDLENBQUM7QUFRMUMsUUFBQSxNQUFNLGVBQWUsRUFBRSxXQU10QixDQUFDO0FBRUYsTUFBTSxXQUFXLHNCQUFzQjtJQUNyQyxPQUFPLEVBQUUsTUFBTSxDQUFDO0lBQ2hCLFlBQVksRUFBRSxtQkFBbUIsQ0FBQztJQUNsQyxhQUFhLEVBQUUsYUFBYSxDQUFDO0lBQzdCLFNBQVMsRUFBRSxNQUFNLENBQUM7SUFDbEIsZUFBZSxDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQ3pCLFdBQVcsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUNyQixJQUFJLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDZjtBQUVELE1BQU0sV0FBVyxzQkFBc0I7SUFDckMsT0FBTyxFQUFFLE1BQU0sQ0FBQztJQUNoQixZQUFZLEVBQUUsbUJBQW1CLENBQUM7SUFDbEMsU0FBUyxFQUFFLGFBQWEsQ0FBQztJQUN6QixVQUFVLEVBQUUsTUFBTSxDQUFDO0lBQ25CLFlBQVksRUFBRSxNQUFNLENBQUM7SUFDckIsT0FBTyxFQUFFLE9BQU8sQ0FBQztJQUNqQixLQUFLLENBQUMsRUFBRSxNQUFNLENBQUM7Q0FDaEI7QUFFRCxjQUFNLG1CQUFtQjtJQUNoQixTQUFTLEVBQUUsWUFBWSxFQUFFLENBQU07SUFDL0IsaUJBQWlCLEVBQUUsTUFBTSxFQUFFLENBQU07SUFDakMsUUFBUSxFQUFFLE1BQU0sRUFBRSxDQUFNO0lBQ3hCLEtBQUssRUFBRSxNQUFNLEVBQUUsQ0FBTTtJQUNyQixPQUFPLEVBQUUsTUFBTSxFQUFFLENBQU07SUFDOUIsT0FBTyxDQUFDLFNBQVMsQ0FBcUI7SUFDdEMsT0FBTyxDQUFDLE1BQU0sQ0FBUztJQUN2QixPQUFPLENBQUMsdUJBQXVCLENBQWdCO0lBRS9DLFlBQVksTUFBTSxFQUFFLE1BQU0sRUFBRSxTQUFTLEVBQUUsT0FBTyxDQUFDLFNBQVMsQ0FBQyxFQUd4RDtJQUVELE9BQU8sU0FJTjtJQUVEOzs7Ozs7O09BT0c7SUFDSCxPQUFPLENBQUMsa0JBQWtCO0lBb0IxQjs7O09BR0c7SUFDSCxPQUFPLENBQUMsa0JBQWtCO0lBa0cxQjs7Ozs7OztPQU9HO0lBQ0csaUJBQWlCLENBQ3JCLGVBQWUsRUFBRSxNQUFNLEVBQ3ZCLE9BQU8sR0FBRTtRQUNQLGFBQWEsQ0FBQyxFQUFFLFFBQVEsR0FBRyxLQUFLLENBQUM7UUFDakMsYUFBYSxDQUFDLEVBQUUsTUFBTSxDQUFDO1FBQ3ZCLFNBQVMsQ0FBQyxFQUFFLE1BQU0sQ0FBQztRQUNuQixZQUFZLENBQUMsRUFBRSxNQUFNLENBQUM7S0FDbEIscUJBK0RQO0lBRUQsNEJBQTRCLFNBRTNCO0lBRUQsa0NBQWtDLFdBRWpDO0lBRUQ7Ozs7O09BS0c7SUFDRyxVQUFVLENBQUMsV0FBVyxFQUFFLE1BQU0sRUFBRSxPQUFPLEVBQUUsTUFBTSxpQkE4Q3BEO0lBRUQ7O09BRUc7SUFDSCxPQUFPLENBQUMsZ0JBQWdCO0lBcUN4Qjs7T0FFRztJQUNHLE9BQU8sa0JBZ0NaO0lBRUQ7Ozs7T0FJRztJQUNHLG1CQUFtQixDQUFDLFFBQVEsRUFBRSxNQUFNLEVBQUUsU0FBUyxHQUFFLE1BQWUsR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBa0J2RjtJQUVELE9BQU8sQ0FBQyxZQUFZO0lBOEJwQjs7Ozs7Ozs7O09BU0c7SUFDRyxtQkFBbUIsQ0FBQyxNQUFNLEVBQUUsc0JBQXNCLEdBQUcsT0FBTyxDQUFDLHNCQUFzQixDQUFDLENBdUV6RjtJQUVELE9BQU8sQ0FBQyxpQkFBaUI7SUFrQ3pCLE9BQU8sQ0FBQyxrQkFBa0I7Q0FpQzNCO0FBRUQsT0FBTyxFQUFFLG1CQUFtQixFQUFFLGVBQWUsRUFBRSxDQUFDO0FBQ2hELFlBQVksRUFBRSxtQkFBbUIsRUFBRSxhQUFhLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQztBQUMzRixPQUFPLEVBQUUsdUJBQXVCLEVBQUUsTUFBTSxrQ0FBa0MsQ0FBQyJ9
@@ -1 +1 @@
1
- {"version":3,"file":"worker_client_manager.d.ts","sourceRoot":"","sources":["../../src/testbench/worker_client_manager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,KAAK,YAAY,EAAQ,MAAM,eAAe,CAAC;AAKxD,OAAO,EAAE,KAAK,SAAS,EAAuB,MAAM,cAAc,CAAC;AAKnE,OAAO,KAAK,EAGV,aAAa,EACb,mBAAmB,EACpB,MAAM,kCAAkC,CAAC;AAQ1C,QAAA,MAAM,eAAe,EAAE,WAMtB,CAAC;AAEF,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,mBAAmB,CAAC;IAClC,aAAa,EAAE,aAAa,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,mBAAmB,CAAC;IAClC,SAAS,EAAE,aAAa,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,cAAM,mBAAmB;IAChB,SAAS,EAAE,YAAY,EAAE,CAAM;IAC/B,iBAAiB,EAAE,MAAM,EAAE,CAAM;IACjC,QAAQ,EAAE,MAAM,EAAE,CAAM;IACxB,KAAK,EAAE,MAAM,EAAE,CAAM;IACrB,OAAO,EAAE,MAAM,EAAE,CAAM;IAC9B,OAAO,CAAC,SAAS,CAAqB;IACtC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,uBAAuB,CAAgB;IAE/C,YAAY,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,EAGxD;IAED,OAAO,SAKN;IAED;;;;;OAKG;IACH,OAAO,CAAC,kBAAkB;IAiB1B;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAgG1B;;;;;;;OAOG;IACG,iBAAiB,CACrB,eAAe,EAAE,MAAM,EACvB,OAAO,GAAE;QACP,aAAa,CAAC,EAAE,QAAQ,GAAG,KAAK,CAAC;QACjC,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,YAAY,CAAC,EAAE,MAAM,CAAC;KAClB,qBA+DP;IAED,4BAA4B,SAE3B;IAED,kCAAkC,WAEjC;IAED;;;;;OAKG;IACG,UAAU,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,iBA8CpD;IAED;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAqCxB;;OAEG;IACG,OAAO,kBAgCZ;IAED;;;;;;;;;OASG;IACG,mBAAmB,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAsEzF;IAED,OAAO,CAAC,iBAAiB;IAkCzB,OAAO,CAAC,kBAAkB;CAiC3B;AAED,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,CAAC;AAChD,YAAY,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAC3F,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC"}
1
+ {"version":3,"file":"worker_client_manager.d.ts","sourceRoot":"","sources":["../../src/testbench/worker_client_manager.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AAEpD,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;AAExD,OAAO,EAAE,KAAK,YAAY,EAAQ,MAAM,eAAe,CAAC;AAKxD,OAAO,EAAE,KAAK,SAAS,EAAuB,MAAM,cAAc,CAAC;AAKnE,OAAO,KAAK,EAGV,aAAa,EACb,mBAAmB,EACpB,MAAM,kCAAkC,CAAC;AAQ1C,QAAA,MAAM,eAAe,EAAE,WAMtB,CAAC;AAEF,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,mBAAmB,CAAC;IAClC,aAAa,EAAE,aAAa,CAAC;IAC7B,SAAS,EAAE,MAAM,CAAC;IAClB,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,MAAM,CAAC;CACf;AAED,MAAM,WAAW,sBAAsB;IACrC,OAAO,EAAE,MAAM,CAAC;IAChB,YAAY,EAAE,mBAAmB,CAAC;IAClC,SAAS,EAAE,aAAa,CAAC;IACzB,UAAU,EAAE,MAAM,CAAC;IACnB,YAAY,EAAE,MAAM,CAAC;IACrB,OAAO,EAAE,OAAO,CAAC;IACjB,KAAK,CAAC,EAAE,MAAM,CAAC;CAChB;AAED,cAAM,mBAAmB;IAChB,SAAS,EAAE,YAAY,EAAE,CAAM;IAC/B,iBAAiB,EAAE,MAAM,EAAE,CAAM;IACjC,QAAQ,EAAE,MAAM,EAAE,CAAM;IACxB,KAAK,EAAE,MAAM,EAAE,CAAM;IACrB,OAAO,EAAE,MAAM,EAAE,CAAM;IAC9B,OAAO,CAAC,SAAS,CAAqB;IACtC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,uBAAuB,CAAgB;IAE/C,YAAY,MAAM,EAAE,MAAM,EAAE,SAAS,EAAE,OAAO,CAAC,SAAS,CAAC,EAGxD;IAED,OAAO,SAIN;IAED;;;;;;;OAOG;IACH,OAAO,CAAC,kBAAkB;IAoB1B;;;OAGG;IACH,OAAO,CAAC,kBAAkB;IAkG1B;;;;;;;OAOG;IACG,iBAAiB,CACrB,eAAe,EAAE,MAAM,EACvB,OAAO,GAAE;QACP,aAAa,CAAC,EAAE,QAAQ,GAAG,KAAK,CAAC;QACjC,aAAa,CAAC,EAAE,MAAM,CAAC;QACvB,SAAS,CAAC,EAAE,MAAM,CAAC;QACnB,YAAY,CAAC,EAAE,MAAM,CAAC;KAClB,qBA+DP;IAED,4BAA4B,SAE3B;IAED,kCAAkC,WAEjC;IAED;;;;;OAKG;IACG,UAAU,CAAC,WAAW,EAAE,MAAM,EAAE,OAAO,EAAE,MAAM,iBA8CpD;IAED;;OAEG;IACH,OAAO,CAAC,gBAAgB;IAqCxB;;OAEG;IACG,OAAO,kBAgCZ;IAED;;;;OAIG;IACG,mBAAmB,CAAC,QAAQ,EAAE,MAAM,EAAE,SAAS,GAAE,MAAe,GAAG,OAAO,CAAC,MAAM,CAAC,CAkBvF;IAED,OAAO,CAAC,YAAY;IA8BpB;;;;;;;;;OASG;IACG,mBAAmB,CAAC,MAAM,EAAE,sBAAsB,GAAG,OAAO,CAAC,sBAAsB,CAAC,CAuEzF;IAED,OAAO,CAAC,iBAAiB;IAkCzB,OAAO,CAAC,kBAAkB;CAiC3B;AAED,OAAO,EAAE,mBAAmB,EAAE,eAAe,EAAE,CAAC;AAChD,YAAY,EAAE,mBAAmB,EAAE,aAAa,EAAE,MAAM,kCAAkC,CAAC;AAC3F,OAAO,EAAE,uBAAuB,EAAE,MAAM,kCAAkC,CAAC"}
@@ -37,7 +37,6 @@ class WorkerClientManager {
37
37
  destroy() {
38
38
  this.cleanup().catch((error)=>{
39
39
  this.logger.error('Failed to cleanup worker client manager', error);
40
- process.exit(1);
41
40
  });
42
41
  }
43
42
  /**
@@ -45,8 +44,10 @@ class WorkerClientManager {
45
44
  * Note: We send the raw peerIdPrivateKey string instead of SecretValue
46
45
  * because SecretValue.toJSON() returns '[Redacted]', losing the value.
47
46
  * The worker must re-wrap it in SecretValue.
47
+ * We also omit priceBumpPercentage since it's a bigint and can't be
48
+ * serialized over IPC (which uses JSON under the hood).
48
49
  */ createClientConfig(clientIndex, port, otherNodes) {
49
- return {
50
+ const { priceBumpPercentage: _, ...config } = {
50
51
  ...getP2PDefaultConfig(),
51
52
  p2pEnabled: true,
52
53
  peerIdPrivateKey: this.peerIdPrivateKeys[clientIndex],
@@ -58,6 +59,7 @@ class WorkerClientManager {
58
59
  ],
59
60
  ...this.p2pConfig
60
61
  };
62
+ return config;
61
63
  }
62
64
  /**
63
65
  * Spawns a worker process and returns a promise that resolves when the worker is ready.
@@ -315,6 +317,55 @@ class WorkerClientManager {
315
317
  this.logger.info('All worker processes cleaned up');
316
318
  }
317
319
  /**
320
+ * Checks that the aggregator (client 0) has sufficient peer connections before running a benchmark.
321
+ * This prevents benchmark cases from starting with degraded connectivity after a previous case
322
+ * caused connection failures.
323
+ */ async waitForConnectivity(minPeers, timeoutMs = 15_000) {
324
+ const waitInterval = 1000;
325
+ let waited = 0;
326
+ while(waited < timeoutMs){
327
+ const count = await this.getPeerCount(0, 5000);
328
+ if (count >= minPeers) {
329
+ this.logger.info(`Connectivity check passed: ${count}/${minPeers} peers connected`);
330
+ return count;
331
+ }
332
+ this.logger.debug(`Waiting for connectivity: ${count}/${minPeers} (waited ${waited}ms)`);
333
+ await sleep(waitInterval);
334
+ waited += waitInterval;
335
+ }
336
+ const finalCount = await this.getPeerCount(0, 5000);
337
+ this.logger.warn(`Connectivity check: only ${finalCount}/${minPeers} peers after ${timeoutMs}ms`);
338
+ return finalCount;
339
+ }
340
+ getPeerCount(clientIndex, timeoutMs) {
341
+ return new Promise((resolve)=>{
342
+ let resolved = false;
343
+ const handler = (msg)=>{
344
+ if (resolved) {
345
+ return;
346
+ }
347
+ if (msg.type === 'PEER_COUNT') {
348
+ resolved = true;
349
+ clearTimeout(timeout);
350
+ this.processes[clientIndex].off('message', handler);
351
+ resolve(msg.count);
352
+ }
353
+ };
354
+ const timeout = setTimeout(()=>{
355
+ if (resolved) {
356
+ return;
357
+ }
358
+ resolved = true;
359
+ this.processes[clientIndex].off('message', handler);
360
+ resolve(0);
361
+ }, timeoutMs);
362
+ this.processes[clientIndex].on('message', handler);
363
+ this.processes[clientIndex].send({
364
+ type: 'GET_PEER_COUNT'
365
+ });
366
+ });
367
+ }
368
+ /**
318
369
  * Run a req/resp benchmark across all worker clients.
319
370
  *
320
371
  * This sends a BENCH_REQRESP command to all workers:
@@ -368,7 +419,8 @@ class WorkerClientManager {
368
419
  seed
369
420
  };
370
421
  this.processes[0].send(aggregatorCmd);
371
- const result = await this.waitForBenchResult(0, config.timeoutMs + 30000);
422
+ const aggregatorBudgetMs = config.timeoutMs + BENCHMARK_CONSTANTS.MAX_PEER_WAIT_MS + 30000;
423
+ const result = await this.waitForBenchResult(0, aggregatorBudgetMs);
372
424
  this.logger.info(`Benchmark complete: fetched=${result.fetchedCount}/${config.txCount}, duration=${result.durationMs.toFixed(0)}ms, success=${result.success}`);
373
425
  return {
374
426
  txCount: config.txCount,
package/dest/util.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { SecretValue } from '@aztec/foundation/config';
2
2
  import type { Logger } from '@aztec/foundation/log';
3
3
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
4
- import type { DataStoreConfig } from '@aztec/kv-store/config';
4
+ import type { DataStoreConfig } from '@aztec/stdlib/kv-store';
5
5
  import type { GossipSub } from '@chainsafe/libp2p-gossipsub';
6
6
  import type { Identify } from '@libp2p/identify';
7
7
  import type { PeerId } from '@libp2p/interface';
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/p2p",
3
- "version": "0.0.1-commit.dbf9cec",
3
+ "version": "0.0.1-commit.ddcf04837",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
@@ -67,17 +67,17 @@
67
67
  ]
68
68
  },
69
69
  "dependencies": {
70
- "@aztec/constants": "0.0.1-commit.dbf9cec",
71
- "@aztec/epoch-cache": "0.0.1-commit.dbf9cec",
72
- "@aztec/ethereum": "0.0.1-commit.dbf9cec",
73
- "@aztec/foundation": "0.0.1-commit.dbf9cec",
74
- "@aztec/kv-store": "0.0.1-commit.dbf9cec",
75
- "@aztec/noir-contracts.js": "0.0.1-commit.dbf9cec",
76
- "@aztec/noir-protocol-circuits-types": "0.0.1-commit.dbf9cec",
77
- "@aztec/protocol-contracts": "0.0.1-commit.dbf9cec",
78
- "@aztec/simulator": "0.0.1-commit.dbf9cec",
79
- "@aztec/stdlib": "0.0.1-commit.dbf9cec",
80
- "@aztec/telemetry-client": "0.0.1-commit.dbf9cec",
70
+ "@aztec/constants": "0.0.1-commit.ddcf04837",
71
+ "@aztec/epoch-cache": "0.0.1-commit.ddcf04837",
72
+ "@aztec/ethereum": "0.0.1-commit.ddcf04837",
73
+ "@aztec/foundation": "0.0.1-commit.ddcf04837",
74
+ "@aztec/kv-store": "0.0.1-commit.ddcf04837",
75
+ "@aztec/noir-contracts.js": "0.0.1-commit.ddcf04837",
76
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.ddcf04837",
77
+ "@aztec/protocol-contracts": "0.0.1-commit.ddcf04837",
78
+ "@aztec/simulator": "0.0.1-commit.ddcf04837",
79
+ "@aztec/stdlib": "0.0.1-commit.ddcf04837",
80
+ "@aztec/telemetry-client": "0.0.1-commit.ddcf04837",
81
81
  "@chainsafe/libp2p-gossipsub": "13.0.0",
82
82
  "@chainsafe/libp2p-noise": "^15.0.0",
83
83
  "@chainsafe/libp2p-yamux": "^6.0.2",
@@ -104,8 +104,8 @@
104
104
  "xxhash-wasm": "^1.1.0"
105
105
  },
106
106
  "devDependencies": {
107
- "@aztec/archiver": "0.0.1-commit.dbf9cec",
108
- "@aztec/world-state": "0.0.1-commit.dbf9cec",
107
+ "@aztec/archiver": "0.0.1-commit.ddcf04837",
108
+ "@aztec/world-state": "0.0.1-commit.ddcf04837",
109
109
  "@jest/globals": "^30.0.0",
110
110
  "@types/jest": "^30.0.0",
111
111
  "@types/node": "^22.15.17",
@@ -3,12 +3,12 @@ import { BlockNumber } from '@aztec/foundation/branded-types';
3
3
  import { type Logger, createLogger } from '@aztec/foundation/log';
4
4
  import { DateProvider } from '@aztec/foundation/timer';
5
5
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
6
- import type { DataStoreConfig } from '@aztec/kv-store/config';
7
6
  import { AztecLMDBStoreV2, createStore } from '@aztec/kv-store/lmdb-v2';
8
7
  import type { L2BlockSource } from '@aztec/stdlib/block';
9
8
  import type { ChainConfig } from '@aztec/stdlib/config';
10
9
  import type { ContractDataSource } from '@aztec/stdlib/contract';
11
10
  import type { AztecNode, ClientProtocolCircuitVerifier, WorldStateSynchronizer } from '@aztec/stdlib/interfaces/server';
11
+ import type { DataStoreConfig } from '@aztec/stdlib/kv-store';
12
12
  import { type TelemetryClient, getTelemetryClient } from '@aztec/telemetry-client';
13
13
 
14
14
  import { P2PClient } from '../client/p2p_client.js';
@@ -17,7 +17,12 @@ import { AttestationPool, type AttestationPoolApi } from '../mem_pools/attestati
17
17
  import type { MemPools } from '../mem_pools/interface.js';
18
18
  import type { TxPoolV2 } from '../mem_pools/tx_pool_v2/interfaces.js';
19
19
  import { AztecKVTxPoolV2 } from '../mem_pools/tx_pool_v2/tx_pool_v2.js';
20
- import { createTxValidatorForTransactionsEnteringPendingTxPool } from '../msg_validators/index.js';
20
+ import {
21
+ createCheckAllowedSetupCalls,
22
+ createTxValidatorForReqResponseReceivedTxs,
23
+ createTxValidatorForTransactionsEnteringPendingTxPool,
24
+ getDefaultAllowedSetupFunctions,
25
+ } from '../msg_validators/index.js';
21
26
  import { DummyP2PService } from '../services/dummy_service.js';
22
27
  import { LibP2PService } from '../services/index.js';
23
28
  import { createFileStoreTxSources } from '../services/tx_collection/file_store_tx_source.js';
@@ -75,6 +80,33 @@ export async function createP2PClient(
75
80
  const rollupAddress = inputConfig.l1Contracts.rollupAddress.toString().toLowerCase().replace(/^0x/, '');
76
81
  const txFileStoreBasePath = `aztec-${inputConfig.l1ChainId}-${inputConfig.rollupVersion}-0x${rollupAddress}`;
77
82
 
83
+ const allowedInSetup = [
84
+ ...(await getDefaultAllowedSetupFunctions()),
85
+ ...(inputConfig.txPublicSetupAllowListExtend ?? []),
86
+ ];
87
+ const checkAllowedSetupCalls = createCheckAllowedSetupCalls(
88
+ archiver,
89
+ allowedInSetup,
90
+ () => epochCache.getEpochAndSlotInNextL1Slot().ts,
91
+ );
92
+
93
+ const createTxValidator = async () => {
94
+ // We accept transactions if they are not expired by the next slot and block number (checked based on the ExpirationTimestamp field)
95
+ const currentBlockNumber = await archiver.getBlockNumber();
96
+ const { ts: nextSlotTimestamp } = epochCache.getEpochAndSlotInNextL1Slot();
97
+ const l1Constants = await archiver.getL1Constants();
98
+ return createTxValidatorForTransactionsEnteringPendingTxPool(
99
+ worldStateSynchronizer,
100
+ nextSlotTimestamp,
101
+ BlockNumber(currentBlockNumber + 1),
102
+ {
103
+ rollupManaLimit: l1Constants.rollupManaLimit,
104
+ maxBlockL2Gas: config.validateMaxL2BlockGas,
105
+ maxBlockDAGas: config.validateMaxDABlockGas,
106
+ },
107
+ );
108
+ };
109
+
78
110
  const txPool =
79
111
  deps.txPool ??
80
112
  new AztecKVTxPoolV2(
@@ -83,16 +115,8 @@ export async function createP2PClient(
83
115
  {
84
116
  l2BlockSource: archiver,
85
117
  worldStateSynchronizer,
86
- createTxValidator: async () => {
87
- // We accept transactions if they are not expired by the next slot and block number (checked based on the ExpirationTimestamp field)
88
- const currentBlockNumber = await archiver.getBlockNumber();
89
- const { ts: nextSlotTimestamp } = epochCache.getEpochAndSlotInNextL1Slot();
90
- return createTxValidatorForTransactionsEnteringPendingTxPool(
91
- worldStateSynchronizer,
92
- nextSlotTimestamp,
93
- BlockNumber(currentBlockNumber + 1),
94
- );
95
- },
118
+ checkAllowedSetupCalls,
119
+ createTxValidator,
96
120
  },
97
121
  telemetry,
98
122
  {
@@ -100,6 +124,7 @@ export async function createP2PClient(
100
124
  archivedTxLimit: config.archivedTxLimit,
101
125
  minTxPoolAgeMs: config.minTxPoolAgeMs,
102
126
  dropTransactionsProbability: config.dropTransactionsProbability,
127
+ priceBumpPercentage: config.priceBumpPercentage,
103
128
  },
104
129
  dateProvider,
105
130
  );
@@ -124,9 +149,12 @@ export async function createP2PClient(
124
149
  telemetry,
125
150
  );
126
151
 
152
+ const txValidatorForTxCollection = createTxValidatorForReqResponseReceivedTxs(proofVerifier, config);
127
153
  const nodeSources = [
128
- ...createNodeRpcTxSources(config.txCollectionNodeRpcUrls, config),
129
- ...(deps.rpcTxProviders ?? []).map((node, i) => new NodeRpcTxSource(node, `node-rpc-provider-${i}`)),
154
+ ...createNodeRpcTxSources(config.txCollectionNodeRpcUrls, txValidatorForTxCollection, config),
155
+ ...(deps.rpcTxProviders ?? []).map(
156
+ (node, i) => new NodeRpcTxSource(node, txValidatorForTxCollection, `node-rpc-provider-${i}`),
157
+ ),
130
158
  ...(deps.txCollectionNodeSources ?? []),
131
159
  ];
132
160
  if (nodeSources.length > 0) {
@@ -138,6 +166,7 @@ export async function createP2PClient(
138
166
  const fileStoreSources = await createFileStoreTxSources(
139
167
  config.txCollectionFileStoreUrls,
140
168
  txFileStoreBasePath,
169
+ txValidatorForTxCollection,
141
170
  logger.createChild('file-store-tx-source'),
142
171
  telemetry,
143
172
  );
@@ -82,7 +82,15 @@ export type P2P = P2PClient & {
82
82
  *
83
83
  * @param handler - A function taking a received checkpoint proposal and producing attestations
84
84
  */
85
- registerCheckpointProposalHandler(callback: P2PCheckpointReceivedCallback): void;
85
+ registerValidatorCheckpointProposalHandler(callback: P2PCheckpointReceivedCallback): void;
86
+
87
+ /**
88
+ * Registers a callback that runs for ALL nodes (not just validators) when a checkpoint proposal is received.
89
+ * Used to set the proposed checkpoint number on the archiver so the sequencer can build on top of it.
90
+ *
91
+ * @param handler - A function taking a received checkpoint proposal
92
+ */
93
+ registerAllNodesCheckpointProposalHandler(callback: P2PCheckpointReceivedCallback): void;
86
94
 
87
95
  /**
88
96
  * Registers a callback invoked when a duplicate proposal is detected (equivocation).