@aztec/p2p 0.0.1-commit.3469e52 → 0.0.1-commit.3895657bc

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 (500) 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 +11 -11
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +46 -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 -224
  12. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +304 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  18. package/dest/config.d.ts +53 -16
  19. package/dest/config.d.ts.map +1 -1
  20. package/dest/config.js +87 -39
  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 +180 -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 +75 -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 +213 -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 +10 -0
  108. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +127 -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 +210 -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 +337 -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 +909 -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 +40 -9
  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 +6 -4
  133. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  134. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  135. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +6 -4
  136. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  137. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  138. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -8
  139. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  140. package/dest/msg_validators/proposal_validator/proposal_validator.js +81 -38
  141. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  142. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  143. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  144. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  145. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  146. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  147. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  148. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  149. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  150. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  151. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  152. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  153. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  154. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  155. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  156. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  157. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  158. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  159. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  160. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  161. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  162. package/dest/msg_validators/tx_validator/factory.d.ts +118 -5
  163. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  164. package/dest/msg_validators/tx_validator/factory.js +228 -57
  165. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
  166. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
  167. package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
  168. package/dest/msg_validators/tx_validator/gas_validator.d.ts +59 -3
  169. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  170. package/dest/msg_validators/tx_validator/gas_validator.js +76 -38
  171. package/dest/msg_validators/tx_validator/index.d.ts +3 -1
  172. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  173. package/dest/msg_validators/tx_validator/index.js +2 -0
  174. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  175. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  176. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  177. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  178. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  179. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  180. package/dest/msg_validators/tx_validator/phases_validator.d.ts +4 -3
  181. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  182. package/dest/msg_validators/tx_validator/phases_validator.js +47 -26
  183. package/dest/msg_validators/tx_validator/size_validator.d.ts +3 -1
  184. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -1
  185. package/dest/msg_validators/tx_validator/size_validator.js +4 -1
  186. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  187. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  188. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  189. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  190. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  191. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  192. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  193. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  194. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  195. package/dest/services/data_store.d.ts +1 -1
  196. package/dest/services/data_store.d.ts.map +1 -1
  197. package/dest/services/data_store.js +10 -6
  198. package/dest/services/discv5/discV5_service.js +1 -1
  199. package/dest/services/dummy_service.d.ts +24 -4
  200. package/dest/services/dummy_service.d.ts.map +1 -1
  201. package/dest/services/dummy_service.js +46 -1
  202. package/dest/services/encoding.d.ts +3 -3
  203. package/dest/services/encoding.d.ts.map +1 -1
  204. package/dest/services/encoding.js +11 -10
  205. package/dest/services/gossipsub/index.d.ts +3 -0
  206. package/dest/services/gossipsub/index.d.ts.map +1 -0
  207. package/dest/services/gossipsub/index.js +2 -0
  208. package/dest/services/gossipsub/scoring.d.ts +21 -3
  209. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  210. package/dest/services/gossipsub/scoring.js +24 -7
  211. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  212. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  213. package/dest/services/gossipsub/topic_score_params.js +346 -0
  214. package/dest/services/index.d.ts +2 -1
  215. package/dest/services/index.d.ts.map +1 -1
  216. package/dest/services/index.js +1 -0
  217. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  218. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  219. package/dest/services/libp2p/instrumentation.js +14 -3
  220. package/dest/services/libp2p/libp2p_service.d.ts +101 -43
  221. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  222. package/dest/services/libp2p/libp2p_service.js +470 -372
  223. package/dest/services/peer-manager/metrics.d.ts +4 -2
  224. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  225. package/dest/services/peer-manager/metrics.js +26 -5
  226. package/dest/services/peer-manager/peer_manager.d.ts +1 -1
  227. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  228. package/dest/services/peer-manager/peer_manager.js +2 -1
  229. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  230. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  231. package/dest/services/peer-manager/peer_scoring.js +33 -4
  232. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +48 -0
  233. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  234. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +539 -0
  235. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  236. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  237. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  238. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +46 -0
  239. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  240. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  241. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +34 -0
  242. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  243. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +130 -0
  244. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +60 -0
  245. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  246. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +173 -0
  247. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  248. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  249. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  250. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  251. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  252. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  253. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  254. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  255. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  256. package/dest/services/reqresp/interface.d.ts +14 -3
  257. package/dest/services/reqresp/interface.d.ts.map +1 -1
  258. package/dest/services/reqresp/interface.js +17 -3
  259. package/dest/services/reqresp/metrics.d.ts +6 -5
  260. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  261. package/dest/services/reqresp/metrics.js +17 -5
  262. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  263. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  264. package/dest/services/reqresp/protocols/block_txs/bitvector.js +5 -0
  265. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  266. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  267. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  268. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  269. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  270. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  271. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  272. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  273. package/dest/services/reqresp/protocols/tx.js +20 -0
  274. package/dest/services/reqresp/reqresp.d.ts +6 -1
  275. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  276. package/dest/services/reqresp/reqresp.js +71 -27
  277. package/dest/services/service.d.ts +42 -3
  278. package/dest/services/service.d.ts.map +1 -1
  279. package/dest/services/tx_collection/config.d.ts +22 -1
  280. package/dest/services/tx_collection/config.d.ts.map +1 -1
  281. package/dest/services/tx_collection/config.js +55 -1
  282. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -4
  283. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  284. package/dest/services/tx_collection/fast_tx_collection.js +71 -44
  285. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  286. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  287. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  288. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  289. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  290. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  291. package/dest/services/tx_collection/index.d.ts +3 -1
  292. package/dest/services/tx_collection/index.d.ts.map +1 -1
  293. package/dest/services/tx_collection/index.js +2 -0
  294. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  295. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  296. package/dest/services/tx_collection/instrumentation.js +10 -2
  297. package/dest/services/tx_collection/missing_txs_tracker.d.ts +32 -0
  298. package/dest/services/tx_collection/missing_txs_tracker.d.ts.map +1 -0
  299. package/dest/services/tx_collection/missing_txs_tracker.js +27 -0
  300. package/dest/services/tx_collection/proposal_tx_collector.d.ts +49 -0
  301. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  302. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  303. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -5
  304. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  305. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  306. package/dest/services/tx_collection/tx_collection.d.ts +29 -16
  307. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  308. package/dest/services/tx_collection/tx_collection.js +79 -7
  309. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  310. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  311. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  312. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  313. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  314. package/dest/services/tx_collection/tx_source.js +19 -2
  315. package/dest/services/tx_file_store/config.d.ts +16 -0
  316. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  317. package/dest/services/tx_file_store/config.js +22 -0
  318. package/dest/services/tx_file_store/index.d.ts +4 -0
  319. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  320. package/dest/services/tx_file_store/index.js +3 -0
  321. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  322. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  323. package/dest/services/tx_file_store/instrumentation.js +29 -0
  324. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  325. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  326. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  327. package/dest/services/tx_provider.d.ts +6 -6
  328. package/dest/services/tx_provider.d.ts.map +1 -1
  329. package/dest/services/tx_provider.js +9 -8
  330. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  331. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  332. package/dest/services/tx_provider_instrumentation.js +5 -5
  333. package/dest/test-helpers/index.d.ts +3 -1
  334. package/dest/test-helpers/index.d.ts.map +1 -1
  335. package/dest/test-helpers/index.js +2 -0
  336. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  337. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  338. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  339. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  340. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  341. package/dest/test-helpers/mock-pubsub.js +105 -4
  342. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  343. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  344. package/dest/test-helpers/reqresp-nodes.js +4 -3
  345. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  346. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  347. package/dest/test-helpers/test_tx_provider.js +41 -0
  348. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  349. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  350. package/dest/test-helpers/testbench-utils.js +366 -0
  351. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  352. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  353. package/dest/testbench/p2p_client_testbench_worker.js +221 -138
  354. package/dest/testbench/worker_client_manager.d.ts +53 -6
  355. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  356. package/dest/testbench/worker_client_manager.js +231 -45
  357. package/dest/util.d.ts +3 -3
  358. package/dest/util.d.ts.map +1 -1
  359. package/package.json +14 -14
  360. package/src/bootstrap/bootstrap.ts +7 -4
  361. package/src/client/factory.ts +85 -37
  362. package/src/client/interface.ts +56 -34
  363. package/src/client/p2p_client.ts +196 -273
  364. package/src/client/test/tx_proposal_collector/README.md +227 -0
  365. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +345 -0
  366. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  367. package/src/config.ts +137 -44
  368. package/src/errors/tx-pool.error.ts +12 -0
  369. package/src/index.ts +1 -0
  370. package/src/mem_pools/attestation_pool/attestation_pool.ts +497 -91
  371. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +442 -102
  372. package/src/mem_pools/attestation_pool/index.ts +9 -2
  373. package/src/mem_pools/attestation_pool/mocks.ts +2 -1
  374. package/src/mem_pools/index.ts +4 -1
  375. package/src/mem_pools/instrumentation.ts +19 -14
  376. package/src/mem_pools/interface.ts +4 -4
  377. package/src/mem_pools/tx_pool/README.md +1 -1
  378. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +2 -2
  379. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +2 -1
  380. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +2 -1
  381. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +10 -7
  382. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +3 -3
  383. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +4 -2
  384. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  385. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  386. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  387. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  388. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  389. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +121 -0
  390. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  391. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  392. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  393. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  394. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  395. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  396. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  397. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  398. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  399. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  400. package/src/mem_pools/tx_pool_v2/interfaces.ts +245 -0
  401. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +327 -0
  402. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  403. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  404. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +226 -0
  405. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1090 -0
  406. package/src/msg_validators/attestation_validator/attestation_validator.ts +25 -13
  407. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +16 -10
  408. package/src/msg_validators/clock_tolerance.ts +51 -0
  409. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +14 -4
  410. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +20 -7
  411. package/src/msg_validators/proposal_validator/proposal_validator.ts +78 -48
  412. package/src/msg_validators/tx_validator/README.md +115 -0
  413. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  414. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  415. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  416. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  417. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  418. package/src/msg_validators/tx_validator/data_validator.ts +6 -2
  419. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  420. package/src/msg_validators/tx_validator/factory.ts +372 -55
  421. package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
  422. package/src/msg_validators/tx_validator/gas_validator.ts +98 -29
  423. package/src/msg_validators/tx_validator/index.ts +2 -0
  424. package/src/msg_validators/tx_validator/metadata_validator.ts +18 -7
  425. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  426. package/src/msg_validators/tx_validator/phases_validator.ts +56 -29
  427. package/src/msg_validators/tx_validator/size_validator.ts +6 -2
  428. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  429. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  430. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  431. package/src/services/data_store.ts +10 -7
  432. package/src/services/discv5/discV5_service.ts +1 -1
  433. package/src/services/dummy_service.ts +59 -2
  434. package/src/services/encoding.ts +9 -9
  435. package/src/services/gossipsub/README.md +641 -0
  436. package/src/services/gossipsub/index.ts +2 -0
  437. package/src/services/gossipsub/scoring.ts +29 -5
  438. package/src/services/gossipsub/topic_score_params.ts +487 -0
  439. package/src/services/index.ts +1 -0
  440. package/src/services/libp2p/instrumentation.ts +15 -2
  441. package/src/services/libp2p/libp2p_service.ts +520 -402
  442. package/src/services/peer-manager/metrics.ts +28 -4
  443. package/src/services/peer-manager/peer_manager.ts +2 -1
  444. package/src/services/peer-manager/peer_scoring.ts +29 -1
  445. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  446. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +678 -0
  447. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  448. package/src/services/reqresp/batch-tx-requester/interface.ts +53 -0
  449. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +161 -0
  450. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +244 -0
  451. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  452. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  453. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  454. package/src/services/reqresp/interface.ts +31 -3
  455. package/src/services/reqresp/metrics.ts +34 -9
  456. package/src/services/reqresp/protocols/block_txs/bitvector.ts +7 -0
  457. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  458. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  459. package/src/services/reqresp/protocols/tx.ts +22 -0
  460. package/src/services/reqresp/reqresp.ts +82 -23
  461. package/src/services/service.ts +55 -2
  462. package/src/services/tx_collection/config.ts +83 -1
  463. package/src/services/tx_collection/fast_tx_collection.ts +93 -47
  464. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  465. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  466. package/src/services/tx_collection/index.ts +6 -0
  467. package/src/services/tx_collection/instrumentation.ts +17 -2
  468. package/src/services/tx_collection/missing_txs_tracker.ts +52 -0
  469. package/src/services/tx_collection/proposal_tx_collector.ts +113 -0
  470. package/src/services/tx_collection/slow_tx_collection.ts +68 -35
  471. package/src/services/tx_collection/tx_collection.ts +121 -24
  472. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  473. package/src/services/tx_collection/tx_source.ts +22 -3
  474. package/src/services/tx_file_store/config.ts +37 -0
  475. package/src/services/tx_file_store/index.ts +3 -0
  476. package/src/services/tx_file_store/instrumentation.ts +36 -0
  477. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  478. package/src/services/tx_provider.ts +12 -11
  479. package/src/services/tx_provider_instrumentation.ts +11 -5
  480. package/src/test-helpers/index.ts +2 -0
  481. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  482. package/src/test-helpers/mock-pubsub.ts +146 -9
  483. package/src/test-helpers/reqresp-nodes.ts +5 -7
  484. package/src/test-helpers/test_tx_provider.ts +64 -0
  485. package/src/test-helpers/testbench-utils.ts +430 -0
  486. package/src/testbench/p2p_client_testbench_worker.ts +335 -132
  487. package/src/testbench/worker_client_manager.ts +312 -47
  488. package/src/util.ts +8 -2
  489. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  490. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  491. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  492. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  493. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  494. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  495. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  496. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  497. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -157
  498. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  499. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  500. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -191
