@aztec/p2p 0.0.1-commit.f295ac2 → 0.0.1-commit.f504929

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 (490) hide show
  1. package/dest/bootstrap/bootstrap.d.ts +4 -3
  2. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  3. package/dest/bootstrap/bootstrap.js +4 -4
  4. package/dest/client/factory.d.ts +10 -10
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +45 -18
  7. package/dest/client/interface.d.ts +46 -33
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +41 -51
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +156 -200
  12. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +304 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  18. package/dest/config.d.ts +42 -15
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +46 -37
  21. package/dest/errors/tx-pool.error.d.ts +8 -0
  22. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  23. package/dest/errors/tx-pool.error.js +9 -0
  24. package/dest/index.d.ts +2 -1
  25. package/dest/index.d.ts.map +1 -1
  26. package/dest/index.js +1 -0
  27. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +104 -88
  28. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  29. package/dest/mem_pools/attestation_pool/attestation_pool.js +445 -3
  30. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  31. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +353 -87
  33. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  34. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  35. package/dest/mem_pools/attestation_pool/index.js +1 -2
  36. package/dest/mem_pools/attestation_pool/mocks.d.ts +2 -2
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  38. package/dest/mem_pools/attestation_pool/mocks.js +2 -2
  39. package/dest/mem_pools/index.d.ts +3 -2
  40. package/dest/mem_pools/index.d.ts.map +1 -1
  41. package/dest/mem_pools/index.js +1 -1
  42. package/dest/mem_pools/instrumentation.d.ts +4 -2
  43. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  44. package/dest/mem_pools/instrumentation.js +18 -16
  45. package/dest/mem_pools/interface.d.ts +5 -5
  46. package/dest/mem_pools/interface.d.ts.map +1 -1
  47. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +3 -3
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  49. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +3 -2
  50. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -1
  51. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +3 -2
  52. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -1
  53. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +3 -3
  54. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -1
  55. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +8 -1
  56. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +3 -3
  57. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +3 -3
  58. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -1
  59. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +2 -0
  60. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  61. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  63. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  64. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  66. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  67. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  69. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  70. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  72. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  73. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +93 -0
  75. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  76. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  77. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  78. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  79. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  80. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  81. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +174 -0
  82. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  83. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  84. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  85. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  90. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  91. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +73 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  99. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  100. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  101. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  102. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  103. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  104. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  105. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +211 -0
  106. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  107. package/dest/mem_pools/tx_pool_v2/interfaces.js +9 -0
  108. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +119 -0
  109. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  110. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +193 -0
  111. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  112. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  113. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  114. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  115. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  116. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +354 -0
  117. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +60 -0
  118. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  119. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +164 -0
  120. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +78 -0
  121. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  122. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +908 -0
  123. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +3 -3
  124. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  125. package/dest/msg_validators/attestation_validator/attestation_validator.js +41 -10
  126. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  127. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  128. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -6
  129. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  130. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  131. package/dest/msg_validators/clock_tolerance.js +37 -0
  132. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +2 -1
  133. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  134. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +2 -1
  135. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  136. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +5 -3
  137. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  138. package/dest/msg_validators/proposal_validator/proposal_validator.js +65 -31
  139. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +4 -3
  140. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -1
  141. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +257 -62
  142. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  143. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  144. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  145. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  146. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  147. package/dest/msg_validators/tx_validator/allowed_public_setup.js +25 -10
  148. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  149. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  150. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  151. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  152. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  153. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  154. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  155. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  156. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  157. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  158. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  159. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  160. package/dest/msg_validators/tx_validator/factory.d.ts +118 -5
  161. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  162. package/dest/msg_validators/tx_validator/factory.js +228 -57
  163. package/dest/msg_validators/tx_validator/gas_validator.d.ts +59 -3
  164. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  165. package/dest/msg_validators/tx_validator/gas_validator.js +76 -38
  166. package/dest/msg_validators/tx_validator/index.d.ts +3 -1
  167. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  168. package/dest/msg_validators/tx_validator/index.js +2 -0
  169. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  170. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  171. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  172. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  173. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  174. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  175. package/dest/msg_validators/tx_validator/phases_validator.d.ts +4 -3
  176. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  177. package/dest/msg_validators/tx_validator/phases_validator.js +28 -27
  178. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  179. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  180. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  181. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  182. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  183. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  184. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  185. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  186. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  187. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  188. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  189. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  190. package/dest/services/data_store.d.ts +1 -1
  191. package/dest/services/data_store.d.ts.map +1 -1
  192. package/dest/services/data_store.js +10 -6
  193. package/dest/services/discv5/discV5_service.js +1 -1
  194. package/dest/services/dummy_service.d.ts +24 -4
  195. package/dest/services/dummy_service.d.ts.map +1 -1
  196. package/dest/services/dummy_service.js +46 -1
  197. package/dest/services/encoding.d.ts +3 -3
  198. package/dest/services/encoding.d.ts.map +1 -1
  199. package/dest/services/encoding.js +13 -13
  200. package/dest/services/gossipsub/index.d.ts +3 -0
  201. package/dest/services/gossipsub/index.d.ts.map +1 -0
  202. package/dest/services/gossipsub/index.js +2 -0
  203. package/dest/services/gossipsub/scoring.d.ts +21 -3
  204. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  205. package/dest/services/gossipsub/scoring.js +24 -7
  206. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  207. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  208. package/dest/services/gossipsub/topic_score_params.js +346 -0
  209. package/dest/services/index.d.ts +2 -1
  210. package/dest/services/index.d.ts.map +1 -1
  211. package/dest/services/index.js +1 -0
  212. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  213. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  214. package/dest/services/libp2p/instrumentation.js +14 -3
  215. package/dest/services/libp2p/libp2p_service.d.ts +101 -43
  216. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  217. package/dest/services/libp2p/libp2p_service.js +463 -366
  218. package/dest/services/peer-manager/metrics.d.ts +4 -2
  219. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  220. package/dest/services/peer-manager/metrics.js +26 -5
  221. package/dest/services/peer-manager/peer_manager.d.ts +1 -1
  222. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  223. package/dest/services/peer-manager/peer_manager.js +2 -1
  224. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  225. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  226. package/dest/services/peer-manager/peer_scoring.js +33 -4
  227. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +48 -0
  228. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  229. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +539 -0
  230. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  231. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  232. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  233. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +46 -0
  234. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  235. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  236. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +34 -0
  237. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  238. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +130 -0
  239. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +60 -0
  240. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  241. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +173 -0
  242. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  243. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  244. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  245. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  246. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  247. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  248. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  249. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  250. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  251. package/dest/services/reqresp/interface.d.ts +14 -3
  252. package/dest/services/reqresp/interface.d.ts.map +1 -1
  253. package/dest/services/reqresp/interface.js +17 -3
  254. package/dest/services/reqresp/metrics.d.ts +6 -5
  255. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  256. package/dest/services/reqresp/metrics.js +17 -5
  257. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  258. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  259. package/dest/services/reqresp/protocols/block_txs/bitvector.js +5 -0
  260. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  261. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  262. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  263. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  264. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  265. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  266. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  267. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  268. package/dest/services/reqresp/protocols/tx.js +20 -0
  269. package/dest/services/reqresp/reqresp.d.ts +6 -1
  270. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  271. package/dest/services/reqresp/reqresp.js +71 -27
  272. package/dest/services/service.d.ts +42 -3
  273. package/dest/services/service.d.ts.map +1 -1
  274. package/dest/services/tx_collection/config.d.ts +22 -1
  275. package/dest/services/tx_collection/config.d.ts.map +1 -1
  276. package/dest/services/tx_collection/config.js +55 -1
  277. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  278. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  279. package/dest/services/tx_collection/fast_tx_collection.js +71 -44
  280. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  281. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  282. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  283. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  284. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  285. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  286. package/dest/services/tx_collection/index.d.ts +3 -1
  287. package/dest/services/tx_collection/index.d.ts.map +1 -1
  288. package/dest/services/tx_collection/index.js +2 -0
  289. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  290. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  291. package/dest/services/tx_collection/instrumentation.js +10 -2
  292. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  293. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  294. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  295. package/dest/services/tx_collection/proposal_tx_collector.d.ts +49 -0
  296. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  297. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  298. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  299. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  300. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  301. package/dest/services/tx_collection/tx_collection.d.ts +29 -16
  302. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  303. package/dest/services/tx_collection/tx_collection.js +79 -7
  304. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  305. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  306. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  307. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  308. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  309. package/dest/services/tx_collection/tx_source.js +19 -2
  310. package/dest/services/tx_file_store/config.d.ts +16 -0
  311. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  312. package/dest/services/tx_file_store/config.js +22 -0
  313. package/dest/services/tx_file_store/index.d.ts +4 -0
  314. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  315. package/dest/services/tx_file_store/index.js +3 -0
  316. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  317. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  318. package/dest/services/tx_file_store/instrumentation.js +29 -0
  319. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  320. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  321. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  322. package/dest/services/tx_provider.d.ts +6 -6
  323. package/dest/services/tx_provider.d.ts.map +1 -1
  324. package/dest/services/tx_provider.js +9 -8
  325. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  326. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  327. package/dest/services/tx_provider_instrumentation.js +5 -5
  328. package/dest/test-helpers/index.d.ts +3 -1
  329. package/dest/test-helpers/index.d.ts.map +1 -1
  330. package/dest/test-helpers/index.js +2 -0
  331. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  332. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  333. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  334. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  335. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  336. package/dest/test-helpers/mock-pubsub.js +105 -4
  337. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  338. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  339. package/dest/test-helpers/reqresp-nodes.js +4 -3
  340. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  341. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  342. package/dest/test-helpers/test_tx_provider.js +41 -0
  343. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  344. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  345. package/dest/test-helpers/testbench-utils.js +366 -0
  346. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  347. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  348. package/dest/testbench/p2p_client_testbench_worker.js +219 -140
  349. package/dest/testbench/worker_client_manager.d.ts +51 -6
  350. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  351. package/dest/testbench/worker_client_manager.js +226 -44
  352. package/dest/util.d.ts +2 -2
  353. package/dest/util.d.ts.map +1 -1
  354. package/package.json +14 -14
  355. package/src/bootstrap/bootstrap.ts +7 -4
  356. package/src/client/factory.ts +83 -36
  357. package/src/client/interface.ts +56 -34
  358. package/src/client/p2p_client.ts +196 -251
  359. package/src/client/test/tx_proposal_collector/README.md +227 -0
  360. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +345 -0
  361. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  362. package/src/config.ts +81 -43
  363. package/src/errors/tx-pool.error.ts +12 -0
  364. package/src/index.ts +1 -0
  365. package/src/mem_pools/attestation_pool/attestation_pool.ts +497 -91
  366. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +442 -102
  367. package/src/mem_pools/attestation_pool/index.ts +9 -2
  368. package/src/mem_pools/attestation_pool/mocks.ts +2 -1
  369. package/src/mem_pools/index.ts +4 -1
  370. package/src/mem_pools/instrumentation.ts +19 -14
  371. package/src/mem_pools/interface.ts +4 -4
  372. package/src/mem_pools/tx_pool/README.md +1 -1
  373. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +2 -2
  374. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +2 -1
  375. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +2 -1
  376. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +10 -7
  377. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  378. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  379. package/src/mem_pools/tx_pool_v2/README.md +275 -0
  380. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  381. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  382. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  383. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  384. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  385. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  386. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  387. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +209 -0
  388. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  389. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  390. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  391. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +90 -0
  392. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  393. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  394. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  395. package/src/mem_pools/tx_pool_v2/interfaces.ts +242 -0
  396. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +297 -0
  397. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  398. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +444 -0
  399. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +226 -0
  400. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1088 -0
  401. package/src/msg_validators/attestation_validator/attestation_validator.ts +26 -14
  402. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  403. package/src/msg_validators/clock_tolerance.ts +51 -0
  404. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +1 -1
  405. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +1 -1
  406. package/src/msg_validators/proposal_validator/proposal_validator.ts +46 -32
  407. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +233 -66
  408. package/src/msg_validators/tx_validator/README.md +115 -0
  409. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  410. package/src/msg_validators/tx_validator/allowed_public_setup.ts +27 -13
  411. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  412. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  413. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  414. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  415. package/src/msg_validators/tx_validator/factory.ts +372 -55
  416. package/src/msg_validators/tx_validator/gas_validator.ts +98 -29
  417. package/src/msg_validators/tx_validator/index.ts +2 -0
  418. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  419. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  420. package/src/msg_validators/tx_validator/phases_validator.ts +30 -32
  421. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  422. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  423. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  424. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  425. package/src/services/data_store.ts +10 -7
  426. package/src/services/discv5/discV5_service.ts +1 -1
  427. package/src/services/dummy_service.ts +59 -2
  428. package/src/services/encoding.ts +11 -12
  429. package/src/services/gossipsub/README.md +641 -0
  430. package/src/services/gossipsub/index.ts +2 -0
  431. package/src/services/gossipsub/scoring.ts +29 -5
  432. package/src/services/gossipsub/topic_score_params.ts +487 -0
  433. package/src/services/index.ts +1 -0
  434. package/src/services/libp2p/instrumentation.ts +15 -2
  435. package/src/services/libp2p/libp2p_service.ts +514 -396
  436. package/src/services/peer-manager/metrics.ts +28 -4
  437. package/src/services/peer-manager/peer_manager.ts +2 -1
  438. package/src/services/peer-manager/peer_scoring.ts +29 -1
  439. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  440. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +678 -0
  441. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  442. package/src/services/reqresp/batch-tx-requester/interface.ts +53 -0
  443. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +161 -0
  444. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +244 -0
  445. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  446. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  447. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  448. package/src/services/reqresp/interface.ts +31 -3
  449. package/src/services/reqresp/metrics.ts +34 -9
  450. package/src/services/reqresp/protocols/block_txs/bitvector.ts +7 -0
  451. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  452. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  453. package/src/services/reqresp/protocols/tx.ts +22 -0
  454. package/src/services/reqresp/reqresp.ts +82 -23
  455. package/src/services/service.ts +55 -2
  456. package/src/services/tx_collection/config.ts +83 -1
  457. package/src/services/tx_collection/fast_tx_collection.ts +93 -47
  458. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  459. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  460. package/src/services/tx_collection/index.ts +6 -0
  461. package/src/services/tx_collection/instrumentation.ts +17 -2
  462. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  463. package/src/services/tx_collection/proposal_tx_collector.ts +113 -0
  464. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  465. package/src/services/tx_collection/tx_collection.ts +121 -24
  466. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  467. package/src/services/tx_collection/tx_source.ts +22 -3
  468. package/src/services/tx_file_store/config.ts +37 -0
  469. package/src/services/tx_file_store/index.ts +3 -0
  470. package/src/services/tx_file_store/instrumentation.ts +36 -0
  471. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  472. package/src/services/tx_provider.ts +12 -11
  473. package/src/services/tx_provider_instrumentation.ts +11 -5
  474. package/src/test-helpers/index.ts +2 -0
  475. package/src/test-helpers/make-test-p2p-clients.ts +3 -5
  476. package/src/test-helpers/mock-pubsub.ts +146 -9
  477. package/src/test-helpers/reqresp-nodes.ts +4 -6
  478. package/src/test-helpers/test_tx_provider.ts +64 -0
  479. package/src/test-helpers/testbench-utils.ts +430 -0
  480. package/src/testbench/p2p_client_testbench_worker.ts +333 -135
  481. package/src/testbench/worker_client_manager.ts +304 -47
  482. package/src/util.ts +7 -1
  483. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  484. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  485. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  486. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  487. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  488. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  489. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  490. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
