@aztec/p2p 0.0.1-commit.24de95ac → 0.0.1-commit.2e2504e2

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 (538) 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 +2 -2
  5. package/dest/client/factory.d.ts.map +1 -1
  6. package/dest/client/factory.js +11 -9
  7. package/dest/client/index.d.ts +1 -1
  8. package/dest/client/interface.d.ts +18 -3
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +18 -37
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +477 -128
  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 +305 -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 +75 -60
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +26 -15
  22. package/dest/enr/generate-enr.d.ts +1 -1
  23. package/dest/enr/index.d.ts +1 -1
  24. package/dest/errors/attestation-pool.error.d.ts +7 -0
  25. package/dest/errors/attestation-pool.error.d.ts.map +1 -0
  26. package/dest/errors/attestation-pool.error.js +12 -0
  27. package/dest/errors/reqresp.error.d.ts +1 -1
  28. package/dest/errors/reqresp.error.d.ts.map +1 -1
  29. package/dest/index.d.ts +1 -1
  30. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +77 -36
  31. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  32. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +1 -1
  33. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  34. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +241 -266
  35. package/dest/mem_pools/attestation_pool/index.d.ts +1 -1
  36. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +24 -14
  37. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
  38. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +123 -95
  39. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +18 -12
  40. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
  41. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +91 -108
  42. package/dest/mem_pools/attestation_pool/mocks.d.ts +234 -10
  43. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  44. package/dest/mem_pools/attestation_pool/mocks.js +17 -13
  45. package/dest/mem_pools/index.d.ts +1 -1
  46. package/dest/mem_pools/instrumentation.d.ts +9 -1
  47. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  48. package/dest/mem_pools/instrumentation.js +37 -10
  49. package/dest/mem_pools/interface.d.ts +3 -4
  50. package/dest/mem_pools/interface.d.ts.map +1 -1
  51. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +33 -58
  52. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  53. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +314 -335
  54. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  55. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  56. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  57. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  58. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  59. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
  60. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  61. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  63. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
  64. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  66. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  67. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  69. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  70. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  72. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  73. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  75. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  76. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  77. package/dest/mem_pools/tx_pool/index.js +0 -1
  78. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  79. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  80. package/dest/mem_pools/tx_pool/priority.js +6 -1
  81. package/dest/mem_pools/tx_pool/tx_pool.d.ts +11 -6
  82. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  83. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  84. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  85. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +30 -24
  86. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  87. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  88. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  89. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  90. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  91. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -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 +119 -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 +90 -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 +89 -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 +131 -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 +17 -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 +63 -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 +91 -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 +70 -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 +63 -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 +5 -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 +4 -0
  125. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +193 -0
  126. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  127. package/dest/mem_pools/tx_pool_v2/interfaces.js +6 -0
  128. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +71 -0
  129. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  130. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +94 -0
  131. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  132. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  133. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  134. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +55 -0
  135. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  136. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +150 -0
  137. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +69 -0
  138. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  139. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +1041 -0
  140. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +7 -6
  141. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  142. package/dest/msg_validators/attestation_validator/attestation_validator.js +57 -24
  143. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +20 -0
  144. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -0
  145. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +76 -0
  146. package/dest/msg_validators/attestation_validator/index.d.ts +2 -1
  147. package/dest/msg_validators/attestation_validator/index.d.ts.map +1 -1
  148. package/dest/msg_validators/attestation_validator/index.js +1 -0
  149. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  150. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  151. package/dest/msg_validators/clock_tolerance.js +37 -0
  152. package/dest/msg_validators/index.d.ts +2 -2
  153. package/dest/msg_validators/index.d.ts.map +1 -1
  154. package/dest/msg_validators/index.js +1 -1
  155. package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts +1 -1
  156. package/dest/msg_validators/msg_seen_validator/msg_seen_validator.d.ts.map +1 -1
  157. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +9 -0
  158. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  159. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +6 -0
  160. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +9 -0
  161. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  162. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +6 -0
  163. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  164. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  165. package/dest/msg_validators/proposal_validator/index.js +3 -0
  166. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -0
  167. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  168. package/dest/msg_validators/proposal_validator/proposal_validator.js +104 -0
  169. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +23 -0
  170. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -0
  171. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +212 -0
  172. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +1 -1
  173. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  174. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +1 -1
  175. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  176. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  177. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  178. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +5 -4
  179. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  180. package/dest/msg_validators/tx_validator/block_header_validator.js +3 -2
  181. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  182. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  183. package/dest/msg_validators/tx_validator/data_validator.js +4 -1
  184. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +3 -2
  185. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  186. package/dest/msg_validators/tx_validator/double_spend_validator.js +3 -2
  187. package/dest/msg_validators/tx_validator/factory.d.ts +10 -4
  188. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  189. package/dest/msg_validators/tx_validator/factory.js +22 -12
  190. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  191. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  192. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  193. package/dest/msg_validators/tx_validator/gas_validator.d.ts +3 -2
  194. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  195. package/dest/msg_validators/tx_validator/gas_validator.js +11 -16
  196. package/dest/msg_validators/tx_validator/index.d.ts +2 -1
  197. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  198. package/dest/msg_validators/tx_validator/index.js +1 -0
  199. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +4 -3
  200. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  201. package/dest/msg_validators/tx_validator/metadata_validator.js +2 -2
  202. package/dest/msg_validators/tx_validator/phases_validator.d.ts +3 -2
  203. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  204. package/dest/msg_validators/tx_validator/phases_validator.js +6 -4
  205. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  206. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  207. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  208. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  209. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  210. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +5 -3
  211. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  212. package/dest/msg_validators/tx_validator/timestamp_validator.js +2 -2
  213. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  214. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  215. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  216. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  217. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  218. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  219. package/dest/services/data_store.d.ts +1 -1
  220. package/dest/services/data_store.d.ts.map +1 -1
  221. package/dest/services/data_store.js +10 -6
  222. package/dest/services/discv5/discV5_service.d.ts +1 -1
  223. package/dest/services/discv5/discV5_service.d.ts.map +1 -1
  224. package/dest/services/discv5/discV5_service.js +1 -1
  225. package/dest/services/dummy_service.d.ts +18 -2
  226. package/dest/services/dummy_service.d.ts.map +1 -1
  227. package/dest/services/dummy_service.js +42 -0
  228. package/dest/services/encoding.d.ts +1 -1
  229. package/dest/services/encoding.d.ts.map +1 -1
  230. package/dest/services/encoding.js +7 -6
  231. package/dest/services/gossipsub/scoring.d.ts +1 -1
  232. package/dest/services/index.d.ts +2 -1
  233. package/dest/services/index.d.ts.map +1 -1
  234. package/dest/services/index.js +1 -0
  235. package/dest/services/libp2p/instrumentation.d.ts +3 -1
  236. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  237. package/dest/services/libp2p/instrumentation.js +36 -71
  238. package/dest/services/libp2p/libp2p_service.d.ts +48 -81
  239. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  240. package/dest/services/libp2p/libp2p_service.js +926 -193
  241. package/dest/services/peer-manager/interface.d.ts +1 -1
  242. package/dest/services/peer-manager/metrics.d.ts +9 -2
  243. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  244. package/dest/services/peer-manager/metrics.js +39 -16
  245. package/dest/services/peer-manager/peer_manager.d.ts +2 -33
  246. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  247. package/dest/services/peer-manager/peer_manager.js +6 -12
  248. package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
  249. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  250. package/dest/services/peer-manager/peer_scoring.js +43 -2
  251. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +47 -0
  252. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  253. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +566 -0
  254. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  255. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  256. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  257. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +50 -0
  258. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  259. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  260. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +37 -0
  261. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  262. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +151 -0
  263. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +54 -0
  264. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  265. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +139 -0
  266. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  267. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  268. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  269. package/dest/services/reqresp/config.d.ts +1 -1
  270. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  271. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  272. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  273. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -4
  274. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  275. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  276. package/dest/services/reqresp/constants.d.ts +12 -0
  277. package/dest/services/reqresp/constants.d.ts.map +1 -0
  278. package/dest/services/reqresp/constants.js +7 -0
  279. package/dest/services/reqresp/index.d.ts +1 -1
  280. package/dest/services/reqresp/interface.d.ts +4 -2
  281. package/dest/services/reqresp/interface.d.ts.map +1 -1
  282. package/dest/services/reqresp/interface.js +1 -1
  283. package/dest/services/reqresp/metrics.d.ts +6 -5
  284. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  285. package/dest/services/reqresp/metrics.js +17 -21
  286. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  287. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  288. package/dest/services/reqresp/protocols/auth.js +2 -2
  289. package/dest/services/reqresp/protocols/block.d.ts +1 -1
  290. package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
  291. package/dest/services/reqresp/protocols/block.js +3 -2
  292. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  293. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  294. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  295. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +1 -1
  296. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  297. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +16 -3
  298. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +19 -9
  299. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  300. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +44 -14
  301. package/dest/services/reqresp/protocols/block_txs/index.d.ts +1 -1
  302. package/dest/services/reqresp/protocols/goodbye.d.ts +1 -1
  303. package/dest/services/reqresp/protocols/goodbye.d.ts.map +1 -1
  304. package/dest/services/reqresp/protocols/index.d.ts +1 -1
  305. package/dest/services/reqresp/protocols/ping.d.ts +1 -1
  306. package/dest/services/reqresp/protocols/status.d.ts +6 -5
  307. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  308. package/dest/services/reqresp/protocols/status.js +7 -3
  309. package/dest/services/reqresp/protocols/tx.d.ts +2 -3
  310. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  311. package/dest/services/reqresp/rate-limiter/index.d.ts +1 -1
  312. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +2 -2
  313. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
  314. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
  315. package/dest/services/reqresp/reqresp.d.ts +6 -41
  316. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  317. package/dest/services/reqresp/reqresp.js +460 -46
  318. package/dest/services/reqresp/status.d.ts +2 -2
  319. package/dest/services/reqresp/status.d.ts.map +1 -1
  320. package/dest/services/service.d.ts +19 -3
  321. package/dest/services/service.d.ts.map +1 -1
  322. package/dest/services/tx_collection/config.d.ts +4 -1
  323. package/dest/services/tx_collection/config.d.ts.map +1 -1
  324. package/dest/services/tx_collection/config.js +10 -2
  325. package/dest/services/tx_collection/fast_tx_collection.d.ts +9 -12
  326. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  327. package/dest/services/tx_collection/fast_tx_collection.js +16 -5
  328. package/dest/services/tx_collection/index.d.ts +2 -1
  329. package/dest/services/tx_collection/index.d.ts.map +1 -1
  330. package/dest/services/tx_collection/index.js +1 -0
  331. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  332. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  333. package/dest/services/tx_collection/instrumentation.js +10 -13
  334. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  335. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  336. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  337. package/dest/services/tx_collection/slow_tx_collection.d.ts +4 -5
  338. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  339. package/dest/services/tx_collection/slow_tx_collection.js +2 -1
  340. package/dest/services/tx_collection/tx_collection.d.ts +10 -10
  341. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  342. package/dest/services/tx_collection/tx_collection.js +5 -5
  343. package/dest/services/tx_collection/tx_collection_sink.d.ts +3 -3
  344. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  345. package/dest/services/tx_collection/tx_source.d.ts +1 -1
  346. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  347. package/dest/services/tx_file_store/config.d.ts +18 -0
  348. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  349. package/dest/services/tx_file_store/config.js +26 -0
  350. package/dest/services/tx_file_store/index.d.ts +4 -0
  351. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  352. package/dest/services/tx_file_store/index.js +3 -0
  353. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  354. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  355. package/dest/services/tx_file_store/instrumentation.js +29 -0
  356. package/dest/services/tx_file_store/tx_file_store.d.ts +47 -0
  357. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  358. package/dest/services/tx_file_store/tx_file_store.js +149 -0
  359. package/dest/services/tx_provider.d.ts +4 -2
  360. package/dest/services/tx_provider.d.ts.map +1 -1
  361. package/dest/services/tx_provider.js +11 -2
  362. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  363. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  364. package/dest/services/tx_provider_instrumentation.js +14 -14
  365. package/dest/test-helpers/generate-peer-id-private-keys.d.ts +1 -1
  366. package/dest/test-helpers/get-ports.d.ts +1 -1
  367. package/dest/test-helpers/get-ports.d.ts.map +1 -1
  368. package/dest/test-helpers/index.d.ts +3 -1
  369. package/dest/test-helpers/index.d.ts.map +1 -1
  370. package/dest/test-helpers/index.js +2 -0
  371. package/dest/test-helpers/make-enrs.d.ts +1 -1
  372. package/dest/test-helpers/make-test-p2p-clients.d.ts +2 -2
  373. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  374. package/dest/test-helpers/mock-pubsub.d.ts +4 -4
  375. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  376. package/dest/test-helpers/mock-tx-helpers.d.ts +2 -2
  377. package/dest/test-helpers/mock-tx-helpers.d.ts.map +1 -1
  378. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  379. package/dest/test-helpers/reqresp-nodes.d.ts +2 -2
  380. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  381. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  382. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  383. package/dest/test-helpers/test_tx_provider.js +41 -0
  384. package/dest/test-helpers/testbench-utils.d.ts +158 -0
  385. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  386. package/dest/test-helpers/testbench-utils.js +297 -0
  387. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  388. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  389. package/dest/testbench/p2p_client_testbench_worker.js +218 -120
  390. package/dest/testbench/parse_log_file.d.ts +1 -1
  391. package/dest/testbench/testbench.d.ts +1 -1
  392. package/dest/testbench/worker_client_manager.d.ts +51 -6
  393. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  394. package/dest/testbench/worker_client_manager.js +226 -39
  395. package/dest/types/index.d.ts +1 -1
  396. package/dest/util.d.ts +2 -1
  397. package/dest/util.d.ts.map +1 -1
  398. package/dest/util.js +11 -2
  399. package/dest/versioning.d.ts +1 -1
  400. package/package.json +19 -18
  401. package/src/bootstrap/bootstrap.ts +7 -4
  402. package/src/client/factory.ts +15 -20
  403. package/src/client/interface.ts +20 -2
  404. package/src/client/p2p_client.ts +121 -156
  405. package/src/client/test/tx_proposal_collector/README.md +227 -0
  406. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +336 -0
  407. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  408. package/src/config.ts +43 -20
  409. package/src/errors/attestation-pool.error.ts +13 -0
  410. package/src/mem_pools/attestation_pool/attestation_pool.ts +86 -35
  411. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +243 -278
  412. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +175 -111
  413. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +147 -136
  414. package/src/mem_pools/attestation_pool/mocks.ts +21 -15
  415. package/src/mem_pools/instrumentation.ts +48 -10
  416. package/src/mem_pools/interface.ts +2 -4
  417. package/src/mem_pools/tx_pool/README.md +270 -0
  418. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +367 -371
  419. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  420. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  421. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  422. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  423. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  424. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  425. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  426. package/src/mem_pools/tx_pool/index.ts +0 -1
  427. package/src/mem_pools/tx_pool/priority.ts +8 -1
  428. package/src/mem_pools/tx_pool/tx_pool.ts +11 -5
  429. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +23 -17
  430. package/src/mem_pools/tx_pool_v2/README.md +188 -0
  431. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  432. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  433. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +147 -0
  434. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +118 -0
  435. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +111 -0
  436. package/src/mem_pools/tx_pool_v2/eviction/index.ts +23 -0
  437. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +164 -0
  438. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  439. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  440. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +86 -0
  441. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +72 -0
  442. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +31 -0
  443. package/src/mem_pools/tx_pool_v2/index.ts +11 -0
  444. package/src/mem_pools/tx_pool_v2/interfaces.ts +225 -0
  445. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +160 -0
  446. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  447. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +209 -0
  448. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1265 -0
  449. package/src/msg_validators/attestation_validator/attestation_validator.ts +45 -32
  450. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +94 -0
  451. package/src/msg_validators/attestation_validator/index.ts +1 -0
  452. package/src/msg_validators/clock_tolerance.ts +51 -0
  453. package/src/msg_validators/index.ts +1 -1
  454. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +10 -0
  455. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +13 -0
  456. package/src/msg_validators/proposal_validator/index.ts +3 -0
  457. package/src/msg_validators/proposal_validator/proposal_validator.ts +92 -0
  458. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +230 -0
  459. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  460. package/src/msg_validators/tx_validator/block_header_validator.ts +6 -5
  461. package/src/msg_validators/tx_validator/data_validator.ts +18 -6
  462. package/src/msg_validators/tx_validator/double_spend_validator.ts +4 -3
  463. package/src/msg_validators/tx_validator/factory.ts +67 -25
  464. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  465. package/src/msg_validators/tx_validator/gas_validator.ts +17 -28
  466. package/src/msg_validators/tx_validator/index.ts +1 -0
  467. package/src/msg_validators/tx_validator/metadata_validator.ts +19 -8
  468. package/src/msg_validators/tx_validator/phases_validator.ts +8 -4
  469. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  470. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  471. package/src/msg_validators/tx_validator/timestamp_validator.ts +11 -5
  472. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  473. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  474. package/src/services/data_store.ts +10 -7
  475. package/src/services/discv5/discV5_service.ts +1 -1
  476. package/src/services/dummy_service.ts +51 -0
  477. package/src/services/encoding.ts +6 -5
  478. package/src/services/index.ts +1 -0
  479. package/src/services/libp2p/instrumentation.ts +39 -71
  480. package/src/services/libp2p/libp2p_service.ts +629 -195
  481. package/src/services/peer-manager/metrics.ts +44 -16
  482. package/src/services/peer-manager/peer_manager.ts +7 -4
  483. package/src/services/peer-manager/peer_scoring.ts +45 -3
  484. package/src/services/reqresp/batch-tx-requester/README.md +305 -0
  485. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +706 -0
  486. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  487. package/src/services/reqresp/batch-tx-requester/interface.ts +57 -0
  488. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +209 -0
  489. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +205 -0
  490. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  491. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  492. package/src/services/reqresp/connection-sampler/connection_sampler.ts +19 -1
  493. package/src/services/reqresp/constants.ts +14 -0
  494. package/src/services/reqresp/interface.ts +4 -1
  495. package/src/services/reqresp/metrics.ts +36 -27
  496. package/src/services/reqresp/protocols/auth.ts +2 -2
  497. package/src/services/reqresp/protocols/block.ts +3 -2
  498. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  499. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +18 -4
  500. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +52 -10
  501. package/src/services/reqresp/protocols/status.ts +16 -12
  502. package/src/services/reqresp/protocols/tx.ts +1 -2
  503. package/src/services/reqresp/reqresp.ts +66 -19
  504. package/src/services/service.ts +23 -4
  505. package/src/services/tx_collection/config.ts +16 -2
  506. package/src/services/tx_collection/fast_tx_collection.ts +39 -15
  507. package/src/services/tx_collection/index.ts +5 -0
  508. package/src/services/tx_collection/instrumentation.ts +5 -13
  509. package/src/services/tx_collection/proposal_tx_collector.ts +114 -0
  510. package/src/services/tx_collection/slow_tx_collection.ts +5 -4
  511. package/src/services/tx_collection/tx_collection.ts +10 -9
  512. package/src/services/tx_file_store/config.ts +43 -0
  513. package/src/services/tx_file_store/index.ts +3 -0
  514. package/src/services/tx_file_store/instrumentation.ts +36 -0
  515. package/src/services/tx_file_store/tx_file_store.ts +173 -0
  516. package/src/services/tx_provider.ts +19 -3
  517. package/src/services/tx_provider_instrumentation.ts +24 -14
  518. package/src/test-helpers/index.ts +2 -0
  519. package/src/test-helpers/mock-pubsub.ts +1 -1
  520. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  521. package/src/test-helpers/reqresp-nodes.ts +1 -1
  522. package/src/test-helpers/test_tx_provider.ts +64 -0
  523. package/src/test-helpers/testbench-utils.ts +374 -0
  524. package/src/testbench/p2p_client_testbench_worker.ts +338 -116
  525. package/src/testbench/worker_client_manager.ts +304 -42
  526. package/src/util.ts +12 -2
  527. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -80
  528. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  529. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -238
  530. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  531. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  532. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -70
  533. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  534. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  535. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  536. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -283
  537. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -81
  538. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -8,7 +8,9 @@ import type { ENR } from '@nethermindeth/enr';
