@aztec/p2p 0.0.1-commit.64b6bbb → 0.0.1-commit.684755437

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 (295) hide show
  1. package/dest/client/factory.d.ts +7 -7
  2. package/dest/client/factory.d.ts.map +1 -1
  3. package/dest/client/factory.js +24 -30
  4. package/dest/client/interface.d.ts +14 -19
  5. package/dest/client/interface.d.ts.map +1 -1
  6. package/dest/client/p2p_client.d.ts +9 -18
  7. package/dest/client/p2p_client.d.ts.map +1 -1
  8. package/dest/client/p2p_client.js +52 -96
  9. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +6 -7
  10. package/dest/config.d.ts +31 -15
  11. package/dest/config.d.ts.map +1 -1
  12. package/dest/config.js +71 -37
  13. package/dest/errors/tx-pool.error.d.ts +8 -0
  14. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  15. package/dest/errors/tx-pool.error.js +9 -0
  16. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +4 -2
  17. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  18. package/dest/mem_pools/attestation_pool/attestation_pool.js +10 -1
  19. package/dest/mem_pools/attestation_pool/mocks.d.ts +2 -2
  20. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  21. package/dest/mem_pools/attestation_pool/mocks.js +2 -2
  22. package/dest/mem_pools/instrumentation.d.ts +4 -2
  23. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  24. package/dest/mem_pools/instrumentation.js +16 -14
  25. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +3 -3
  26. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +30 -13
  27. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -1
  28. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +91 -20
  29. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +3 -3
  30. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -1
  31. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +18 -9
  32. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +1 -1
  33. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -1
  34. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +5 -2
  35. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +3 -3
  36. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -1
  37. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +12 -4
  38. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +2 -2
  39. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -1
  40. package/dest/mem_pools/tx_pool_v2/eviction/index.js +1 -1
  41. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +54 -5
  42. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -1
  43. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +8 -0
  44. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +7 -5
  45. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +7 -5
  46. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +2 -2
  47. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -1
  48. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +14 -6
  49. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +4 -4
  50. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -1
  51. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +16 -4
  52. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +3 -3
  53. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -1
  54. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +3 -3
  55. package/dest/mem_pools/tx_pool_v2/index.d.ts +2 -2
  56. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -1
  57. package/dest/mem_pools/tx_pool_v2/index.js +1 -1
  58. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  59. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  60. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  61. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +22 -6
  62. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -1
  63. package/dest/mem_pools/tx_pool_v2/interfaces.js +5 -1
  64. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +48 -14
  65. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -1
  66. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +100 -17
  67. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +12 -3
  68. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -1
  69. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +50 -45
  70. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +9 -4
  71. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -1
  72. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +14 -6
  73. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +14 -5
  74. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -1
  75. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +300 -142
  76. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +6 -4
  77. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  78. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  79. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +6 -4
  80. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  81. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  82. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -8
  83. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  84. package/dest/msg_validators/proposal_validator/proposal_validator.js +48 -36
  85. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +2 -2
  86. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  87. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  88. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  89. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  90. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  91. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  92. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  93. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  94. package/dest/msg_validators/tx_validator/factory.d.ts +114 -6
  95. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  96. package/dest/msg_validators/tx_validator/factory.js +219 -58
  97. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
  98. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
  99. package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
  100. package/dest/msg_validators/tx_validator/gas_validator.d.ts +58 -3
  101. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  102. package/dest/msg_validators/tx_validator/gas_validator.js +73 -36
  103. package/dest/msg_validators/tx_validator/index.d.ts +3 -1
  104. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  105. package/dest/msg_validators/tx_validator/index.js +2 -0
  106. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +1 -1
  107. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  108. package/dest/msg_validators/tx_validator/metadata_validator.js +4 -4
  109. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  110. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  111. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  112. package/dest/msg_validators/tx_validator/phases_validator.d.ts +2 -2
  113. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  114. package/dest/msg_validators/tx_validator/phases_validator.js +44 -23
  115. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +2 -2
  116. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  117. package/dest/msg_validators/tx_validator/timestamp_validator.js +6 -6
  118. package/dest/services/dummy_service.d.ts +4 -4
  119. package/dest/services/dummy_service.d.ts.map +1 -1
  120. package/dest/services/dummy_service.js +4 -4
  121. package/dest/services/encoding.d.ts +2 -2
  122. package/dest/services/encoding.d.ts.map +1 -1
  123. package/dest/services/encoding.js +9 -8
  124. package/dest/services/gossipsub/topic_score_params.d.ts +18 -6
  125. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -1
  126. package/dest/services/gossipsub/topic_score_params.js +32 -10
  127. package/dest/services/libp2p/libp2p_service.d.ts +16 -13
  128. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  129. package/dest/services/libp2p/libp2p_service.js +84 -90
  130. package/dest/services/peer-manager/metrics.d.ts +3 -1
  131. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  132. package/dest/services/peer-manager/metrics.js +6 -0
  133. package/dest/services/peer-manager/peer_manager.d.ts +1 -1
  134. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  135. package/dest/services/peer-manager/peer_manager.js +2 -1
  136. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +4 -3
  137. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -1
  138. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +19 -46
  139. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +2 -6
  140. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -1
  141. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +10 -13
  142. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -1
  143. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +25 -46
  144. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +17 -11
  145. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -1
  146. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +49 -15
  147. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +2 -2
  148. package/dest/services/reqresp/reqresp.d.ts +1 -1
  149. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  150. package/dest/services/reqresp/reqresp.js +2 -1
  151. package/dest/services/service.d.ts +5 -3
  152. package/dest/services/service.d.ts.map +1 -1
  153. package/dest/services/tx_collection/config.d.ts +13 -1
  154. package/dest/services/tx_collection/config.d.ts.map +1 -1
  155. package/dest/services/tx_collection/config.js +30 -0
  156. package/dest/services/tx_collection/fast_tx_collection.d.ts +1 -1
  157. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  158. package/dest/services/tx_collection/fast_tx_collection.js +39 -33
  159. package/dest/services/tx_collection/file_store_tx_collection.d.ts +38 -29
  160. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -1
  161. package/dest/services/tx_collection/file_store_tx_collection.js +126 -77
  162. package/dest/services/tx_collection/file_store_tx_source.d.ts +16 -6
  163. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -1
  164. package/dest/services/tx_collection/file_store_tx_source.js +49 -16
  165. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  166. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  167. package/dest/services/tx_collection/instrumentation.js +2 -1
  168. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  169. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  170. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  171. package/dest/services/tx_collection/proposal_tx_collector.d.ts +7 -6
  172. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -1
  173. package/dest/services/tx_collection/proposal_tx_collector.js +5 -4
  174. package/dest/services/tx_collection/slow_tx_collection.d.ts +5 -3
  175. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  176. package/dest/services/tx_collection/slow_tx_collection.js +17 -12
  177. package/dest/services/tx_collection/tx_collection.d.ts +9 -6
  178. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  179. package/dest/services/tx_collection/tx_collection.js +26 -10
  180. package/dest/services/tx_collection/tx_collection_sink.d.ts +6 -5
  181. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  182. package/dest/services/tx_collection/tx_collection_sink.js +13 -22
  183. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  184. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  185. package/dest/services/tx_collection/tx_source.js +19 -2
  186. package/dest/services/tx_file_store/tx_file_store.d.ts +3 -2
  187. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -1
  188. package/dest/services/tx_file_store/tx_file_store.js +9 -6
  189. package/dest/services/tx_provider.d.ts +3 -3
  190. package/dest/services/tx_provider.d.ts.map +1 -1
  191. package/dest/services/tx_provider.js +4 -4
  192. package/dest/test-helpers/make-test-p2p-clients.d.ts +5 -6
  193. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  194. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  195. package/dest/test-helpers/mock-pubsub.d.ts +4 -4
  196. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  197. package/dest/test-helpers/mock-pubsub.js +8 -2
  198. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  199. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  200. package/dest/test-helpers/reqresp-nodes.js +2 -2
  201. package/dest/test-helpers/testbench-utils.d.ts +8 -3
  202. package/dest/test-helpers/testbench-utils.d.ts.map +1 -1
  203. package/dest/test-helpers/testbench-utils.js +7 -1
  204. package/dest/testbench/p2p_client_testbench_worker.d.ts +2 -2
  205. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  206. package/dest/testbench/p2p_client_testbench_worker.js +15 -14
  207. package/dest/testbench/worker_client_manager.d.ts +3 -1
  208. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  209. package/dest/testbench/worker_client_manager.js +6 -2
  210. package/dest/util.d.ts +3 -3
  211. package/dest/util.d.ts.map +1 -1
  212. package/package.json +14 -14
  213. package/src/client/factory.ts +41 -49
  214. package/src/client/interface.ts +17 -20
  215. package/src/client/p2p_client.ts +60 -126
  216. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +20 -11
  217. package/src/config.ts +100 -43
  218. package/src/errors/tx-pool.error.ts +12 -0
  219. package/src/mem_pools/attestation_pool/attestation_pool.ts +13 -4
  220. package/src/mem_pools/attestation_pool/mocks.ts +2 -1
  221. package/src/mem_pools/instrumentation.ts +17 -13
  222. package/src/mem_pools/tx_pool/README.md +1 -1
  223. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  224. package/src/mem_pools/tx_pool_v2/README.md +52 -28
  225. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +109 -22
  226. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +21 -8
  227. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +5 -2
  228. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +18 -4
  229. package/src/mem_pools/tx_pool_v2/eviction/index.ts +4 -0
  230. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +59 -4
  231. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +5 -5
  232. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +5 -5
  233. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +14 -9
  234. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +33 -6
  235. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +4 -3
  236. package/src/mem_pools/tx_pool_v2/index.ts +1 -1
  237. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  238. package/src/mem_pools/tx_pool_v2/interfaces.ts +24 -6
  239. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +145 -25
  240. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +58 -45
  241. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +21 -7
  242. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +333 -138
  243. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +14 -4
  244. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +20 -7
  245. package/src/msg_validators/proposal_validator/proposal_validator.ts +63 -40
  246. package/src/msg_validators/tx_validator/README.md +115 -0
  247. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +3 -3
  248. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  249. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  250. package/src/msg_validators/tx_validator/factory.ts +353 -77
  251. package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
  252. package/src/msg_validators/tx_validator/gas_validator.ts +90 -27
  253. package/src/msg_validators/tx_validator/index.ts +2 -0
  254. package/src/msg_validators/tx_validator/metadata_validator.ts +12 -4
  255. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  256. package/src/msg_validators/tx_validator/phases_validator.ts +51 -26
  257. package/src/msg_validators/tx_validator/timestamp_validator.ts +7 -7
  258. package/src/services/dummy_service.ts +6 -6
  259. package/src/services/encoding.ts +7 -7
  260. package/src/services/gossipsub/README.md +29 -14
  261. package/src/services/gossipsub/topic_score_params.ts +49 -13
  262. package/src/services/libp2p/libp2p_service.ts +95 -96
  263. package/src/services/peer-manager/metrics.ts +7 -0
  264. package/src/services/peer-manager/peer_manager.ts +2 -1
  265. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +20 -48
  266. package/src/services/reqresp/batch-tx-requester/interface.ts +1 -5
  267. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +23 -71
  268. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +63 -24
  269. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +2 -2
  270. package/src/services/reqresp/reqresp.ts +3 -1
  271. package/src/services/service.ts +11 -2
  272. package/src/services/tx_collection/config.ts +42 -0
  273. package/src/services/tx_collection/fast_tx_collection.ts +51 -30
  274. package/src/services/tx_collection/file_store_tx_collection.ts +143 -93
  275. package/src/services/tx_collection/file_store_tx_source.ts +64 -17
  276. package/src/services/tx_collection/instrumentation.ts +7 -1
  277. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  278. package/src/services/tx_collection/proposal_tx_collector.ts +8 -7
  279. package/src/services/tx_collection/slow_tx_collection.ts +17 -13
  280. package/src/services/tx_collection/tx_collection.ts +45 -14
  281. package/src/services/tx_collection/tx_collection_sink.ts +15 -29
  282. package/src/services/tx_collection/tx_source.ts +22 -3
  283. package/src/services/tx_file_store/tx_file_store.ts +6 -4
  284. package/src/services/tx_provider.ts +2 -2
  285. package/src/test-helpers/make-test-p2p-clients.ts +1 -3
  286. package/src/test-helpers/mock-pubsub.ts +13 -6
  287. package/src/test-helpers/reqresp-nodes.ts +3 -6
  288. package/src/test-helpers/testbench-utils.ts +11 -3
  289. package/src/testbench/p2p_client_testbench_worker.ts +24 -20
  290. package/src/testbench/worker_client_manager.ts +13 -5
  291. package/src/util.ts +8 -2
  292. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  293. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  294. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -212
  295. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -230
