@aztec/p2p 0.0.1-commit.9b94fc1 → 0.0.1-commit.9ee6fcc6

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 (573) hide show
  1. package/README.md +129 -3
  2. package/dest/bootstrap/bootstrap.d.ts +4 -3
  3. package/dest/bootstrap/bootstrap.d.ts.map +1 -1
  4. package/dest/bootstrap/bootstrap.js +4 -4
  5. package/dest/client/factory.d.ts +11 -11
  6. package/dest/client/factory.d.ts.map +1 -1
  7. package/dest/client/factory.js +58 -19
  8. package/dest/client/interface.d.ts +61 -35
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +52 -65
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +613 -336
  13. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts +2 -0
  14. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.d.ts.map +1 -0
  15. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker.js +304 -0
  16. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts +73 -0
  17. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.d.ts.map +1 -0
  18. package/dest/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.js +8 -0
  19. package/dest/config.d.ts +68 -22
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +117 -52
  22. package/dest/errors/tx-pool.error.d.ts +8 -0
  23. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  24. package/dest/errors/tx-pool.error.js +9 -0
  25. package/dest/index.d.ts +2 -1
  26. package/dest/index.d.ts.map +1 -1
  27. package/dest/index.js +1 -0
  28. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +111 -76
  29. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  30. package/dest/mem_pools/attestation_pool/attestation_pool.js +445 -3
  31. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  33. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +529 -289
  34. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  35. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  36. package/dest/mem_pools/attestation_pool/index.js +1 -2
  37. package/dest/mem_pools/attestation_pool/mocks.d.ts +11 -8
  38. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  39. package/dest/mem_pools/attestation_pool/mocks.js +17 -13
  40. package/dest/mem_pools/index.d.ts +3 -2
  41. package/dest/mem_pools/index.d.ts.map +1 -1
  42. package/dest/mem_pools/index.js +1 -1
  43. package/dest/mem_pools/instrumentation.d.ts +9 -1
  44. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  45. package/dest/mem_pools/instrumentation.js +33 -13
  46. package/dest/mem_pools/interface.d.ts +6 -7
  47. package/dest/mem_pools/interface.d.ts.map +1 -1
  48. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +37 -27
  49. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  50. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +314 -335
  51. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  52. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  53. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  54. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  55. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  56. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
  57. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  58. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  59. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +123 -0
  60. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
  61. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  66. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  67. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  69. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  70. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  72. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  73. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  74. package/dest/mem_pools/tx_pool/index.js +0 -1
  75. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  76. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  77. package/dest/mem_pools/tx_pool/priority.js +8 -3
  78. package/dest/mem_pools/tx_pool/tx_pool.d.ts +11 -6
  79. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  80. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  81. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  82. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +33 -25
  83. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  84. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  85. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  86. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  87. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  88. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  89. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  90. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  91. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  92. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  93. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  94. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  95. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  96. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  97. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +94 -0
  98. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  99. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  100. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  101. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  102. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  103. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  104. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  105. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  106. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  107. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  108. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  109. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  110. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  111. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  112. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  113. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  114. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  115. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  116. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  117. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  118. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  119. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  120. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  121. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  122. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  123. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  124. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  125. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  126. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  127. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  128. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +215 -0
  129. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  130. package/dest/mem_pools/tx_pool_v2/interfaces.js +10 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +134 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  133. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +216 -0
  134. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  135. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  136. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  137. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  138. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  139. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +337 -0
  140. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +62 -0
  141. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  142. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +167 -0
  143. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +78 -0
  144. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  145. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +923 -0
  146. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +4 -4
  147. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  148. package/dest/msg_validators/attestation_validator/attestation_validator.js +54 -20
  149. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +7 -7
  150. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  151. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +22 -13
  152. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  153. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  154. package/dest/msg_validators/clock_tolerance.js +38 -0
  155. package/dest/msg_validators/index.d.ts +2 -2
  156. package/dest/msg_validators/index.d.ts.map +1 -1
  157. package/dest/msg_validators/index.js +1 -1
  158. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +11 -0
  159. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  160. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +14 -0
  161. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +11 -0
  162. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  163. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +20 -0
  164. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  165. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  166. package/dest/msg_validators/proposal_validator/index.js +3 -0
  167. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +18 -0
  168. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  169. package/dest/msg_validators/proposal_validator/proposal_validator.js +116 -0
  170. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  171. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  172. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  173. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  174. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  175. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  176. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  177. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  178. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  179. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  180. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  181. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  182. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  183. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  184. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  185. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  186. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  187. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  188. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  189. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  190. package/dest/msg_validators/tx_validator/data_validator.js +39 -3
  191. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  192. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  193. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  194. package/dest/msg_validators/tx_validator/factory.d.ts +139 -6
  195. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  196. package/dest/msg_validators/tx_validator/factory.js +255 -58
  197. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  198. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  199. package/dest/msg_validators/tx_validator/fee_payer_balance.js +24 -0
  200. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  201. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  202. package/dest/msg_validators/tx_validator/gas_validator.js +114 -52
  203. package/dest/msg_validators/tx_validator/index.d.ts +4 -1
  204. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  205. package/dest/msg_validators/tx_validator/index.js +3 -0
  206. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +4 -3
  207. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  208. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  209. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  210. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  211. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  212. package/dest/msg_validators/tx_validator/phases_validator.d.ts +24 -3
  213. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  214. package/dest/msg_validators/tx_validator/phases_validator.js +75 -27
  215. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  216. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  217. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  218. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  219. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  220. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +23 -5
  221. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  222. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  223. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  224. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  225. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  226. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  227. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  228. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  229. package/dest/services/data_store.d.ts +1 -1
  230. package/dest/services/data_store.d.ts.map +1 -1
  231. package/dest/services/data_store.js +10 -6
  232. package/dest/services/discv5/discV5_service.js +1 -1
  233. package/dest/services/dummy_service.d.ts +28 -4
  234. package/dest/services/dummy_service.d.ts.map +1 -1
  235. package/dest/services/dummy_service.js +49 -1
  236. package/dest/services/encoding.d.ts +7 -3
  237. package/dest/services/encoding.d.ts.map +1 -1
  238. package/dest/services/encoding.js +23 -15
  239. package/dest/services/gossipsub/index.d.ts +3 -0
  240. package/dest/services/gossipsub/index.d.ts.map +1 -0
  241. package/dest/services/gossipsub/index.js +2 -0
  242. package/dest/services/gossipsub/scoring.d.ts +21 -3
  243. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  244. package/dest/services/gossipsub/scoring.js +24 -7
  245. package/dest/services/gossipsub/topic_score_params.d.ts +173 -0
  246. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  247. package/dest/services/gossipsub/topic_score_params.js +346 -0
  248. package/dest/services/index.d.ts +2 -1
  249. package/dest/services/index.d.ts.map +1 -1
  250. package/dest/services/index.js +1 -0
  251. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  252. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  253. package/dest/services/libp2p/instrumentation.js +30 -72
  254. package/dest/services/libp2p/libp2p_service.d.ts +111 -43
  255. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  256. package/dest/services/libp2p/libp2p_service.js +1047 -388
  257. package/dest/services/peer-manager/metrics.d.ts +9 -2
  258. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  259. package/dest/services/peer-manager/metrics.js +39 -21
  260. package/dest/services/peer-manager/peer_manager.d.ts +2 -2
  261. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  262. package/dest/services/peer-manager/peer_manager.js +10 -15
  263. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  264. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  265. package/dest/services/peer-manager/peer_scoring.js +32 -6
  266. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +51 -0
  267. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  268. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +540 -0
  269. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  270. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  271. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  272. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +47 -0
  273. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  274. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  275. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +35 -0
  276. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  277. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +136 -0
  278. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +62 -0
  279. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  280. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +176 -0
  281. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  282. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  283. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  284. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  285. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  286. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  287. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  288. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  289. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  290. package/dest/services/reqresp/constants.d.ts +12 -0
  291. package/dest/services/reqresp/constants.d.ts.map +1 -0
  292. package/dest/services/reqresp/constants.js +7 -0
  293. package/dest/services/reqresp/interface.d.ts +13 -2
  294. package/dest/services/reqresp/interface.d.ts.map +1 -1
  295. package/dest/services/reqresp/interface.js +16 -2
  296. package/dest/services/reqresp/metrics.d.ts +6 -5
  297. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  298. package/dest/services/reqresp/metrics.js +17 -21
  299. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  300. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  301. package/dest/services/reqresp/protocols/auth.js +2 -2
  302. package/dest/services/reqresp/protocols/block.d.ts +1 -1
  303. package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
  304. package/dest/services/reqresp/protocols/block.js +3 -2
  305. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  306. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  307. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  308. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  309. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  310. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  311. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +30 -7
  312. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  313. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +60 -14
  314. package/dest/services/reqresp/protocols/status.d.ts +5 -4
  315. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  316. package/dest/services/reqresp/protocols/status.js +7 -3
  317. package/dest/services/reqresp/protocols/tx.d.ts +8 -3
  318. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  319. package/dest/services/reqresp/protocols/tx.js +20 -0
  320. package/dest/services/reqresp/reqresp.d.ts +6 -1
  321. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  322. package/dest/services/reqresp/reqresp.js +488 -58
  323. package/dest/services/service.d.ts +56 -4
  324. package/dest/services/service.d.ts.map +1 -1
  325. package/dest/services/tx_collection/config.d.ts +22 -1
  326. package/dest/services/tx_collection/config.d.ts.map +1 -1
  327. package/dest/services/tx_collection/config.js +56 -2
  328. package/dest/services/tx_collection/fast_tx_collection.d.ts +10 -9
  329. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  330. package/dest/services/tx_collection/fast_tx_collection.js +95 -84
  331. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  332. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  333. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  334. package/dest/services/tx_collection/file_store_tx_source.d.ts +37 -0
  335. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  336. package/dest/services/tx_collection/file_store_tx_source.js +90 -0
  337. package/dest/services/tx_collection/index.d.ts +3 -1
  338. package/dest/services/tx_collection/index.d.ts.map +1 -1
  339. package/dest/services/tx_collection/index.js +2 -0
  340. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  341. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  342. package/dest/services/tx_collection/instrumentation.js +11 -13
  343. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  344. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  345. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  346. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  347. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  348. package/dest/services/tx_collection/request_tracker.js +84 -0
  349. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -4
  350. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  351. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  352. package/dest/services/tx_collection/tx_collection.d.ts +31 -20
  353. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  354. package/dest/services/tx_collection/tx_collection.js +79 -7
  355. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  356. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  357. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  358. package/dest/services/tx_collection/tx_source.d.ts +8 -3
  359. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  360. package/dest/services/tx_collection/tx_source.js +19 -2
  361. package/dest/services/tx_file_store/config.d.ts +16 -0
  362. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  363. package/dest/services/tx_file_store/config.js +22 -0
  364. package/dest/services/tx_file_store/index.d.ts +4 -0
  365. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  366. package/dest/services/tx_file_store/index.js +3 -0
  367. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  368. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  369. package/dest/services/tx_file_store/instrumentation.js +29 -0
  370. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  371. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  372. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  373. package/dest/services/tx_provider.d.ts +7 -5
  374. package/dest/services/tx_provider.d.ts.map +1 -1
  375. package/dest/services/tx_provider.js +20 -10
  376. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  377. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  378. package/dest/services/tx_provider_instrumentation.js +14 -14
  379. package/dest/test-helpers/index.d.ts +3 -1
  380. package/dest/test-helpers/index.d.ts.map +1 -1
  381. package/dest/test-helpers/index.js +2 -0
  382. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  383. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  384. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  385. package/dest/test-helpers/mock-pubsub.d.ts +30 -4
  386. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  387. package/dest/test-helpers/mock-pubsub.js +105 -4
  388. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  389. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  390. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  391. package/dest/test-helpers/reqresp-nodes.js +4 -3
  392. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  393. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  394. package/dest/test-helpers/test_tx_provider.js +41 -0
  395. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  396. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  397. package/dest/test-helpers/testbench-utils.js +385 -0
  398. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  399. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  400. package/dest/testbench/p2p_client_testbench_worker.js +226 -130
  401. package/dest/testbench/worker_client_manager.d.ts +53 -6
  402. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  403. package/dest/testbench/worker_client_manager.js +231 -40
  404. package/dest/util.d.ts +3 -3
  405. package/dest/util.d.ts.map +1 -1
  406. package/package.json +18 -18
  407. package/src/bootstrap/bootstrap.ts +7 -4
  408. package/src/client/factory.ts +110 -44
  409. package/src/client/interface.ts +73 -36
  410. package/src/client/p2p_client.ts +277 -397
  411. package/src/client/test/tx_proposal_collector/README.md +227 -0
  412. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +343 -0
  413. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  414. package/src/config.ts +182 -62
  415. package/src/errors/tx-pool.error.ts +12 -0
  416. package/src/index.ts +1 -0
  417. package/src/mem_pools/attestation_pool/attestation_pool.ts +511 -78
  418. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +614 -322
  419. package/src/mem_pools/attestation_pool/index.ts +9 -2
  420. package/src/mem_pools/attestation_pool/mocks.ts +22 -15
  421. package/src/mem_pools/index.ts +4 -1
  422. package/src/mem_pools/instrumentation.ts +43 -14
  423. package/src/mem_pools/interface.ts +5 -7
  424. package/src/mem_pools/tx_pool/README.md +270 -0
  425. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +367 -371
  426. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  427. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  428. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +163 -0
  429. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  430. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  431. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  432. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  433. package/src/mem_pools/tx_pool/index.ts +0 -1
  434. package/src/mem_pools/tx_pool/priority.ts +10 -3
  435. package/src/mem_pools/tx_pool/tx_pool.ts +11 -5
  436. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +26 -18
  437. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  438. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  439. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  440. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  441. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  442. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +122 -0
  443. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  444. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  445. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  446. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  447. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  448. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  449. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  450. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  451. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  452. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  453. package/src/mem_pools/tx_pool_v2/interfaces.ts +247 -0
  454. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +337 -0
  455. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  456. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  457. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +238 -0
  458. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1105 -0
  459. package/src/msg_validators/attestation_validator/README.md +49 -0
  460. package/src/msg_validators/attestation_validator/attestation_validator.ts +39 -23
  461. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +21 -18
  462. package/src/msg_validators/clock_tolerance.ts +52 -0
  463. package/src/msg_validators/index.ts +1 -1
  464. package/src/msg_validators/proposal_validator/README.md +123 -0
  465. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +20 -0
  466. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +26 -0
  467. package/src/msg_validators/proposal_validator/index.ts +3 -0
  468. package/src/msg_validators/proposal_validator/proposal_validator.ts +116 -0
  469. package/src/msg_validators/tx_validator/README.md +119 -0
  470. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  471. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  472. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  473. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  474. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  475. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  476. package/src/msg_validators/tx_validator/data_validator.ts +60 -7
  477. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  478. package/src/msg_validators/tx_validator/factory.ts +416 -58
  479. package/src/msg_validators/tx_validator/fee_payer_balance.ts +44 -0
  480. package/src/msg_validators/tx_validator/gas_validator.ts +140 -55
  481. package/src/msg_validators/tx_validator/index.ts +3 -0
  482. package/src/msg_validators/tx_validator/metadata_validator.ts +31 -12
  483. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  484. package/src/msg_validators/tx_validator/phases_validator.ts +87 -30
  485. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  486. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  487. package/src/msg_validators/tx_validator/timestamp_validator.ts +30 -19
  488. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  489. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  490. package/src/services/data_store.ts +10 -7
  491. package/src/services/discv5/discV5_service.ts +1 -1
  492. package/src/services/dummy_service.ts +65 -2
  493. package/src/services/encoding.ts +22 -13
  494. package/src/services/gossipsub/README.md +641 -0
  495. package/src/services/gossipsub/index.ts +2 -0
  496. package/src/services/gossipsub/scoring.ts +29 -5
  497. package/src/services/gossipsub/topic_score_params.ts +487 -0
  498. package/src/services/index.ts +1 -0
  499. package/src/services/libp2p/instrumentation.ts +32 -73
  500. package/src/services/libp2p/libp2p_service.ts +746 -406
  501. package/src/services/peer-manager/metrics.ts +46 -21
  502. package/src/services/peer-manager/peer_manager.ts +12 -7
  503. package/src/services/peer-manager/peer_scoring.ts +28 -4
  504. package/src/services/reqresp/README.md +229 -0
  505. package/src/services/reqresp/batch-tx-requester/README.md +344 -0
  506. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +670 -0
  507. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  508. package/src/services/reqresp/batch-tx-requester/interface.ts +54 -0
  509. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +168 -0
  510. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +249 -0
  511. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  512. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  513. package/src/services/reqresp/connection-sampler/connection_sampler.ts +19 -1
  514. package/src/services/reqresp/constants.ts +14 -0
  515. package/src/services/reqresp/interface.ts +30 -2
  516. package/src/services/reqresp/metrics.ts +36 -27
  517. package/src/services/reqresp/protocols/auth.ts +2 -2
  518. package/src/services/reqresp/protocols/block.ts +3 -2
  519. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  520. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  521. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +75 -10
  522. package/src/services/reqresp/protocols/status.ts +16 -12
  523. package/src/services/reqresp/protocols/tx.ts +23 -2
  524. package/src/services/reqresp/reqresp.ts +99 -32
  525. package/src/services/service.ts +73 -5
  526. package/src/services/tx_collection/config.ts +84 -2
  527. package/src/services/tx_collection/fast_tx_collection.ts +114 -93
  528. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  529. package/src/services/tx_collection/file_store_tx_source.ts +117 -0
  530. package/src/services/tx_collection/index.ts +6 -0
  531. package/src/services/tx_collection/instrumentation.ts +11 -13
  532. package/src/services/tx_collection/proposal_tx_collector.ts +108 -0
  533. package/src/services/tx_collection/request_tracker.ts +127 -0
  534. package/src/services/tx_collection/slow_tx_collection.ts +69 -36
  535. package/src/services/tx_collection/tx_collection.ts +123 -27
  536. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  537. package/src/services/tx_collection/tx_source.ts +22 -3
  538. package/src/services/tx_file_store/config.ts +37 -0
  539. package/src/services/tx_file_store/index.ts +3 -0
  540. package/src/services/tx_file_store/instrumentation.ts +36 -0
  541. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  542. package/src/services/tx_provider.ts +29 -12
  543. package/src/services/tx_provider_instrumentation.ts +24 -14
  544. package/src/test-helpers/index.ts +2 -0
  545. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  546. package/src/test-helpers/mock-pubsub.ts +147 -10
  547. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  548. package/src/test-helpers/reqresp-nodes.ts +6 -8
  549. package/src/test-helpers/test_tx_provider.ts +64 -0
  550. package/src/test-helpers/testbench-utils.ts +456 -0
  551. package/src/testbench/p2p_client_testbench_worker.ts +350 -129
  552. package/src/testbench/worker_client_manager.ts +312 -42
  553. package/src/util.ts +8 -2
  554. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -37
  555. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  556. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -213
  557. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -30
  558. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  559. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -219
  560. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -80
  561. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  562. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -238
  563. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  564. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  565. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -82
  566. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  567. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  568. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  569. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -298
  570. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -287
  571. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -283
  572. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -97
  573. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -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,11 +60,29 @@ 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);
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
80
+ };
81
+ const childProcess = fork(workerPath, {
82
+ cwd: p2pRoot,
83
+ execArgv,
84
+ env
85
+ });
58
86
  childProcess.send({
59
87
  type: 'START',
60
88
  config,
@@ -73,29 +101,54 @@ class WorkerClientManager {
73
101
  });
74
102
  // Create ready signal promise
75
103
  const readySignal = new Promise((resolve, reject)=>{
76
- // Set a timeout to avoid hanging indefinitely
104
+ let resolved = false;
77
105
  const timeout = setTimeout(()=>{
106
+ if (resolved) {
107
+ return;
108
+ }
109
+ resolved = true;
110
+ childProcess.off('message', messageHandler);
111
+ childProcess.off('exit', exitHandler);
78
112
  reject(new Error(`Timeout waiting for worker ${clientIndex} to be ready`));
79
- }, 30000); // 30 second timeout
80
- childProcess.once('message', (msg)=>{
81
- 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)
82
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
+ }
83
127
  resolve();
84
- }
85
- // For future use
86
- 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);
87
133
  reject(new Error(msg.error));
88
134
  }
