@aztec/p2p 0.0.1-commit.29c6b1a3 → 0.0.1-commit.2eb6648a

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 (276) 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 +3 -3
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +10 -7
  7. package/dest/client/interface.d.ts +9 -2
  8. package/dest/client/interface.d.ts.map +1 -1
  9. package/dest/client/p2p_client.d.ts +7 -4
  10. package/dest/client/p2p_client.d.ts.map +1 -1
  11. package/dest/client/p2p_client.js +24 -7
  12. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +2 -2
  13. package/dest/config.d.ts +9 -3
  14. package/dest/config.d.ts.map +1 -1
  15. package/dest/config.js +3 -1
  16. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +94 -87
  17. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  18. package/dest/mem_pools/attestation_pool/attestation_pool.js +411 -3
  19. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  20. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  21. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +351 -85
  22. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  23. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  24. package/dest/mem_pools/attestation_pool/index.js +1 -2
  25. package/dest/mem_pools/index.d.ts +2 -2
  26. package/dest/mem_pools/index.d.ts.map +1 -1
  27. package/dest/mem_pools/index.js +1 -1
  28. package/dest/mem_pools/instrumentation.d.ts +1 -1
  29. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  30. package/dest/mem_pools/instrumentation.js +2 -2
  31. package/dest/mem_pools/interface.d.ts +3 -3
  32. package/dest/mem_pools/interface.d.ts.map +1 -1
  33. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  34. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  35. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  36. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  37. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  38. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  39. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  40. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  41. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +119 -0
  42. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  43. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  44. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +90 -0
  45. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  46. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  47. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +89 -0
  48. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  49. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  50. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  51. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +131 -0
  52. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  53. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +17 -0
  54. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  55. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  56. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +63 -0
  57. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  58. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  59. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +91 -0
  60. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  61. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +70 -0
  63. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  64. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +63 -0
  66. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  67. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  69. package/dest/mem_pools/tx_pool_v2/index.d.ts +5 -0
  70. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool_v2/index.js +4 -0
  72. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +197 -0
  73. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool_v2/interfaces.js +6 -0
  75. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +71 -0
  76. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  77. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +95 -0
  78. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  79. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  80. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  81. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +99 -0
  82. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  83. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +332 -0
  84. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +55 -0
  85. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  86. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +156 -0
  87. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +69 -0
  88. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  89. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +748 -0
  90. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +3 -3
  91. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  92. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +7 -2
  93. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  94. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  95. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  96. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +5 -4
  97. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  98. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  99. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  100. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  101. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  102. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +3 -2
  103. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  104. package/dest/msg_validators/tx_validator/double_spend_validator.js +3 -2
  105. package/dest/msg_validators/tx_validator/factory.d.ts +4 -3
  106. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  107. package/dest/msg_validators/tx_validator/factory.js +12 -12
  108. package/dest/msg_validators/tx_validator/gas_validator.d.ts +3 -2
  109. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  110. package/dest/msg_validators/tx_validator/gas_validator.js +3 -2
  111. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  112. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  113. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  114. package/dest/msg_validators/tx_validator/phases_validator.d.ts +3 -2
  115. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  116. package/dest/msg_validators/tx_validator/phases_validator.js +3 -3
  117. package/dest/msg_validators/tx_validator/size_validator.d.ts +3 -1
  118. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -1
  119. package/dest/msg_validators/tx_validator/size_validator.js +4 -1
  120. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +3 -2
  121. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  122. package/dest/msg_validators/tx_validator/timestamp_validator.js +2 -2
  123. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  124. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  125. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  126. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  127. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  128. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  129. package/dest/services/data_store.d.ts +1 -1
  130. package/dest/services/data_store.d.ts.map +1 -1
  131. package/dest/services/data_store.js +10 -6
  132. package/dest/services/discv5/discV5_service.js +1 -1
  133. package/dest/services/dummy_service.d.ts +6 -2
  134. package/dest/services/dummy_service.d.ts.map +1 -1
  135. package/dest/services/dummy_service.js +3 -0
  136. package/dest/services/index.d.ts +2 -1
  137. package/dest/services/index.d.ts.map +1 -1
  138. package/dest/services/index.js +1 -0
  139. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  140. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  141. package/dest/services/libp2p/instrumentation.js +14 -3
  142. package/dest/services/libp2p/libp2p_service.d.ts +74 -33
  143. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  144. package/dest/services/libp2p/libp2p_service.js +309 -238
  145. package/dest/services/peer-manager/metrics.d.ts +2 -2
  146. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  147. package/dest/services/peer-manager/metrics.js +20 -5
  148. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  149. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  150. package/dest/services/peer-manager/peer_scoring.js +8 -2
  151. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +4 -4
  152. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -1
  153. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +9 -9
  154. package/dest/services/reqresp/metrics.d.ts +6 -5
  155. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  156. package/dest/services/reqresp/metrics.js +17 -5
  157. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +6 -4
  158. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  159. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +17 -12
  160. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +19 -14
  161. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  162. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +25 -24
  163. package/dest/services/service.d.ts +18 -1
  164. package/dest/services/service.d.ts.map +1 -1
  165. package/dest/services/tx_collection/config.d.ts +3 -3
  166. package/dest/services/tx_collection/config.js +3 -3
  167. package/dest/services/tx_collection/fast_tx_collection.d.ts +4 -5
  168. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  169. package/dest/services/tx_collection/fast_tx_collection.js +10 -14
  170. package/dest/services/tx_collection/index.d.ts +1 -1
  171. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  172. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  173. package/dest/services/tx_collection/instrumentation.js +9 -2
  174. package/dest/services/tx_collection/proposal_tx_collector.d.ts +12 -12
  175. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -1
  176. package/dest/services/tx_collection/proposal_tx_collector.js +4 -5
  177. package/dest/services/tx_file_store/config.d.ts +18 -0
  178. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  179. package/dest/services/tx_file_store/config.js +26 -0
  180. package/dest/services/tx_file_store/index.d.ts +4 -0
  181. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  182. package/dest/services/tx_file_store/index.js +3 -0
  183. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  184. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  185. package/dest/services/tx_file_store/instrumentation.js +29 -0
  186. package/dest/services/tx_file_store/tx_file_store.d.ts +47 -0
  187. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  188. package/dest/services/tx_file_store/tx_file_store.js +149 -0
  189. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  190. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  191. package/dest/services/tx_provider_instrumentation.js +5 -5
  192. package/dest/test-helpers/testbench-utils.d.ts +12 -16
  193. package/dest/test-helpers/testbench-utils.d.ts.map +1 -1
  194. package/dest/test-helpers/testbench-utils.js +34 -31
  195. package/dest/testbench/p2p_client_testbench_worker.js +2 -2
  196. package/package.json +14 -14
  197. package/src/bootstrap/bootstrap.ts +7 -4
  198. package/src/client/factory.ts +12 -13
  199. package/src/client/interface.ts +13 -1
  200. package/src/client/p2p_client.ts +32 -8
  201. package/src/client/test/tx_proposal_collector/README.md +4 -4
  202. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +2 -2
  203. package/src/config.ts +8 -1
  204. package/src/mem_pools/attestation_pool/attestation_pool.ts +444 -90
  205. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +436 -100
  206. package/src/mem_pools/attestation_pool/index.ts +9 -2
  207. package/src/mem_pools/index.ts +1 -1
  208. package/src/mem_pools/instrumentation.ts +2 -1
  209. package/src/mem_pools/interface.ts +2 -2
  210. package/src/mem_pools/tx_pool_v2/README.md +209 -0
  211. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  212. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  213. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +147 -0
  214. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +118 -0
  215. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +111 -0
  216. package/src/mem_pools/tx_pool_v2/eviction/index.ts +23 -0
  217. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +164 -0
  218. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  219. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  220. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +86 -0
  221. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +72 -0
  222. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  223. package/src/mem_pools/tx_pool_v2/index.ts +11 -0
  224. package/src/mem_pools/tx_pool_v2/interfaces.ts +227 -0
  225. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +161 -0
  226. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  227. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +417 -0
  228. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +212 -0
  229. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +882 -0
  230. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +10 -4
  231. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  232. package/src/msg_validators/tx_validator/block_header_validator.ts +7 -8
  233. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  234. package/src/msg_validators/tx_validator/double_spend_validator.ts +4 -3
  235. package/src/msg_validators/tx_validator/factory.ts +46 -30
  236. package/src/msg_validators/tx_validator/gas_validator.ts +9 -3
  237. package/src/msg_validators/tx_validator/metadata_validator.ts +6 -3
  238. package/src/msg_validators/tx_validator/phases_validator.ts +5 -3
  239. package/src/msg_validators/tx_validator/size_validator.ts +6 -2
  240. package/src/msg_validators/tx_validator/timestamp_validator.ts +6 -3
  241. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  242. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  243. package/src/services/data_store.ts +10 -7
  244. package/src/services/discv5/discV5_service.ts +1 -1
  245. package/src/services/dummy_service.ts +6 -0
  246. package/src/services/index.ts +1 -0
  247. package/src/services/libp2p/instrumentation.ts +15 -2
  248. package/src/services/libp2p/libp2p_service.ts +324 -246
  249. package/src/services/peer-manager/metrics.ts +21 -4
  250. package/src/services/peer-manager/peer_scoring.ts +4 -1
  251. package/src/services/reqresp/batch-tx-requester/README.md +14 -14
  252. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +12 -12
  253. package/src/services/reqresp/metrics.ts +34 -9
  254. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +23 -14
  255. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +30 -24
  256. package/src/services/service.ts +20 -0
  257. package/src/services/tx_collection/config.ts +6 -6
  258. package/src/services/tx_collection/fast_tx_collection.ts +14 -24
  259. package/src/services/tx_collection/index.ts +1 -1
  260. package/src/services/tx_collection/instrumentation.ts +11 -2
  261. package/src/services/tx_collection/proposal_tx_collector.ts +12 -14
  262. package/src/services/tx_file_store/config.ts +43 -0
  263. package/src/services/tx_file_store/index.ts +3 -0
  264. package/src/services/tx_file_store/instrumentation.ts +36 -0
  265. package/src/services/tx_file_store/tx_file_store.ts +173 -0
  266. package/src/services/tx_provider_instrumentation.ts +11 -5
  267. package/src/test-helpers/testbench-utils.ts +20 -39
  268. package/src/testbench/p2p_client_testbench_worker.ts +2 -2
  269. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  270. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  271. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  272. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  273. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  274. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  275. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  276. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
