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

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 (563) 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 +60 -20
  8. package/dest/client/interface.d.ts +68 -35
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +53 -65
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +632 -335
  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 +315 -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 +137 -87
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +124 -54
  22. package/dest/errors/p2p-service.error.d.ts +9 -0
  23. package/dest/errors/p2p-service.error.d.ts.map +1 -0
  24. package/dest/errors/p2p-service.error.js +10 -0
  25. package/dest/errors/tx-pool.error.d.ts +8 -0
  26. package/dest/errors/tx-pool.error.d.ts.map +1 -0
  27. package/dest/errors/tx-pool.error.js +9 -0
  28. package/dest/index.d.ts +2 -2
  29. package/dest/index.d.ts.map +1 -1
  30. package/dest/index.js +1 -1
  31. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +113 -76
  32. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  33. package/dest/mem_pools/attestation_pool/attestation_pool.js +448 -3
  34. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +2 -2
  35. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  36. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +529 -289
  37. package/dest/mem_pools/attestation_pool/index.d.ts +2 -3
  38. package/dest/mem_pools/attestation_pool/index.d.ts.map +1 -1
  39. package/dest/mem_pools/attestation_pool/index.js +1 -2
  40. package/dest/mem_pools/attestation_pool/mocks.d.ts +11 -8
  41. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  42. package/dest/mem_pools/attestation_pool/mocks.js +17 -13
  43. package/dest/mem_pools/index.d.ts +3 -3
  44. package/dest/mem_pools/index.d.ts.map +1 -1
  45. package/dest/mem_pools/index.js +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 +33 -13
  49. package/dest/mem_pools/interface.d.ts +6 -7
  50. package/dest/mem_pools/interface.d.ts.map +1 -1
  51. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts +2 -0
  52. package/dest/mem_pools/tx_pool_v2/archive/index.d.ts.map +1 -0
  53. package/dest/mem_pools/tx_pool_v2/archive/index.js +1 -0
  54. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts +43 -0
  55. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.d.ts.map +1 -0
  56. package/dest/mem_pools/tx_pool_v2/archive/tx_archive.js +103 -0
  57. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts +104 -0
  58. package/dest/mem_pools/tx_pool_v2/deleted_pool.d.ts.map +1 -0
  59. package/dest/mem_pools/tx_pool_v2/deleted_pool.js +251 -0
  60. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts +47 -0
  61. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.d.ts.map +1 -0
  62. package/dest/mem_pools/tx_pool_v2/eviction/eviction_manager.js +128 -0
  63. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts +17 -0
  64. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  65. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.js +94 -0
  66. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts +19 -0
  67. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.d.ts.map +1 -0
  68. package/dest/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.js +97 -0
  69. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts +10 -0
  70. package/dest/mem_pools/tx_pool_v2/eviction/index.d.ts.map +1 -0
  71. package/dest/mem_pools/tx_pool_v2/eviction/index.js +11 -0
  72. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts +180 -0
  73. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.d.ts.map +1 -0
  74. package/dest/mem_pools/tx_pool_v2/eviction/interfaces.js +25 -0
  75. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts +15 -0
  76. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  77. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.js +65 -0
  78. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts +17 -0
  79. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  80. package/dest/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.js +93 -0
  81. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts +16 -0
  82. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  83. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.js +78 -0
  84. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts +20 -0
  85. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.d.ts.map +1 -0
  86. package/dest/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.js +75 -0
  87. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts +15 -0
  88. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.d.ts.map +1 -0
  89. package/dest/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.js +19 -0
  90. package/dest/mem_pools/tx_pool_v2/index.d.ts +6 -0
  91. package/dest/mem_pools/tx_pool_v2/index.d.ts.map +1 -0
  92. package/dest/mem_pools/tx_pool_v2/index.js +5 -0
  93. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts +15 -0
  94. package/dest/mem_pools/tx_pool_v2/instrumentation.d.ts.map +1 -0
  95. package/dest/mem_pools/tx_pool_v2/instrumentation.js +43 -0
  96. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts +215 -0
  97. package/dest/mem_pools/tx_pool_v2/interfaces.d.ts.map +1 -0
  98. package/dest/mem_pools/tx_pool_v2/interfaces.js +10 -0
  99. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts +134 -0
  100. package/dest/mem_pools/tx_pool_v2/tx_metadata.d.ts.map +1 -0
  101. package/dest/mem_pools/tx_pool_v2/tx_metadata.js +220 -0
  102. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts +26 -0
  103. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.d.ts.map +1 -0
  104. package/dest/mem_pools/tx_pool_v2/tx_pool_bench_metrics.js +70 -0
  105. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts +108 -0
  106. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.d.ts.map +1 -0
  107. package/dest/mem_pools/tx_pool_v2/tx_pool_indices.js +337 -0
  108. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts +62 -0
  109. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.d.ts.map +1 -0
  110. package/dest/mem_pools/tx_pool_v2/tx_pool_v2.js +167 -0
  111. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts +78 -0
  112. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.d.ts.map +1 -0
  113. package/dest/mem_pools/tx_pool_v2/tx_pool_v2_impl.js +923 -0
  114. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +8 -5
  115. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  116. package/dest/msg_validators/attestation_validator/attestation_validator.js +63 -21
  117. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +9 -7
  118. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  119. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +24 -15
  120. package/dest/msg_validators/clock_tolerance.d.ts +32 -0
  121. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  122. package/dest/msg_validators/clock_tolerance.js +88 -0
  123. package/dest/msg_validators/index.d.ts +2 -2
  124. package/dest/msg_validators/index.d.ts.map +1 -1
  125. package/dest/msg_validators/index.js +1 -1
  126. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +12 -0
  127. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  128. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +14 -0
  129. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +12 -0
  130. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  131. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +20 -0
  132. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  133. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  134. package/dest/msg_validators/proposal_validator/index.js +3 -0
  135. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +20 -0
  136. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  137. package/dest/msg_validators/proposal_validator/proposal_validator.js +124 -0
  138. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  139. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  140. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  141. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  142. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  143. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  144. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  145. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  146. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  147. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  148. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  149. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  150. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  151. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  152. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  153. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  154. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  155. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  156. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  157. package/dest/msg_validators/tx_validator/data_validator.js +39 -3
  158. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  159. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  160. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  161. package/dest/msg_validators/tx_validator/factory.d.ts +139 -6
  162. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  163. package/dest/msg_validators/tx_validator/factory.js +255 -58
  164. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  165. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  166. package/dest/msg_validators/tx_validator/fee_payer_balance.js +24 -0
  167. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  168. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  169. package/dest/msg_validators/tx_validator/gas_validator.js +122 -58
  170. package/dest/msg_validators/tx_validator/index.d.ts +4 -1
  171. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  172. package/dest/msg_validators/tx_validator/index.js +3 -0
  173. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +4 -3
  174. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  175. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  176. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  177. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  178. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  179. package/dest/msg_validators/tx_validator/phases_validator.d.ts +24 -3
  180. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  181. package/dest/msg_validators/tx_validator/phases_validator.js +75 -27
  182. package/dest/msg_validators/tx_validator/size_validator.d.ts +8 -0
  183. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  184. package/dest/msg_validators/tx_validator/size_validator.js +23 -0
  185. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  186. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  187. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +23 -5
  188. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  189. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  190. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  191. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  192. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  193. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  194. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  195. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  196. package/dest/services/data_store.d.ts +1 -1
  197. package/dest/services/data_store.d.ts.map +1 -1
  198. package/dest/services/data_store.js +14 -10
  199. package/dest/services/discv5/discV5_service.js +1 -1
  200. package/dest/services/dummy_service.d.ts +31 -4
  201. package/dest/services/dummy_service.d.ts.map +1 -1
  202. package/dest/services/dummy_service.js +54 -1
  203. package/dest/services/encoding.d.ts +7 -3
  204. package/dest/services/encoding.d.ts.map +1 -1
  205. package/dest/services/encoding.js +23 -15
  206. package/dest/services/gossipsub/index.d.ts +3 -0
  207. package/dest/services/gossipsub/index.d.ts.map +1 -0
  208. package/dest/services/gossipsub/index.js +2 -0
  209. package/dest/services/gossipsub/scoring.d.ts +21 -3
  210. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  211. package/dest/services/gossipsub/scoring.js +24 -7
  212. package/dest/services/gossipsub/topic_score_params.d.ts +184 -0
  213. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  214. package/dest/services/gossipsub/topic_score_params.js +363 -0
  215. package/dest/services/index.d.ts +2 -1
  216. package/dest/services/index.d.ts.map +1 -1
  217. package/dest/services/index.js +1 -0
  218. package/dest/services/libp2p/instrumentation.d.ts +3 -1
  219. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  220. package/dest/services/libp2p/instrumentation.js +43 -71
  221. package/dest/services/libp2p/libp2p_service.d.ts +109 -44
  222. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  223. package/dest/services/libp2p/libp2p_service.js +1128 -431
  224. package/dest/services/peer-manager/metrics.d.ts +9 -2
  225. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  226. package/dest/services/peer-manager/metrics.js +39 -21
  227. package/dest/services/peer-manager/peer_manager.d.ts +7 -3
  228. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  229. package/dest/services/peer-manager/peer_manager.js +43 -23
  230. package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
  231. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  232. package/dest/services/peer-manager/peer_scoring.js +64 -16
  233. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +51 -0
  234. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  235. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +543 -0
  236. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  237. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  238. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  239. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +47 -0
  240. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  241. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  242. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +35 -0
  243. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  244. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +136 -0
  245. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +62 -0
  246. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  247. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +176 -0
  248. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  249. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  250. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  251. package/dest/services/reqresp/config.d.ts +3 -3
  252. package/dest/services/reqresp/config.d.ts.map +1 -1
  253. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  254. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  255. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  256. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  257. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  258. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  259. package/dest/services/reqresp/constants.d.ts +12 -0
  260. package/dest/services/reqresp/constants.d.ts.map +1 -0
  261. package/dest/services/reqresp/constants.js +7 -0
  262. package/dest/services/reqresp/interface.d.ts +25 -9
  263. package/dest/services/reqresp/interface.d.ts.map +1 -1
  264. package/dest/services/reqresp/interface.js +23 -10
  265. package/dest/services/reqresp/metrics.d.ts +6 -5
  266. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  267. package/dest/services/reqresp/metrics.js +16 -21
  268. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  269. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  270. package/dest/services/reqresp/protocols/auth.js +2 -2
  271. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  272. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  273. package/dest/services/reqresp/protocols/block_txs/bitvector.js +12 -0
  274. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  275. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  276. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  277. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +30 -7
  278. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  279. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +60 -14
  280. package/dest/services/reqresp/protocols/index.d.ts +1 -2
  281. package/dest/services/reqresp/protocols/index.d.ts.map +1 -1
  282. package/dest/services/reqresp/protocols/index.js +0 -1
  283. package/dest/services/reqresp/protocols/status.d.ts +5 -4
  284. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  285. package/dest/services/reqresp/protocols/status.js +7 -3
  286. package/dest/services/reqresp/protocols/tx.d.ts +8 -3
  287. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  288. package/dest/services/reqresp/protocols/tx.js +21 -3
  289. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +5 -4
  290. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
  291. package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -8
  292. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
  293. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -1
  294. package/dest/services/reqresp/rate-limiter/rate_limits.js +0 -10
  295. package/dest/services/reqresp/reqresp.d.ts +9 -2
  296. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  297. package/dest/services/reqresp/reqresp.js +497 -58
  298. package/dest/services/service.d.ts +59 -4
  299. package/dest/services/service.d.ts.map +1 -1
  300. package/dest/services/tx_collection/config.d.ts +22 -1
  301. package/dest/services/tx_collection/config.d.ts.map +1 -1
  302. package/dest/services/tx_collection/config.js +56 -2
  303. package/dest/services/tx_collection/fast_tx_collection.d.ts +10 -9
  304. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  305. package/dest/services/tx_collection/fast_tx_collection.js +95 -84
  306. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  307. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  308. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  309. package/dest/services/tx_collection/file_store_tx_source.d.ts +38 -0
  310. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  311. package/dest/services/tx_collection/file_store_tx_source.js +100 -0
  312. package/dest/services/tx_collection/index.d.ts +3 -1
  313. package/dest/services/tx_collection/index.d.ts.map +1 -1
  314. package/dest/services/tx_collection/index.js +2 -0
  315. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  316. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  317. package/dest/services/tx_collection/instrumentation.js +11 -13
  318. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  319. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  320. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  321. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  322. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  323. package/dest/services/tx_collection/request_tracker.js +84 -0
  324. package/dest/services/tx_collection/slow_tx_collection.d.ts +9 -4
  325. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  326. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  327. package/dest/services/tx_collection/tx_collection.d.ts +31 -20
  328. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  329. package/dest/services/tx_collection/tx_collection.js +79 -7
  330. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  331. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  332. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  333. package/dest/services/tx_collection/tx_source.d.ts +13 -7
  334. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  335. package/dest/services/tx_collection/tx_source.js +26 -7
  336. package/dest/services/tx_file_store/config.d.ts +16 -0
  337. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  338. package/dest/services/tx_file_store/config.js +22 -0
  339. package/dest/services/tx_file_store/index.d.ts +4 -0
  340. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  341. package/dest/services/tx_file_store/index.js +3 -0
  342. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  343. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  344. package/dest/services/tx_file_store/instrumentation.js +29 -0
  345. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  346. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  347. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  348. package/dest/services/tx_provider.d.ts +7 -5
  349. package/dest/services/tx_provider.d.ts.map +1 -1
  350. package/dest/services/tx_provider.js +20 -10
  351. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  352. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  353. package/dest/services/tx_provider_instrumentation.js +14 -14
  354. package/dest/test-helpers/index.d.ts +3 -1
  355. package/dest/test-helpers/index.d.ts.map +1 -1
  356. package/dest/test-helpers/index.js +2 -0
  357. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  358. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  359. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  360. package/dest/test-helpers/mock-pubsub.d.ts +40 -6
  361. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  362. package/dest/test-helpers/mock-pubsub.js +139 -13
  363. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  364. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  365. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  366. package/dest/test-helpers/reqresp-nodes.js +5 -5
  367. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  368. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  369. package/dest/test-helpers/test_tx_provider.js +41 -0
  370. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  371. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  372. package/dest/test-helpers/testbench-utils.js +386 -0
  373. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  374. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  375. package/dest/testbench/p2p_client_testbench_worker.js +281 -134
  376. package/dest/testbench/worker_client_manager.d.ts +60 -6
  377. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  378. package/dest/testbench/worker_client_manager.js +280 -41
  379. package/dest/util.d.ts +3 -3
  380. package/dest/util.d.ts.map +1 -1
  381. package/package.json +18 -18
  382. package/src/bootstrap/bootstrap.ts +7 -4
  383. package/src/client/factory.ts +116 -45
  384. package/src/client/interface.ts +81 -36
  385. package/src/client/p2p_client.ts +299 -396
  386. package/src/client/test/tx_proposal_collector/README.md +227 -0
  387. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +355 -0
  388. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  389. package/src/config.ts +196 -64
  390. package/src/errors/p2p-service.error.ts +11 -0
  391. package/src/errors/tx-pool.error.ts +12 -0
  392. package/src/index.ts +1 -1
  393. package/src/mem_pools/attestation_pool/attestation_pool.ts +515 -78
  394. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +614 -322
  395. package/src/mem_pools/attestation_pool/index.ts +9 -2
  396. package/src/mem_pools/attestation_pool/mocks.ts +22 -15
  397. package/src/mem_pools/index.ts +2 -2
  398. package/src/mem_pools/instrumentation.ts +43 -14
  399. package/src/mem_pools/interface.ts +5 -7
  400. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  401. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  402. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  403. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  404. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  405. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +122 -0
  406. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  407. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  408. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  409. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  410. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  411. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  412. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  413. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  414. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  415. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  416. package/src/mem_pools/tx_pool_v2/interfaces.ts +247 -0
  417. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +343 -0
  418. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  419. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  420. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +238 -0
  421. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1105 -0
  422. package/src/msg_validators/attestation_validator/README.md +49 -0
  423. package/src/msg_validators/attestation_validator/attestation_validator.ts +51 -24
  424. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +25 -19
  425. package/src/msg_validators/clock_tolerance.ts +120 -0
  426. package/src/msg_validators/index.ts +1 -1
  427. package/src/msg_validators/proposal_validator/README.md +123 -0
  428. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +23 -0
  429. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +29 -0
  430. package/src/msg_validators/proposal_validator/index.ts +3 -0
  431. package/src/msg_validators/proposal_validator/proposal_validator.ts +122 -0
  432. package/src/msg_validators/tx_validator/README.md +119 -0
  433. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  434. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  435. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  436. package/src/msg_validators/tx_validator/archive_cache.ts +2 -2
  437. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  438. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  439. package/src/msg_validators/tx_validator/data_validator.ts +60 -7
  440. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  441. package/src/msg_validators/tx_validator/factory.ts +416 -58
  442. package/src/msg_validators/tx_validator/fee_payer_balance.ts +44 -0
  443. package/src/msg_validators/tx_validator/gas_validator.ts +162 -61
  444. package/src/msg_validators/tx_validator/index.ts +3 -0
  445. package/src/msg_validators/tx_validator/metadata_validator.ts +31 -12
  446. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  447. package/src/msg_validators/tx_validator/phases_validator.ts +87 -30
  448. package/src/msg_validators/tx_validator/size_validator.ts +22 -0
  449. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  450. package/src/msg_validators/tx_validator/timestamp_validator.ts +30 -19
  451. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  452. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  453. package/src/services/data_store.ts +14 -19
  454. package/src/services/discv5/discV5_service.ts +1 -1
  455. package/src/services/dummy_service.ts +71 -2
  456. package/src/services/encoding.ts +22 -13
  457. package/src/services/gossipsub/README.md +641 -0
  458. package/src/services/gossipsub/index.ts +2 -0
  459. package/src/services/gossipsub/scoring.ts +29 -5
  460. package/src/services/gossipsub/topic_score_params.ts +519 -0
  461. package/src/services/index.ts +1 -0
  462. package/src/services/libp2p/instrumentation.ts +48 -75
  463. package/src/services/libp2p/libp2p_service.ts +827 -461
  464. package/src/services/peer-manager/metrics.ts +46 -21
  465. package/src/services/peer-manager/peer_manager.ts +50 -15
  466. package/src/services/peer-manager/peer_scoring.ts +55 -9
  467. package/src/services/reqresp/README.md +229 -0
  468. package/src/services/reqresp/batch-tx-requester/README.md +344 -0
  469. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +673 -0
  470. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  471. package/src/services/reqresp/batch-tx-requester/interface.ts +54 -0
  472. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +168 -0
  473. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +249 -0
  474. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  475. package/src/services/reqresp/config.ts +2 -2
  476. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  477. package/src/services/reqresp/connection-sampler/connection_sampler.ts +19 -1
  478. package/src/services/reqresp/constants.ts +14 -0
  479. package/src/services/reqresp/interface.ts +48 -10
  480. package/src/services/reqresp/metrics.ts +35 -27
  481. package/src/services/reqresp/protocols/auth.ts +2 -2
  482. package/src/services/reqresp/protocols/block_txs/bitvector.ts +16 -0
  483. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  484. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +75 -10
  485. package/src/services/reqresp/protocols/index.ts +0 -1
  486. package/src/services/reqresp/protocols/status.ts +16 -12
  487. package/src/services/reqresp/protocols/tx.ts +24 -5
  488. package/src/services/reqresp/rate-limiter/rate_limiter.ts +13 -9
  489. package/src/services/reqresp/rate-limiter/rate_limits.ts +0 -10
  490. package/src/services/reqresp/reqresp.ts +116 -32
  491. package/src/services/service.ts +78 -5
  492. package/src/services/tx_collection/config.ts +84 -2
  493. package/src/services/tx_collection/fast_tx_collection.ts +114 -93
  494. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  495. package/src/services/tx_collection/file_store_tx_source.ts +129 -0
  496. package/src/services/tx_collection/index.ts +6 -0
  497. package/src/services/tx_collection/instrumentation.ts +11 -13
  498. package/src/services/tx_collection/proposal_tx_collector.ts +108 -0
  499. package/src/services/tx_collection/request_tracker.ts +127 -0
  500. package/src/services/tx_collection/slow_tx_collection.ts +69 -36
  501. package/src/services/tx_collection/tx_collection.ts +123 -27
  502. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  503. package/src/services/tx_collection/tx_source.ts +28 -8
  504. package/src/services/tx_file_store/config.ts +37 -0
  505. package/src/services/tx_file_store/index.ts +3 -0
  506. package/src/services/tx_file_store/instrumentation.ts +36 -0
  507. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  508. package/src/services/tx_provider.ts +29 -12
  509. package/src/services/tx_provider_instrumentation.ts +24 -14
  510. package/src/test-helpers/index.ts +2 -0
  511. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  512. package/src/test-helpers/mock-pubsub.ts +178 -15
  513. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  514. package/src/test-helpers/reqresp-nodes.ts +8 -10
  515. package/src/test-helpers/test_tx_provider.ts +64 -0
  516. package/src/test-helpers/testbench-utils.ts +457 -0
  517. package/src/testbench/p2p_client_testbench_worker.ts +410 -131
  518. package/src/testbench/worker_client_manager.ts +367 -43
  519. package/src/util.ts +8 -2
  520. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -37
  521. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  522. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -213
  523. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -30
  524. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  525. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -219
  526. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +0 -115
  527. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +0 -1
  528. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +0 -617
  529. package/dest/mem_pools/tx_pool/index.d.ts +0 -4
  530. package/dest/mem_pools/tx_pool/index.d.ts.map +0 -1
  531. package/dest/mem_pools/tx_pool/index.js +0 -3
  532. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -80
  533. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  534. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -238
  535. package/dest/mem_pools/tx_pool/priority.d.ts +0 -8
  536. package/dest/mem_pools/tx_pool/priority.d.ts.map +0 -1
  537. package/dest/mem_pools/tx_pool/priority.js +0 -10
  538. package/dest/mem_pools/tx_pool/tx_pool.d.ts +0 -122
  539. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +0 -1
  540. package/dest/mem_pools/tx_pool/tx_pool.js +0 -3
  541. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +0 -7
  542. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +0 -1
  543. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +0 -394
  544. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  545. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  546. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -82
  547. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  548. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  549. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  550. package/dest/services/reqresp/protocols/block.d.ts +0 -9
  551. package/dest/services/reqresp/protocols/block.d.ts.map +0 -1
  552. package/dest/services/reqresp/protocols/block.js +0 -31
  553. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -298
  554. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -287
  555. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +0 -750
  556. package/src/mem_pools/tx_pool/index.ts +0 -3
  557. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -283
  558. package/src/mem_pools/tx_pool/priority.ts +0 -13
  559. package/src/mem_pools/tx_pool/tx_pool.ts +0 -135
  560. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +0 -313
  561. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -97
  562. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
  563. package/src/services/reqresp/protocols/block.ts +0 -36