package/dest/config.js CHANGED
@@ -3,9 +3,11 @@ import { Fr } from '@aztec/foundation/curves/bn254';
3
3
  import { dataConfigMappings } from '@aztec/kv-store/config';
4
4
  import { FunctionSelector } from '@aztec/stdlib/abi/function-selector';
5
5
  import { AztecAddress } from '@aztec/stdlib/aztec-address';
6
- import { chainConfigMappings } from '@aztec/stdlib/config';
6
+ import { chainConfigMappings, sharedSequencerConfigMappings } from '@aztec/stdlib/config';
7
+ import { batchTxRequesterConfigMappings } from './services/reqresp/batch-tx-requester/config.js';
7
8
  import { p2pReqRespConfigMappings } from './services/reqresp/config.js';
8
9
  import { txCollectionConfigMappings } from './services/tx_collection/config.js';
10
+ import { txFileStoreConfigMappings } from './services/tx_file_store/config.js';
9
11
  export const DEFAULT_P2P_PORT = 40400;
10
12
  export const p2pConfigMappings = {
11
13
  p2pEnabled: {
@@ -23,6 +25,11 @@ export const p2pConfigMappings = {
23
25
  description: 'The frequency in which to check for new L2 blocks.',
24
26
  ...numberConfigHelper(100)
25
27
  },
28
+ slotCheckIntervalMS: {
29
+ env: 'P2P_SLOT_CHECK_INTERVAL_MS',
30
+ description: 'The frequency in which to check for new L2 slots.',
31
+ ...numberConfigHelper(1000)
32
+ },
26
33
  debugDisableColocationPenalty: {
27
34
  env: 'DEBUG_P2P_DISABLE_COLOCATION_PENALTY',
28
35
  description: 'DEBUG: Disable colocation penalty - NEVER set to true in production',
@@ -199,11 +206,11 @@ export const p2pConfigMappings = {
199
206
  parseEnv: (val)=>val ? +val : undefined,
200
207
  description: 'The maximum possible size of the P2P DB in KB. Overwrites the general dataStoreMapSizeKb.'
201
208
  },
202
- txPublicSetupAllowList: {
209
+ txPublicSetupAllowListExtend: {
203
210
  env: 'TX_PUBLIC_SETUP_ALLOWLIST',
204
211
  parseEnv: (val)=>parseAllowList(val),
205
- description: 'The list of functions calls allowed to run in setup',
206
- printDefault: ()=>'AuthRegistry, FeeJuice.increase_public_balance, Token.increase_public_balance, FPC.prepare_fee'
212
+ description: 'Additional entries to extend the default setup allow list. Format: I:address:selector,C:classId:selector',
213
+ printDefault: ()=>'Default: AuthRegistry._set_authorized, FeeJuice._increase_public_balance, Token._increase_public_balance, Token.transfer_in_public'
207
214
  },
208
215
  maxPendingTxCount: {
209
216
  env: 'P2P_MAX_PENDING_TX_COUNT',
@@ -232,11 +239,6 @@ export const p2pConfigMappings = {
232
239
  description: 'Number of auth attempts to allow before peer is banned. Number is inclusive',
233
240
  ...numberConfigHelper(3)
234
241
  },
235
- dropTransactions: {
236
- env: 'P2P_DROP_TX',
237
- description: 'True to simulate discarding transactions. - For testing purposes only',
238
- ...booleanConfigHelper(false)
239
- },
240
242
  dropTransactionsProbability: {
241
243
  env: 'P2P_DROP_TX_CHANCE',
242
244
  description: 'The probability that a transaction is discarded (0 - 1). - For testing purposes only',
@@ -262,9 +264,21 @@ export const p2pConfigMappings = {
262
264
  description: 'Whether to run in fisherman mode: validates all proposals and attestations but does not broadcast attestations or participate in consensus.',
263
265
  ...booleanConfigHelper(false)
264
266
  },
267
+ broadcastEquivocatedProposals: {
268
+ description: 'Broadcast block proposals even when a conflicting proposal for the same slot already exists in the pool (for testing purposes only).',
269
+ ...booleanConfigHelper(false)
270
+ },
271
+ minTxPoolAgeMs: {
272
+ env: 'P2P_MIN_TX_POOL_AGE_MS',
273
+ description: 'Minimum age (ms) a transaction must have been in the pool before it is eligible for block building.',
274
+ ...numberConfigHelper(2_000)
275
+ },
276
+ ...sharedSequencerConfigMappings,
265
277
  ...p2pReqRespConfigMappings,
278
+ ...batchTxRequesterConfigMappings,
266
279
  ...chainConfigMappings,
267
- ...txCollectionConfigMappings
280
+ ...txCollectionConfigMappings,
281
+ ...txFileStoreConfigMappings
268
282
  };
269
283
  /**
270
284
  * Gets the config values for p2p client from environment variables.
@@ -295,11 +309,9 @@ export const bootnodeConfigMappings = pickConfigMappings({
295
309
  }, bootnodeConfigKeys);
296
310
  /**
297
311
  * Parses a string to a list of allowed elements.
298
- * Each encoded is expected to be of one of the following formats
299
- * `I:${address}`
300
- * `I:${address}:${selector}`
301
- * `C:${classId}`
302
- * `C:${classId}:${selector}`
312
+ * Each entry is expected to be of one of the following formats:
313
+ * `I:${address}:${selector}` — instance (contract address) with function selector
314
+ * `C:${classId}:${selector}` — class with function selector
303
315
  *
304
316
  * @param value The string to parse
305
317
  * @returns A list of allowed elements
@@ -309,30 +321,27 @@ export const bootnodeConfigMappings = pickConfigMappings({
309
321
  return entries;
310
322
  }
311
323
  for (const val of value.split(',')){
312
- const [typeString, identifierString, selectorString] = val.split(':');
313
- const selector = selectorString !== undefined ? FunctionSelector.fromString(selectorString) : undefined;
324
+ const trimmed = val.trim();
325
+ if (!trimmed) {
326
+ continue;
327
+ }
328
+ const [typeString, identifierString, selectorString] = trimmed.split(':');
329
+ if (!selectorString) {
330
+ throw new Error(`Invalid allow list entry "${trimmed}": selector is required. Expected format: I:address:selector or C:classId:selector`);
331
+ }
332
+ const selector = FunctionSelector.fromString(selectorString);
314
333
  if (typeString === 'I') {
315
- if (selector) {
316
- entries.push({
317
- address: AztecAddress.fromString(identifierString),
318
- selector
319
- });
320
- } else {
321
- entries.push({
322
- address: AztecAddress.fromString(identifierString)
323
- });
324
- }
334
+ entries.push({
335
+ address: AztecAddress.fromString(identifierString),
336
+ selector
337
+ });
325
338
  } else if (typeString === 'C') {
326
- if (selector) {
327
- entries.push({
328
- classId: Fr.fromHexString(identifierString),
329
- selector
330
- });
331
- } else {
332
- entries.push({
333
- classId: Fr.fromHexString(identifierString)
334
- });
335
- }
339
+ entries.push({
340
+ classId: Fr.fromHexString(identifierString),
341
+ selector
342
+ });
343
+ } else {
344
+ throw new Error(`Invalid allow list entry "${trimmed}": unknown type "${typeString}". Expected "I" (instance) or "C" (class).`);
336
345
  }
337
346
  }
338
347
  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
+ }
package/dest/index.d.ts CHANGED
@@ -6,6 +6,7 @@ export * from './enr/index.js';
6
6
  export * from './config.js';
7
7
  export * from './mem_pools/attestation_pool/index.js';
8
8
  export * from './mem_pools/tx_pool/index.js';
9
+ export * from './mem_pools/tx_pool_v2/index.js';
9
10
  export * from './msg_validators/index.js';
10
11
  export * from './services/index.js';
11
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxxQkFBcUIsQ0FBQyJ9
12
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uL3NyYy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUscUJBQXFCLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNoRSxZQUFZLEVBQUUsTUFBTSxFQUFFLE1BQU0sbUJBQW1CLENBQUM7QUFFaEQsY0FBYywwQkFBMEIsQ0FBQztBQUN6QyxjQUFjLG1CQUFtQixDQUFDO0FBQ2xDLGNBQWMsZ0JBQWdCLENBQUM7QUFDL0IsY0FBYyxhQUFhLENBQUM7QUFDNUIsY0FBYyx1Q0FBdUMsQ0FBQztBQUN0RCxjQUFjLDhCQUE4QixDQUFDO0FBQzdDLGNBQWMsaUNBQWlDLENBQUM7QUFDaEQsY0FBYywyQkFBMkIsQ0FBQztBQUMxQyxjQUFjLHFCQUFxQixDQUFDIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,YAAY,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,aAAa,CAAC;AAC5B,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,2BAA2B,CAAC;AAC1C,cAAc,qBAAqB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,qBAAqB,EAAE,MAAM,yBAAyB,CAAC;AAChE,YAAY,EAAE,MAAM,EAAE,MAAM,mBAAmB,CAAC;AAEhD,cAAc,0BAA0B,CAAC;AACzC,cAAc,mBAAmB,CAAC;AAClC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,aAAa,CAAC;AAC5B,cAAc,uCAAuC,CAAC;AACtD,cAAc,8BAA8B,CAAC;AAC7C,cAAc,iCAAiC,CAAC;AAChD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,qBAAqB,CAAC"}
package/dest/index.js CHANGED
@@ -5,5 +5,6 @@ export * from './enr/index.js';
5
5
  export * from './config.js';
6
6
  export * from './mem_pools/attestation_pool/index.js';
7
7
  export * from './mem_pools/tx_pool/index.js';
8
+ export * from './mem_pools/tx_pool_v2/index.js';
8
9
  export * from './msg_validators/index.js';
9
10
  export * from './services/index.js';
@@ -1,43 +1,101 @@
1
- import type { SlotNumber } from '@aztec/foundation/branded-types';
2
- import type { BlockProposal, CheckpointAttestation, CheckpointProposal, CheckpointProposalCore } from '@aztec/stdlib/p2p';
1
+ import { SlotNumber } from '@aztec/foundation/branded-types';
2
+ import type { AztecAsyncKVStore } from '@aztec/kv-store';
3
+ import { BlockProposal, CheckpointAttestation, type CheckpointProposalCore } from '@aztec/stdlib/p2p';
4
+ import { type TelemetryClient } from '@aztec/telemetry-client';
5
+ /** Result of trying to add an item (proposal or attestation) to the pool */
6
+ export type TryAddResult = {
7
+ /** Whether the item was added */
8
+ added: boolean;
9
+ /** Whether the exact item already existed */
10
+ alreadyExists: boolean;
11
+ /** Count of items for the position. Meaning varies by method:
12
+ * - tryAddBlockProposal: proposals at (slot, indexWithinCheckpoint)
13
+ * - tryAddCheckpointProposal: proposals at slot
14
+ * - tryAddCheckpointAttestation: attestations by this signer for this slot */
15
+ count: number;
16
+ };
17
+ export declare const MAX_CHECKPOINT_PROPOSALS_PER_SLOT = 5;
18
+ export declare const MAX_BLOCK_PROPOSALS_PER_POSITION = 3;
19
+ /** Maximum attestations a single signer can make per slot before being rejected. */
20
+ export declare const MAX_ATTESTATIONS_PER_SLOT_AND_SIGNER = 3;
21
+ /** Public API interface for attestation pools. Used for typing mocks and test implementations. */
22
+ export type AttestationPoolApi = Pick<AttestationPool, 'tryAddBlockProposal' | 'getBlockProposal' | 'tryAddCheckpointProposal' | 'getCheckpointProposal' | 'addOwnCheckpointAttestations' | 'tryAddCheckpointAttestation' | 'deleteOlderThan' | 'getCheckpointAttestationsForSlot' | 'getCheckpointAttestationsForSlotAndProposal' | 'hasBlockProposalsForSlot' | 'isEmpty'>;
3
23
  /**
4
- * An Attestation Pool contains attestations collected by a validator
24
+ * Pool for storing attestations and proposals collected by a validator.
5
25
  *
6
- * Attestations that are observed via the p2p network are stored for requests
26
+ * Attestations and proposals observed via the p2p network are stored for requests
7
27
  * from the validator to produce a block, or to serve to other peers.
8
28
  */
9
- export interface AttestationPool {
10
- /**
11
- * Adds new block proposal to the pool
12
- */
13
- addBlockProposal(blockProposal: BlockProposal): Promise<void>;
14
- /**
15
- * Get block proposal by it's ID
29
+ export declare class AttestationPool {
30
+ private store;
31
+ private log;
32
+ private metrics;
33
+ private checkpointAttestations;
34
+ private checkpointProposals;
35
+ private checkpointProposalsForSlot;
36
+ private blockProposals;
37
+ private blockProposalsForSlotAndIndex;
38
+ private checkpointAttestationsPerSlotAndSigner;
39
+ constructor(store: AztecAsyncKVStore, telemetry?: TelemetryClient, log?: import("@aztec/foundation/log").Logger);
40
+ private poolStats;
41
+ /** Returns whether the pool is empty. */
42
+ isEmpty(): Promise<boolean>;
43
+ private getProposalKey;
44
+ private getAttestationKey;
45
+ /** Returns range bounds for querying all attestations for a given slot. */
46
+ private getAttestationKeyRangeForSlot;
47
+ /** Returns range bounds for querying all attestations for a given (slot, proposalId). */
48
+ private getAttestationKeyRangeForProposal;
49
+ /** Creates a key for the per-signer-per-slot attestation index. Uses padded slot for lexicographic ordering. */
50
+ private getSlotSignerKey;
51
+ /** Number of bits reserved for indexWithinCheckpoint in position keys. */
52
+ private static readonly INDEX_BITS;
53
+ /** Maximum indexWithinCheckpoint value (2^10 - 1 = 1023). */
54
+ private static readonly MAX_INDEX;
55
+ /** Creates a position key for block proposals: (slot << 10) | indexWithinCheckpoint. */
56
+ private getBlockPositionKey;
57
+ /**
58
+ * Attempts to add a block proposal to the pool.
59
+ *
60
+ * This method performs validation and addition in a single call:
61
+ * - Checks if the proposal already exists (returns alreadyExists: true if so)
62
+ * - Checks if the position has reached the proposal cap (returns added: false if so)
63
+ * - Adds the proposal if validation passes
64
+ *
65
+ * @param blockProposal - The block proposal to add
66
+ * @returns Result indicating whether the proposal was added and duplicate detection info
67
+ */
68
+ tryAddBlockProposal(blockProposal: BlockProposal): Promise<TryAddResult>;
69
+ /** Gets the count of block proposals for a given position (slot, indexWithinCheckpoint). */
70
+ private getBlockProposalCountForPosition;
71
+ private addBlockProposal;
72
+ /**
73
+ * Get block proposal by its ID.
16
74
  *
17
75
  * @param id - The ID of the block proposal to retrieve. The ID is proposal.payload.archive
18
76
  *
19
77
  * @return The block proposal if it exists, otherwise undefined.
20
78
  */
21
79
  getBlockProposal(id: string): Promise<BlockProposal | undefined>;
80
+ /** Checks if any block proposals exist for a given slot (at index 0). */
81
+ hasBlockProposalsForSlot(slot: SlotNumber): Promise<boolean>;
22
82
  /**
23
- * Check if a block proposal exists in the pool
24
- *
25
- * @param idOrProposal - The ID of the block proposal or the block proposal itself to check. The ID is proposal.payload.archive
83
+ * Attempts to add a checkpoint proposal to the pool.
26
84
  *
27
- * @return True if the block proposal exists, false otherwise.
28
- */
29
- hasBlockProposal(idOrProposal: string | BlockProposal): Promise<boolean>;
30
- /**
31
- * Adds a checkpoint proposal to the pool.
85
+ * This method performs validation and addition in a single call:
86
+ * - Checks if the proposal already exists (returns alreadyExists: true if so)
87
+ * - Checks if the slot has reached the proposal cap (returns added: false if so)
88
+ * - Adds the proposal if validation passes
32
89
  *
33
- * If the proposal contains a lastBlock, the BlockProposal is automatically extracted
34
- * and stored separately via addBlockProposal. The checkpoint proposal is then stored
35
- * without the lastBlock info (as CheckpointProposalCore).
90
+ * Note: This method only handles the CheckpointProposalCore. If the original
91
+ * CheckpointProposal contains a lastBlock, the caller should extract it via
92
+ * getBlockProposal() and add it separately via tryAddBlockProposal().
36
93
  *
37
- * @param proposal - The checkpoint proposal to add
38
- * @throws ProposalSlotCapExceededError if the slot has reached the maximum number of proposals
94
+ * @param proposal - The checkpoint proposal core to add
95
+ * @returns Result indicating whether the proposal was added and duplicate detection info
39
96
  */
40
- addCheckpointProposal(proposal: CheckpointProposal): Promise<void>;
97
+ tryAddCheckpointProposal(proposal: CheckpointProposalCore): Promise<TryAddResult>;
98
+ private addCheckpointProposal;
41
99
  /**
42
100
  * Get checkpoint proposal by its ID.
43
101
  *
@@ -49,33 +107,19 @@ export interface AttestationPool {
49
107
  */
50
108
  getCheckpointProposal(id: string): Promise<CheckpointProposalCore | undefined>;
51
109
  /**
52
- * Check if a checkpoint proposal exists in the pool
53
- *
54
- * @param idOrProposal - The ID of the checkpoint proposal or the proposal itself
55
- * @return True if the proposal exists, false otherwise.
56
- */
57
- hasCheckpointProposal(idOrProposal: string | CheckpointProposal): Promise<boolean>;
58
- /**
59
- * Add checkpoint attestations to the pool
60
- *
61
- * @param attestations - Checkpoint attestations to add into the pool
62
- */
63
- addCheckpointAttestations(attestations: CheckpointAttestation[]): Promise<void>;
64
- /**
65
- * Delete checkpoint attestations older than the given slot
66
- *
67
- * @param slot - The oldest slot to keep.
110
+ * Adds own checkpoint attestations to the pool.
111
+ * Skips validations on number of checkpoint attestations stored for the given slot.
68
112
  */
69
- deleteCheckpointAttestationsOlderThan(slot: SlotNumber): Promise<void>;
113
+ addOwnCheckpointAttestations(attestations: CheckpointAttestation[]): Promise<void>;
70
114
  /**
71
- * Get all checkpoint attestations for a given slot
115
+ * Get all checkpoint attestations for a given slot.
72
116
  *
73
117
  * @param slot - The slot to query
74
118
  * @return CheckpointAttestations
75
119
  */
76
120
  getCheckpointAttestationsForSlot(slot: SlotNumber): Promise<CheckpointAttestation[]>;
77
121
  /**
78
- * Get checkpoint attestations for slot and given proposal
122
+ * Get checkpoint attestations for slot and given proposal.
79
123
  *
80
124
  * @param slot - The slot to query
81
125
  * @param proposalId - The proposal to query
@@ -83,54 +127,26 @@ export interface AttestationPool {
83
127
  */
84
128
  getCheckpointAttestationsForSlotAndProposal(slot: SlotNumber, proposalId: string): Promise<CheckpointAttestation[]>;
85
129
  /**
86
- * Check if a specific checkpoint attestation exists in the pool
87
- *
88
- * @param attestation - The attestation to check
89
- * @return True if the attestation exists, false otherwise
90
- */
91
- hasCheckpointAttestation(attestation: CheckpointAttestation): Promise<boolean>;
92
- /**
93
- * Returns whether adding this proposal is permitted at current capacity:
94
- * - True if the proposal already exists, allow overwrite to keep parity with tests.
95
- * - True if the slot is below the proposal cap.
96
- * - False if the slot is at/above cap and this would be a new unique proposal.
97
- *
98
- * @param block - The block proposal to check
99
- * @returns True if the proposal can be added (or already exists), false otherwise.
100
- */
101
- canAddProposal(block: BlockProposal): Promise<boolean>;
102
- /**
103
- * Returns whether adding this checkpoint proposal is permitted at current capacity.
130
+ * Delete all pool data (attestations, proposals) older than the given slot.
104
131
  *
105
- * @param proposal - The checkpoint proposal to check
106
- * @returns True if the proposal can be added, false otherwise.
132
+ * @param oldestSlot - The oldest slot to keep.
107
133
  */
108
- canAddCheckpointProposal(proposal: CheckpointProposal): Promise<boolean>;
134
+ deleteOlderThan(oldestSlot: SlotNumber): Promise<void>;
109
135
  /**
110
- * Returns whether a checkpoint attestation would be accepted for (slot, proposalId).
136
+ * Attempts to add a checkpoint attestation to the pool.
111
137
  *
112
- * @param attestation - The attestation to check
113
- * @param committeeSize - Committee size for the attestation's slot
114
- * @returns True if the attestation can be added, false otherwise.
115
- */
116
- canAddCheckpointAttestation(attestation: CheckpointAttestation, committeeSize: number): Promise<boolean>;
117
- /**
118
- * Returns whether the checkpoint proposal cap for the given slot has been reached.
138
+ * This method performs validation and addition in a single call:
139
+ * - Checks if the attestation already exists (returns alreadyExists: true if so)
140
+ * - Checks if this signer has reached the per-signer attestation cap for this slot
141
+ * - Adds the attestation if validation passes
119
142
  *
120
- * @param slot - The slot to check
121
- * @returns True if the cap has been reached, false otherwise.
143
+ * @param attestation - The checkpoint attestation to add
144
+ * @returns Result indicating whether the attestation was added, existence info, and count of
145
+ * attestations by this signer for this slot (for equivocation detection)
122
146
  */
123
- hasReachedCheckpointProposalCap(slot: SlotNumber): Promise<boolean>;
124
- /**
125
- * Returns whether the checkpoint attestation cap for the given slot and proposal has been reached.
126
- *
127
- * @param slot - The slot to check
128
- * @param proposalId - The proposal to check
129
- * @param committeeSize - Committee size for the slot
130
- * @returns True if the cap has been reached, false otherwise.
131
- */
132
- hasReachedCheckpointAttestationCap(slot: SlotNumber, proposalId: string, committeeSize: number): Promise<boolean>;
133
- /** Returns whether the pool is empty. */
134
- isEmpty(): Promise<boolean>;
147
+ tryAddCheckpointAttestation(attestation: CheckpointAttestation): Promise<TryAddResult>;
148
+ private getSignerAttestationCountForSlot;
135
149
  }
136
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0ZXN0YXRpb25fcG9vbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21lbV9wb29scy9hdHRlc3RhdGlvbl9wb29sL2F0dGVzdGF0aW9uX3Bvb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxLQUFLLEVBQUUsVUFBVSxFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDbEUsT0FBTyxLQUFLLEVBQ1YsYUFBYSxFQUNiLHFCQUFxQixFQUNyQixrQkFBa0IsRUFDbEIsc0JBQXNCLEVBQ3ZCLE1BQU0sbUJBQW1CLENBQUM7QUFFM0I7Ozs7O0dBS0c7QUFDSCxNQUFNLFdBQVcsZUFBZTtJQUM5Qjs7T0FFRztJQUNILGdCQUFnQixDQUFDLGFBQWEsRUFBRSxhQUFhLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFDO0lBRTlEOzs7Ozs7T0FNRztJQUNILGdCQUFnQixDQUFDLEVBQUUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FBQztJQUVqRTs7Ozs7O09BTUc7SUFDSCxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsTUFBTSxHQUFHLGFBQWEsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFFekU7Ozs7Ozs7OztPQVNHO0lBQ0gscUJBQXFCLENBQUMsUUFBUSxFQUFFLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUVuRTs7Ozs7Ozs7T0FRRztJQUNILHFCQUFxQixDQUFDLEVBQUUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLHNCQUFzQixHQUFHLFNBQVMsQ0FBQyxDQUFDO0lBRS9FOzs7OztPQUtHO0lBQ0gscUJBQXFCLENBQUMsWUFBWSxFQUFFLE1BQU0sR0FBRyxrQkFBa0IsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFFbkY7Ozs7T0FJRztJQUNILHlCQUF5QixDQUFDLFlBQVksRUFBRSxxQkFBcUIsRUFBRSxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBQztJQUVoRjs7OztPQUlHO0lBQ0gscUNBQXFDLENBQUMsSUFBSSxFQUFFLFVBQVUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUM7SUFFdkU7Ozs7O09BS0c7SUFDSCxnQ0FBZ0MsQ0FBQyxJQUFJLEVBQUUsVUFBVSxHQUFHLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLENBQUM7SUFFckY7Ozs7OztPQU1HO0lBQ0gsMkNBQTJDLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLENBQUM7SUFFcEg7Ozs7O09BS0c7SUFDSCx3QkFBd0IsQ0FBQyxXQUFXLEVBQUUscUJBQXFCLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRS9FOzs7Ozs7OztPQVFHO0lBQ0gsY0FBYyxDQUFDLEtBQUssRUFBRSxhQUFhLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRXZEOzs7OztPQUtHO0lBQ0gsd0JBQXdCLENBQUMsUUFBUSxFQUFFLGtCQUFrQixHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUV6RTs7Ozs7O09BTUc7SUFDSCwyQkFBMkIsQ0FBQyxXQUFXLEVBQUUscUJBQXFCLEVBQUUsYUFBYSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBQUM7SUFFekc7Ozs7O09BS0c7SUFDSCwrQkFBK0IsQ0FBQyxJQUFJLEVBQUUsVUFBVSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FBQztJQUVwRTs7Ozs7OztPQU9HO0lBQ0gsa0NBQWtDLENBQUMsSUFBSSxFQUFFLFVBQVUsRUFBRSxVQUFVLEVBQUUsTUFBTSxFQUFFLGFBQWEsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0lBRWxILHlDQUF5QztJQUN6QyxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUFDO0NBQzdCIn0=
150
+ /** Creates an AttestationPool backed by a temporary store for testing. */
151
+ export declare function createTestAttestationPool(telemetry?: TelemetryClient): Promise<AttestationPool>;
152
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXR0ZXN0YXRpb25fcG9vbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vc3JjL21lbV9wb29scy9hdHRlc3RhdGlvbl9wb29sL2F0dGVzdGF0aW9uX3Bvb2wudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUF5QixVQUFVLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUlwRixPQUFPLEtBQUssRUFBRSxpQkFBaUIsRUFBcUMsTUFBTSxpQkFBaUIsQ0FBQztBQUM1RixPQUFPLEVBQ0wsYUFBYSxFQUNiLHFCQUFxQixFQUVyQixLQUFLLHNCQUFzQixFQUM1QixNQUFNLG1CQUFtQixDQUFDO0FBQzNCLE9BQU8sRUFBRSxLQUFLLGVBQWUsRUFBc0IsTUFBTSx5QkFBeUIsQ0FBQztBQUluRiw0RUFBNEU7QUFDNUUsTUFBTSxNQUFNLFlBQVksR0FBRztJQUN6QixpQ0FBaUM7SUFDakMsS0FBSyxFQUFFLE9BQU8sQ0FBQztJQUNmLDZDQUE2QztJQUM3QyxhQUFhLEVBQUUsT0FBTyxDQUFDO0lBQ3ZCOzs7bUZBRytFO0lBQy9FLEtBQUssRUFBRSxNQUFNLENBQUM7Q0FDZixDQUFDO0FBRUYsZUFBTyxNQUFNLGlDQUFpQyxJQUFJLENBQUM7QUFDbkQsZUFBTyxNQUFNLGdDQUFnQyxJQUFJLENBQUM7QUFDbEQsb0ZBQW9GO0FBQ3BGLGVBQU8sTUFBTSxvQ0FBb0MsSUFBSSxDQUFDO0FBRXRELGtHQUFrRztBQUNsRyxNQUFNLE1BQU0sa0JBQWtCLEdBQUcsSUFBSSxDQUNuQyxlQUFlLEVBQ2IscUJBQXFCLEdBQ3JCLGtCQUFrQixHQUNsQiwwQkFBMEIsR0FDMUIsdUJBQXVCLEdBQ3ZCLDhCQUE4QixHQUM5Qiw2QkFBNkIsR0FDN0IsaUJBQWlCLEdBQ2pCLGtDQUFrQyxHQUNsQyw2Q0FBNkMsR0FDN0MsMEJBQTBCLEdBQzFCLFNBQVMsQ0FDWixDQUFDO0FBRUY7Ozs7O0dBS0c7QUFDSCxxQkFBYSxlQUFlO0lBMEJ4QixPQUFP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
@@ -1 +1 @@
1
- {"version":3,"file":"attestation_pool.d.ts","sourceRoot":"","sources":["../../../src/mem_pools/attestation_pool/attestation_pool.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,iCAAiC,CAAC;AAClE,OAAO,KAAK,EACV,aAAa,EACb,qBAAqB,EACrB,kBAAkB,EAClB,sBAAsB,EACvB,MAAM,mBAAmB,CAAC;AAE3B;;;;;GAKG;AACH,MAAM,WAAW,eAAe;IAC9B;;OAEG;IACH,gBAAgB,CAAC,aAAa,EAAE,aAAa,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAE9D;;;;;;OAMG;IACH,gBAAgB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,aAAa,GAAG,SAAS,CAAC,CAAC;IAEjE;;;;;;OAMG;IACH,gBAAgB,CAAC,YAAY,EAAE,MAAM,GAAG,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEzE;;;;;;;;;OASG;IACH,qBAAqB,CAAC,QAAQ,EAAE,kBAAkB,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEnE;;;;;;;;OAQG;IACH,qBAAqB,CAAC,EAAE,EAAE,MAAM,GAAG,OAAO,CAAC,sBAAsB,GAAG,SAAS,CAAC,CAAC;IAE/E;;;;;OAKG;IACH,qBAAqB,CAAC,YAAY,EAAE,MAAM,GAAG,kBAAkB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEnF;;;;OAIG;IACH,yBAAyB,CAAC,YAAY,EAAE,qBAAqB,EAAE,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEhF;;;;OAIG;IACH,qCAAqC,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,IAAI,CAAC,CAAC;IAEvE;;;;;OAKG;IACH,gCAAgC,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAErF;;;;;;OAMG;IACH,2CAA2C,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,qBAAqB,EAAE,CAAC,CAAC;IAEpH;;;;;OAKG;IACH,wBAAwB,CAAC,WAAW,EAAE,qBAAqB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAE/E;;;;;;;;OAQG;IACH,cAAc,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEvD;;;;;OAKG;IACH,wBAAwB,CAAC,QAAQ,EAAE,kBAAkB,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEzE;;;;;;OAMG;IACH,2BAA2B,CAAC,WAAW,EAAE,qBAAqB,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEzG;;;;;OAKG;IACH,+BAA+B,CAAC,IAAI,EAAE,UAAU,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAEpE;;;;;;;OAOG;IACH,kCAAkC,CAAC,IAAI,EAAE,UAAU,EAAE,UAAU,EAAE,MAAM,EAAE,aAAa,EAAE,MAAM,GAAG,OAAO,CAAC,OAAO,CAAC,CAAC;IAElH,yCAAyC;IACzC,OAAO,IAAI,OAAO,CAAC,OAAO,CAAC,CAAC;CAC7B"}
1
+ {"version":3,"file":"attestation_pool.d.ts","sourceRoot":"","sources":["../../../src/mem_pools/attestation_pool/attestation_pool.ts"],"names":[],"mappings":"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"}