89
- });
90
- // Also resolve/reject if process exits before sending message
91
- 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;
92
142
  clearTimeout(timeout);
143
+ childProcess.off('message', messageHandler);
93
144
  if (code === 0) {
94
145
  resolve();
95
146
  } else {
96
147
  reject(new Error(`Worker ${clientIndex} exited with code ${code} before becoming ready`));
97
148
  }
98
- });
149
+ };
150
+ childProcess.on('message', messageHandler);
151
+ childProcess.once('exit', exitHandler);
99
152
  });
100
153
  return [
101
154
  childProcess,
@@ -103,34 +156,46 @@ class WorkerClientManager {
103
156
  ];
104
157
  }
105
158
  /**
106
- * Creates a number of worker clients in separate processes
107
- * 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.
108
161
  *
109
162
  * @param numberOfClients - The number of clients to create
163
+ * @param options - Optional overrides for seeding/bootstrapping strategy
110
164
  * @returns The ENRs of the created clients
111
- */ async makeWorkerClients(numberOfClients) {
165
+ */ async makeWorkerClients(numberOfClients, options = {}) {
112
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);
113
171
  this.messageReceivedByClient = new Array(numberOfClients).fill(0);
114
172
  this.peerIdPrivateKeys = generatePeerIdPrivateKeys(numberOfClients);
115
173
  this.ports = await getPorts(numberOfClients);
116
174
  this.peerEnrs = await makeEnrs(this.peerIdPrivateKeys, this.ports, testChainConfig);
175
+ this.peerIds = new Array(numberOfClients);
117
176
  this.processes = [];
118
177
  const readySignals = [];
119
- for(let i = 0; i < numberOfClients; i++){
120
- this.logger.info(`Creating client ${i}`);
121
- // Maximum seed with 10 other peers to allow peer discovery to connect them at a smoother rate
122
- const otherNodes = this.peerEnrs.filter((_, ind)=>ind < Math.min(i, 10));
123
- const config = this.createClientConfig(i, this.ports[i], otherNodes);
124
- const [childProcess, readySignal] = this.spawnWorkerProcess(config, i);
125
- readySignals.push(readySignal);
126
- 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
+ }
127
194
  }