8
8
  import EventEmitter from 'events';
9
9
 
10
10
  import type { PeerManagerInterface } from './peer-manager/interface.js';
11
+ import type { BatchTxRequesterLibP2PService } from './reqresp/batch-tx-requester/interface.js';
11
12
  import type { P2PReqRespConfig } from './reqresp/config.js';
13
+ import type { ConnectionSampler } from './reqresp/connection-sampler/connection_sampler.js';
12
14
  import { type AuthRequest, StatusMessage } from './reqresp/index.js';
13
15
  import type {
14
16
  ReqRespInterface,
@@ -23,6 +25,7 @@ import type { GoodByeReason } from './reqresp/protocols/goodbye.js';
23
25
  import { ReqRespStatus } from './reqresp/status.js';
24
26
  import {
25
27
  type P2PBlockReceivedCallback,
28
+ type P2PCheckpointReceivedCallback,
26
29
  type P2PService,
27
30
  type PeerDiscoveryService,
28
31
  PeerDiscoveryState,
@@ -74,6 +77,11 @@ export class DummyP2PService implements P2PService {
74
77
  */
75
78
  public registerBlockReceivedCallback(_callback: P2PBlockReceivedCallback) {}
76
79
 
80
+ /**
81
+ * Register a callback into the validator client for when a checkpoint proposal is received
82
+ */
83
+ public registerCheckpointReceivedCallback(_callback: P2PCheckpointReceivedCallback) {}
84
+
77
85
  /**
78
86
  * Sends a request to a peer.
79
87
  * @param _protocol - The protocol to send the request on.
@@ -100,6 +108,15 @@ export class DummyP2PService implements P2PService {
100
108
  return Promise.resolve([]);
101
109
  }
102
110
 
111
+ public sendRequestToPeer(
112
+ _peerId: PeerId,
113
+ _subProtocol: ReqRespSubProtocol,
114
+ _payload: Buffer,
115
+ _dialTimeout?: number,
116
+ ): Promise<ReqRespResponse> {
117
+ return Promise.resolve({ status: ReqRespStatus.SUCCESS, data: Buffer.from([]) });
118
+ }
119
+
103
120
  /**
104
121
  * Returns the ENR of the peer.
105
122
  * @returns The ENR of the peer, otherwise undefined.
@@ -112,6 +129,10 @@ export class DummyP2PService implements P2PService {
112
129
  return Promise.resolve();
113
130
  }
114
131
 
132
+ validatePropagatedTx(_tx: Tx, _peerId: PeerId): Promise<boolean> {
133
+ return Promise.resolve(true);
134
+ }
135
+
115
136
  addReqRespSubProtocol(
116
137
  _subProtocol: ReqRespSubProtocol,
117
138
  _handler: ReqRespSubProtocolHandler,
@@ -126,6 +147,27 @@ export class DummyP2PService implements P2PService {
126
147
 
127
148
  //this is no-op
128
149
  registerThisValidatorAddresses(_address: EthAddress[]): void {}
150
+
151
+ /**
152
+ * Get dummy BatchTxRequesterLibP2PService for testing
153
+ */
154
+ getBatchTxRequesterService(): BatchTxRequesterLibP2PService {
155
+ return {
156
+ reqResp: this, // The dummy service implements ReqRespInterface
157
+ connectionSampler: new DummyReqResp().getConnectionSampler(),
158
+ txValidatorConfig: {
159
+ l1ChainId: 1,
160
+ rollupVersion: 1,
161
+ proofVerifier: {
162
+ verifyProof: () => Promise.resolve({ valid: true, durationMs: 0, totalDurationMs: 0 }),
163
+ stop: () => Promise.resolve(),
164
+ },
165
+ },
166
+ peerScoring: {
167
+ penalizePeer: (_peerId, _penalty) => {},
168
+ },
169
+ };
170
+ }
129
171
  }
130
172
 
131
173
  /**
@@ -262,6 +304,15 @@ export class DummyReqResp implements ReqRespInterface {
262
304
  return Promise.resolve({ status: ReqRespStatus.SUCCESS, data: Buffer.from([]) });
263
305
  }
264
306
 
307
+ /**
308
+ * Get dummy connection sampler for testing
309
+ */
310
+ getConnectionSampler(): Pick<ConnectionSampler, 'getPeerListSortedByConnectionCountAsc'> {
311
+ return {
312
+ getPeerListSortedByConnectionCountAsc: () => [],
313
+ };
314
+ }
315
+
265
316
  addSubProtocol(
266
317
  _subProtocol: ReqRespSubProtocol,
267
318
  _handler: ReqRespSubProtocolHandler,
@@ -1,7 +1,7 @@
1
1
  // Taken from lodestar: https://github.com/ChainSafe/lodestar
2
- import { sha256 } from '@aztec/foundation/crypto';
2
+ import { sha256 } from '@aztec/foundation/crypto/sha256';
3
3
  import { createLogger } from '@aztec/foundation/log';
4
- import { TopicType, getTopicFromString } from '@aztec/stdlib/p2p';
4
+ import { MAX_TX_SIZE_KB, TopicType, getTopicFromString } from '@aztec/stdlib/p2p';
5
5
 
6
6
  import type { RPC } from '@chainsafe/libp2p-gossipsub/message';
7
7
  import type { DataTransform } from '@chainsafe/libp2p-gossipsub/types';
@@ -52,13 +52,14 @@ export function getMsgIdFn(message: Message) {
52
52
  }
53
53
 
54
54
  const DefaultMaxSizesKb: Record<TopicType, number> = {
55
- // Tx effects should not exceed 128kb, so 512kb for the full tx obj should be sufficient
56
- [TopicType.tx]: 512,
55
+ [TopicType.tx]: MAX_TX_SIZE_KB,
57
56
  // An attestation has roughly 30 fields, which is 1kb, so 5x is plenty
58
- [TopicType.block_attestation]: 5,
57
+ [TopicType.checkpoint_attestation]: 5,
59
58
  // Proposals may carry some tx objects, so we allow a larger size capped at 10mb
60
59
  // Note this may not be enough for carrying all tx objects in a block
61
60
  [TopicType.block_proposal]: 1024 * 10,
61
+ // TODO(palla/mbps): Check size for checkpoint proposal
62
+ [TopicType.checkpoint_proposal]: 1024 * 10,
62
63
  };
63
64
 
64
65
  /**
@@ -3,4 +3,5 @@ export * from './libp2p/libp2p_service.js';
3
3
  export * from './tx_provider.js';
4
4
  export * from './dummy_service.js';
5
5
  export * from './reqresp/index.js';
6
+ export * from './tx_file_store/index.js';
6
7
  export * from './tx_collection/index.js';
@@ -8,7 +8,7 @@ import {
8
8
  type ObservableGauge,
9
9
  type TelemetryClient,
10
10
  type UpDownCounter,
11
- ValueType,
11
+ createUpDownCounterWithDefault,
12
12
  } from '@aztec/telemetry-client';
13
13
 
14
14
  import { type RecordableHistogram, createHistogram } from 'node:perf_hooks';
@@ -17,6 +17,7 @@ export class P2PInstrumentation {
17
17
  private messageValidationDuration: Histogram;
18
18
  private messagePrevalidationCount: UpDownCounter;
19
19
  private messageLatency: Histogram;
20
+ private txReceivedCount: UpDownCounter;
20
21
 
21
22
  private aggLatencyHisto = new Map<TopicType, RecordableHistogram>();
22
23
  private aggValidationHisto = new Map<TopicType, RecordableHistogram>();
@@ -27,77 +28,40 @@ export class P2PInstrumentation {
27
28
  constructor(client: TelemetryClient, name: string) {
28
29
  const meter = client.getMeter(name);
29
30
 
30
- this.messageValidationDuration = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_VALIDATION_DURATION, {
31
- unit: 'ms',
32
- description: 'How long validating a gossiped message takes',
33
- valueType: ValueType.INT,
34
- });
31
+ this.messageValidationDuration = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_VALIDATION_DURATION);
35
32
 
36
- this.messagePrevalidationCount = meter.createUpDownCounter(Metrics.P2P_GOSSIP_MESSAGE_PREVALIDATION_COUNT, {
37
- description: 'How many message pass/fail prevalidation',
38
- valueType: ValueType.INT,
39
- });
33
+ this.messagePrevalidationCount = createUpDownCounterWithDefault(
34
+ meter,
35
+ Metrics.P2P_GOSSIP_MESSAGE_PREVALIDATION_COUNT,
36
+ {
37
+ [Attributes.TOPIC_NAME]: [
38
+ TopicType.tx,
39
+ TopicType.block_proposal,
40
+ TopicType.checkpoint_proposal,
41
+ TopicType.checkpoint_attestation,
42
+ ],
43
+ [Attributes.OK]: [true, false],
44
+ },
45
+ );
40
46
 
41
- this.messageLatency = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_LATENCY, {
42
- unit: 'ms',
43
- description: 'P2P message latency',
44
- valueType: ValueType.INT,
45
- });
47
+ this.messageLatency = meter.createHistogram(Metrics.P2P_GOSSIP_MESSAGE_LATENCY);
48
+
49
+ this.txReceivedCount = createUpDownCounterWithDefault(meter, Metrics.P2P_GOSSIP_TX_RECEIVED_COUNT);
46
50
 
47
51
  this.aggLatencyMetrics = {
48
- avg: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_AVG, {
49
- valueType: ValueType.DOUBLE,
50
- description: 'AVG msg latency',
51
- unit: 'ms',
52
- }),
53
- max: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_MAX, {
54
- valueType: ValueType.DOUBLE,
55
- description: 'MAX msg latency',
56
- unit: 'ms',
57
- }),
58
- min: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_MIN, {
59
- valueType: ValueType.DOUBLE,
60
- description: 'MIN msg latency',
61
- unit: 'ms',
62
- }),
63
- p50: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_P50, {
64
- valueType: ValueType.DOUBLE,
65
- description: 'P50 msg latency',
66
- unit: 'ms',
67
- }),
68
- p90: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_P90, {
69
- valueType: ValueType.DOUBLE,
70
- description: 'P90 msg latency',
71
- unit: 'ms',
72
- }),
52
+ avg: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_AVG),
53
+ max: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_MAX),
54
+ min: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_MIN),
55
+ p50: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_P50),
56
+ p90: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_LATENCY_P90),
73
57
  };
74
58
 
75
59
  this.aggValidationMetrics = {
76
- avg: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_AVG, {
77
- valueType: ValueType.DOUBLE,
78
- description: 'AVG msg validation',
79
- unit: 'ms',
80
- }),
81
- max: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_MAX, {
82
- valueType: ValueType.DOUBLE,
83
- description: 'MAX msg validation',
84
- unit: 'ms',
85
- }),
86
- min: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_MIN, {
87
- valueType: ValueType.DOUBLE,
88
- description: 'MIN msg validation',
89
- unit: 'ms',
90
- }),
91
- p50: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_P50, {
92
- valueType: ValueType.DOUBLE,
93
- description: 'P50 msg validation',
94
- unit: 'ms',
95
- }),
96
- p90: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_P90, {
97
- valueType: ValueType.DOUBLE,
98
- description: 'P90 msg validation',
99
- unit: 'ms',
100
- }),
60
+ avg: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_AVG),
61
+ max: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_MAX),
62
+ min: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_MIN),
63
+ p50: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_P50),
64
+ p90: meter.createObservableGauge(Metrics.P2P_GOSSIP_AGG_MESSAGE_VALIDATION_DURATION_P90),
101
65
  };
102
66
 
103
67
  meter.addBatchObservableCallback(this.aggregate, [
@@ -119,6 +83,10 @@ export class P2PInstrumentation {
119
83
  validationHistogram.record(Math.max(ms, 1));
120
84
  }
121
85
 
86
+ public incrementTxReceived(count: number) {
87
+ this.txReceivedCount.add(count);
88
+ }
89
+
122
90
  public incMessagePrevalidationStatus(passed: boolean, topicName: TopicType | undefined) {
123
91
  this.messagePrevalidationCount.add(1, { [Attributes.TOPIC_NAME]: topicName, [Attributes.OK]: passed });
124
92
  }
@@ -129,7 +97,7 @@ export class P2PInstrumentation {
129
97
 
130
98
  let latencyHistogram = this.aggLatencyHisto.get(topicName);
131
99
  if (!latencyHistogram) {
132
- latencyHistogram = createHistogram({ min: 1, max: 24 * 60 * 60 * 1000 }); // 24hrs
100
+ latencyHistogram = createHistogram({ min: 1, max: 60 * 1000 }); // Max: 1 minute
133
101
  this.aggLatencyHisto.set(topicName, latencyHistogram);
134
102
  }
135
103
 
@@ -147,11 +115,11 @@ export class P2PInstrumentation {
147
115
  continue;
148
116
  }
149
117
 
150
- res.observe(metrics.avg, histogram.mean, { [Attributes.TOPIC_NAME]: topicName });
151
- res.observe(metrics.max, histogram.max, { [Attributes.TOPIC_NAME]: topicName });
152
- res.observe(metrics.min, histogram.min, { [Attributes.TOPIC_NAME]: topicName });
153
- res.observe(metrics.p50, histogram.percentile(50), { [Attributes.TOPIC_NAME]: topicName });
154
- res.observe(metrics.p90, histogram.percentile(90), { [Attributes.TOPIC_NAME]: topicName });
118
+ res.observe(metrics.avg, Math.ceil(histogram.mean), { [Attributes.TOPIC_NAME]: topicName });
119
+ res.observe(metrics.max, Math.ceil(histogram.max), { [Attributes.TOPIC_NAME]: topicName });
120
+ res.observe(metrics.min, Math.ceil(histogram.min), { [Attributes.TOPIC_NAME]: topicName });
121
+ res.observe(metrics.p50, Math.ceil(histogram.percentile(50)), { [Attributes.TOPIC_NAME]: topicName });
122
+ res.observe(metrics.p90, Math.ceil(histogram.percentile(90)), { [Attributes.TOPIC_NAME]: topicName });
155
123
  }
156
124
  }
157
125
  };