@@ -0,0 +1,149 @@
1
+ import { createLogger } from '@aztec/foundation/log';
2
+ import { RunningPromise } from '@aztec/foundation/promise';
3
+ import { makeBackoff, retry } from '@aztec/foundation/retry';
4
+ import { Timer } from '@aztec/foundation/timer';
5
+ import { createFileStore } from '@aztec/stdlib/file-store';
6
+ import { getTelemetryClient } from '@aztec/telemetry-client';
7
+ import { TxFileStoreInstrumentation } from './instrumentation.js';
8
+ /**
9
+ * Uploads validated transactions to a file store as a fallback retrieval mechanism.
10
+ * Listens to TxPool txs-added events and uploads txs asynchronously with bounded concurrency.
11
+ */ export class TxFileStore {
12
+ fileStore;
13
+ txPool;
14
+ config;
15
+ instrumentation;
16
+ log;
17
+ uploadQueue;
18
+ activeUploads;
19
+ queueProcessor;
20
+ handleTxsAdded;
21
+ /** Recently uploaded tx hashes for deduplication. */ recentUploads;
22
+ recentUploadsOrder;
23
+ maxRecentUploads;
24
+ constructor(fileStore, txPool, config, instrumentation, log){
25
+ this.fileStore = fileStore;
26
+ this.txPool = txPool;
27
+ this.config = config;
28
+ this.instrumentation = instrumentation;
29
+ this.log = log;
30
+ this.uploadQueue = [];
31
+ this.activeUploads = 0;
32
+ this.recentUploads = new Set();
33
+ this.recentUploadsOrder = [];
34
+ this.maxRecentUploads = 1000;
35
+ this.handleTxsAdded = (args)=>{
36
+ this.enqueueTxs(args.txs);
37
+ };
38
+ this.queueProcessor = new RunningPromise(()=>this.processQueueBatch(), this.log, 100);
39
+ }
40
+ /**
41
+ * Creates and initializes the file store.
42
+ * @param txPool - The transaction pool to listen to.
43
+ * @param config - The file store configuration.
44
+ * @param log - Optional logger.
45
+ * @param telemetry - Optional telemetry client.
46
+ * @param fileStoreOverride - Optional FileStore for testing (bypasses createFileStore).
47
+ * @returns The file store instance, or undefined if not configured/enabled.
48
+ */ static async create(txPool, config, log = createLogger('p2p:tx_file_store'), telemetry = getTelemetryClient(), fileStoreOverride) {
49
+ if (!config.txFileStoreEnabled) {
50
+ log.debug('Tx file store is disabled');
51
+ return undefined;
52
+ }
53
+ if (!config.txFileStoreUrl) {
54
+ log.warn('Tx file store is enabled but URL is not configured');
55
+ return undefined;
56
+ }
57
+ const fileStore = fileStoreOverride ?? await createFileStore(config.txFileStoreUrl, log);
58
+ if (!fileStore) {
59
+ log.warn('Failed to create file store for tx file store');
60
+ return undefined;
61
+ }
62
+ const instrumentation = new TxFileStoreInstrumentation(telemetry, 'TxFileStore');
63
+ log.info('Created tx file store', {
64
+ url: config.txFileStoreUrl
65
+ });
66
+ return new TxFileStore(fileStore, txPool, config, instrumentation, log);
67
+ }
68
+ /** Starts listening to TxPool events and uploading txs. */ start() {
69
+ this.queueProcessor.start();
70
+ this.txPool.on('txs-added', this.handleTxsAdded);
71
+ this.log.info('Started tx file store', {
72
+ concurrency: this.config.txFileStoreUploadConcurrency,
73
+ maxQueueSize: this.config.txFileStoreMaxQueueSize
74
+ });
75
+ }
76
+ /** Stops listening and waits for pending uploads to complete. */ async stop() {
77
+ this.txPool.removeListener('txs-added', this.handleTxsAdded);
78
+ await this.queueProcessor.stop();
79
+ this.log.info('Stopped tx file store');
80
+ }
81
+ enqueueTxs(txs) {
82
+ this.uploadQueue.push(...txs);
83
+ // Enforce max queue size by dropping oldest entries
84
+ const overflow = this.uploadQueue.length - this.config.txFileStoreMaxQueueSize;
85
+ if (overflow > 0) {
86
+ this.log.warn(`Upload queue overflow, dropping ${overflow} oldest txs`);
87
+ this.uploadQueue.splice(0, overflow);
88
+ }
89
+ this.instrumentation.recordQueueSize(this.uploadQueue.length);
90
+ // Immediately start uploading txs
91
+ void this.queueProcessor.trigger();
92
+ }
93
+ async processQueueBatch() {
94
+ const batch = this.uploadQueue.splice(0, this.config.txFileStoreUploadConcurrency);
95
+ this.instrumentation.recordQueueSize(this.uploadQueue.length);
96
+ this.activeUploads += batch.length;
97
+ try {
98
+ await Promise.all(batch.map((tx)=>this.uploadTx(tx)));
99
+ } finally{
100
+ this.activeUploads -= batch.length;
101
+ }
102
+ }
103
+ async uploadTx(tx) {
104
+ const txHash = tx.getTxHash().toString();
105
+ const path = `txs/${txHash}.bin`;
106
+ const timer = new Timer();
107
+ if (this.recentUploads.has(txHash)) {
108
+ return;
109
+ }
110
+ try {
111
+ this.recentUploads.add(txHash);
112
+ this.recentUploadsOrder.push(txHash);
113
+ if (this.recentUploadsOrder.length > this.maxRecentUploads) {
114
+ // delete old entries in recentUploads
115
+ for (const txHashToRemove of this.recentUploadsOrder.splice(0, this.recentUploadsOrder.length - this.maxRecentUploads)){
116
+ this.recentUploads.delete(txHashToRemove);
117
+ }
118
+ }
119
+ await retry(()=>this.fileStore.save(path, tx.toBuffer(), {
120
+ compress: false
121
+ }), `Uploading tx ${txHash}`, makeBackoff([
122
+ 0.1,
123
+ 0.5,
124
+ 2
125
+ ]), this.log, true);
126
+ const durationMs = Math.trunc(timer.ms());
127
+ this.log.debug(`Uploaded tx to file store`, {
128
+ txHash,
129
+ path,
130
+ durationMs
131
+ });
132
+ this.instrumentation.recordUploadSuccess(durationMs);
133
+ } catch (err) {
134
+ this.log.warn(`Failed to upload tx to file store after retries`, {
135
+ txHash,
136
+ error: err
137
+ });
138
+ this.instrumentation.recordUploadFailed();
139
+ }
140
+ }
141
+ /** Waits for all queued and in-flight uploads to complete. For testing. */ async flush() {
142
+ while(this.uploadQueue.length > 0 || this.activeUploads > 0){
143
+ await this.queueProcessor.trigger();
144
+ }
145
+ }
146
+ /** Returns the number of pending uploads (queued + in-flight). */ getPendingUploadCount() {
147
+ return this.uploadQueue.length + this.activeUploads;
148
+ }
149
+ }
@@ -13,4 +13,4 @@ export declare class TxProviderInstrumentation {
13
13
  recordTxsRequestDelay(delay: number): void;
14
14
  incMissingTxs(count: number): void;
15
15
  }