128
- // Wait for peers to all connect with each other
129
- await sleep(10000);
130
- // Wait for all peers to be booted up with timeout
195
+ await sleep(BENCHMARK_CONSTANTS.PEER_DISCOVERY_WAIT_MS);
131
196
  await Promise.race([
132
197
  Promise.all(readySignals),
133
- 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))
134
199
  ]);
135
200
  return this.peerEnrs;
136
201
  } catch (error) {
@@ -172,10 +237,9 @@ class WorkerClientManager {
172
237
  const config = this.createClientConfig(clientIndex, newPort, otherNodes);
173
238
  const [childProcess, readySignal] = this.spawnWorkerProcess(config, clientIndex);
174
239
  this.processes[clientIndex] = childProcess;
175
- // Wait for the process to be ready with a timeout
176
240
  await Promise.race([
177
241
  readySignal,
178
- 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))
179
243
  ]);
180
244
  } catch (error) {
181
245
  this.logger.error(`Error during changePort for client ${clientIndex}:`, error);
@@ -191,15 +255,14 @@ class WorkerClientManager {
191
255
  return Promise.resolve();
192
256
  }
193
257
  return new Promise((resolve)=>{
194
- // Set a timeout for the graceful exit
195
258
  const forceKillTimeout = setTimeout(()=>{
196
259
  this.logger.warn(`Process ${index} didn't exit gracefully, force killing...`);
197
260
  try {
198
- process1.kill('SIGKILL'); // Force kill
261
+ process1.kill('SIGKILL');
199
262
  } catch (e) {
200
263
  this.logger.error(`Error force killing process ${index}:`, e);
201
264
  }
202
- }, 5000); // 5 second timeout for graceful exit
265
+ }, BENCHMARK_CONSTANTS.GRACEFUL_SHUTDOWN_TIMEOUT_MS);
203
266
  // Listen for process exit
204
267
  process1.once('exit', ()=>{
205
268
  clearTimeout(forceKillTimeout);
@@ -228,7 +291,6 @@ class WorkerClientManager {
228
291
  this.logger.info(`Cleaning up ${this.processes.length} worker processes`);
229
292
  // Create array of promises for each process termination
230
293
  const terminationPromises = this.processes.map((process1, index)=>this.terminateProcess(process1, index));
231
- // Wait for all processes to terminate with a timeout
232
294
  try {
233
295
  await Promise.race([
234
296
  Promise.all(terminationPromises),
@@ -245,14 +307,143 @@ class WorkerClientManager {
245
307
  }
246
308
  });
247
309
  resolve();
248
- }, 10000); // 10 second timeout for all processes
310
+ }, BENCHMARK_CONSTANTS.CLEANUP_TIMEOUT_MS);
249
311
  })