@@ -1,15 +1,19 @@
1
- import { SecretValue } from '@aztec/foundation/config';
2
1
  import { EthAddress } from '@aztec/foundation/eth-address';
3
2
  import { sleep } from '@aztec/foundation/sleep';
4
3
  import { fork } from 'child_process';
4
+ import { existsSync } from 'fs';
5
5
  import path from 'path';
6
6
  import { fileURLToPath } from 'url';
7
7
  import { getP2PDefaultConfig } from '../config.js';
8
8
  import { generatePeerIdPrivateKeys } from '../test-helpers/generate-peer-id-private-keys.js';
9
9
  import { getPorts } from '../test-helpers/get-ports.js';
10
10
  import { makeEnr, makeEnrs } from '../test-helpers/make-enrs.js';
11
+ import { BENCHMARK_CONSTANTS } from '../test-helpers/testbench-utils.js';
11
12
  const __dirname = path.dirname(fileURLToPath(import.meta.url));
12
- const workerPath = path.join(__dirname, '../../dest/testbench/p2p_client_testbench_worker.js');
13
+ const p2pRoot = path.resolve(__dirname, '../..');
14
+ const workerTsPath = path.join(__dirname, 'p2p_client_testbench_worker.ts');
15
+ const workerJsPath = path.join(p2pRoot, 'dest/testbench/p2p_client_testbench_worker.js');
16
+ const tsconfigPath = path.join(p2pRoot, 'tsconfig.json');
13
17
  const testChainConfig = {
14
18
  l1ChainId: 31337,
15
19
  rollupVersion: 1,
@@ -22,6 +26,7 @@ class WorkerClientManager {
22
26
  peerIdPrivateKeys = [];
23
27
  peerEnrs = [];
24
28
  ports = [];
29
+ peerIds = [];
25
30
  p2pConfig;
26
31
  logger;
27
32
  messageReceivedByClient = [];
@@ -36,12 +41,17 @@ class WorkerClientManager {
36
41
  });
37
42
  }