@@ -372,18 +372,16 @@ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
372
372
  }
373
373
  var _dec, _dec1, _initProto;
374
374
  import { GENESIS_BLOCK_HEADER_HASH } from '@aztec/constants';
375
- import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
375
+ import { BlockNumber, CheckpointNumber, SlotNumber } from '@aztec/foundation/branded-types';
376
376
  import { createLogger } from '@aztec/foundation/log';
377
377
  import { RunningPromise } from '@aztec/foundation/promise';
378
378
  import { DateProvider } from '@aztec/foundation/timer';
379
379
  import { L2TipsKVStore } from '@aztec/kv-store/stores';
380
380
  import { L2BlockStream } from '@aztec/stdlib/block';
381
- import { getTimestampForSlot } from '@aztec/stdlib/epoch-helpers';
382
381
  import { tryStop } from '@aztec/stdlib/interfaces/server';
383
382
  import { Attributes, WithTracer, getTelemetryClient, trackSpan } from '@aztec/telemetry-client';
384
383
  import { getP2PDefaultConfig } from '../config.js';
385
- import { ReqRespSubProtocol } from '../services/reqresp/interface.js';
386
- import { chunkTxHashesRequest } from '../services/reqresp/protocols/tx.js';
384
+ import { TxPoolError } from '../errors/tx-pool.error.js';
387
385
  import { TxProvider } from '../services/tx_provider.js';
388
386
  import { P2PClientState } from './interface.js';
389
387
  _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
@@ -438,7 +436,7 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
438
436
  validatorAddresses;
439
437
  /** Tracks the last slot for which we called prepareForSlot */ lastSlotProcessed;
440
438
  /** Polls for slot changes and calls prepareForSlot on the tx pool */ slotMonitor;