250
312
  ]);
251
313
  } catch (error) {
252
314
  this.logger.error('Error during cleanup:', error);
253
315
  }
254
316
  this.processes = [];
317
+ this.peerIds = [];
255
318
  this.logger.info('All worker processes cleaned up');
256
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
+ }
257
447
  }
258
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.9b94fc1",
3
+ "version": "0.0.1-commit.9ee6fcc6",
4
4
  "type": "module",
5
5
  "exports": {
6
6
  ".": "./dest/index.js",
@@ -19,12 +19,12 @@
19
19
  "tsconfig": "./tsconfig.json"
20
20
  },
21
21
  "scripts": {
22
- "build": "yarn clean && tsgo -b",
23
- "build:dev": "tsgo -b --watch",
22
+ "build": "yarn clean && ../scripts/tsc.sh",
23
+ "build:dev": "../scripts/tsc.sh --watch",
24
24
  "clean": "rm -rf ./dest .tsbuildinfo",
25
25
  "test": "NODE_NO_WARNINGS=1 node --experimental-vm-modules ../node_modules/.bin/jest --passWithNoTests --maxWorkers=${JEST_MAX_WORKERS:-8}",
26
26
  "start": "node ./dest",
27
- "start:dev": "concurrently -k \"tsgo -b -w\" \"nodemon --watch dest --exec yarn start\""
27
+ "start:dev": "concurrently -k \"../scripts/tsc.sh --watch\" \"nodemon --watch dest --exec yarn start\""
28
28
  },