38
43
  /**
39
- * Creates a client configuration object
44
+ * Creates a client configuration object for IPC.
45
+ * Note: We send the raw peerIdPrivateKey string instead of SecretValue
46
+ * because SecretValue.toJSON() returns '[Redacted]', losing the value.
47
+ * The worker must re-wrap it in SecretValue.
48
+ * We also omit priceBumpPercentage since it's a bigint and can't be
49
+ * serialized over IPC (which uses JSON under the hood).
40
50
  */ createClientConfig(clientIndex, port, otherNodes) {
41
- return {
51
+ const { priceBumpPercentage: _, ...config } = {
42
52
  ...getP2PDefaultConfig(),
43
53
  p2pEnabled: true,
44
- peerIdPrivateKey: new SecretValue(this.peerIdPrivateKeys[clientIndex]),
54
+ peerIdPrivateKey: this.peerIdPrivateKeys[clientIndex],
45
55
  listenAddress: '127.0.0.1',
46
56
  p2pIp: '127.0.0.1',
47
57
  p2pPort: port,
@@ -50,19 +60,32 @@ class WorkerClientManager {
50
60
  ],
51
61
  ...this.p2pConfig
52
62
  };
63
+ return config;
53
64
  }
54
65
  /**
55
- * Spawns a worker process and returns a promise that resolves when the worker is ready
66
+ * Spawns a worker process and returns a promise that resolves when the worker is ready.
67
+ * Config uses raw string for peerIdPrivateKey (not SecretValue) for IPC serialization.
56
68
  */ spawnWorkerProcess(config, clientIndex) {
57
- const childProcess = fork(workerPath);
58
- // Extract the raw peerIdPrivateKey value since SecretValue can't be serialized via IPC
59
- const serializedConfig = {
60
- ...config,
61
- peerIdPrivateKey: config.peerIdPrivateKey?.getValue()
69
+ const useCompiled = existsSync(workerJsPath);
70
+ const workerPath = useCompiled ? workerJsPath : workerTsPath;
71
+ const execArgv = [
72
+ ...process.execArgv
73
+ ];
74
+ if (!useCompiled && !execArgv.includes('ts-node/esm')) {
75
+ execArgv.push('--loader', 'ts-node/esm');
76
+ }
77
+ const env = {
78
+ ...process.env,
79
+ TS_NODE_PROJECT: tsconfigPath
62
80
  };
81
+ const childProcess = fork(workerPath, {
82
+ cwd: p2pRoot,
83
+ execArgv,
84
+ env
85
+ });
63
86
  childProcess.send({
64
87
  type: 'START',
65
- config: serializedConfig,
88
+ config,
66
89
  clientIndex
67
90
  });
68
91
  // Handle unexpected child process exit
@@ -78,29 +101,54 @@ class WorkerClientManager {
78
101
  });
79
102
  // Create ready signal promise
80
103
  const readySignal = new Promise((resolve, reject)=>{
81
- // Set a timeout to avoid hanging indefinitely
104
+ let resolved = false;
82
105
  const timeout = setTimeout(()=>{
106
+ if (resolved) {
107
+ return;
108
+ }
109
+ resolved = true;
110
+ childProcess.off('message', messageHandler);
111
+ childProcess.off('exit', exitHandler);
83
112
  reject(new Error(`Timeout waiting for worker ${clientIndex} to be ready`));
84
- }, 30000); // 30 second timeout
85
- childProcess.once('message', (msg)=>{
86
- clearTimeout(timeout);
113
+ }, BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS);
114
+ const messageHandler = (msg)=>{
115
+ if (resolved) {
116
+ return;
117
+ }
118
+ // Only handle READY or ERROR messages; ignore others (e.g., GOSSIP_RECEIVED)
87
119
  if (msg.type === 'READY') {
120
+ resolved = true;
121
+ clearTimeout(timeout);
122
+ childProcess.off('message', messageHandler);
123
+ childProcess.off('exit', exitHandler);
124
+ if (typeof msg.peerId === 'string') {
125
+ this.peerIds[clientIndex] = msg.peerId;
126
+ }
88
127
  resolve();
89
- }
90
- // For future use
91
- if (msg.type === 'ERROR') {
128
+ } else if (msg.type === 'ERROR') {
129
+ resolved = true;
130
+ clearTimeout(timeout);
131
+ childProcess.off('message', messageHandler);
132
+ childProcess.off('exit', exitHandler);
92
133
  reject(new Error(msg.error));
93
134
  }
94
- });
95
- // Also resolve/reject if process exits before sending message
96
- childProcess.once('exit', (code)=>{
135
+ // Ignore other message types and keep waiting for READY/ERROR
136
+ };
137
+ const exitHandler = (code)=>{
138
+ if (resolved) {
139
+ return;
140
+ }
141
+ resolved = true;
97
142
  clearTimeout(timeout);
143
+ childProcess.off('message', messageHandler);
98
144
  if (code === 0) {
99
145
  resolve();
100
146
  } else {
101
147
  reject(new Error(`Worker ${clientIndex} exited with code ${code} before becoming ready`));
102
148
  }
103
- });
149
+ };
150
+ childProcess.on('message', messageHandler);
151
+ childProcess.once('exit', exitHandler);
104
152
  });