@@ -1,394 +0,0 @@
1
- import { unfreeze } from '@aztec/foundation/types';
2
- import { GasFees } from '@aztec/stdlib/gas';
3
- import { mockTx } from '@aztec/stdlib/testing';
4
- import { BlockHeader, GlobalVariables } from '@aztec/stdlib/tx';
5
- /**
6
- * Tests a TxPool implementation.
7
- * @param getTxPool - Gets a fresh TxPool
8
- */ export function describeTxPool(getTxPool) {
9
- let pool;
10
- const minedBlockHeader = BlockHeader.empty({
11
- globalVariables: GlobalVariables.empty({
12
- blockNumber: 1,
13
- timestamp: 0n
14
- })
15
- });
16
- beforeEach(()=>{
17
- pool = getTxPool();
18
- });
19
- afterEach(()=>{
20
- pool.removeAllListeners('txs-added');
21
- });
22
- it('adds txs to the pool as pending', async ()=>{
23
- const tx1 = await mockTx();
24
- await pool.addTxs([
25
- tx1
26
- ]);
27
- const poolTx = await pool.getTxByHash(tx1.getTxHash());
28
- expect(poolTx.getTxHash()).toEqual(tx1.getTxHash());
29
- await expect(pool.getTxStatus(tx1.getTxHash())).resolves.toEqual('pending');
30
- await expect(pool.getPendingTxHashes()).resolves.toEqual([
31
- tx1.getTxHash()
32
- ]);
33
- await expect(pool.getPendingTxCount()).resolves.toEqual(1);
34
- });
35
- it('emits txs-added event with new txs', async ()=>{
36
- const tx1 = await mockTx(); // existing and pending
37
- const tx2 = await mockTx(); // mined but not known
38
- const tx3 = await mockTx(); // brand new
39
- await pool.addTxs([
40
- tx1
41
- ]);
42
- await pool.markAsMined([
43
- tx2.getTxHash()
44
- ], minedBlockHeader);
45
- let txsFromEvent = undefined;
46
- pool.once('txs-added', ({ txs })=>{
47
- txsFromEvent = txs;
48
- });
49
- await pool.addTxs([
50
- tx1,
51
- tx2,
52
- tx3
53
- ]);
54
- expect(txsFromEvent).toBeDefined();
55
- expect(txsFromEvent).toHaveLength(2);
56
- expect(txsFromEvent).toEqual(expect.arrayContaining([
57
- tx2,
58
- tx3
59
- ]));
60
- });
61
- it('permanently deletes pending txs and soft-deletes mined txs', async ()=>{
62
- const pendingTx = await mockTx(1);
63
- const minedTx = await mockTx(2);
64
- await pool.addTxs([
65
- pendingTx,
66
- minedTx
67
- ]);
68
- await pool.markAsMined([
69
- minedTx.getTxHash()
70
- ], minedBlockHeader);
71
- // Delete a pending tx - should be permanently deleted
72
- await pool.deleteTxs([
73
- pendingTx.getTxHash()
74
- ]);
75
- await expect(pool.getTxByHash(pendingTx.getTxHash())).resolves.toBeUndefined();
76
- await expect(pool.getTxStatus(pendingTx.getTxHash())).resolves.toBeUndefined();
77
- // Delete a mined tx - should be soft-deleted (still in storage)
78
- await pool.deleteTxs([
79
- minedTx.getTxHash()
80
- ]);
81
- await expect(pool.getTxByHash(minedTx.getTxHash())).resolves.toBeDefined();
82
- await expect(pool.getTxStatus(minedTx.getTxHash())).resolves.toEqual('deleted');
83
- await expect(pool.getMinedTxHashes()).resolves.toEqual([]);
84
- await expect(pool.getPendingTxCount()).resolves.toEqual(0);
85
- });
86
- it('marks txs as mined', async ()=>{
87
- const tx1 = await mockTx(1);
88
- const tx2 = await mockTx(2);
89
- await pool.addTxs([
90
- tx1,
91
- tx2
92
- ]);
93
- await pool.markAsMined([
94
- tx1.getTxHash()
95
- ], minedBlockHeader);
96
- await expect(pool.getTxByHash(tx1.getTxHash())).resolves.toEqual(tx1);
97
- await expect(pool.getTxStatus(tx1.getTxHash())).resolves.toEqual('mined');
98
- await expect(pool.getMinedTxHashes()).resolves.toEqual([
99
- [
100
- tx1.getTxHash(),
101
- 1
102
- ]
103
- ]);
104
- await expect(pool.getPendingTxHashes()).resolves.toEqual([
105
- tx2.getTxHash()
106
- ]);
107
- await expect(pool.getPendingTxCount()).resolves.toEqual(1);
108
- });
109
- it('marks txs as pending after being mined', async ()=>{
110
- const tx1 = await mockTx(1);
111
- const tx2 = await mockTx(2);
112
- await pool.addTxs([
113
- tx1,
114
- tx2
115
- ]);
116
- await pool.markAsMined([
117
- tx1.getTxHash()
118
- ], minedBlockHeader);
119
- await pool.markMinedAsPending([
120
- tx1.getTxHash()
121
- ]);
122
- await expect(pool.getMinedTxHashes()).resolves.toEqual([]);
123
- const pending = await pool.getPendingTxHashes();
124
- expect(pending).toHaveLength(2);
125
- expect(pending).toEqual(expect.arrayContaining([
126
- tx1.getTxHash(),
127
- tx2.getTxHash()
128
- ]));
129
- await expect(pool.getPendingTxCount()).resolves.toEqual(2);
130
- });
131
- it('only marks txs as pending if they are known', async ()=>{
132
- const tx1 = await mockTx(1);
133
- // simulate a situation where not all peers have all the txs
134
- const tx2 = await mockTx(2);
135
- const someTxHashThatThisPeerDidNotSee = tx2.getTxHash();
136
- await pool.addTxs([
137
- tx1
138
- ]);
139
- // this peer knows that tx2 was mined, but it does not have the tx object
140
- await pool.markAsMined([
141
- tx1.getTxHash(),
142
- someTxHashThatThisPeerDidNotSee
143
- ], minedBlockHeader);
144
- expect(await pool.getMinedTxHashes()).toEqual(expect.arrayContaining([
145
- [
146
- tx1.getTxHash(),
147
- 1
148
- ],
149
- [
150
- someTxHashThatThisPeerDidNotSee,
151
- 1
152
- ]
153
- ]));
154
- // reorg: both txs should now become available again
155
- await pool.markMinedAsPending([
156
- tx1.getTxHash(),
157
- someTxHashThatThisPeerDidNotSee
158
- ]);
159
- await expect(pool.getMinedTxHashes()).resolves.toEqual([]);
160
- await expect(pool.getPendingTxHashes()).resolves.toEqual([
161
- tx1.getTxHash()
162
- ]); // tx2 is not in the pool
163
- await expect(pool.getPendingTxCount()).resolves.toEqual(1);
164
- });
165
- it('returns all transactions in the pool', async ()=>{
166
- const tx1 = await mockTx(1);
167
- const tx2 = await mockTx(2);
168
- const tx3 = await mockTx(3);
169
- await pool.addTxs([
170
- tx1,
171
- tx2,
172
- tx3
173
- ]);
174
- const poolTxs = await pool.getAllTxs();
175
- expect(poolTxs).toHaveLength(3);
176
- expect(poolTxs).toEqual(expect.arrayContaining([
177
- tx1,
178
- tx2,
179
- tx3
180
- ]));
181
- await expect(pool.getPendingTxCount()).resolves.toEqual(3);
182
- });
183
- it('returns all txHashes in the pool', async ()=>{
184
- const tx1 = await mockTx(1);
185
- const tx2 = await mockTx(2);
186
- const tx3 = await mockTx(3);
187
- await pool.addTxs([
188
- tx1,
189
- tx2,
190
- tx3
191
- ]);
192
- const poolTxHashes = await pool.getAllTxHashes();
193
- const expectedHashes = [
194
- tx1,
195
- tx2,
196
- tx3
197
- ].map((tx)=>tx.getTxHash());
198
- expect(poolTxHashes).toHaveLength(3);
199
- expect(poolTxHashes).toEqual(expect.arrayContaining(expectedHashes));
200
- await expect(pool.getPendingTxCount()).resolves.toEqual(3);
201
- });
202
- it('returns txs by their hash', async ()=>{
203
- const tx1 = await mockTx(1);
204
- const tx2 = await mockTx(2);
205
- const tx3 = await mockTx(3);
206
- await pool.addTxs([
207
- tx1,
208
- tx2,
209
- tx3
210
- ]);
211
- const requestedTxs = await pool.getTxsByHash([
212
- tx1.getTxHash(),
213
- tx3.getTxHash()
214
- ]);
215
- expect(requestedTxs).toHaveLength(2);
216
- expect(requestedTxs).toEqual(expect.arrayContaining([
217
- tx1,
218
- tx3
219
- ]));
220
- });
221
- it('returns a large number of transactions by their hash', async ()=>{
222
- const numTxs = 1000;
223
- const txs = await Promise.all(Array.from({
224
- length: numTxs
225
- }, (_, i)=>mockTx(i)));
226
- const hashes = txs.map((tx)=>tx.getTxHash());
227
- await pool.addTxs(txs);
228
- const requestedTxs = await pool.getTxsByHash(hashes);
229
- expect(requestedTxs).toHaveLength(numTxs);
230
- expect(requestedTxs).toEqual(expect.arrayContaining(txs));
231
- });
232
- it('returns whether or not txs exist', async ()=>{
233
- const tx1 = await mockTx(1);
234
- const tx2 = await mockTx(2);
235
- const tx3 = await mockTx(3);
236
- await pool.addTxs([
237
- tx1,
238
- tx2,
239
- tx3
240
- ]);
241
- const tx4 = await mockTx(4);
242
- const tx5 = await mockTx(5);
243
- const availability = await pool.hasTxs([
244
- tx1.getTxHash(),
245
- tx2.getTxHash(),
246
- tx3.getTxHash(),
247
- tx4.getTxHash(),
248
- tx5.getTxHash()
249
- ]);
250
- expect(availability).toHaveLength(5);
251
- expect(availability).toEqual(expect.arrayContaining([
252
- true,
253
- true,
254
- true,
255
- false,
256
- false
257
- ]));
258
- });
259
- it('returns pending tx hashes sorted by priority', async ()=>{
260
- const withPriorityFee = (tx, fee)=>{
261
- unfreeze(tx.data.constants.txContext.gasSettings).maxPriorityFeesPerGas = new GasFees(fee, fee);
262
- return tx;
263
- };
264
- const tx1 = withPriorityFee(await mockTx(0), 1000);
265
- const tx2 = withPriorityFee(await mockTx(1), 100);
266
- const tx3 = withPriorityFee(await mockTx(2), 200);
267
- const tx4 = withPriorityFee(await mockTx(3), 3000);
268
- await pool.addTxs([
269
- tx1,
270
- tx2,
271
- tx3,
272
- tx4
273
- ]);
274
- const poolTxHashes = await pool.getPendingTxHashes();
275
- expect(poolTxHashes).toHaveLength(4);
276
- expect(poolTxHashes).toEqual([
277
- tx4,
278
- tx1,
279
- tx3,
280
- tx2
281
- ].map((tx)=>tx.getTxHash()));
282
- });
283
- describe('soft-delete', ()=>{
284
- it('soft-deletes mined txs and keeps them in storage', async ()=>{
285
- const txs = await Promise.all([
286
- mockTx(1),
287
- mockTx(2),
288
- mockTx(3)
289
- ]);
290
- await pool.addTxs(txs);
291
- // Mark first tx as mined
292
- await pool.markAsMined([
293
- txs[0].getTxHash()
294
- ], minedBlockHeader);
295
- // Verify initial state
296
- await expect(pool.getPendingTxCount()).resolves.toBe(2);
297
- await expect(pool.getTxByHash(txs[0].getTxHash())).resolves.toBeDefined();
298
- await expect(pool.getTxByHash(txs[1].getTxHash())).resolves.toBeDefined();
299
- // Delete mined tx - should be soft-deleted
300
- await pool.deleteTxs([
301
- txs[0].getTxHash()
302
- ]);
303
- // Delete pending tx - should be permanently deleted
304
- await pool.deleteTxs([
305
- txs[1].getTxHash()
306
- ]);
307
- // Verify mined tx still exists in storage but has 'deleted' status
308
- await expect(pool.getTxByHash(txs[0].getTxHash())).resolves.toBeDefined();
309
- await expect(pool.getTxStatus(txs[0].getTxHash())).resolves.toEqual('deleted');
310
- // Verify pending tx is permanently deleted
311
- await expect(pool.getTxByHash(txs[1].getTxHash())).resolves.toBeUndefined();
312
- await expect(pool.getTxStatus(txs[1].getTxHash())).resolves.toBeUndefined();
313
- // Verify remaining pending count
314
- await expect(pool.getPendingTxCount()).resolves.toBe(1);
315
- // Verify pending hashes don't include deleted txs
316
- const pendingHashes = await pool.getPendingTxHashes();
317
- expect(pendingHashes).toHaveLength(1);
318
- expect(pendingHashes.map((h)=>h.toString())).toContain(txs[2].getTxHash().toString());
319
- });
320
- it('cleans up old deleted mined transactions', async ()=>{
321
- const txs = await Promise.all([
322
- mockTx(1),
323
- mockTx(2),
324
- mockTx(3)
325
- ]);
326
- await pool.addTxs(txs);
327
- // Mark first two as mined in block 1
328
- await pool.markAsMined([
329
- txs[0].getTxHash(),
330
- txs[1].getTxHash()
331
- ], minedBlockHeader);
332
- // Soft-delete mined transactions
333
- await pool.deleteTxs([
334
- txs[0].getTxHash(),
335
- txs[1].getTxHash()
336
- ]);
337
- // Clean up deleted mined txs from block 1 and earlier
338
- const deletedCount = await pool.cleanupDeletedMinedTxs(1);
339
- // Verify old transactions are permanently deleted
340
- expect(deletedCount).toBe(2);
341
- await expect(pool.getTxByHash(txs[0].getTxHash())).resolves.toBeUndefined();
342
- await expect(pool.getTxByHash(txs[1].getTxHash())).resolves.toBeUndefined();
343
- await expect(pool.getTxByHash(txs[2].getTxHash())).resolves.toBeDefined();
344
- });
345
- it('does not clean up recent deleted mined transactions', async ()=>{
346
- const txs = await Promise.all([
347
- mockTx(1),
348
- mockTx(2)
349
- ]);
350
- await pool.addTxs(txs);
351
- // Mark as mined in block 2
352
- const laterBlockHeader = BlockHeader.empty({
353
- globalVariables: GlobalVariables.empty({
354
- blockNumber: 2,
355
- timestamp: 0n
356
- })
357
- });
358
- await pool.markAsMined([
359
- txs[0].getTxHash()
360
- ], laterBlockHeader);
361
- // Soft-delete a mined transaction
362
- await pool.deleteTxs([
363
- txs[0].getTxHash()
364
- ]);
365
- // Try to clean up with block 1 (before the mined block)
366
- const deletedCount = await pool.cleanupDeletedMinedTxs(1);
367
- // Verify no transactions were cleaned up
368
- expect(deletedCount).toBe(0);
369
- await expect(pool.getTxByHash(txs[0].getTxHash())).resolves.toBeDefined();
370
- });
371
- it('restores deleted mined tx when it is mined again', async ()=>{
372
- const tx = await mockTx(1);
373
- await pool.addTxs([
374
- tx
375
- ]);
376
- // Mark as mined
377
- await pool.markAsMined([
378
- tx.getTxHash()
379
- ], minedBlockHeader);
380
- // Soft-delete it
381
- await pool.deleteTxs([
382
- tx.getTxHash()
383
- ]);
384
- await expect(pool.getTxStatus(tx.getTxHash())).resolves.toEqual('deleted');
385
- // Mark as mined again (e.g., after a reorg)
386
- await pool.markAsMined([
387
- tx.getTxHash()
388
- ], minedBlockHeader);
389
- // Should be back to mined status
390
- await expect(pool.getTxStatus(tx.getTxHash())).resolves.toEqual('mined');
391
- await expect(pool.getTxByHash(tx.getTxHash())).resolves.toBeDefined();
392
- });
393
- });
394
- }
@@ -1,12 +0,0 @@
1
- import type { EpochCacheInterface } from '@aztec/epoch-cache';
2
- import { type BlockProposal, type P2PValidator, PeerErrorSeverity } from '@aztec/stdlib/p2p';
3
- export declare class BlockProposalValidator implements P2PValidator<BlockProposal> {
4
- private epochCache;
5
- private logger;
6
- private txsPermitted;
7
- constructor(epochCache: EpochCacheInterface, opts: {
8
- txsPermitted: boolean;
9
- });
10
- validate(block: BlockProposal): Promise<PeerErrorSeverity | undefined>;
11
- }
12
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2tfcHJvcG9zYWxfdmFsaWRhdG9yLmQudHMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi9zcmMvbXNnX3ZhbGlkYXRvcnMvYmxvY2tfcHJvcG9zYWxfdmFsaWRhdG9yL2Jsb2NrX3Byb3Bvc2FsX3ZhbGlkYXRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEtBQUssRUFBRSxtQkFBbUIsRUFBRSxNQUFNLG9CQUFvQixDQUFDO0FBRzlELE9BQU8sRUFBRSxLQUFLLGFBQWEsRUFBRSxLQUFLLFlBQVksRUFBRSxpQkFBaUIsRUFBRSxNQUFNLG1CQUFtQixDQUFDO0FBRTdGLHFCQUFhLHNCQUF1QixZQUFXLFlBQVksQ0FBQyxhQUFhLENBQUM7SUFDeEUsT0FBTyxDQUFDLFVBQVUsQ0FBc0I7SUFDeEMsT0FBTyxDQUFDLE1BQU0sQ0FBUztJQUN2QixPQUFPLENBQUMsWUFBWSxDQUFVO0lBRTlCLFlBQVksVUFBVSxFQUFFLG1CQUFtQixFQUFFLElBQUksRUFBRTtRQUFFLFlBQVksRUFBRSxPQUFPLENBQUE7S0FBRSxFQUkzRTtJQUVLLFFBQVEsQ0FBQyxLQUFLLEVBQUUsYUFBYSxHQUFHLE9BQU8sQ0FBQyxpQkFBaUIsR0FBRyxTQUFTLENBQUMsQ0ErRTNFO0NBQ0YifQ==
@@ -1 +0,0 @@
1
- {"version":3,"file":"block_proposal_validator.d.ts","sourceRoot":"","sources":["../../../src/msg_validators/block_proposal_validator/block_proposal_validator.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,mBAAmB,EAAE,MAAM,oBAAoB,CAAC;AAG9D,OAAO,EAAE,KAAK,aAAa,EAAE,KAAK,YAAY,EAAE,iBAAiB,EAAE,MAAM,mBAAmB,CAAC;AAE7F,qBAAa,sBAAuB,YAAW,YAAY,CAAC,aAAa,CAAC;IACxE,OAAO,CAAC,UAAU,CAAsB;IACxC,OAAO,CAAC,MAAM,CAAS;IACvB,OAAO,CAAC,YAAY,CAAU;IAE9B,YAAY,UAAU,EAAE,mBAAmB,EAAE,IAAI,EAAE;QAAE,YAAY,EAAE,OAAO,CAAA;KAAE,EAI3E;IAEK,QAAQ,CAAC,KAAK,EAAE,aAAa,GAAG,OAAO,CAAC,iBAAiB,GAAG,SAAS,CAAC,CA+E3E;CACF"}
@@ -1,82 +0,0 @@
1
- import { NoCommitteeError } from '@aztec/ethereum';
2
- import { createLogger } from '@aztec/foundation/log';
3
- import { PeerErrorSeverity } from '@aztec/stdlib/p2p';
4
- export class BlockProposalValidator {
5
- epochCache;
6
- logger;
7
- txsPermitted;
8
- constructor(epochCache, opts){
9
- this.epochCache = epochCache;
10
- this.txsPermitted = opts.txsPermitted;
11
- this.logger = createLogger('p2p:block_proposal_validator');
12
- }
13
- async validate(block) {
14
- try {
15
- // Check signature validity first - invalid signatures are a high-severity issue
16
- const proposer = block.getSender();
17
- if (!proposer) {
18
- this.logger.debug(`Penalizing peer for block proposal with invalid signature`);
19
- return PeerErrorSeverity.MidToleranceError;
20
- }
21
- // Check if transactions are permitted when the proposal contains transaction hashes
22
- const embeddedTxCount = block.txs?.length ?? 0;
23
- if (!this.txsPermitted && (block.txHashes.length > 0 || embeddedTxCount > 0)) {
24
- this.logger.debug(`Penalizing peer for block proposal with ${block.txHashes.length} transaction(s) when transactions are not permitted`);
25
- return PeerErrorSeverity.MidToleranceError;
26
- }
27
- // If there are embedded txs, they must be listed in txHashes; if there are no txHashes, there must be no txs
28
- const hashSet = new Set(block.txHashes.map((h)=>h.toString()));
29
- const missingTxHashes = embeddedTxCount > 0 ? block.txs.filter((tx)=>!hashSet.has(tx.getTxHash().toString())).map((tx)=>tx.getTxHash().toString()) : [];
30
- if (embeddedTxCount > 0 && missingTxHashes.length > 0) {
31
- this.logger.warn('Penalizing peer for embedded transaction(s) not included in txHashes', {
32
- embeddedTxCount,
33
- txHashesLength: block.txHashes.length,
34
- missingTxHashes
35
- });
36
- return PeerErrorSeverity.MidToleranceError;
37
- }
38
- const { currentProposer, nextProposer, currentSlot, nextSlot } = await this.epochCache.getProposerAttesterAddressInCurrentOrNextSlot();
39
- // Check that the attestation is for the current or next slot
40
- const slotNumber = block.payload.header.slotNumber;
41
- if (slotNumber !== currentSlot && slotNumber !== nextSlot) {
42
- this.logger.debug(`Penalizing peer for invalid slot number ${slotNumber}`, {
43
- currentSlot,
44
- nextSlot
45
- });
46
- return PeerErrorSeverity.HighToleranceError;
47
- }
48
- // Check that the block proposal is from the current or next proposer
49
- if (slotNumber === currentSlot && currentProposer !== undefined && !proposer.equals(currentProposer)) {
50
- this.logger.debug(`Penalizing peer for invalid proposer for current slot ${slotNumber}`, {
51
- currentProposer,
52
- nextProposer,
53
- proposer: proposer.toString()
54
- });
55
- return PeerErrorSeverity.MidToleranceError;
56
- }
57
- if (slotNumber === nextSlot && nextProposer !== undefined && !proposer.equals(nextProposer)) {
58
- this.logger.debug(`Penalizing peer for invalid proposer for next slot ${slotNumber}`, {
59
- currentProposer,
60
- nextProposer,
61
- proposer: proposer.toString()
62
- });
63
- return PeerErrorSeverity.MidToleranceError;
64
- }
65
- // Validate tx hashes for all txs embedded in the proposal
66
- if (!(await Promise.all(block.txs?.map((tx)=>tx.validateTxHash()) ?? [])).every((v)=>v)) {
67
- this.logger.warn(`Penalizing peer for invalid tx hashes in block proposal`, {
68
- proposer,
69
- slotNumber
70
- });
71
- return PeerErrorSeverity.LowToleranceError;
72
- }
73
- return undefined;
74
- } catch (e) {
75
- // People shouldn't be sending us block proposals if the committee doesn't exist
76
- if (e instanceof NoCommitteeError) {
77
- return PeerErrorSeverity.LowToleranceError;
78
- }
79
- throw e;
80
- }
81
- }
82
- }
@@ -1,2 +0,0 @@
1
- export * from './block_proposal_validator.js';
2
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uL3NyYy9tc2dfdmFsaWRhdG9ycy9ibG9ja19wcm9wb3NhbF92YWxpZGF0b3IvaW5kZXgudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsY0FBYywrQkFBK0IsQ0FBQyJ9
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/msg_validators/block_proposal_validator/index.ts"],"names":[],"mappings":"AAAA,cAAc,+BAA+B,CAAC"}
@@ -1 +0,0 @@
1
- export * from './block_proposal_validator.js';
@@ -1,9 +0,0 @@
1
- import type { L2BlockSource } from '@aztec/stdlib/block';
2
- import type { ReqRespSubProtocolHandler } from '../interface.js';
3
- /**
4
- * Handler for L2 Block requests
5
- * @param l2BlockSource - source for L2 blocks
6
- * @returns the Block request handler
7
- * */
8
- export declare function reqRespBlockHandler(l2BlockSource: L2BlockSource): ReqRespSubProtocolHandler;
9
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYmxvY2suZC50cyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9zZXJ2aWNlcy9yZXFyZXNwL3Byb3RvY29scy9ibG9jay50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFDQSxPQUFPLEtBQUssRUFBRSxhQUFhLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUl6RCxPQUFPLEtBQUssRUFBRSx5QkFBeUIsRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBR2pFOzs7O0tBSUs7QUFDTCx3QkFBZ0IsbUJBQW1CLENBQUMsYUFBYSxFQUFFLGFBQWEsR0FBRyx5QkFBeUIsQ0FzQjNGIn0=
@@ -1 +0,0 @@
1
- {"version":3,"file":"block.d.ts","sourceRoot":"","sources":["../../../../src/services/reqresp/protocols/block.ts"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,aAAa,EAAE,MAAM,qBAAqB,CAAC;AAIzD,OAAO,KAAK,EAAE,yBAAyB,EAAE,MAAM,iBAAiB,CAAC;AAGjE;;;;KAIK;AACL,wBAAgB,mBAAmB,CAAC,aAAa,EAAE,aAAa,GAAG,yBAAyB,CAsB3F"}
@@ -1,31 +0,0 @@
1
- import { Fr } from '@aztec/foundation/fields';
2
- import { ReqRespStatus, ReqRespStatusError } from '../status.js';
3
- /**
4
- * Handler for L2 Block requests
5
- * @param l2BlockSource - source for L2 blocks
6
- * @returns the Block request handler
7
- * */ export function reqRespBlockHandler(l2BlockSource) {
8
- /**
9
- * @param peerId - the peer ID of the requester
10
- * @param msg - the block request message, which is expected to contain valid block number as a Buffer
11
- * @returns a Buffer containing the requested block data, or an empty Buffer if the block is not found
12
- * @throws ReqRespStatusError if the input msg is not a valid block number
13
- * */ return async (_peerId, msg)=>{
14
- let blockNumber;
15
- try {
16
- blockNumber = Fr.fromBuffer(msg);
17
- } catch (err) {
18
- throw new ReqRespStatusError(ReqRespStatus.BADLY_FORMED_REQUEST, {
19
- cause: err
20
- });
21
- }
22
- try {
23
- const foundBlock = await l2BlockSource.getBlock(Number(blockNumber));
24
- return foundBlock ? foundBlock.toBuffer() : Buffer.alloc(0);
25
- } catch (err) {
26
- throw new ReqRespStatusError(ReqRespStatus.INTERNAL_ERROR, {
27
- cause: err
28
- });
29
- }
30
- };
31
- }