29
29
  "inherits": [
30
30
  "../package.common.json"
@@ -67,17 +67,17 @@
67
67
  ]
68
68
  },
69
69
  "dependencies": {
70
- "@aztec/constants": "0.0.1-commit.9b94fc1",
71
- "@aztec/epoch-cache": "0.0.1-commit.9b94fc1",
72
- "@aztec/ethereum": "0.0.1-commit.9b94fc1",
73
- "@aztec/foundation": "0.0.1-commit.9b94fc1",
74
- "@aztec/kv-store": "0.0.1-commit.9b94fc1",
75
- "@aztec/noir-contracts.js": "0.0.1-commit.9b94fc1",
76
- "@aztec/noir-protocol-circuits-types": "0.0.1-commit.9b94fc1",
77
- "@aztec/protocol-contracts": "0.0.1-commit.9b94fc1",
78
- "@aztec/simulator": "0.0.1-commit.9b94fc1",
79
- "@aztec/stdlib": "0.0.1-commit.9b94fc1",
80
- "@aztec/telemetry-client": "0.0.1-commit.9b94fc1",
70
+ "@aztec/constants": "0.0.1-commit.9ee6fcc6",
71
+ "@aztec/epoch-cache": "0.0.1-commit.9ee6fcc6",
72
+ "@aztec/ethereum": "0.0.1-commit.9ee6fcc6",
73
+ "@aztec/foundation": "0.0.1-commit.9ee6fcc6",
74
+ "@aztec/kv-store": "0.0.1-commit.9ee6fcc6",
75
+ "@aztec/noir-contracts.js": "0.0.1-commit.9ee6fcc6",
76
+ "@aztec/noir-protocol-circuits-types": "0.0.1-commit.9ee6fcc6",
77
+ "@aztec/protocol-contracts": "0.0.1-commit.9ee6fcc6",
78
+ "@aztec/simulator": "0.0.1-commit.9ee6fcc6",
79
+ "@aztec/stdlib": "0.0.1-commit.9ee6fcc6",
80
+ "@aztec/telemetry-client": "0.0.1-commit.9ee6fcc6",
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,12 +104,12 @@
104
104
  "xxhash-wasm": "^1.1.0"
105
105
  },
106
106
  "devDependencies": {
107
- "@aztec/archiver": "0.0.1-commit.9b94fc1",
108
- "@aztec/world-state": "0.0.1-commit.9b94fc1",
107
+ "@aztec/archiver": "0.0.1-commit.9ee6fcc6",
108
+ "@aztec/world-state": "0.0.1-commit.9ee6fcc6",
109
109
  "@jest/globals": "^30.0.0",
110
110
  "@types/jest": "^30.0.0",
111
111
  "@types/node": "^22.15.17",
112
- "@typescript/native-preview": "7.0.0-dev.20251126.1",
112
+ "@typescript/native-preview": "7.0.0-dev.20260113.1",
113
113
  "get-port": "^7.1.0",
114
114
  "it-drain": "^3.0.5",
115
115
  "it-length": "^3.0.6",
@@ -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,