105
153
  return [
106
154
  childProcess,
@@ -108,34 +156,46 @@ class WorkerClientManager {
108
156
  ];
109
157
  }
110
158
  /**
111
- * Creates a number of worker clients in separate processes
112
- * All are configured to connect to each other and overrided with the test specific config
159
+ * Creates a number of worker clients in separate processes.
160
+ * All are configured to connect to each other and overridden with the test-specific config.
113
161
  *
114
162
  * @param numberOfClients - The number of clients to create
163
+ * @param options - Optional overrides for seeding/bootstrapping strategy
115
164
  * @returns The ENRs of the created clients
116
- */ async makeWorkerClients(numberOfClients) {
165
+ */ async makeWorkerClients(numberOfClients, options = {}) {
117
166
  try {
167
+ const bootstrapMode = options.bootstrapMode ?? (this.p2pConfig.bootstrapNodesAsFullPeers ? 'all' : 'subset');
168
+ const seedPeerLimit = options.seedPeerLimit ?? 10;
169
+ const batchSize = options.batchSize ?? (bootstrapMode === 'all' ? Math.min(5, numberOfClients) : numberOfClients);
170
+ const batchDelayMs = options.batchDelayMs ?? (bootstrapMode === 'all' ? 500 : 0);
118
171
  this.messageReceivedByClient = new Array(numberOfClients).fill(0);
119
172
  this.peerIdPrivateKeys = generatePeerIdPrivateKeys(numberOfClients);
120
173
  this.ports = await getPorts(numberOfClients);
121
174
  this.peerEnrs = await makeEnrs(this.peerIdPrivateKeys, this.ports, testChainConfig);
175
+ this.peerIds = new Array(numberOfClients);
122
176
  this.processes = [];
123
177
  const readySignals = [];
124
- for(let i = 0; i < numberOfClients; i++){
125
- this.logger.info(`Creating client ${i}`);
126
- // Maximum seed with 10 other peers to allow peer discovery to connect them at a smoother rate
127
- const otherNodes = this.peerEnrs.filter((_, ind)=>ind < Math.min(i, 10));
128
- const config = this.createClientConfig(i, this.ports[i], otherNodes);
129
- const [childProcess, readySignal] = this.spawnWorkerProcess(config, i);
130
- readySignals.push(readySignal);
131
- this.processes.push(childProcess);
178
+ for(let batchStart = 0; batchStart < numberOfClients; batchStart += batchSize){
179
+ const batchEnd = Math.min(batchStart + batchSize, numberOfClients);
180
+ const batchPromises = [];
181
+ for(let i = batchStart; i < batchEnd; i++){
182
+ this.logger.info(`Creating client ${i}`);
183
+ const otherNodes = bootstrapMode === 'all' ? this.peerEnrs.filter((_, ind)=>ind !== i) : this.peerEnrs.filter((_, ind)=>ind < Math.min(i, seedPeerLimit));
184
+ const config = this.createClientConfig(i, this.ports[i], otherNodes);
185
+ const [childProcess, readySignal] = this.spawnWorkerProcess(config, i);
186
+ readySignals.push(readySignal);
187
+ batchPromises.push(readySignal);
188
+ this.processes.push(childProcess);
189
+ }
190
+ await Promise.all(batchPromises);
191
+ if (batchEnd < numberOfClients && batchDelayMs > 0) {
192
+ await sleep(batchDelayMs);
193
+ }
132
194
  }
133
- // Wait for peers to all connect with each other
134
- await sleep(10000);
135
- // Wait for all peers to be booted up with timeout
195
+ await sleep(BENCHMARK_CONSTANTS.PEER_DISCOVERY_WAIT_MS);
136
196
  await Promise.race([
137
197
  Promise.all(readySignals),
138
- new Promise((_, reject)=>setTimeout(()=>reject(new Error('Timeout waiting for all workers to be ready')), 30000))
198
+ new Promise((_, reject)=>setTimeout(()=>reject(new Error('Timeout waiting for all workers to be ready')), BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS))
139
199
  ]);
140
200
  return this.peerEnrs;
141
201
  } catch (error) {
@@ -177,10 +237,9 @@ class WorkerClientManager {
177
237
  const config = this.createClientConfig(clientIndex, newPort, otherNodes);
178
238
  const [childProcess, readySignal] = this.spawnWorkerProcess(config, clientIndex);
179
239
  this.processes[clientIndex] = childProcess;
180
- // Wait for the process to be ready with a timeout
181
240
  await Promise.race([
182
241
  readySignal,
183
- new Promise((_, reject)=>setTimeout(()=>reject(new Error(`Timeout waiting for client ${clientIndex} to be ready`)), 30000))
242
+ new Promise((_, reject)=>setTimeout(()=>reject(new Error(`Timeout waiting for client ${clientIndex} to be ready`)), BENCHMARK_CONSTANTS.WORKER_READY_TIMEOUT_MS))
184
243
  ]);
185
244
  } catch (error) {
186
245
  this.logger.error(`Error during changePort for client ${clientIndex}:`, error);
@@ -196,15 +255,14 @@ class WorkerClientManager {
196
255
  return Promise.resolve();
197
256
  }
198
257
  return new Promise((resolve)=>{
199
- // Set a timeout for the graceful exit
200
258
  const forceKillTimeout = setTimeout(()=>{
201
259
  this.logger.warn(`Process ${index} didn't exit gracefully, force killing...`);
202
260
  try {
203
- process1.kill('SIGKILL'); // Force kill
261
+ process1.kill('SIGKILL');
204
262
  } catch (e) {
205
263
  this.logger.error(`Error force killing process ${index}:`, e);
206
264
  }
207
- }, 5000); // 5 second timeout for graceful exit
265
+ }, BENCHMARK_CONSTANTS.GRACEFUL_SHUTDOWN_TIMEOUT_MS);
208
266
  // Listen for process exit
209
267
  process1.once('exit', ()=>{
210
268
  clearTimeout(forceKillTimeout);
@@ -233,7 +291,6 @@ class WorkerClientManager {
233
291
  this.logger.info(`Cleaning up ${this.processes.length} worker processes`);
234
292
  // Create array of promises for each process termination
235
293
  const terminationPromises = this.processes.map((process1, index)=>this.terminateProcess(process1, index));
236
- // Wait for all processes to terminate with a timeout
237
294
  try {
238
295
  await Promise.race([
239
296
  Promise.all(terminationPromises),
@@ -250,14 +307,143 @@ class WorkerClientManager {
250
307
  }
251
308
  });
252
309
  resolve();
253
- }, 10000); // 10 second timeout for all processes
310
+ }, BENCHMARK_CONSTANTS.CLEANUP_TIMEOUT_MS);
254
311
  })
255
312
  ]);
256
313
  } catch (error) {
257
314
  this.logger.error('Error during cleanup:', error);
258
315
  }