441
- constructor(_clientType, store, l2BlockSource, mempools, p2pService, txCollection, txFileStore, epochCache, config = {}, _dateProvider = new DateProvider(), telemetry = getTelemetryClient(), log = createLogger('p2p')){
439
+ constructor(store, l2BlockSource, mempools, p2pService, txCollection, txFileStore, epochCache, config = {}, _dateProvider = new DateProvider(), telemetry = getTelemetryClient(), log = createLogger('p2p')){
442
440
  super(telemetry, 'P2PClient'), this.store = store, this.l2BlockSource = l2BlockSource, this.p2pService = p2pService, this.txCollection = txCollection, this.txFileStore = txFileStore, this.epochCache = epochCache, this._dateProvider = _dateProvider, this.telemetry = telemetry, this.log = log, this.currentState = (_initProto(this), P2PClientState.IDLE), this.syncPromise = Promise.resolve(), this.syncResolve = undefined, this.latestBlockNumberAtStart = -1, this.provenBlockNumberAtStart = -1, this.finalizedBlockNumberAtStart = -1, this.validatorAddresses = [], this.lastSlotProcessed = SlotNumber.ZERO;
443
441
  this.config = {
444
442
  ...getP2PDefaultConfig(),
@@ -447,29 +445,6 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
447
445
  this.txPool = mempools.txPool;
448
446
  this.attestationPool = mempools.attestationPool;
449
447
  this.txProvider = new TxProvider(this.txCollection, this.txPool, this, this.log.createChild('tx-provider'), this.telemetry);
450
- // Default to collecting all txs when we see a valid proposal
451
- // This can be overridden by the validator client to validate, and it will call getTxsForBlockProposal on its own
452
- // Note: Validators do NOT attest to individual blocks - attestations are only for checkpoint proposals.
453
- // TODO(palla/txs): We should not trigger a request for txs on a proposal before fully validating it. We need to bring
454
- // validator-client code into here so we can validate a proposal is reasonable.
455
- this.registerBlockProposalHandler(async (block, sender)=>{
456
- this.log.debug(`Received block proposal from ${sender.toString()}`);
457
- // TODO(palla/txs): Need to subtract validatorReexecuteDeadlineMs from this deadline (see ValidatorClient.getReexecutionDeadline)
458
- const constants = this.txCollection.getConstants();
459
- const nextSlotTimestampSeconds = Number(getTimestampForSlot(SlotNumber(block.slotNumber + 1), constants));
460
- const deadline = new Date(nextSlotTimestampSeconds * 1000);
461
- const parentBlock = await this.l2BlockSource.getBlockHeaderByArchive(block.blockHeader.lastArchive.root);
462
- if (!parentBlock) {
463
- this.log.debug(`Cannot collect txs for proposal as parent block not found`);
464
- return false;
465
- }
466
- const blockNumber = BlockNumber(parentBlock.getBlockNumber() + 1);
467
- await this.txProvider.getTxsForBlockProposal(block, blockNumber, {
468
- pinnedPeer: sender,
469
- deadline
470
- });
471
- return true;
472
- });
473
448
  this.l2Tips = new L2TipsKVStore(store, 'p2p_client');
474
449
  this.synchedLatestSlot = store.openSingleton('p2p_pool_last_l2_slot');
475
450
  }
@@ -491,6 +466,9 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
491
466
  getPeers(includePending) {
492
467
  return Promise.resolve(this.p2pService.getPeers(includePending));
493
468
  }
469
+ getGossipMeshPeerCount(topicType) {
470
+ return Promise.resolve(this.p2pService.getGossipMeshPeerCount(topicType));
471
+ }
494
472
  getL2BlockHash(number) {
495
473
  return this.l2Tips.getL2BlockHash(number);
496
474
  }
@@ -523,7 +501,7 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
523
501
  break;
524
502
  case 'chain-pruned':
525
503
  this.txCollection.stopCollectingForBlocksAfter(event.block.number);
526
- await this.handlePruneL2Blocks(event.block);
504
+ await this.handlePruneL2Blocks(event.block, event.checkpoint);
527
505
  break;
528
506
  case 'chain-checkpointed':
529
507
  break;
@@ -676,6 +654,9 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
676
654
  addOwnCheckpointAttestations(attestations) {
677
655
  return this.attestationPool.addOwnCheckpointAttestations(attestations);
678
656
  }
657
+ hasBlockProposalsForSlot(slot) {
658
+ return this.attestationPool.hasBlockProposalsForSlot(slot);
659
+ }
679
660
  // REVIEW: https://github.com/AztecProtocol/aztec-packages/issues/7963
680
661
  // ^ This pattern is not my favorite (md)
681
662
  registerBlockProposalHandler(handler) {
@@ -690,23 +671,6 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
690
671
  registerDuplicateAttestationCallback(callback) {
691
672
  this.p2pService.registerDuplicateAttestationCallback(callback);
692
673
  }
693
- /**
694
- * Uses the batched Request Response protocol to request a set of transactions from the network.
695
- */ async requestTxsByHash(txHashes, pinnedPeerId) {
696
- const timeoutMs = 8000; // Longer timeout for now
697
- const maxRetryAttempts = 10; // Keep retrying within the timeout
698
- const requests = chunkTxHashesRequest(txHashes);
699
- const maxPeers = Math.min(Math.ceil(requests.length / 3), 10);
700
- const txBatches = await this.p2pService.sendBatchRequest(ReqRespSubProtocol.TX, requests, pinnedPeerId, timeoutMs, maxPeers, maxRetryAttempts);
701
- const txs = txBatches.flat();
702
- if (txs.length > 0) {
703
- await this.txPool.addPendingTxs(txs);
704
- }
705
- const txHashesStr = txHashes.map((tx)=>tx.toString()).join(', ');
706
- this.log.debug(`Requested txs ${txHashesStr} (${txs.length} / ${txHashes.length}) from peers`);
707
- // We return all transactions, even the not found ones to the caller, such they can handle missing items themselves.
708
- return txs;
709
- }
710
674
  async getPendingTxs(limit, after) {
711
675
  if (limit !== undefined && limit <= 0) {
712
676
  throw new TypeError('limit must be greater than 0');
@@ -736,6 +700,14 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
736
700
  }
737
701
  }
738
702
  }
703
+ async *iterateEligiblePendingTxs() {
704
+ for (const txHash of (await this.txPool.getEligiblePendingTxHashes())){
705
+ const tx = await this.txPool.getTxByHash(txHash);
706
+ if (tx) {
707
+ yield tx;
708
+ }
709
+ }
710
+ }
739
711
  /**
740
712
  * Returns a transaction in the transaction pool by its hash.
741
713
  * @param txHash - Hash of the transaction to look for in the pool.
@@ -754,42 +726,6 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
754
726
  return this.txPool.hasTxs(txHashes);
755
727
  }
756
728
  /**
757
- * Returns transactions in the transaction pool by hash.
758
- * If a transaction is not in the pool, it will be requested from the network.
759
- * @param txHashes - Hashes of the transactions to look for.
760
- * @returns The txs found, or undefined if not found in the order requested.
761
- */ async getTxsByHash(txHashes, pinnedPeerId) {
762
- const txs = await Promise.all(txHashes.map((txHash)=>this.txPool.getTxByHash(txHash)));
763
- const missingTxHashes = txs.map((tx, index)=>[
764
- tx,
765
- index
766
- ]).filter(([tx, _index])=>!tx).map(([_tx, index])=>txHashes[index]);
767
- if (missingTxHashes.length === 0) {
768
- return txs;
769
- }
770
- const missingTxs = await this.requestTxsByHash(missingTxHashes, pinnedPeerId);
771
- // TODO: optimize
772
- // Merge the found txs in order
773
- const mergingTxs = txHashes.map((txHash)=>{
774
- // Is it in the txs list from the mempool?
775
- for (const tx of txs){
776
- if (tx !== undefined && tx.getTxHash().equals(txHash)) {
777
- return tx;
778
- }
779
- }
780
- // Is it in the fetched missing txs?
781
- // Note: this is an O(n^2) operation, but we expect the number of missing txs to be small.
782
- for (const tx of missingTxs){
783
- if (tx.getTxHash().equals(txHash)) {
784
- return tx;
785
- }
786
- }
787
- // Otherwise return undefined
788
- return undefined;
789
- });
790
- return mergingTxs;
791
- }
792
- /**
793
729
  * Returns an archived transaction in the transaction pool by its hash.
794
730
  * @param txHash - Hash of the archived transaction to look for.
795
731
  * @returns A single tx or undefined.
@@ -804,19 +740,20 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
804
740
  this.#assertIsReady();
805
741
  const result = await this.txPool.addPendingTxs([
806
742
  tx
807
- ]);
743
+ ], {
744
+ feeComparisonOnly: true
745
+ });
808
746
  if (result.accepted.length === 1) {
809
747
  await this.p2pService.propagate(tx);
810
- } else {
811
- this.log.warn(`Tx ${tx.getTxHash()} not propagated: accepted=${result.accepted.length} ignored=${result.ignored.length} rejected=${result.rejected.length}`);
748
+ return;
812
749
  }
813
- }
814
- /**
815
- * Adds transactions to the pool. Does not send to peers or validate the txs.
816
- * @param txs - The transactions.
817
- **/ async addTxsToPool(txs) {
818
- this.#assertIsReady();
819
- return (await this.txPool.addPendingTxs(txs)).accepted.length;
750
+ const txHashStr = tx.getTxHash().toString();
751
+ const reason = result.errors?.get(txHashStr);
752
+ if (reason) {
753
+ this.log.warn(`Tx ${txHashStr} not added to pool: ${reason.message}`);
754
+ throw new TxPoolError(reason);
755
+ }
756
+ this.log.warn(`Tx ${txHashStr} not propagated: accepted=${result.accepted.length} ignored=${result.ignored.length} rejected=${result.rejected.length}`);
820
757
  }
821
758
  /**
822
759
  * Returns whether the given tx hash is flagged as pending or mined.
@@ -944,9 +881,28 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
944
881
  }
945
882
  /**
946
883
  * Updates the tx pool after a chain prune.
884
+ * Detects epoch prunes (checkpoint number changed) and deletes all txs in that case.
947
885
  * @param latestBlock - The block ID the chain was pruned to.
948
- */ async handlePruneL2Blocks(latestBlock) {
949
- await this.txPool.handlePrunedBlocks(latestBlock);
886
+ * @param newCheckpoint - The checkpoint ID after the prune.
887
+ */ async handlePruneL2Blocks(latestBlock, newCheckpoint) {
888
+ const deleteAllTxs = this.config.txPoolDeleteTxsAfterReorg && await this.isEpochPrune(newCheckpoint);
889
+ await this.txPool.handlePrunedBlocks(latestBlock, {
890
+ deleteAllTxs
891
+ });
892
+ }
893
+ /**
894
+ * Returns true if the prune crossed a checkpoint boundary.
895
+ * If the old and new checkpoint numbers are the same, the prune is within a single checkpoint.
896
+ * If they differ, the prune spans across checkpoints (epoch prune).
897
+ */ async isEpochPrune(newCheckpoint) {
898
+ const tips = await this.l2Tips.getL2Tips();
899
+ const oldCheckpointNumber = tips.checkpointed.checkpoint.number;
900
+ if (oldCheckpointNumber <= CheckpointNumber.ZERO) {
901
+ return false;
902
+ }
903
+ const isEpochPrune = oldCheckpointNumber !== newCheckpoint.number;
904
+ this.log.info(`Detected epoch prune: ${isEpochPrune}. Old checkpoint: ${oldCheckpointNumber}, new checkpoint: ${newCheckpoint.number}`);
905
+ return isEpochPrune;
950
906
  }
951
907
  /** Checks if the slot has changed and calls prepareForSlot if so. */ async maybeCallPrepareForSlot() {
952
908
  const { currentSlot } = this.epochCache.getCurrentAndNextSlot();
@@ -985,8 +941,8 @@ _dec = trackSpan('p2pClient.broadcastProposal', async (proposal)=>({
985
941
  this.currentState = newState;
986
942
  this.log.debug(`Moved from state ${P2PClientState[oldState]} to ${P2PClientState[this.currentState]}`);
987
943
  }
988
- validate(txs) {
989
- return this.p2pService.validate(txs);
944
+ validateTxsReceivedInBlockProposal(txs) {
945
+ return this.p2pService.validateTxsReceivedInBlockProposal(txs);
990
946
  }
991
947
  /**
992
948
  * Protects existing transactions by hash for a given slot.
@@ -4,13 +4,12 @@ import { createLogger } from '@aztec/foundation/log';
4
4
  import { sleep } from '@aztec/foundation/sleep';
5
5
  import { DateProvider, Timer, executeTimeout } from '@aztec/foundation/timer';
6
6
  import { openTmpStore } from '@aztec/kv-store/lmdb-v2';
7
- import { P2PClientType } from '@aztec/stdlib/p2p';
8
7
  import { getTelemetryClient } from '@aztec/telemetry-client';
9
8
  import { peerIdFromString } from '@libp2p/peer-id';
9
+ import { BatchTxRequesterCollector, SendBatchRequestCollector } from '../../../services/index.js';
10
10
  import { RateLimitStatus } from '../../../services/reqresp/rate-limiter/rate_limiter.js';
11
- import { BatchTxRequesterCollector, SendBatchRequestCollector } from '../../../services/tx_collection/proposal_tx_collector.js';
12
- import { AlwaysTrueCircuitVerifier } from '../../../test-helpers/reqresp-nodes.js';
13
- import { BENCHMARK_CONSTANTS, InMemoryAttestationPool, InMemoryTxPool, UNLIMITED_RATE_LIMIT_QUOTA, calculateInternalTimeout, createMockEpochCache, createMockWorldStateSynchronizer } from '../../../test-helpers/testbench-utils.js';
11
+ import { MissingTxsTracker } from '../../../services/tx_collection/missing_txs_tracker.js';
12
+ import { AlwaysTrueCircuitVerifier, BENCHMARK_CONSTANTS, InMemoryAttestationPool, InMemoryTxPool, UNLIMITED_RATE_LIMIT_QUOTA, calculateInternalTimeout, createMockEpochCache, createMockWorldStateSynchronizer } from '../../../test-helpers/index.js';
14
13
  import { createP2PClient } from '../../index.js';
15
14
  import { deserializeBlockProposal, deserializeTx, deserializeTxHash } from './proposal_tx_collector_worker_protocol.js';
16
15
  let client;
@@ -83,7 +82,7 @@ async function startClient(config, clientIndex) {
83
82
  store: kvStore,
84
83
  logger
85
84
  };
86
- client = await createP2PClient(P2PClientType.Full, config, l2BlockSource, proofVerifier, worldState, epochCache, 'proposal-tx-collector-bench-worker', new DateProvider(), telemetry, deps);
85
+ client = await createP2PClient(config, l2BlockSource, proofVerifier, worldState, epochCache, 'proposal-tx-collector-bench-worker', new DateProvider(), telemetry, deps);
87
86
  await client.start();
88
87
  installUnlimitedRateLimits();
89
88
  for(let i = 0; i < 120; i++){
@@ -162,11 +161,11 @@ async function runCollector(cmd) {
162
161
  try {
163
162
  if (collectorType === 'batch-requester') {
164
163
  const collector = new BatchTxRequesterCollector(p2pService, logger, new DateProvider(), noopTxValidator);
165
- const fetched = await executeTimeout((_signal)=>collector.collectTxs(parsedTxHashes, parsedProposal, pinnedPeer, internalTimeoutMs), timeoutMs, ()=>new Error(`Collector timed out after ${timeoutMs}ms`));
164
+ const fetched = await executeTimeout((_signal)=>collector.collectTxs(MissingTxsTracker.fromArray(parsedTxHashes), parsedProposal, pinnedPeer, internalTimeoutMs), timeoutMs, ()=>new Error(`Collector timed out after ${timeoutMs}ms`));
166
165
  fetchedCount = fetched.length;
167
166
  } else {
168
167
  const collector = new SendBatchRequestCollector(p2pService, BENCHMARK_CONSTANTS.FIXED_MAX_PEERS, BENCHMARK_CONSTANTS.FIXED_MAX_RETRY_ATTEMPTS);
169
- const fetched = await executeTimeout((_signal)=>collector.collectTxs(parsedTxHashes, parsedProposal, pinnedPeer, internalTimeoutMs), timeoutMs, ()=>new Error(`Collector timed out after ${timeoutMs}ms`));
168
+ const fetched = await executeTimeout((_signal)=>collector.collectTxs(MissingTxsTracker.fromArray(parsedTxHashes), parsedProposal, pinnedPeer, internalTimeoutMs), timeoutMs, ()=>new Error(`Collector timed out after ${timeoutMs}ms`));
170
169
  fetchedCount = fetched.length;
171
170
  }
172
171
  } catch (err) {
package/dest/config.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import { type ConfigMappingsType, SecretValue } from '@aztec/foundation/config';
2
- import { type DataStoreConfig } from '@aztec/kv-store/config';
3
2
  import { type AllowedElement, type ChainConfig, type SequencerConfig } from '@aztec/stdlib/config';
3
+ import { type DataStoreConfig } from '@aztec/stdlib/kv-store';
4
4
  import { type BatchTxRequesterConfig } from './services/reqresp/batch-tx-requester/config.js';
5
5
  import { type P2PReqRespConfig } from './services/reqresp/config.js';
6
6
  import { type TxCollectionConfig } from './services/tx_collection/config.js';
@@ -8,7 +8,9 @@ import { type TxFileStoreConfig } from './services/tx_file_store/config.js';
8
8
  /**
9
9
  * P2P client configuration values.
10
10
  */
11
- export interface P2PConfig extends P2PReqRespConfig, BatchTxRequesterConfig, ChainConfig, TxCollectionConfig, TxFileStoreConfig, Pick<SequencerConfig, 'blockDurationMs'> {
11
+ export interface P2PConfig extends P2PReqRespConfig, BatchTxRequesterConfig, ChainConfig, TxCollectionConfig, TxFileStoreConfig, Pick<SequencerConfig, 'blockDurationMs' | 'expectedBlockProposalsPerSlot' | 'maxTxsPerBlock'> {
12
+ /** Maximum transactions per block for validation. Overrides maxTxsPerBlock for gossip validation when set. */
13
+ validateMaxTxsPerBlock?: number;
12
14
  /** A flag dictating whether the P2P subsystem should be enabled. */
13
15
  p2pEnabled: boolean;
14
16
  /** The frequency in which to check for new L2 blocks. */
@@ -83,8 +85,8 @@ export interface P2PConfig extends P2PReqRespConfig, BatchTxRequesterConfig, Cha
83
85
  preferredPeers: string[];
84
86
  /** The maximum possible size of the P2P DB in KB. Overwrites the general dataStoreMapSizeKb. */
85
87
  p2pStoreMapSizeKb?: number;
86
- /** Which calls are allowed in the public setup phase of a tx. */
87
- txPublicSetupAllowList: AllowedElement[];
88
+ /** Additional entries to extend the default setup allow list. */
89
+ txPublicSetupAllowListExtend: AllowedElement[];
88
90
  /** The maximum number of pending txs before evicting lower priority txs. */
89
91
  maxPendingTxCount: number;
90
92
  /** The node's seen message ID cache size */
@@ -99,9 +101,7 @@ export interface P2PConfig extends P2PReqRespConfig, BatchTxRequesterConfig, Cha
99
101
  p2pMaxFailedAuthAttemptsAllowed: number;
100
102
  /** Whether transactions are disabled for this node. This means transactions will be rejected at the RPC and P2P layers. */
101
103
  disableTransactions: boolean;
102
- /** True to simulate discarding transactions. - For testing purposes only*/
103
- dropTransactions: boolean;
104
- /** The probability that a transaction is discarded. - For testing purposes only */
104
+ /** The probability that a transaction is discarded (0 = disabled). - For testing purposes only */
105
105
  dropTransactionsProbability: number;
106
106
  /** Whether to delete transactions from the pool after a reorg instead of moving them back to pending. */
107
107
  txPoolDeleteTxsAfterReorg: boolean;
@@ -111,6 +111,10 @@ export interface P2PConfig extends P2PReqRespConfig, BatchTxRequesterConfig, Cha
111
111
  fishermanMode: boolean;
112
112
  /** Broadcast block proposals even when a conflicting proposal for the same slot already exists in the pool (for testing purposes only). */
113
113
  broadcastEquivocatedProposals?: boolean;
114
+ /** Minimum age (ms) a transaction must have been in the pool before it's eligible for block building. */
115
+ minTxPoolAgeMs: number;
116
+ /** Minimum percentage fee increase required to replace an existing tx via RPC (0 = no bump). */
117
+ priceBumpPercentage: bigint;
114
118
  }
115
119
  export declare const DEFAULT_P2P_PORT = 40400;
116
120
  export declare const p2pConfigMappings: ConfigMappingsType<P2PConfig>;
@@ -144,8 +148,8 @@ export declare const bootnodeConfigMappings: ConfigMappingsType<Pick<{
144
148
  dialTimeoutMs: unknown;
145
149
  disableTransactions: unknown;
146
150
  doubleSpendSeverePeerPenaltyWindow: unknown;
147
- dropTransactions: unknown;
148
151
  dropTransactionsProbability: unknown;
152
+ expectedBlockProposalsPerSlot: unknown;
149
153
  fishermanMode: unknown;
150
154
  gossipsubD: unknown;
151
155
  gossipsubDLazy: unknown;
@@ -166,6 +170,8 @@ export declare const bootnodeConfigMappings: ConfigMappingsType<Pick<{
166
170
  listenAddress: unknown;
167
171
  maxPeerCount: unknown;
168
172
  maxPendingTxCount: unknown;
173
+ maxTxsPerBlock: unknown;
174
+ minTxPoolAgeMs: unknown;
169
175
  overallRequestTimeoutMs: unknown;
170
176
  p2pAllowOnlyValidators: unknown;
171
177
  p2pBroadcastPort: unknown;
@@ -182,6 +188,7 @@ export declare const bootnodeConfigMappings: ConfigMappingsType<Pick<{
182
188
  peerIdPrivateKeyPath: unknown;
183
189
  peerPenaltyValues: unknown;
184
190
  preferredPeers: unknown;
191
+ priceBumpPercentage: unknown;
185
192
  privatePeers: unknown;
186
193
  queryForIp: unknown;
187
194
  rollupVersion: unknown;
@@ -192,8 +199,14 @@ export declare const bootnodeConfigMappings: ConfigMappingsType<Pick<{
192
199
  txCollectionFastMaxParallelRequestsPerNode: unknown;
193
200
  txCollectionFastNodeIntervalMs: unknown;
194
201
  txCollectionFastNodesTimeoutBeforeReqRespMs: unknown;
202
+ txCollectionFileStoreFastBackoffBaseMs: unknown;
203
+ txCollectionFileStoreFastBackoffMaxMs: unknown;
195
204
  txCollectionFileStoreFastDelayMs: unknown;
205
+ txCollectionFileStoreFastWorkerCount: unknown;
206
+ txCollectionFileStoreSlowBackoffBaseMs: unknown;
207
+ txCollectionFileStoreSlowBackoffMaxMs: unknown;
196
208
  txCollectionFileStoreSlowDelayMs: unknown;
209
+ txCollectionFileStoreSlowWorkerCount: unknown;
197
210
  txCollectionFileStoreUrls: unknown;
198
211
  txCollectionMissingTxsCollectorType: unknown;
199
212
  txCollectionNodeRpcMaxBatchSize: unknown;
@@ -207,18 +220,21 @@ export declare const bootnodeConfigMappings: ConfigMappingsType<Pick<{
207
220
  txFileStoreUploadConcurrency: unknown;
208
221
  txFileStoreUrl: unknown;
209
222
  txPoolDeleteTxsAfterReorg: unknown;
210
- txPublicSetupAllowList: unknown;
223
+ txPublicSetupAllowListExtend: unknown;
224
+ validateMaxTxsPerBlock: unknown;
211
225
  }, "bootstrapNodes" | "dataDirectory" | "dataStoreMapSizeKb" | "l1ChainId" | "listenAddress" | "p2pBroadcastPort" | "p2pIp" | "p2pPort" | "peerIdPrivateKey" | "peerIdPrivateKeyPath" | "queryForIp">>;
212
226
  /**
213
227
  * Parses a string to a list of allowed elements.
214
- * Each encoded is expected to be of one of the following formats
215
- * `I:${address}`
216
- * `I:${address}:${selector}`
217
- * `C:${classId}`
218
- * `C:${classId}:${selector}`
228
+ * Each entry is expected to be of one of the following formats:
229
+ * `I:${address}:${selector}` — instance (contract address) with function selector
230
+ * `C:${classId}:${selector}` — class with function selector
231
+ *
232
+ * An optional flags segment can be appended after the selector:
233
+ * `I:${address}:${selector}:${flags}` or `C:${classId}:${selector}:${flags}`
234
+ * where flags is a `+`-separated list of: `os` (onlySelf), `rn` (rejectNullMsgSender), `cl=N` (calldataLength).
219
235
  *
220
236
  * @param value The string to parse
221
237
  * @returns A list of allowed elements
222
238
  */
223
239
  export declare function parseAllowList(value: string): AllowedElement[];
224
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxLQUFLLGtCQUFrQixFQUN2QixXQUFXLEVBUVosTUFBTSwwQkFBMEIsQ0FBQztBQUVsQyxPQUFPLEVBQUUsS0FBSyxlQUFlLEVBQXNCLE1BQU0sd0JBQXdCLENBQUM7QUFHbEYsT0FBTyxFQUNMLEtBQUssY0FBYyxFQUNuQixLQUFLLFdBQVcsRUFDaEIsS0FBSyxlQUFlLEVBR3JCLE1BQU0sc0JBQXNCLENBQUM7QUFFOUIsT0FBTyxFQUNMLEtBQUssc0JBQXNCLEVBRTVCLE1BQU0saURBQWlELENBQUM7QUFDekQsT0FBTyxFQUFFLEtBQUssZ0JBQWdCLEVBQTRCLE1BQU0sOEJBQThCLENBQUM7QUFDL0YsT0FBTyxFQUFFLEtBQUssa0JBQWtCLEVBQThCLE1BQU0sb0NBQW9DLENBQUM7QUFDekcsT0FBTyxFQUFFLEtBQUssaUJBQWlCLEVBQTZCLE1BQU0sb0NBQW9DLENBQUM7QUFFdkc7O0dBRUc7QUFDSCxNQUFNLFdBQVcsU0FDZixTQUFRLGdCQUFnQixFQUN0QixzQkFBc0IsRUFDdEIsV0FBVyxFQUNYLGtCQUFrQixFQUNsQixpQkFBaUIsRUFDakIsSUFBSSxDQUFDLGVBQWUsRUFBRSxpQkFBaUIsQ0FBQztJQUMxQyxvRUFBb0U7SUFDcEUsVUFBVSxFQUFFLE9BQU8sQ0FBQztJQUVwQix5REFBeUQ7SUFDekQsb0JBQW9CLEVBQUUsTUFBTSxDQUFDO0lBRTdCLHdEQUF3RDtJQUN4RCxtQkFBbUIsRUFBRSxNQUFNLENBQUM7SUFFNUIsdURBQXVEO0lBQ3ZELHFCQUFxQixFQUFFLE1BQU0sQ0FBQztJQUU5QixvRUFBb0U7SUFDcEUsNkJBQTZCLEVBQUUsT0FBTyxDQUFDO0lBRXZDLHFEQUFxRDtJQUNyRCxtQkFBbUIsRUFBRSxNQUFNLENBQUM7SUFFNUIsMkNBQTJDO0lBQzNDLFdBQVcsRUFB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
240
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiY29uZmlnLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi9zcmMvY29uZmlnLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFDTCxLQUFLLGtCQUFrQixFQUN2QixXQUFXLEVBU1osTUFBTSwwQkFBMEIsQ0FBQztBQUlsQyxPQUFPLEVBQ0wsS0FBSyxjQUFjLEVBQ25CLEtBQUssV0FBVyxFQUNoQixLQUFLLGVBQWUsRUFHckIsTUFBTSxzQkFBc0IsQ0FBQztBQUM5QixPQUFPLEVBQUUsS0FBSyxlQUFlLEVBQXNCLE1BQU0sd0JBQXdCLENBQUM7QUFFbEYsT0FBTyxFQUNMLEtBQUssc0JBQXNCLEVBRTVCLE1BQU0saURBQWlELENBQUM7QUFDekQsT0FBTyxFQUFFLEtBQUssZ0JBQWdCLEVBQTRCLE1BQU0sOEJBQThCLENBQUM7QUFDL0YsT0FBTyxFQUFFLEtBQUssa0JBQWtCLEVBQThCLE1BQU0sb0NBQW9DLENBQUM7QUFDekcsT0FBTyxFQUFFLEtBQUssaUJBQWlCLEVBQTZCLE1BQU0sb0NBQW9DLENBQUM7QUFFdkc7O0dBRUc7QUFDSCxNQUFNLFdBQVcsU0FDZixTQUFRLGdCQUFnQixFQUN0QixzQkFBc0IsRUFDdEIsV0FBVyxFQUNYLGtCQUFrQixFQUNsQixpQkFBaUIsRUFDakIsSUFBSSxDQUFDLGVBQWUsRUFBRSxpQkFBaUIsR0FBRywrQkFBK0IsR0FBRyxnQkFBZ0IsQ0FBQztJQUMvRiw4R0FBOEc7SUFDOUcsc0JBQXNCLENBQUMsRUFBRSxNQUFNLENBQUM7SUFFaEMsb0VBQW9FO0lBQ3BFLFVBQVUsRUFBRSxPQUFPLENBQUM7SUFFcEIseURBQXlEO0lBQ3pELG9CQUFvQixFQUFFLE1BQU0sQ0FBQztJQUU3Qix3REFBd0Q7SUFDeEQsbUJBQW1CLEVBQUUsTUFBTSxDQUFDO0lBRTVCLHVEQUF1RDtJQUN2RCxxQkFBcUIsRUFBRSxNQUFNLENBQUM7SUFFOUIsb0VBQW9FO0lBQ3BFLDZCQUE2QixFQUFFLE9BQU8sQ0FB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
@@ -1 +1 @@
1
- {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"AAAA,OAAO,EACL,KAAK,kBAAkB,EACvB,WAAW,EAQZ,MAAM,0BAA0B,CAAC;AAElC,OAAO,EAAE,KAAK,eAAe,EAAsB,MAAM,wBAAwB,CAAC;AAGlF,OAAO,EACL,KAAK,cAAc,EACnB,KAAK,WAAW,EAChB,KAAK,eAAe,EAGrB,MAAM,sBAAsB,CAAC;AAE9B,OAAO,EACL,KAAK,sBAAsB,EAE5B,MAAM,iDAAiD,CAAC;AACzD,OAAO,EAAE,KAAK,gBAAgB,EAA4B,MAAM,8BAA8B,CAAC;AAC/F,OAAO,EAAE,KAAK,kBAAkB,EAA8B,MAAM,oCAAoC,CAAC;AACzG,OAAO,EAAE,KAAK,iBAAiB,EAA6B,MAAM,oCAAoC,CAAC;AAEvG;;GAEG;AACH,MAAM,WAAW,SACf,SAAQ,gBAAgB,EACtB,sBAAsB,EACtB,WAAW,EACX,kBAAkB,EAClB,iBAAiB,EACjB,IAAI,CAAC,eAAe,EAAE,iBAAiB,CAAC;IAC1C,oEAAoE;IACpE,UAAU,EAAE,OAAO,CAAC;IAEpB,yDAAyD;IACzD,oBAAoB,EAAE,MAAM,CAAC;IAE7B,wDAAwD;IACxD,mBAAmB,EAAE,MAAM,CAAC;IAE5B,uDAAuD;IACvD,qBAAqB,EAAE,MAAM,CAAC;IAE9B,oEAAoE;IACpE,6BAA6B,EAAE,OAAO,CAAC;IAEvC,qDAAqD;IACrD,mBAAmB,EAAE,MAAM,CAAC;IAE5B,2CAA2C;IAC3C,WAAW,EAAE,MAAM,CAAC;IAEpB,oCAAoC;IACpC,OAAO,EAAE,MAAM,CAAC;IAEhB,6EAA6E;IAC7E,gBAAgB,CAAC,EAAE,MAAM,CAAC;IAE1B,0CAA0C;IAC1C,KAAK,CAAC,EAAE,MAAM,CAAC;IAEf,0BAA0B;IAC1B,aAAa,EAAE,MAAM,CAAC;IAEtB,6EAA6E;IAC7E,gBAAgB,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAEvC,4IAA4I;IAC5I,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAE9B,+CAA+C;IAC/C,cAAc,EAAE,MAAM,EAAE,CAAC;IAEzB,sEAAsE;IACtE,4BAA4B,EAAE,OAAO,CAAC;IAEtC,iGAAiG;IACjG,yBAAyB,EAAE,OAAO,CAAC;IAEnC,8GAA8G;IAC9G,YAAY,EAAE,MAAM,CAAC;IAErB,+HAA+H;IAC/H,UAAU,EAAE,OAAO,CAAC;IAEpB,4EAA4E;IAC5E,iBAAiB,EAAE,MAAM,CAAC;IAE1B,kDAAkD;IAClD,UAAU,EAAE,MAAM,CAAC;IAEnB,oDAAoD;IACpD,YAAY,EAAE,MAAM,CAAC;IAErB,oDAAoD;IACpD,YAAY,EAAE,MAAM,CAAC;IAErB,sDAAsD;IACtD,cAAc,EAAE,MAAM,CAAC;IAEvB,qEAAqE;IACrE,qBAAqB,EAAE,OAAO,CAAC;IAE/B,sEAAsE;IACtE,qBAAqB,EAAE,MAAM,CAAC;IAE9B,iFAAiF;IACjF,qBAAqB,EAAE,MAAM,CAAC;IAE9B,2DAA2D;IAC3D,gBAAgB,EAAE,MAAM,CAAC;IAEzB,gHAAgH;IAChH,kCAAkC,EAAE,MAAM,CAAC;IAE3C,gKAAgK;IAChK,sBAAsB,EAAE,MAAM,CAAC;IAE/B,iFAAiF;IACjF,yCAAyC,EAAE,MAAM,CAAC;IAElD,2GAA2G;IAC3G,wCAAwC,EAAE,MAAM,CAAC;IAEjD,oIAAoI;IACpI,iBAAiB,EAAE,MAAM,EAAE,CAAC;IAE5B,sIAAsI;IACtI,eAAe,EAAE,MAAM,CAAC;IAExB,+BAA+B;IAC/B,YAAY,EAAE,MAAM,EAAE,CAAC;IAEvB,+BAA+B;IAC/B,YAAY,EAAE,MAAM,EAAE,CAAC;IAEvB,iCAAiC;IACjC,cAAc,EAAE,MAAM,EAAE,CAAC;IAEzB,gGAAgG;IAChG,iBAAiB,CAAC,EAAE,MAAM,CAAC;IAE3B,iEAAiE;IACjE,sBAAsB,EAAE,cAAc,EAAE,CAAC;IAEzC,4EAA4E;IAC5E,iBAAiB,EAAE,MAAM,CAAC;IAE1B,4CAA4C;IAC5C,oBAAoB,EAAE,MAAM,CAAC;IAE7B,8DAA8D;IAC9D,yBAAyB,CAAC,EAAE,OAAO,CAAC;IAEpC,gDAAgD;IAChD,sBAAsB,CAAC,EAAE,OAAO,CAAC;IAEjC,iDAAiD;IACjD,oBAAoB,CAAC,EAAE,OAAO,CAAC;IAC/B,iFAAiF;IACjF,+BAA+B,EAAE,MAAM,CAAC;IAExC,2HAA2H;IAC3H,mBAAmB,EAAE,OAAO,CAAC;IAE7B,2EAA2E;IAC3E,gBAAgB,EAAE,OAAO,CAAC;IAE1B,mFAAmF;IACnF,2BAA2B,EAAE,MAAM,CAAC;IAEpC,yGAAyG;IACzG,yBAAyB,EAAE,OAAO,CAAC;IAEnC,oGAAoG;IACpG,0BAA0B,EAAE,OAAO,CAAC;IAEpC,iJAAiJ;IACjJ,aAAa,EAAE,OAAO,CAAC;IAEvB,2IAA2I;IAC3I,6BAA6B,CAAC,EAAE,OAAO,CAAC;CACzC;AAED,eAAO,MAAM,gBAAgB,QAAQ,CAAC;AAEtC,eAAO,MAAM,iBAAiB,EAAE,kBAAkB,CAAC,SAAS,CAoR3D,CAAC;AAEF;;;GAGG;AACH,wBAAgB,mBAAmB,IAAI,SAAS,CAE/C;AAED,wBAAgB,mBAAmB,IAAI,SAAS,CAE/C;AAED;;GAEG;AACH,MAAM,MAAM,cAAc,GAAG,IAAI,CAC/B,SAAS,EACP,OAAO,GACP,SAAS,GACT,kBAAkB,GAClB,kBAAkB,GAClB,sBAAsB,GACtB,gBAAgB,GAChB,eAAe,GACf,YAAY,CACf,GACC,QAAQ,CAAC,IAAI,CAAC,SAAS,EAAE,OAAO,GAAG,SAAS,CAAC,CAAC,GAC9C,IAAI,CAAC,eAAe,EAAE,eAAe,GAAG,oBAAoB,CAAC,GAC7D,IAAI,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;AAgBjC,eAAO,MAAM,sBAAsB;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;sMAGlC,CAAC;AAEF;;;;;;;;;;GAUG;AACH,wBAAgB,cAAc,CAAC,KAAK,EAAE,MAAM,GAAG,cAAc,EAAE,CAqC9D"}
1
+ {"version":3,"file":"config.d.ts","sourceRoot":"","sources":["../src/config.ts"],"names":[],"mappings":"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"}
package/dest/config.js CHANGED
@@ -1,15 +1,20 @@
1
- import { booleanConfigHelper, getConfigFromMappings, getDefaultConfig, numberConfigHelper, percentageConfigHelper, pickConfigMappings, secretStringConfigHelper } from '@aztec/foundation/config';
1
+ import { bigintConfigHelper, booleanConfigHelper, getConfigFromMappings, getDefaultConfig, numberConfigHelper, percentageConfigHelper, pickConfigMappings, secretStringConfigHelper } from '@aztec/foundation/config';
2
2
  import { Fr } from '@aztec/foundation/curves/bn254';
3
- import { dataConfigMappings } from '@aztec/kv-store/config';
4
3
  import { FunctionSelector } from '@aztec/stdlib/abi/function-selector';
5
4
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
6
5
  import { chainConfigMappings, sharedSequencerConfigMappings } from '@aztec/stdlib/config';
6
+ import { dataConfigMappings } from '@aztec/stdlib/kv-store';
7
7
  import { batchTxRequesterConfigMappings } from './services/reqresp/batch-tx-requester/config.js';
8
8
  import { p2pReqRespConfigMappings } from './services/reqresp/config.js';
9
9
  import { txCollectionConfigMappings } from './services/tx_collection/config.js';
10
10
  import { txFileStoreConfigMappings } from './services/tx_file_store/config.js';
11
11
  export const DEFAULT_P2P_PORT = 40400;
12
12
  export const p2pConfigMappings = {
13
+ validateMaxTxsPerBlock: {
14
+ env: 'VALIDATOR_MAX_TX_PER_BLOCK',
15
+ description: 'Maximum transactions per block for validation. Overrides maxTxsPerBlock for gossip validation when set.',
16
+ parseEnv: (val)=>val ? parseInt(val, 10) : undefined
17
+ },
13
18
  p2pEnabled: {
14
19
  env: 'P2P_ENABLED',
15
20
  description: 'A flag dictating whether the P2P subsystem should be enabled.',
@@ -206,11 +211,11 @@ export const p2pConfigMappings = {
206
211
  parseEnv: (val)=>val ? +val : undefined,
207
212
  description: 'The maximum possible size of the P2P DB in KB. Overwrites the general dataStoreMapSizeKb.'
208
213
  },
209
- txPublicSetupAllowList: {
214
+ txPublicSetupAllowListExtend: {
210
215
  env: 'TX_PUBLIC_SETUP_ALLOWLIST',
211
216
  parseEnv: (val)=>parseAllowList(val),
212
- description: 'The list of functions calls allowed to run in setup',
213
- printDefault: ()=>'AuthRegistry, FeeJuice.increase_public_balance, Token.increase_public_balance, FPC.prepare_fee'
217
+ description: 'Additional entries to extend the default setup allow list. Format: I:address:selector[:flags],C:classId:selector[:flags]. Flags: os (onlySelf), rn (rejectNullMsgSender), cl=N (calldataLength), joined with +.',
218
+ printDefault: ()=>'Default: AuthRegistry._set_authorized, AuthRegistry.set_authorized, FeeJuice._increase_public_balance'
214
219
  },
215
220
  maxPendingTxCount: {
216
221
  env: 'P2P_MAX_PENDING_TX_COUNT',
@@ -239,11 +244,6 @@ export const p2pConfigMappings = {
239
244
  description: 'Number of auth attempts to allow before peer is banned. Number is inclusive',
240
245
  ...numberConfigHelper(3)
241
246
  },
242
- dropTransactions: {
243
- env: 'P2P_DROP_TX',
244
- description: 'True to simulate discarding transactions. - For testing purposes only',
245
- ...booleanConfigHelper(false)
246
- },
247
247
  dropTransactionsProbability: {
248
248
  env: 'P2P_DROP_TX_CHANCE',
249
249
  description: 'The probability that a transaction is discarded (0 - 1). - For testing purposes only',
@@ -273,6 +273,16 @@ export const p2pConfigMappings = {
273
273
  description: 'Broadcast block proposals even when a conflicting proposal for the same slot already exists in the pool (for testing purposes only).',
274
274
  ...booleanConfigHelper(false)
275
275
  },
276
+ minTxPoolAgeMs: {
277
+ env: 'P2P_MIN_TX_POOL_AGE_MS',
278
+ description: 'Minimum age (ms) a transaction must have been in the pool before it is eligible for block building.',
279
+ ...numberConfigHelper(2_000)
280
+ },
281
+ priceBumpPercentage: {
282
+ env: 'P2P_RPC_PRICE_BUMP_PERCENTAGE',
283
+ description: 'Minimum percentage fee increase required to replace an existing tx via RPC. Even at 0%, replacement still requires paying at least 1 unit more.',
284
+ ...bigintConfigHelper(10n)
285
+ },
276
286
  ...sharedSequencerConfigMappings,
277
287
  ...p2pReqRespConfigMappings,
278
288
  ...batchTxRequesterConfigMappings,
@@ -307,13 +317,37 @@ export const bootnodeConfigMappings = pickConfigMappings({
307
317
  ...dataConfigMappings,
308
318
  ...chainConfigMappings
309
319
  }, bootnodeConfigKeys);
320
+ /**
321
+ * Parses a `+`-separated flags string into validation properties for an allow list entry.
322
+ * Supported flags: `os` (onlySelf), `rn` (rejectNullMsgSender), `cl=N` (calldataLength).
323
+ */ function parseFlags(flags, entry) {
324
+ const result = {};
325
+ for (const flag of flags.split('+')){
326
+ if (flag === 'os') {
327
+ result.onlySelf = true;
328
+ } else if (flag === 'rn') {
329
+ result.rejectNullMsgSender = true;
330
+ } else if (flag.startsWith('cl=')) {
331
+ const n = parseInt(flag.slice(3), 10);
332
+ if (isNaN(n) || n < 0) {
333
+ throw new Error(`Invalid allow list entry "${entry}": invalid calldataLength in flag "${flag}". Expected a non-negative integer.`);
334
+ }
335
+ result.calldataLength = n;
336
+ } else {
337
+ throw new Error(`Invalid allow list entry "${entry}": unknown flag "${flag}". Supported flags: os, rn, cl=N.`);
338
+ }
339
+ }
340
+ return result;
341
+ }
310
342
  /**
311
343
  * Parses a string to a list of allowed elements.
312
- * Each encoded is expected to be of one of the following formats
313
- * `I:${address}`
314
- * `I:${address}:${selector}`
315
- * `C:${classId}`
316
- * `C:${classId}:${selector}`
344
+ * Each entry is expected to be of one of the following formats:
345
+ * `I:${address}:${selector}` — instance (contract address) with function selector
346
+ * `C:${classId}:${selector}` — class with function selector
347
+ *
348
+ * An optional flags segment can be appended after the selector:
349
+ * `I:${address}:${selector}:${flags}` or `C:${classId}:${selector}:${flags}`
350
+ * where flags is a `+`-separated list of: `os` (onlySelf), `rn` (rejectNullMsgSender), `cl=N` (calldataLength).
317
351
  *
318
352
  * @param value The string to parse
319
353
  * @returns A list of allowed elements
@@ -323,30 +357,30 @@ export const bootnodeConfigMappings = pickConfigMappings({
323
357
  return entries;
324
358
  }
325
359
  for (const val of value.split(',')){
326
- const [typeString, identifierString, selectorString] = val.split(':');
327
- const selector = selectorString !== undefined ? FunctionSelector.fromString(selectorString) : undefined;
360
+ const trimmed = val.trim();
361
+ if (!trimmed) {
362
+ continue;
363
+ }
364
+ const [typeString, identifierString, selectorString, flagsString] = trimmed.split(':');
365
+ if (!selectorString) {
366
+ throw new Error(`Invalid allow list entry "${trimmed}": selector is required. Expected format: I:address:selector or C:classId:selector`);
367
+ }
368
+ const selector = FunctionSelector.fromString(selectorString);
369
+ const flags = flagsString ? parseFlags(flagsString, trimmed) : {};
328
370
  if (typeString === 'I') {
329
- if (selector) {
330
- entries.push({
331
- address: AztecAddress.fromString(identifierString),
332
- selector
333
- });
334
- } else {
335
- entries.push({
336
- address: AztecAddress.fromString(identifierString)
337
- });
338
- }
371
+ entries.push({
372
+ address: AztecAddress.fromString(identifierString),
373
+ selector,
374
+ ...flags
375
+ });
339
376
  } else if (typeString === 'C') {
340
- if (selector) {
341
- entries.push({
342
- classId: Fr.fromHexString(identifierString),
343
- selector
344
- });
345
- } else {
346
- entries.push({
347
- classId: Fr.fromHexString(identifierString)
348
- });
349
- }
377
+ entries.push({
378
+ classId: Fr.fromHexString(identifierString),
379
+ selector,
380
+ ...flags
381
+ });
382
+ } else {
383
+ throw new Error(`Invalid allow list entry "${trimmed}": unknown type "${typeString}". Expected "I" (instance) or "C" (class).`);
350
384
  }
351
385
  }
352
386
  return entries;
@@ -0,0 +1,8 @@
1
+ import type { TxPoolRejectionError } from '../mem_pools/tx_pool_v2/eviction/interfaces.js';
2
+ /** Error thrown when a transaction is not added to the mempool. */
3
+ export declare class TxPoolError extends Error {
4
+ readonly reason: TxPoolRejectionError;
5
+ readonly data: TxPoolRejectionError;
6
+ constructor(reason: TxPoolRejectionError);
7
+ }
8
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHgtcG9vbC5lcnJvci5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vc3JjL2Vycm9ycy90eC1wb29sLmVycm9yLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sS0FBSyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sZ0RBQWdELENBQUM7QUFFM0YsbUVBQW1FO0FBQ25FLHFCQUFhLFdBQVksU0FBUSxLQUFLO2FBR1IsTUFBTSxFQUFFLG9CQUFvQjtJQUZ4RCxTQUFnQixJQUFJLEVBQUUsb0JBQW9CLENBQUM7SUFFM0MsWUFBNEIsTUFBTSxFQUFFLG9CQUFvQixFQUl2RDtDQUNGIn0=
@@ -0,0 +1 @@
1
+ {"version":3,"file":"tx-pool.error.d.ts","sourceRoot":"","sources":["../../src/errors/tx-pool.error.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,oBAAoB,EAAE,MAAM,gDAAgD,CAAC;AAE3F,mEAAmE;AACnE,qBAAa,WAAY,SAAQ,KAAK;aAGR,MAAM,EAAE,oBAAoB;IAFxD,SAAgB,IAAI,EAAE,oBAAoB,CAAC;IAE3C,YAA4B,MAAM,EAAE,oBAAoB,EAIvD;CACF"}
@@ -0,0 +1,9 @@
1
+ /** Error thrown when a transaction is not added to the mempool. */ export class TxPoolError extends Error {
2
+ reason;
3
+ data;
4
+ constructor(reason){
5
+ super(reason.message), this.reason = reason;
6
+ this.name = 'TxPoolError';
7
+ this.data = reason;
8
+ }
9
+ }