16
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHhfcHJvdmlkZXJfaW5zdHJ1bWVudGF0aW9uLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvdHhfcHJvdmlkZXJfaW5zdHJ1bWVudGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBMkIsS0FBSyxlQUFlLEVBQXNCLE1BQU0seUJBQXlCLENBQUM7QUFFNUcscUJBQWEseUJBQXlCO0lBQ3BDLE9BQU8sQ0FBQyxtQkFBbUIsQ0FBZ0I7SUFDM0MsT0FBTyxDQUFDLGtCQUFrQixDQUFnQjtJQUMxQyxPQUFPLENBQUMsY0FBYyxDQUFnQjtJQUN0QyxPQUFPLENBQUMsZUFBZSxDQUFnQjtJQUV2QyxPQUFPLENBQUMsNkJBQTZCLENBQVk7SUFDakQsT0FBTyxDQUFDLGVBQWUsQ0FBWTtJQUVuQyxZQUFZLE1BQU0sRUFBRSxlQUFlLEVBQUUsSUFBSSxFQUFFLE1BQU0sRUFjaEQ7SUFFRCxtQkFBbUIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxRQUVoQztJQUVELGlCQUFpQixDQUFDLEtBQUssRUFBRSxNQUFNLFFBRTlCO0lBRUQsYUFBYSxDQUFDLEtBQUssRUFBRSxNQUFNLEVBQUUsS0FBSyxFQUFFLE1BQU0sUUFHekM7SUFFRCxxQkFBcUIsQ0FBQyxLQUFLLEVBQUUsTUFBTSxRQUVsQztJQUVELGFBQWEsQ0FBQyxLQUFLLEVBQUUsTUFBTSxRQUUxQjtDQUNGIn0=
16
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHhfcHJvdmlkZXJfaW5zdHJ1bWVudGF0aW9uLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvc2VydmljZXMvdHhfcHJvdmlkZXJfaW5zdHJ1bWVudGF0aW9uLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFHTCxLQUFLLGVBQWUsRUFHckIsTUFBTSx5QkFBeUIsQ0FBQztBQUVqQyxxQkFBYSx5QkFBeUI7SUFDcEMsT0FBTyxDQUFDLG1CQUFtQixDQUFnQjtJQUMzQyxPQUFPLENBQUMsa0JBQWtCLENBQWdCO0lBQzFDLE9BQU8sQ0FBQyxjQUFjLENBQWdCO0lBQ3RDLE9BQU8sQ0FBQyxlQUFlLENBQWdCO0lBRXZDLE9BQU8sQ0FBQyw2QkFBNkIsQ0FBWTtJQUNqRCxPQUFPLENBQUMsZUFBZSxDQUFZO0lBRW5DLFlBQVksTUFBTSxFQUFFLGVBQWUsRUFBRSxJQUFJLEVBQUUsTUFBTSxFQWNoRDtJQUVELG1CQUFtQixDQUFDLEtBQUssRUFBRSxNQUFNLFFBRWhDO0lBRUQsaUJBQWlCLENBQUMsS0FBSyxFQUFFLE1BQU0sUUFFOUI7SUFFRCxhQUFhLENBQUMsS0FBSyxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUUsTUFBTSxRQUd6QztJQUVELHFCQUFxQixDQUFDLEtBQUssRUFBRSxNQUFNLFFBRWxDO0lBRUQsYUFBYSxDQUFDLEtBQUssRUFBRSxNQUFNLFFBRTFCO0NBQ0YifQ==
@@ -1 +1 @@
1
- {"version":3,"file":"tx_provider_instrumentation.d.ts","sourceRoot":"","sources":["../../src/services/tx_provider_instrumentation.ts"],"names":[],"mappings":"AAAA,OAAO,EAA2B,KAAK,eAAe,EAAsB,MAAM,yBAAyB,CAAC;AAE5G,qBAAa,yBAAyB;IACpC,OAAO,CAAC,mBAAmB,CAAgB;IAC3C,OAAO,CAAC,kBAAkB,CAAgB;IAC1C,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,eAAe,CAAgB;IAEvC,OAAO,CAAC,6BAA6B,CAAY;IACjD,OAAO,CAAC,eAAe,CAAY;IAEnC,YAAY,MAAM,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,EAchD;IAED,mBAAmB,CAAC,KAAK,EAAE,MAAM,QAEhC;IAED,iBAAiB,CAAC,KAAK,EAAE,MAAM,QAE9B;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAGzC;IAED,qBAAqB,CAAC,KAAK,EAAE,MAAM,QAElC;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,QAE1B;CACF"}
1
+ {"version":3,"file":"tx_provider_instrumentation.d.ts","sourceRoot":"","sources":["../../src/services/tx_provider_instrumentation.ts"],"names":[],"mappings":"AAAA,OAAO,EAGL,KAAK,eAAe,EAGrB,MAAM,yBAAyB,CAAC;AAEjC,qBAAa,yBAAyB;IACpC,OAAO,CAAC,mBAAmB,CAAgB;IAC3C,OAAO,CAAC,kBAAkB,CAAgB;IAC1C,OAAO,CAAC,cAAc,CAAgB;IACtC,OAAO,CAAC,eAAe,CAAgB;IAEvC,OAAO,CAAC,6BAA6B,CAAY;IACjD,OAAO,CAAC,eAAe,CAAY;IAEnC,YAAY,MAAM,EAAE,eAAe,EAAE,IAAI,EAAE,MAAM,EAchD;IAED,mBAAmB,CAAC,KAAK,EAAE,MAAM,QAEhC;IAED,iBAAiB,CAAC,KAAK,EAAE,MAAM,QAE9B;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,EAAE,KAAK,EAAE,MAAM,QAGzC;IAED,qBAAqB,CAAC,KAAK,EAAE,MAAM,QAElC;IAED,aAAa,CAAC,KAAK,EAAE,MAAM,QAE1B;CACF"}
@@ -1,4 +1,4 @@
1
- import { Metrics } from '@aztec/telemetry-client';
1
+ import { Metrics, createUpDownCounterWithDefault } from '@aztec/telemetry-client';
2
2
  export class TxProviderInstrumentation {
3
3
  txFromProposalCount;
4
4
  txFromMempoolCount;
@@ -8,10 +8,10 @@ export class TxProviderInstrumentation {
8
8
  txsRequestDelay;
9
9
  constructor(client, name){
10
10
  const meter = client.getMeter(name);
11
- this.txFromProposalCount = meter.createUpDownCounter(Metrics.TX_PROVIDER_TXS_FROM_PROPOSALS_COUNT);
12
- this.txFromMempoolCount = meter.createUpDownCounter(Metrics.TX_PROVIDER_TXS_FROM_MEMPOOL_COUNT);
13
- this.txFromP2PCount = meter.createUpDownCounter(Metrics.TX_PROVIDER_TXS_FROM_P2P_COUNT);
14
- this.missingTxsCount = meter.createUpDownCounter(Metrics.TX_PROVIDER_MISSING_TXS_COUNT);
11
+ this.txFromProposalCount = createUpDownCounterWithDefault(meter, Metrics.TX_PROVIDER_TXS_FROM_PROPOSALS_COUNT);
12
+ this.txFromMempoolCount = createUpDownCounterWithDefault(meter, Metrics.TX_PROVIDER_TXS_FROM_MEMPOOL_COUNT);
13
+ this.txFromP2PCount = createUpDownCounterWithDefault(meter, Metrics.TX_PROVIDER_TXS_FROM_P2P_COUNT);
14
+ this.missingTxsCount = createUpDownCounterWithDefault(meter, Metrics.TX_PROVIDER_MISSING_TXS_COUNT);
15
15
  this.fractionOfTxsRequestedFromP2P = meter.createHistogram(Metrics.TX_PROVIDER_P2P_TXS_REQUESTED_FRACTION);
16
16
  this.txsRequestDelay = meter.createHistogram(Metrics.TX_PROVIDER_P2P_TXS_REQUEST_DELAY);
17
17
  }
@@ -5,7 +5,7 @@ import type { WorldStateSynchronizer } from '@aztec/stdlib/interfaces/server';
5
5
  import type { BlockProposal, CheckpointAttestation, CheckpointProposal, CheckpointProposalCore } from '@aztec/stdlib/p2p';
6
6
  import { type BlockHeader, Tx, TxHash } from '@aztec/stdlib/tx';
7
7
  import EventEmitter from 'events';
8
- import type { AttestationPool } from '../mem_pools/attestation_pool/attestation_pool.js';
8
+ import type { TryAddResult } from '../mem_pools/attestation_pool/attestation_pool.js';
9
9
  import type { TxPool } from '../mem_pools/tx_pool/index.js';
10
10
  /**
11
11
  * In-memory TxPool implementation for testing.
@@ -48,26 +48,20 @@ export declare class InMemoryTxPool extends EventEmitter implements TxPool {
48
48
  cleanupDeletedMinedTxs(_blockNumber: BlockNumber): Promise<number>;
49
49
  }
50
50
  /**
51
- * In-memory AttestationPool implementation for testing.
51
+ * In-memory AttestationPool mock for testing/benchmarking.
52
+ * Provides minimal implementation without persistence.
52
53
  */
53
- export declare class InMemoryAttestationPool implements AttestationPool {
54
+ export declare class InMemoryAttestationPool {
54
55
  private proposals;
55
- addBlockProposal(blockProposal: BlockProposal): Promise<void>;
56
+ tryAddBlockProposal(blockProposal: BlockProposal): Promise<TryAddResult>;
56
57
  getBlockProposal(id: string): Promise<BlockProposal | undefined>;
57
- hasBlockProposal(idOrProposal: string | BlockProposal): Promise<boolean>;
58
- canAddProposal(_block: BlockProposal): Promise<boolean>;
59
- addCheckpointProposal(_proposal: CheckpointProposal): Promise<void>;
58
+ tryAddCheckpointProposal(_proposal: CheckpointProposal): Promise<TryAddResult>;
60
59
  getCheckpointProposal(_id: string): Promise<CheckpointProposalCore | undefined>;
61
- hasCheckpointProposal(_idOrProposal: string | CheckpointProposal): Promise<boolean>;
62
- addCheckpointAttestations(_attestations: CheckpointAttestation[]): Promise<void>;
63
- deleteCheckpointAttestationsOlderThan(_slot: SlotNumber): Promise<void>;
60
+ addOwnCheckpointAttestations(_attestations: CheckpointAttestation[]): Promise<void>;
61
+ deleteOlderThan(_slot: SlotNumber): Promise<void>;
64
62
  getCheckpointAttestationsForSlot(_slot: SlotNumber): Promise<CheckpointAttestation[]>;
65
63
  getCheckpointAttestationsForSlotAndProposal(_slot: SlotNumber, _proposalId: string): Promise<CheckpointAttestation[]>;
66
- hasCheckpointAttestation(_attestation: CheckpointAttestation): Promise<boolean>;
67
- canAddCheckpointProposal(_proposal: CheckpointProposal): Promise<boolean>;
68
- canAddCheckpointAttestation(_attestation: CheckpointAttestation, _committeeSize: number): Promise<boolean>;
69
- hasReachedCheckpointProposalCap(_slot: SlotNumber): Promise<boolean>;
70
- hasReachedCheckpointAttestationCap(_slot: SlotNumber, _proposalId: string, _committeeSize: number): Promise<boolean>;
64
+ tryAddCheckpointAttestation(_attestation: CheckpointAttestation, _committeeSize: number): Promise<TryAddResult>;
71
65
  isEmpty(): Promise<boolean>;
72
66
  resetState(): void;
73
67
  }
@@ -136,6 +130,8 @@ export declare const BENCHMARK_CONSTANTS: {
136
130
  readonly FIXED_MAX_PEERS: 10;
137
131
  /** Fixed max retry attempts for fair benchmarking */
138
132
  readonly FIXED_MAX_RETRY_ATTEMPTS: 3;
133
+ /** LMDB map size for temp stores used in benchmarks (in KB). */
134
+ readonly KV_STORE_MAP_SIZE_KB: number;
139
135
  };
140
136
  /**
141
137
  * Filters transactions based on distribution pattern for benchmark responders.
@@ -153,4 +149,4 @@ export declare function filterTxsByDistribution(allTxs: Tx[], peerIndex: number,
153
149
  * Ensures we return before the outer timeout while maintaining a minimum.
154
150
  */
155
151
  export declare function calculateInternalTimeout(timeoutMs: number): number;
156
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdGJlbmNoLXV0aWxzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC1oZWxwZXJzL3Rlc3RiZW5jaC11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzlELE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBZSxVQUFVLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUM1RixPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRCxPQUFPLEtBQUssRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUNWLGFBQWEsRUFDYixxQkFBcUIsRUFDckIsa0JBQWtCLEVBQ2xCLHNCQUFzQixFQUN2QixNQUFNLG1CQUFtQixDQUFDO0FBQzNCLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFaEUsT0FBTyxZQUFZLE1BQU0sUUFBUSxDQUFDO0FBRWxDLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3pGLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRzVEOzs7R0FHRztBQUNILHFCQUFhLGNBQWUsU0FBUSxZQUFhLFlBQVcsTUFBTTtJQUNoRSxPQUFPLENBQUMsU0FBUyxDQUF5QjtJQUMxQyxPQUFPLENBQUMsTUFBTSxDQUF1QjtJQUVyQyxTQUFTLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxJQUFJLENBRTlCO0lBRUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxNQUFNLENBR3hCO0lBRUQsU0FBUyxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxNQUFNLENBVTNCO0lBRUQsUUFBUSxJQUFJLElBQUksQ0FFZjtJQUVELFVBQVUsSUFBSSxJQUFJLENBR2pCO0lBRUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsRUFBRSxJQUFJLENBQUMsRUFBRTtRQUFFLE1BQU0sQ0FBQyxFQUFFLE1BQU0sQ0FBQTtLQUFFLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQWU3RDtJQUVELFdBQVcsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLENBRWpEO0lBRUQsWUFBWSxDQUFDLE1BQU0sRUFBRSxNQUFNLEVBQUUsR0FBRyxPQUFPLENBQUMsQ0FBQyxFQUFFLEdBQUcsU0FBUyxDQUFDLEVBQUUsQ0FBQyxDQUsxRDtJQUVELE1BQU0sQ0FBQyxNQUFNLEVBQUUsTUFBTSxFQUFFLEdBQUcsT0FBTyxDQUFDLE9BQU8sRUFBRSxDQUFDLENBRTNDO0lBRUQsS0FBSyxDQUFDLElBQUksRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUVwQztJQUVELG1CQUFtQixDQUFDLEtBQUssRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLEVBQUUsR0FBRyxTQUFTLENBQUMsQ0FFMUQ7SUFFSyxXQUFXLENBQUMsU0FBUyxFQUFFLE1BQU0sRUFBRSxFQUFFLFlBQVksRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFHO0lBRTdFLGtCQUFrQixDQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUUsRUFBRSxZQUFZLEVBQUUsV0FBVyxHQUFHLE9BQU8sQ0FBQyxJQUFJLENBQUMsQ0FBRztJQUUxRixTQUFTLENBQUMsUUFBUSxFQUFFLE1BQU0sRUFBRSxFQUFFLEtBQUssQ0FBQyxFQUFFO1FBQUUsV0FBVyxDQUFDLEVBQUUsT0FBTyxDQUFBO0tBQUUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBSzlFO0lBRUQsU0FBUyxJQUFJLE9BQU8sQ0FBQyxFQUFFLEVBQUUsQ0FBQyxDQUV6QjtJQUVELGNBQWMsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FFbEM7SUFFRCxrQkFBa0IsSUFBSSxPQUFPLENBQUMsTUFBTSxFQUFFLENBQUMsQ0FFdEM7SUFFRCxpQkFBaUIsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBRW5DO0lBRUQsZ0JBQWdCLElBQUksT0FBTyxDQUFDLENBQUMsRUFBRSxFQUFFLE1BQU0sRUFBRSxXQUFXLEVBQUUsV0FBVyxDQUFDLEVBQUUsQ0FBQyxDQUVwRTtJQUVELFdBQVcsQ0FBQyxJQUFJLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxTQUFTLEdBQUcsT0FBTyxHQUFHLFNBQVMsR0FBRyxTQUFTLENBQUMsQ0FFOUU7SUFFRCxZQUFZLENBQUMsT0FBTyxFQUFFO1FBQUUsaUJBQWlCLENBQUMsRUFBRSxNQUFNLENBQUM7UUFBQyxlQUFlLENBQUMsRUFBRSxNQUFNLENBQUE7S0FBRSxHQUFHLElBQUksQ0FBRztJQUV4RixPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUUxQjtJQUVLLHFCQUFxQixDQUFDLFNBQVMsRUFBRSxNQUFNLEVBQUUsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUc7SUFFNUQsb0JBQW9CLElBQUksT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFHO0lBRTlDLHNCQUFzQixDQUFDLFlBQVksRUFBRSxXQUFXLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQUVqRTtDQUNGO0FBRUQ7O0dBRUc7QUFDSCxxQkFBYSx1QkFBd0IsWUFBVyxlQUFlO0lBQzdELE9BQU8sQ0FBQyxTQUFTLENBQW9DO0lBRXJELGdCQUFnQixDQUFDLGFBQWEsRUFBRSxhQUFhLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUc1RDtJQUVELGdCQUFnQixDQUFDLEVBQUUsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLGFBQWEsR0FBRyxTQUFTLENBQUMsQ0FFL0Q7SUFFRCxnQkFBZ0IsQ0FBQyxZQUFZLEVBQUUsTUFBTSxHQUFHLGFBQWEsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBR3ZFO0lBRUQsY0FBYyxDQUFDLE1BQU0sRUFBRSxhQUFhLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUV0RDtJQUVLLHFCQUFxQixDQUFDLFNBQVMsRUFBRSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsSUFBSSxDQUFDLENBQUc7SUFFNUUscUJBQXFCLENBQUMsR0FBRyxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsc0JBQXNCLEdBQUcsU0FBUyxDQUFDLENBRTlFO0lBRUQscUJBQXFCLENBQUMsYUFBYSxFQUFFLE1BQU0sR0FBRyxrQkFBa0IsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBRWxGO0lBRUsseUJBQXlCLENBQUMsYUFBYSxFQUFFLHFCQUFxQixFQUFFLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFHO0lBRW5GLHFDQUFxQyxDQUFDLEtBQUssRUFBRSxVQUFVLEdBQUcsT0FBTyxDQUFDLElBQUksQ0FBQyxDQUFHO0lBRWhGLGdDQUFnQyxDQUFDLEtBQUssRUFBRSxVQUFVLEdBQUcsT0FBTyxDQUFDLHFCQUFxQixFQUFFLENBQUMsQ0FFcEY7SUFFRCwyQ0FBMkMsQ0FDekMsS0FBSyxFQUFFLFVBQVUsRUFDakIsV0FBVyxFQUFFLE1BQU0sR0FDbEIsT0FBTyxDQUFDLHFCQUFxQixFQUFFLENBQUMsQ0FFbEM7SUFFRCx3QkFBd0IsQ0FBQyxZQUFZLEVBQUUscUJBQXFCLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUU5RTtJQUVELHdCQUF3QixDQUFDLFNBQVMsRUFBRSxrQkFBa0IsR0FBRyxPQUFPLENBQUMsT0FBTyxDQUFDLENBRXhFO0lBRUQsMkJBQTJCLENBQUMsWUFBWSxFQUFFLHFCQUFxQixFQUFFLGNBQWMsRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUV6RztJQUVELCtCQUErQixDQUFDLEtBQUssRUFBRSxVQUFVLEdBQUcsT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUVuRTtJQUVELGtDQUFrQyxDQUFDLEtBQUssRUFBRSxVQUFVLEVBQUUsV0FBVyxFQUFFLE1BQU0sRUFBRSxjQUFjLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxPQUFPLENBQUMsQ0FFbkg7SUFFRCxPQUFPLElBQUksT0FBTyxDQUFDLE9BQU8sQ0FBQyxDQUUxQjtJQUVELFVBQVUsSUFBSSxJQUFJLENBRWpCO0NBQ0Y7QUFFRDs7R0FFRztBQUNILHdCQUFnQixvQkFBb0IsSUFBSSxtQkFBbUIsQ0FhMUQ7QUFFRDs7R0FFRztBQUNILHdCQUFnQixnQ0FBZ0MsSUFBSSxzQkFBc0IsQ0FhekU7QUFFRDs7R0FFRztBQUNILGVBQU8sTUFBTSwwQkFBMEI7Ozs7Ozs7OztDQUd0QyxDQUFDO0FBRUY7Ozs7OztHQU1HO0FBQ0gsd0JBQWdCLG1DQUFtQyxDQUFDLE9BQU8sRUFBRSxHQUFHLEdBQUcsSUFBSSxDQUl0RTtBQUVEOztHQUVHO0FBQ0gsTUFBTSxNQUFNLG1CQUFtQixHQUFHLFNBQVMsR0FBRyxRQUFRLEdBQUcsYUFBYSxDQUFDO0FBRXZFOztHQUVHO0FBQ0gsTUFBTSxNQUFNLGFBQWEsR0FBRyxpQkFBaUIsR0FBRyxvQkFBb0IsQ0FBQztBQUVyRTs7R0FFRztBQUNILGVBQU8sTUFBTSx1QkFBdUIsRUFBRSxNQUFNLENBQUMsYUFBYSxFQUFFLE1BQU0sQ0FHakUsQ0FBQztBQUVGOztHQUVHO0FBQ0gsZUFBTyxNQUFNLG1CQUFtQjtJQUM5QixrRUFBa0U7O0lBRWxFLGdEQUFnRDs7SUFFaEQsOENBQThDOztJQUU5QyxtQ0FBbUM7O0lBRW5DLGtEQUFrRDs7SUFFbEQsOEJBQThCOztJQUU5QixnRkFBZ0Y7O0lBRWhGLG9EQUFvRDs7SUFFcEQsNENBQTRDOztJQUU1QyxxREFBcUQ7O0NBRTdDLENBQUM7QUFFWDs7Ozs7Ozs7O0dBU0c7QUFDSCx3QkFBZ0IsdUJBQXVCLENBQ3JDLE1BQU0sRUFBRSxFQUFFLEVBQUUsRUFDWixTQUFTLEVBQUUsTUFBTSxFQUNqQixTQUFTLEVBQUUsTUFBTSxFQUNqQixZQUFZLEVBQUUsbUJBQW1CLEVBQ2pDLGVBQWUsR0FBRSxNQUFVLEdBQzFCLEVBQUUsRUFBRSxDQXNCTjtBQUVEOzs7R0FHRztBQUNILHdCQUFnQix3QkFBd0IsQ0FBQyxTQUFTLEVBQUUsTUFBTSxHQUFHLE1BQU0sQ0FFbEUifQ==
152
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGVzdGJlbmNoLXV0aWxzLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi9zcmMvdGVzdC1oZWxwZXJzL3Rlc3RiZW5jaC11dGlscy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBQzlELE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBZSxVQUFVLEVBQUUsTUFBTSxpQ0FBaUMsQ0FBQztBQUM1RixPQUFPLEtBQUssRUFBRSxNQUFNLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUNwRCxPQUFPLEtBQUssRUFBRSxzQkFBc0IsRUFBRSxNQUFNLGlDQUFpQyxDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUNWLGFBQWEsRUFDYixxQkFBcUIsRUFDckIsa0JBQWtCLEVBQ2xCLHNCQUFzQixFQUN2QixNQUFNLG1CQUFtQixDQUFDO0FBQzNCLE9BQU8sRUFBRSxLQUFLLFdBQVcsRUFBRSxFQUFFLEVBQUUsTUFBTSxFQUFFLE1BQU0sa0JBQWtCLENBQUM7QUFFaEUsT0FBTyxZQUFZLE1BQU0sUUFBUSxDQUFDO0FBRWxDLE9BQU8sS0FBSyxFQUFFLFlBQVksRUFBRSxNQUFNLG1EQUFtRCxDQUFDO0FBQ3RGLE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLCtCQUErQixDQUFDO0FBRzVEOzs7R0FHRztBQUNILHFCQUFhLGNBQWUsU0FBUSxZQUFhLFlBQVcsTUFBTTtJQUNoRSxPQUFPLENBQUMsU0FBUyxDQUF5QjtJQUMxQyxPQUFPLENBQUMsTUFBTSxDQUF1QjtJQUVyQyxTQUFTLENBQUMsTUFBTSxFQUFFLE1BQU0sR0FBRyxJQUFJLENBRTlCO0lBRUQsTUFBTSxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxNQUFNLENBR3hCO0lBRUQsU0FBUyxDQUFDLEdBQUcsRUFBRSxFQUFFLEVBQUUsR0FBRyxNQUFNLENBVTNCO0lBRUQsUUFBUSxJQUFJLElBQUksQ0FF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
@@ -1 +1 @@
1
- {"version":3,"file":"testbench-utils.d.ts","sourceRoot":"","sources":["../../src/test-helpers/testbench-utils.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"testbench-utils.d.ts","sourceRoot":"","sources":["../../src/test-helpers/testbench-utils.ts"],"names":[],"mappings":"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"}
@@ -113,52 +113,54 @@ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.j
113
113
  }
114
114
  }
115
115
  /**
116
- * In-memory AttestationPool implementation for testing.
116
+ * In-memory AttestationPool mock for testing/benchmarking.
117
+ * Provides minimal implementation without persistence.
117
118
  */ export class InMemoryAttestationPool {
118
119
  proposals = new Map();
119
- addBlockProposal(blockProposal) {
120
- this.proposals.set(blockProposal.archive.toString(), blockProposal);
121
- return Promise.resolve();
120
+ tryAddBlockProposal(blockProposal) {
121
+ const id = blockProposal.archive.toString();
122
+ const alreadyExists = this.proposals.has(id);
123
+ if (alreadyExists) {
124
+ return Promise.resolve({
125
+ added: false,
126
+ alreadyExists: true,
127
+ totalForPosition: 1
128
+ });
129
+ }
130
+ this.proposals.set(id, blockProposal);
131
+ return Promise.resolve({
132
+ added: true,
133
+ alreadyExists: false,
134
+ totalForPosition: 1
135
+ });
122
136
  }
123
137
  getBlockProposal(id) {
124
138
  return Promise.resolve(this.proposals.get(id));
125
139
  }
126
- hasBlockProposal(idOrProposal) {
127
- const id = typeof idOrProposal === 'string' ? idOrProposal : idOrProposal.archive.toString();
128
- return Promise.resolve(this.proposals.has(id));
140
+ tryAddCheckpointProposal(_proposal) {
141
+ return Promise.resolve({
142
+ added: true,
143
+ alreadyExists: false,
144
+ totalForPosition: 1
145
+ });
129
146
  }
130
- canAddProposal(_block) {
131
- return Promise.resolve(true);
132
- }
133
- async addCheckpointProposal(_proposal) {}
134
147
  getCheckpointProposal(_id) {
135
148
  return Promise.resolve(undefined);
136
149
  }
137
- hasCheckpointProposal(_idOrProposal) {
138
- return Promise.resolve(false);
139
- }
140
- async addCheckpointAttestations(_attestations) {}
141
- async deleteCheckpointAttestationsOlderThan(_slot) {}
150
+ async addOwnCheckpointAttestations(_attestations) {}
151
+ async deleteOlderThan(_slot) {}
142
152
  getCheckpointAttestationsForSlot(_slot) {
143
153
  return Promise.resolve([]);
144
154
  }
145
155
  getCheckpointAttestationsForSlotAndProposal(_slot, _proposalId) {
146
156
  return Promise.resolve([]);
147
157
  }
148
- hasCheckpointAttestation(_attestation) {
149
- return Promise.resolve(false);
150
- }
151
- canAddCheckpointProposal(_proposal) {
152
- return Promise.resolve(true);
153
- }
154
- canAddCheckpointAttestation(_attestation, _committeeSize) {
155
- return Promise.resolve(true);
156
- }
157
- hasReachedCheckpointProposalCap(_slot) {
158
- return Promise.resolve(false);
159
- }
160
- hasReachedCheckpointAttestationCap(_slot, _proposalId, _committeeSize) {
161
- return Promise.resolve(false);
158
+ tryAddCheckpointAttestation(_attestation, _committeeSize) {
159
+ return Promise.resolve({
160
+ added: true,
161
+ alreadyExists: false,
162
+ totalForPosition: 1
163
+ });
162
164
  }
163
165
  isEmpty() {
164
166
  return Promise.resolve(this.proposals.size === 0);
@@ -257,7 +259,8 @@ import { RateLimitStatus } from '../services/reqresp/rate-limiter/rate_limiter.j
257
259
  /** Buffer time for internal timeout to ensure we return before outer timeout */ TIMEOUT_BUFFER_MS: 5_000,
258
260
  /** Minimum internal timeout regardless of buffer */ MIN_INTERNAL_TIMEOUT_MS: 1_000,
259
261
  /** Fixed max peers for fair benchmarking */ FIXED_MAX_PEERS: 10,
260
- /** Fixed max retry attempts for fair benchmarking */ FIXED_MAX_RETRY_ATTEMPTS: 3
262
+ /** Fixed max retry attempts for fair benchmarking */ FIXED_MAX_RETRY_ATTEMPTS: 3,
263
+ /** LMDB map size for temp stores used in benchmarks (in KB). */ KV_STORE_MAP_SIZE_KB: 256 * 1024
261
264
  };
262
265
  /**
263
266
  * Filters transactions based on distribution pattern for benchmark responders.
@@ -204,7 +204,7 @@ process.on('message', async (msg)=>{
204
204
  const worldState = createMockWorldStateSynchronizer();
205
205
  const l2BlockSource = new MockL2BlockSource();
206
206
  const proofVerifier = new AlwaysTrueCircuitVerifier();
207
- kvStore = await openTmpStore(`test-${clientIndex}`);
207
+ kvStore = await openTmpStore(`test-${clientIndex}`, true, BENCHMARK_CONSTANTS.KV_STORE_MAP_SIZE_KB);
208
208
  workerLogger = createLogger(`p2p:${clientIndex}`);
209
209
  workerTxPool.setLogger(workerLogger);
210
210
  const telemetry = getTelemetryClient();
@@ -273,7 +273,7 @@ process.on('message', async (msg)=>{
273
273
  const allTxs = await generateDeterministicTxs(benchCmd.txCount, benchCmd.seed, workerConfig);
274
274
  const txHashes = allTxs.map((tx)=>tx.getTxHash());
275
275
  const blockProposal = await createBlockProposal(benchCmd.blockNumber, txHashes, benchCmd.seed);
276
- await workerAttestationPool.addBlockProposal(blockProposal);
276
+ await workerAttestationPool.tryAddBlockProposal(blockProposal);
277
277
  workerLogger.debug(`[BENCH] Added block proposal with archive ${blockProposal.archive.toString().slice(0, 10)}...`);
278
278
  if (benchCmd.isAggregator) {
279
279
  workerTxPool.clearTxs();
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/p2p",
3
- "version": "0.0.1-commit.29c6b1a3",
3
+ "version": "0.0.1-commit.2eb6648a",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
@@ -67,17 +67,17 @@
67
67
  ]
68
68
  },
69
69
  "dependencies": {
70
- "@aztec/constants": "0.0.1-commit.29c6b1a3",
71
- "@aztec/epoch-cache": "0.0.1-commit.29c6b1a3",
72
- "@aztec/ethereum": "0.0.1-commit.29c6b1a3",
73
- "@aztec/foundation": "0.0.1-commit.29c6b1a3",
74
- "@aztec/kv-store": "0.0.1-commit.29c6b1a3",
75
- "@aztec/noir-contracts.js": "0.0.1-commit.29c6b1a3",
76
- "@aztec/noir-protocol-circuits-types": "0.0.1-commit.29c6b1a3",
77
- "@aztec/protocol-contracts": "0.0.1-commit.29c6b1a3",
78
- "@aztec/simulator": "0.0.1-commit.29c6b1a3",
79
- "@aztec/stdlib": "0.0.1-commit.29c6b1a3",
80
- "@aztec/telemetry-client": "0.0.1-commit.29c6b1a3",
70
+ "@aztec/constants": "0.0.1-commit.2eb6648a",
71
+ "@aztec/epoch-cache": "0.0.1-commit.2eb6648a",
72
+ "@aztec/ethereum": "0.0.1-commit.2eb6648a",
73
+ "@aztec/foundation": "0.0.1-commit.2eb6648a",
74
+ "@aztec/kv-store": "0.0.1-commit.2eb6648a",
75
+ "@aztec/noir-contracts.js": "0.0.1-commit.2eb6648a",
76
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.2eb6648a",
77
+ "@aztec/protocol-contracts": "0.0.1-commit.2eb6648a",
78
+ "@aztec/simulator": "0.0.1-commit.2eb6648a",
79
+ "@aztec/stdlib": "0.0.1-commit.2eb6648a",
80
+ "@aztec/telemetry-client": "0.0.1-commit.2eb6648a",
81
81
  "@chainsafe/libp2p-gossipsub": "13.0.0",
82
82
  "@chainsafe/libp2p-noise": "^15.0.0",
83
83
  "@chainsafe/libp2p-yamux": "^6.0.2",
@@ -104,8 +104,8 @@
104
104
  "xxhash-wasm": "^1.1.0"
105
105
  },
106
106
  "devDependencies": {
107
- "@aztec/archiver": "0.0.1-commit.29c6b1a3",
108
- "@aztec/world-state": "0.0.1-commit.29c6b1a3",
107
+ "@aztec/archiver": "0.0.1-commit.2eb6648a",
108
+ "@aztec/world-state": "0.0.1-commit.2eb6648a",
109
109
  "@jest/globals": "^30.0.0",
110
110
  "@types/jest": "^30.0.0",
111
111
  "@types/node": "^22.15.17",
@@ -1,4 +1,4 @@
1
- import { createLogger } from '@aztec/foundation/log';
1
+ import { type Logger, type LoggerBindings, createLogger } from '@aztec/foundation/log';
2
2
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
3
3
  import type { P2PBootstrapApi } from '@aztec/stdlib/interfaces/server';
4
4
  import { OtelMetricsAdapter, type TelemetryClient } from '@aztec/telemetry-client';
@@ -18,12 +18,15 @@ import { convertToMultiaddr, getPeerIdPrivateKey, getPublicIp } from '../util.js
18
18
  export class BootstrapNode implements P2PBootstrapApi {
19
19
  private node?: Discv5EventEmitter = undefined;
20
20
  private peerId?: PeerId;
21
+ private logger: Logger;
21
22
 
22
23
  constructor(
23
24
  private store: AztecAsyncKVStore,
24
25
  private telemetry: TelemetryClient,
25
- private logger = createLogger('p2p:bootstrap'),
26
- ) {}
26
+ bindings?: LoggerBindings,
27
+ ) {
28
+ this.logger = createLogger('p2p:bootstrap', bindings);
29
+ }
27
30
 
28
31
  /**
29
32
  * Starts the bootstrap node.
@@ -65,7 +68,7 @@ export class BootstrapNode implements P2PBootstrapApi {
65
68
 
66
69
  this.logger.debug(`Starting bootstrap node ${peerId} listening on ${listenAddrUdp.toString()}`);
67
70
 
68
- const metricsRegistry = new OtelMetricsAdapter(this.telemetry);
71
+ const metricsRegistry = new OtelMetricsAdapter(this.telemetry, this.logger.getBindings());
69
72
  this.node = Discv5.create({
70
73
  enr: ourEnr,
71
74
  peerId,
@@ -13,20 +13,20 @@ import { type TelemetryClient, getTelemetryClient } from '@aztec/telemetry-clien
13
13
 
14
14
  import { P2PClient } from '../client/p2p_client.js';
15
15
  import type { P2PConfig } from '../config.js';
16
- import type { AttestationPool } from '../mem_pools/attestation_pool/attestation_pool.js';
17
- import { KvAttestationPool } from '../mem_pools/attestation_pool/kv_attestation_pool.js';
16
+ import { AttestationPool, type AttestationPoolApi } from '../mem_pools/attestation_pool/attestation_pool.js';
18
17
  import type { MemPools } from '../mem_pools/interface.js';
19
18
  import { AztecKVTxPool, type TxPool } from '../mem_pools/tx_pool/index.js';
20
19
  import { DummyP2PService } from '../services/dummy_service.js';
21
20
  import { LibP2PService } from '../services/index.js';
22
21
  import { TxCollection } from '../services/tx_collection/tx_collection.js';
23
22
  import { type TxSource, createNodeRpcTxSources } from '../services/tx_collection/tx_source.js';
23
+ import { TxFileStore } from '../services/tx_file_store/tx_file_store.js';
24
24
  import { configureP2PClientAddresses, createLibP2PPeerIdFromPrivateKey, getPeerIdPrivateKey } from '../util.js';
25
25
 
26
26
  export type P2PClientDeps<T extends P2PClientType> = {
27
27
  txPool?: TxPool;
28
28
  store?: AztecAsyncKVStore;
29
- attestationPool?: AttestationPool;
29
+ attestationPool?: AttestationPoolApi;
30
30
  logger?: Logger;
31
31
  txCollectionNodeSources?: TxSource[];
32
32
  p2pServiceFactory?: (...args: Parameters<(typeof LibP2PService)['new']>) => Promise<LibP2PService<T>>;
@@ -62,15 +62,11 @@ export async function createP2PClient<T extends P2PClientType>(
62
62
  );
63
63
  }
64
64
 
65
- const store = deps.store ?? (await createStore(P2P_STORE_NAME, 2, config, createLogger('p2p:lmdb-v2')));
66
- const archive = await createStore(P2P_ARCHIVE_STORE_NAME, 1, config, createLogger('p2p-archive:lmdb-v2'));
67
- const peerStore = await createStore(P2P_PEER_STORE_NAME, 1, config, createLogger('p2p-peer:lmdb-v2'));
68
- const attestationStore = await createStore(
69
- P2P_ATTESTATION_STORE_NAME,
70
- 1,
71
- config,
72
- createLogger('p2p-attestation:lmdb-v2'),
73
- );
65
+ const bindings = logger.getBindings();
66
+ const store = deps.store ?? (await createStore(P2P_STORE_NAME, 2, config, bindings));
67
+ const archive = await createStore(P2P_ARCHIVE_STORE_NAME, 1, config, bindings);
68
+ const peerStore = await createStore(P2P_PEER_STORE_NAME, 1, config, bindings);
69
+ const attestationStore = await createStore(P2P_ATTESTATION_STORE_NAME, 1, config, bindings);
74
70
  const l1Constants = await archiver.getL1Constants();
75
71
 
76
72
  const mempools: MemPools = {
@@ -80,7 +76,7 @@ export async function createP2PClient<T extends P2PClientType>(
80
76
  maxPendingTxCount: config.maxPendingTxCount,
81
77
  archivedTxLimit: config.archivedTxLimit,
82
78
  }),
83
- attestationPool: deps.attestationPool ?? new KvAttestationPool(attestationStore, telemetry),
79
+ attestationPool: deps.attestationPool ?? new AttestationPool(attestationStore, telemetry),
84
80
  };
85
81
 
86
82
  const p2pService = await createP2PService<T>(
@@ -120,6 +116,8 @@ export async function createP2PClient<T extends P2PClientType>(
120
116
  logger.createChild('tx-collection'),
121
117
  );
122
118
 
119
+ const txFileStore = await TxFileStore.create(mempools.txPool, config, logger.createChild('tx-file-store'), telemetry);
120
+
123
121
  return new P2PClient(
124
122
  clientType,
125
123
  store,
@@ -127,6 +125,7 @@ export async function createP2PClient<T extends P2PClientType>(
127
125
  mempools,
128
126
  p2pService,
129
127
  txCollection,
128
+ txFileStore,
130
129
  config,
131
130
  dateProvider,
132
131
  telemetry,
@@ -13,7 +13,11 @@ import type {
13
13
  ReqRespSubProtocolHandler,
14
14
  ReqRespSubProtocolValidators,
15
15
  } from '../services/reqresp/interface.js';
16
- import type { P2PBlockReceivedCallback, P2PCheckpointReceivedCallback } from '../services/service.js';
16
+ import type {
17
+ DuplicateProposalInfo,
18
+ P2PBlockReceivedCallback,
19
+ P2PCheckpointReceivedCallback,
20
+ } from '../services/service.js';
17
21
 
18
22
  /**
19
23
  * Enum defining the possible states of the p2p client.
@@ -78,6 +82,14 @@ export type P2P<T extends P2PClientType = P2PClientType.Full> = P2PApiFull<T> &
78
82
  */
79
83
  registerCheckpointProposalHandler(callback: P2PCheckpointReceivedCallback): void;
80
84
 
85
+ /**
86
+ * Registers a callback invoked when a duplicate proposal is detected (equivocation).
87
+ * The callback is triggered on the first duplicate (when count goes from 1 to 2).
88
+ *
89
+ * @param callback - Function called with info about the duplicate proposal
90
+ */
91
+ registerDuplicateProposalCallback(callback: (info: DuplicateProposalInfo) => void): void;
92
+
81
93
  /**
82
94
  * Request a list of transactions from another peer by their tx hashes.
83
95
  * @param txHashes - Hashes of the txs to query.