259
316
  this.processes = [];
317
+ this.peerIds = [];
260
318
  this.logger.info('All worker processes cleaned up');
261
319
  }
320
+ /**
321
+ * Run a req/resp benchmark across all worker clients.
322
+ *
323
+ * This sends a BENCH_REQRESP command to all workers:
324
+ * - Aggregator (client 0) runs the collector and returns timing results
325
+ * - Responders (clients 1..N) populate their tx pools based on distribution
326
+ *
327
+ * All workers generate the same txs deterministically from a shared seed,
328
+ * then filter based on their peerIndex and distribution pattern.
329
+ */ async runReqRespBenchmark(config) {
330
+ const peerCount = this.processes.length;
331
+ if (peerCount < 2) {
332
+ throw new Error('Need at least 2 peers to run req/resp benchmark');
333
+ }
334
+ const seed = config.seed ?? Date.now();
335
+ const blockNumber = config.blockNumber ?? 1;
336
+ const pinnedPeerId = config.pinnedPeerIndex !== undefined ? this.peerIds[config.pinnedPeerIndex] : undefined;
337
+ this.logger.info(`Starting req/resp benchmark: txCount=${config.txCount}, distribution=${config.distribution}, collector=${config.collectorType}`);
338
+ const readyPromises = [];
339
+ for(let i = 1; i < peerCount; i++){
340
+ const cmd = {
341
+ type: 'BENCH_REQRESP',
342
+ txCount: config.txCount,
343
+ peerCount,
344
+ distribution: config.distribution,
345
+ collectorType: config.collectorType,
346
+ timeoutMs: config.timeoutMs,
347
+ isAggregator: false,
348
+ peerIndex: i,
349
+ pinnedPeerIndex: config.pinnedPeerIndex,
350
+ pinnedPeerId,
351
+ blockNumber,
352
+ seed
353
+ };
354
+ this.processes[i].send(cmd);
355
+ readyPromises.push(this.waitForBenchReady(i, 30000));
356
+ }
357
+ await Promise.all(readyPromises);
358
+ this.logger.info('All responder peers ready, starting aggregator benchmark...');
359
+ const aggregatorCmd = {
360
+ type: 'BENCH_REQRESP',
361
+ txCount: config.txCount,
362
+ peerCount,
363
+ distribution: config.distribution,
364
+ collectorType: config.collectorType,
365
+ timeoutMs: config.timeoutMs,
366
+ isAggregator: true,
367
+ peerIndex: 0,
368
+ pinnedPeerIndex: config.pinnedPeerIndex,
369
+ pinnedPeerId,
370
+ blockNumber,
371
+ seed
372
+ };
373
+ this.processes[0].send(aggregatorCmd);
374
+ const aggregatorBudgetMs = config.timeoutMs + BENCHMARK_CONSTANTS.MAX_PEER_WAIT_MS + 30000;
375
+ const result = await this.waitForBenchResult(0, aggregatorBudgetMs);
376
+ this.logger.info(`Benchmark complete: fetched=${result.fetchedCount}/${config.txCount}, duration=${result.durationMs.toFixed(0)}ms, success=${result.success}`);
377
+ return {
378
+ txCount: config.txCount,
379
+ distribution: config.distribution,
380
+ collector: config.collectorType,
381
+ durationMs: result.durationMs,
382
+ fetchedCount: result.fetchedCount,
383
+ success: result.success,
384
+ error: result.error
385
+ };
386
+ }
387
+ waitForBenchReady(clientIndex, timeoutMs) {
388
+ return new Promise((resolve, reject)=>{
389
+ let resolved = false;
390
+ const handler = (msg)=>{
391
+ if (resolved) {
392
+ return;
393
+ }
394
+ if (msg.type === 'BENCH_READY') {
395
+ resolved = true;
396
+ clearTimeout(timeout);
397
+ this.processes[clientIndex].off('message', handler);
398
+ resolve();
399
+ } else if (msg.type === 'ERROR') {
400
+ resolved = true;
401
+ clearTimeout(timeout);
402
+ this.processes[clientIndex].off('message', handler);
403
+ reject(new Error(`Client ${clientIndex} error: ${msg.error}`));
404
+ }
405
+ };
406
+ const timeout = setTimeout(()=>{
407
+ if (resolved) {
408
+ return;
409
+ }
410
+ resolved = true;
411
+ this.processes[clientIndex].off('message', handler);
412
+ reject(new Error(`Timeout waiting for BENCH_READY from client ${clientIndex}`));
413
+ }, timeoutMs);
414
+ this.processes[clientIndex].on('message', handler);
415
+ });
416
+ }
417
+ waitForBenchResult(clientIndex, timeoutMs) {
418
+ return new Promise((resolve, reject)=>{
419
+ let resolved = false;
420
+ const handler = (msg)=>{
421
+ if (resolved) {
422
+ return;
423
+ }
424
+ if (msg.type === 'BENCH_RESULT') {
425
+ resolved = true;
426
+ clearTimeout(timeout);
427
+ this.processes[clientIndex].off('message', handler);
428
+ resolve(msg);
429
+ } else if (msg.type === 'ERROR') {
430
+ resolved = true;
431
+ clearTimeout(timeout);
432
+ this.processes[clientIndex].off('message', handler);
433
+ reject(new Error(`Client ${clientIndex} error: ${msg.error}`));
434
+ }
435
+ };
436
+ const timeout = setTimeout(()=>{
437
+ if (resolved) {
438
+ return;
439
+ }
440
+ resolved = true;
441
+ this.processes[clientIndex].off('message', handler);
442
+ reject(new Error(`Timeout waiting for BENCH_RESULT from client ${clientIndex}`));
443
+ }, timeoutMs);
444
+ this.processes[clientIndex].on('message', handler);
445
+ });
446
+ }
262
447
  }
263
448
  export { WorkerClientManager, testChainConfig };
449
+ export { COLLECTOR_DISPLAY_NAMES } from './p2p_client_testbench_worker.js';
package/dest/util.d.ts CHANGED
@@ -1,7 +1,7 @@
1
1
  import { SecretValue } from '@aztec/foundation/config';
2
2
  import type { Logger } from '@aztec/foundation/log';
3
3
  import type { AztecAsyncKVStore } from '@aztec/kv-store';
4
- import type { DataStoreConfig } from '@aztec/kv-store/config';
4
+ import type { DataStoreConfig } from '@aztec/stdlib/kv-store';
5
5
  import type { GossipSub } from '@chainsafe/libp2p-gossipsub';
6
6
  import type { Identify } from '@libp2p/identify';
7
7
  import type { PeerId } from '@libp2p/interface';
@@ -10,7 +10,7 @@ import type { Libp2p } from 'libp2p';
10
10
  import type { P2PConfig } from './config.js';
11
11
  export interface PubSubLibp2p extends Pick<Libp2p, 'status' | 'start' | 'stop' | 'peerId'> {
12
12
  services: {
13
- pubsub: Pick<GossipSub, 'addEventListener' | 'removeEventListener' | 'publish' | 'subscribe' | 'reportMessageValidationResult' | 'direct'> & {
13
+ pubsub: Pick<GossipSub, 'addEventListener' | 'removeEventListener' | 'publish' | 'subscribe' | 'reportMessageValidationResult' | 'direct' | 'getMeshPeers'> & {
14
14
  score: Pick<GossipSub['score'], 'score'>;
15
15
  };
16
16
  };
@@ -58,4 +58,4 @@ export declare function getPeerIdPrivateKey(config: {
58
58
  * @returns The peer ID.
59
59
  */
60
60
  export declare function createLibP2PPeerIdFromPrivateKey(privateKey: string): Promise<PeerId>;
61
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUF1QixNQUFNLGlCQUFpQixDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTlELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTdELE9BQU8sS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBYyxNQUFNLG1CQUFtQixDQUFDO0FBQzVELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFJcEUsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBSXJDLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUk3QyxNQUFNLFdBQVcsWUFBYSxTQUFRLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxHQUFHLE9BQU8sR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDO0lBQ3hGLFFBQVEsRUFBRTtRQUNSLE1BQU0sRUFBRSxJQUFJLENBQ1YsU0FBUyxFQUNULGtCQUFrQixHQUFHLHFCQUFxQixHQUFHLFNBQVMsR0FBRyxXQUFXLEdBQUcsK0JBQStCLEdBQUcsUUFBUSxDQUNsSCxHQUFHO1lBQUUsS0FBSyxFQUFFLElBQUksQ0FBQyxTQUFTLENBQUMsT0FBTyxDQUFDLEVBQUUsT0FBTyxDQUFDLENBQUE7U0FBRSxDQUFDO0tBQ2xELENBQUM7Q0FDSDtBQUVELE1BQU0sTUFBTSxVQUFVLEdBQUcsTUFBTSxDQUFDO0lBQzlCLFFBQVEsRUFBRSxRQUFRLENBQUM7SUFDbkIsTUFBTSxFQUFFLFNBQVMsQ0FBQztJQUNsQixVQUFVLEVBQUU7UUFDVixpQkFBaUIsRUFBRSxpQkFBaUIsQ0FBQztLQUN0QyxDQUFDO0NBQ0gsQ0FBQyxDQUFDO0FBRUg7Ozs7Ozs7NkNBTzZDO0FBQzdDLHdCQUFnQixrQkFBa0IsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEVBQUUsUUFBUSxFQUFFLEtBQUssR0FBRyxLQUFLLEdBQUcsTUFBTSxDQU9qRztBQUVEOztHQUVHO0FBQ0gsd0JBQXNCLFdBQVcsSUFBSSxPQUFPLENBQUMsTUFBTSxDQUFDLENBUW5EO0FBRUQsd0JBQWdCLGdCQUFnQixDQUFDLE9BQU8sRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUd6RDtBQUVELHdCQUFzQix5QkFBeUIsQ0FBQyxPQUFPLEVBQUUsTUFBTSxFQUFFLElBQUksRUFBRSxNQUFNLEdBQUcsT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQVc5RjtBQWNELHdCQUFzQiwyQkFBMkIsQ0FDL0MsT0FBTyxFQUFFLFNBQVMsR0FBRyxlQUFlLEdBQ25DLE9BQU8sQ0FBQyxTQUFTLEdBQUcsZUFBZSxDQUFDLENBbUJ0QztBQUVEOzs7Ozs7OztHQVFHO0FBQ0gsd0JBQXNCLG1CQUFtQixDQUN2QyxNQUFNLEVBQUU7SUFBRSxnQkFBZ0IsQ0FBQyxFQUFFLFdBQVcsQ0FBQyxNQUFNLENBQUMsQ0FBQztJQUFDLG9CQUFvQixDQUFDLEVBQUUsTUFBTSxDQUFDO0lBQUMsYUFBYSxDQUFDLEVBQUUsTUFBTSxDQUFBO0NBQUUsRUFDekcsS0FBSyxFQUFFLGlCQUFpQixFQUN4QixNQUFNLEVBQUUsTUFBTSxHQUNiLE9BQU8sQ0FBQyxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUMsQ0EyRDlCO0FBRUQ7Ozs7R0FJRztBQUNILHdCQUFzQixnQ0FBZ0MsQ0FBQyxVQUFVLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FTMUYifQ==
61
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidXRpbC5kLnRzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vc3JjL3V0aWwudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLFdBQVcsRUFBRSxNQUFNLDBCQUEwQixDQUFDO0FBQ3ZELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBRSxNQUFNLHVCQUF1QixDQUFDO0FBQ3BELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUF1QixNQUFNLGlCQUFpQixDQUFDO0FBQzlFLE9BQU8sS0FBSyxFQUFFLGVBQWUsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRTlELE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLDZCQUE2QixDQUFDO0FBRTdELE9BQU8sS0FBSyxFQUFFLFFBQVEsRUFBRSxNQUFNLGtCQUFrQixDQUFDO0FBQ2pELE9BQU8sS0FBSyxFQUFFLE1BQU0sRUFBYyxNQUFNLG1CQUFtQixDQUFDO0FBQzVELE9BQU8sS0FBSyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sNEJBQTRCLENBQUM7QUFJcEUsT0FBTyxLQUFLLEVBQUUsTUFBTSxFQUFFLE1BQU0sUUFBUSxDQUFDO0FBSXJDLE9BQU8sS0FBSyxFQUFFLFNBQVMsRUFBRSxNQUFNLGFBQWEsQ0FBQztBQUk3QyxNQUFNLFdBQVcsWUFBYSxTQUFRLElBQUksQ0FBQyxNQUFNLEVBQUUsUUFBUSxHQUFHLE9BQU8sR0FBRyxNQUFNLEdBQUcsUUFBUSxDQUFDO0lBQ3hGLFFBQVEsRUFBRTtRQUNSLE1BQU0sRUFBRSxJQUFJLENBQ1YsU0FBUyxFQUNQLGtCQUFrQixHQUNsQixxQkFBcUIsR0FDckIsU0FBUyxHQUNULFdBQVcsR0FDWCwrQkFBK0IsR0FDL0IsUUFBUSxHQUNSLGNBQWMsQ0FDakIsR0FBRztZQUFFLEtBQUssRUFBRSxJQUFJLENBQUMsU0FBUyxDQUFDLE9BQU8sQ0FBQyxFQUFFLE9BQU8sQ0FBQyxDQUFBO1NBQUUsQ0FBQztLQUNsRCxDQUFDO0NBQ0g7QUFFRCxNQUFNLE1BQU0sVUFBVSxHQUFHLE1BQU0sQ0FBQztJQUM5QixRQUFRLEVBQUUsUUFBUSxDQUFDO0lBQ25CLE1BQU0sRUFBRSxTQUFTLENBQUM7SUFDbEIsVUFBVSxFQUFFO1FBQ1YsaUJBQWlCLEVBQUUsaUJBQWlCLENBQUM7S0FDdEMsQ0FBQztDQUNILENBQUMsQ0FBQztBQUVIOzs7Ozs7OzZDQU82QztBQUM3Qyx3QkFBZ0Isa0JBQWtCLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxFQUFFLFFBQVEsRUFBRSxLQUFLLEdBQUcsS0FBSyxHQUFHLE1BQU0sQ0FPakc7QUFFRDs7R0FFRztBQUNILHdCQUFzQixXQUFXLElBQUksT0FBTyxDQUFDLE1BQU0sQ0FBQyxDQVFuRDtBQUVELHdCQUFnQixnQkFBZ0IsQ0FBQyxPQUFPLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FHekQ7QUFFRCx3QkFBc0IseUJBQXlCLENBQUMsT0FBTyxFQUFFLE1BQU0sRUFBRSxJQUFJLEVBQUUsTUFBTSxHQUFHLE9BQU8sQ0FBQyxNQUFNLENBQUMsQ0FXOUY7QUFjRCx3QkFBc0IsMkJBQTJCLENBQy9DLE9BQU8sRUFBRSxTQUFTLEdBQUcsZUFBZSxHQUNuQyxPQUFPLENBQUMsU0FBUyxHQUFHLGVBQWUsQ0FBQyxDQW1CdEM7QUFFRDs7Ozs7Ozs7R0FRRztBQUNILHdCQUFzQixtQkFBbUIsQ0FDdkMsTUFBTSxFQUFFO0lBQUUsZ0JBQWdCLENBQUMsRUFBRSxXQUFXLENBQUMsTUFBTSxDQUFDLENBQUM7SUFBQyxvQkFBb0IsQ0FBQyxFQUFFLE1BQU0sQ0FBQztJQUFDLGFBQWEsQ0FBQyxFQUFFLE1BQU0sQ0FBQTtDQUFFLEVBQ3pHLEtBQUssRUFBRSxpQkFBaUIsRUFDeEIsTUFBTSxFQUFFLE1BQU0sR0FDYixPQUFPLENBQUMsV0FBVyxDQUFDLE1BQU0sQ0FBQyxDQUFDLENBMkQ5QjtBQUVEOzs7O0dBSUc7QUFDSCx3QkFBc0IsZ0NBQWdDLENBQUMsVUFBVSxFQUFFLE1BQU0sR0FBRyxPQUFPLENBQUMsTUFBTSxDQUFDLENBUzFGIn0=
@@ -1 +1 @@
1
- {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,KAAK,EAAE,iBAAiB,EAAuB,MAAM,iBAAiB,CAAC;AAC9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAE7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAc,MAAM,mBAAmB,CAAC;AAC5D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAIpE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAIrC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAI7C,MAAM,WAAW,YAAa,SAAQ,IAAI,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACxF,QAAQ,EAAE;QACR,MAAM,EAAE,IAAI,CACV,SAAS,EACT,kBAAkB,GAAG,qBAAqB,GAAG,SAAS,GAAG,WAAW,GAAG,+BAA+B,GAAG,QAAQ,CAClH,GAAG;YAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,CAAA;SAAE,CAAC;KAClD,CAAC;CACH;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC;IAC9B,QAAQ,EAAE,QAAQ,CAAC;IACnB,MAAM,EAAE,SAAS,CAAC;IAClB,UAAU,EAAE;QACV,iBAAiB,EAAE,iBAAiB,CAAC;KACtC,CAAC;CACH,CAAC,CAAC;AAEH;;;;;;;6CAO6C;AAC7C,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,GAAG,KAAK,GAAG,MAAM,CAOjG;AAED;;GAEG;AACH,wBAAsB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAQnD;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAGzD;AAED,wBAAsB,yBAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAW9F;AAcD,wBAAsB,2BAA2B,CAC/C,OAAO,EAAE,SAAS,GAAG,eAAe,GACnC,OAAO,CAAC,SAAS,GAAG,eAAe,CAAC,CAmBtC;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CACvC,MAAM,EAAE;IAAE,gBAAgB,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,EACzG,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CA2D9B;AAED;;;;GAIG;AACH,wBAAsB,gCAAgC,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAS1F"}
1
+ {"version":3,"file":"util.d.ts","sourceRoot":"","sources":["../src/util.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,WAAW,EAAE,MAAM,0BAA0B,CAAC;AACvD,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,uBAAuB,CAAC;AACpD,OAAO,KAAK,EAAE,iBAAiB,EAAuB,MAAM,iBAAiB,CAAC;AAC9E,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,wBAAwB,CAAC;AAE9D,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,6BAA6B,CAAC;AAE7D,OAAO,KAAK,EAAE,QAAQ,EAAE,MAAM,kBAAkB,CAAC;AACjD,OAAO,KAAK,EAAE,MAAM,EAAc,MAAM,mBAAmB,CAAC;AAC5D,OAAO,KAAK,EAAE,iBAAiB,EAAE,MAAM,4BAA4B,CAAC;AAIpE,OAAO,KAAK,EAAE,MAAM,EAAE,MAAM,QAAQ,CAAC;AAIrC,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,aAAa,CAAC;AAI7C,MAAM,WAAW,YAAa,SAAQ,IAAI,CAAC,MAAM,EAAE,QAAQ,GAAG,OAAO,GAAG,MAAM,GAAG,QAAQ,CAAC;IACxF,QAAQ,EAAE;QACR,MAAM,EAAE,IAAI,CACV,SAAS,EACP,kBAAkB,GAClB,qBAAqB,GACrB,SAAS,GACT,WAAW,GACX,+BAA+B,GAC/B,QAAQ,GACR,cAAc,CACjB,GAAG;YAAE,KAAK,EAAE,IAAI,CAAC,SAAS,CAAC,OAAO,CAAC,EAAE,OAAO,CAAC,CAAA;SAAE,CAAC;KAClD,CAAC;CACH;AAED,MAAM,MAAM,UAAU,GAAG,MAAM,CAAC;IAC9B,QAAQ,EAAE,QAAQ,CAAC;IACnB,MAAM,EAAE,SAAS,CAAC;IAClB,UAAU,EAAE;QACV,iBAAiB,EAAE,iBAAiB,CAAC;KACtC,CAAC;CACH,CAAC,CAAC;AAEH;;;;;;;6CAO6C;AAC7C,wBAAgB,kBAAkB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,EAAE,QAAQ,EAAE,KAAK,GAAG,KAAK,GAAG,MAAM,CAOjG;AAED;;GAEG;AACH,wBAAsB,WAAW,IAAI,OAAO,CAAC,MAAM,CAAC,CAQnD;AAED,wBAAgB,gBAAgB,CAAC,OAAO,EAAE,MAAM,GAAG,OAAO,CAGzD;AAED,wBAAsB,yBAAyB,CAAC,OAAO,EAAE,MAAM,EAAE,IAAI,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAW9F;AAcD,wBAAsB,2BAA2B,CAC/C,OAAO,EAAE,SAAS,GAAG,eAAe,GACnC,OAAO,CAAC,SAAS,GAAG,eAAe,CAAC,CAmBtC;AAED;;;;;;;;GAQG;AACH,wBAAsB,mBAAmB,CACvC,MAAM,EAAE;IAAE,gBAAgB,CAAC,EAAE,WAAW,CAAC,MAAM,CAAC,CAAC;IAAC,oBAAoB,CAAC,EAAE,MAAM,CAAC;IAAC,aAAa,CAAC,EAAE,MAAM,CAAA;CAAE,EACzG,KAAK,EAAE,iBAAiB,EACxB,MAAM,EAAE,MAAM,GACb,OAAO,CAAC,WAAW,CAAC,MAAM,CAAC,CAAC,CA2D9B;AAED;;;;GAIG;AACH,wBAAsB,gCAAgC,CAAC,UAAU,EAAE,MAAM,GAAG,OAAO,CAAC,MAAM,CAAC,CAS1F"}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aztec/p2p",
3
- "version": "0.0.1-commit.3469e52",
3
+ "version": "0.0.1-commit.3895657bc",
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.3469e52",
71
- "@aztec/epoch-cache": "0.0.1-commit.3469e52",
72
- "@aztec/ethereum": "0.0.1-commit.3469e52",
73
- "@aztec/foundation": "0.0.1-commit.3469e52",
74
- "@aztec/kv-store": "0.0.1-commit.3469e52",
75
- "@aztec/noir-contracts.js": "0.0.1-commit.3469e52",
76
- "@aztec/noir-protocol-circuits-types": "0.0.1-commit.3469e52",
77
- "@aztec/protocol-contracts": "0.0.1-commit.3469e52",
78
- "@aztec/simulator": "0.0.1-commit.3469e52",
79
- "@aztec/stdlib": "0.0.1-commit.3469e52",
80
- "@aztec/telemetry-client": "0.0.1-commit.3469e52",
70
+ "@aztec/constants": "0.0.1-commit.3895657bc",
71
+ "@aztec/epoch-cache": "0.0.1-commit.3895657bc",
72
+ "@aztec/ethereum": "0.0.1-commit.3895657bc",
73
+ "@aztec/foundation": "0.0.1-commit.3895657bc",
74
+ "@aztec/kv-store": "0.0.1-commit.3895657bc",
75
+ "@aztec/noir-contracts.js": "0.0.1-commit.3895657bc",
76
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.3895657bc",
77
+ "@aztec/protocol-contracts": "0.0.1-commit.3895657bc",
78
+ "@aztec/simulator": "0.0.1-commit.3895657bc",
79
+ "@aztec/stdlib": "0.0.1-commit.3895657bc",
80
+ "@aztec/telemetry-client": "0.0.1-commit.3895657bc",
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.3469e52",
108
- "@aztec/world-state": "0.0.1-commit.3469e52",
107
+ "@aztec/archiver": "0.0.1-commit.3895657bc",
108
+ "@aztec/world-state": "0.0.1-commit.3895657bc",
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,