@aztec/p2p 0.0.1-commit.e6bd8901 → 0.0.1-commit.ec7ac5448

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 (555) 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 -19
  8. package/dest/client/interface.d.ts +54 -34
  9. package/dest/client/interface.d.ts.map +1 -1
  10. package/dest/client/p2p_client.d.ts +43 -52
  11. package/dest/client/p2p_client.d.ts.map +1 -1
  12. package/dest/client/p2p_client.js +181 -224
  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 +67 -16
  20. package/dest/config.d.ts.map +1 -1
  21. package/dest/config.js +112 -39
  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 +106 -88
  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 +353 -87
  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 +2 -2
  41. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  42. package/dest/mem_pools/attestation_pool/mocks.js +2 -2
  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 +4 -2
  47. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  48. package/dest/mem_pools/instrumentation.js +18 -16
  49. package/dest/mem_pools/interface.d.ts +5 -5
  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 → tx_pool_v2}/eviction/invalid_txs_after_mining_rule.js +16 -35
  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 → tx_pool_v2}/eviction/invalid_txs_after_reorg_rule.js +39 -24
  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 +5 -2
  115. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  116. package/dest/msg_validators/attestation_validator/attestation_validator.js +20 -11
  117. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -3
  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 +9 -4
  120. package/dest/msg_validators/clock_tolerance.d.ts +12 -1
  121. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -1
  122. package/dest/msg_validators/clock_tolerance.js +54 -3
  123. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +7 -4
  124. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -1
  125. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +10 -2
  126. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +7 -4
  127. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -1
  128. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +16 -2
  129. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +15 -8
  130. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -1
  131. package/dest/msg_validators/proposal_validator/proposal_validator.js +70 -50
  132. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts +4 -4
  133. package/dest/msg_validators/tx_validator/aggregate_tx_validator.d.ts.map +1 -1
  134. package/dest/msg_validators/tx_validator/aggregate_tx_validator.js +3 -3
  135. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts +2 -1
  136. package/dest/msg_validators/tx_validator/allowed_public_setup.d.ts.map +1 -1
  137. package/dest/msg_validators/tx_validator/allowed_public_setup.js +24 -20
  138. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts +17 -0
  139. package/dest/msg_validators/tx_validator/allowed_setup_helpers.d.ts.map +1 -0
  140. package/dest/msg_validators/tx_validator/allowed_setup_helpers.js +24 -0
  141. package/dest/msg_validators/tx_validator/archive_cache.d.ts +3 -3
  142. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  143. package/dest/msg_validators/tx_validator/archive_cache.js +1 -1
  144. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +20 -6
  145. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  146. package/dest/msg_validators/tx_validator/block_header_validator.js +4 -3
  147. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts +9 -0
  148. package/dest/msg_validators/tx_validator/contract_instance_validator.d.ts.map +1 -0
  149. package/dest/msg_validators/tx_validator/contract_instance_validator.js +48 -0
  150. package/dest/msg_validators/tx_validator/data_validator.d.ts +3 -1
  151. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  152. package/dest/msg_validators/tx_validator/data_validator.js +39 -3
  153. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts +15 -4
  154. package/dest/msg_validators/tx_validator/double_spend_validator.d.ts.map +1 -1
  155. package/dest/msg_validators/tx_validator/double_spend_validator.js +7 -6
  156. package/dest/msg_validators/tx_validator/factory.d.ts +137 -5
  157. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  158. package/dest/msg_validators/tx_validator/factory.js +255 -58
  159. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +1 -1
  160. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -1
  161. package/dest/msg_validators/tx_validator/fee_payer_balance.js +6 -2
  162. package/dest/msg_validators/tx_validator/gas_validator.d.ts +68 -3
  163. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  164. package/dest/msg_validators/tx_validator/gas_validator.js +114 -44
  165. package/dest/msg_validators/tx_validator/index.d.ts +3 -1
  166. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  167. package/dest/msg_validators/tx_validator/index.js +2 -0
  168. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +3 -2
  169. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  170. package/dest/msg_validators/tx_validator/metadata_validator.js +6 -6
  171. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts +14 -0
  172. package/dest/msg_validators/tx_validator/nullifier_cache.d.ts.map +1 -0
  173. package/dest/msg_validators/tx_validator/nullifier_cache.js +24 -0
  174. package/dest/msg_validators/tx_validator/phases_validator.d.ts +24 -3
  175. package/dest/msg_validators/tx_validator/phases_validator.d.ts.map +1 -1
  176. package/dest/msg_validators/tx_validator/phases_validator.js +75 -27
  177. package/dest/msg_validators/tx_validator/size_validator.d.ts +3 -1
  178. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -1
  179. package/dest/msg_validators/tx_validator/size_validator.js +4 -1
  180. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +22 -5
  181. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  182. package/dest/msg_validators/tx_validator/timestamp_validator.js +8 -8
  183. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts +3 -2
  184. package/dest/msg_validators/tx_validator/tx_permitted_validator.d.ts.map +1 -1
  185. package/dest/msg_validators/tx_validator/tx_permitted_validator.js +2 -2
  186. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts +3 -2
  187. package/dest/msg_validators/tx_validator/tx_proof_validator.d.ts.map +1 -1
  188. package/dest/msg_validators/tx_validator/tx_proof_validator.js +2 -2
  189. package/dest/services/data_store.d.ts +1 -1
  190. package/dest/services/data_store.d.ts.map +1 -1
  191. package/dest/services/data_store.js +14 -10
  192. package/dest/services/discv5/discV5_service.js +1 -1
  193. package/dest/services/dummy_service.d.ts +28 -5
  194. package/dest/services/dummy_service.d.ts.map +1 -1
  195. package/dest/services/dummy_service.js +52 -2
  196. package/dest/services/encoding.d.ts +7 -3
  197. package/dest/services/encoding.d.ts.map +1 -1
  198. package/dest/services/encoding.js +18 -11
  199. package/dest/services/gossipsub/index.d.ts +3 -0
  200. package/dest/services/gossipsub/index.d.ts.map +1 -0
  201. package/dest/services/gossipsub/index.js +2 -0
  202. package/dest/services/gossipsub/scoring.d.ts +21 -3
  203. package/dest/services/gossipsub/scoring.d.ts.map +1 -1
  204. package/dest/services/gossipsub/scoring.js +24 -7
  205. package/dest/services/gossipsub/topic_score_params.d.ts +184 -0
  206. package/dest/services/gossipsub/topic_score_params.d.ts.map +1 -0
  207. package/dest/services/gossipsub/topic_score_params.js +363 -0
  208. package/dest/services/index.d.ts +2 -1
  209. package/dest/services/index.d.ts.map +1 -1
  210. package/dest/services/index.js +1 -0
  211. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  212. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  213. package/dest/services/libp2p/instrumentation.js +14 -3
  214. package/dest/services/libp2p/libp2p_service.d.ts +98 -50
  215. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  216. package/dest/services/libp2p/libp2p_service.js +580 -449
  217. package/dest/services/peer-manager/metrics.d.ts +4 -2
  218. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  219. package/dest/services/peer-manager/metrics.js +26 -5
  220. package/dest/services/peer-manager/peer_manager.d.ts +6 -2
  221. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  222. package/dest/services/peer-manager/peer_manager.js +24 -9
  223. package/dest/services/peer-manager/peer_scoring.d.ts +7 -2
  224. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  225. package/dest/services/peer-manager/peer_scoring.js +65 -14
  226. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts +51 -0
  227. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.d.ts.map +1 -0
  228. package/dest/services/reqresp/batch-tx-requester/batch_tx_requester.js +543 -0
  229. package/dest/services/reqresp/batch-tx-requester/config.d.ts +17 -0
  230. package/dest/services/reqresp/batch-tx-requester/config.d.ts.map +1 -0
  231. package/dest/services/reqresp/batch-tx-requester/config.js +27 -0
  232. package/dest/services/reqresp/batch-tx-requester/interface.d.ts +47 -0
  233. package/dest/services/reqresp/batch-tx-requester/interface.d.ts.map +1 -0
  234. package/dest/services/reqresp/batch-tx-requester/interface.js +1 -0
  235. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts +35 -0
  236. package/dest/services/reqresp/batch-tx-requester/missing_txs.d.ts.map +1 -0
  237. package/dest/services/reqresp/batch-tx-requester/missing_txs.js +136 -0
  238. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts +62 -0
  239. package/dest/services/reqresp/batch-tx-requester/peer_collection.d.ts.map +1 -0
  240. package/dest/services/reqresp/batch-tx-requester/peer_collection.js +176 -0
  241. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts +20 -0
  242. package/dest/services/reqresp/batch-tx-requester/tx_validator.d.ts.map +1 -0
  243. package/dest/services/reqresp/batch-tx-requester/tx_validator.js +21 -0
  244. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts +22 -3
  245. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.d.ts.map +1 -1
  246. package/dest/services/reqresp/connection-sampler/batch_connection_sampler.js +63 -4
  247. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +2 -1
  248. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  249. package/dest/services/reqresp/connection-sampler/connection_sampler.js +12 -0
  250. package/dest/services/reqresp/interface.d.ts +25 -9
  251. package/dest/services/reqresp/interface.d.ts.map +1 -1
  252. package/dest/services/reqresp/interface.js +23 -10
  253. package/dest/services/reqresp/metrics.d.ts +6 -5
  254. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  255. package/dest/services/reqresp/metrics.js +16 -5
  256. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +5 -1
  257. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  258. package/dest/services/reqresp/protocols/block_txs/bitvector.js +5 -0
  259. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts +7 -5
  260. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.d.ts.map +1 -1
  261. package/dest/services/reqresp/protocols/block_txs/block_txs_handler.js +27 -9
  262. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +29 -6
  263. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  264. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +59 -13
  265. package/dest/services/reqresp/protocols/index.d.ts +1 -2
  266. package/dest/services/reqresp/protocols/index.d.ts.map +1 -1
  267. package/dest/services/reqresp/protocols/index.js +0 -1
  268. package/dest/services/reqresp/protocols/tx.d.ts +7 -1
  269. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  270. package/dest/services/reqresp/protocols/tx.js +21 -3
  271. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts +5 -4
  272. package/dest/services/reqresp/rate-limiter/rate_limiter.d.ts.map +1 -1
  273. package/dest/services/reqresp/rate-limiter/rate_limiter.js +10 -8
  274. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts +1 -1
  275. package/dest/services/reqresp/rate-limiter/rate_limits.d.ts.map +1 -1
  276. package/dest/services/reqresp/rate-limiter/rate_limits.js +0 -10
  277. package/dest/services/reqresp/reqresp.d.ts +9 -2
  278. package/dest/services/reqresp/reqresp.d.ts.map +1 -1
  279. package/dest/services/reqresp/reqresp.js +95 -34
  280. package/dest/services/service.d.ts +46 -4
  281. package/dest/services/service.d.ts.map +1 -1
  282. package/dest/services/tx_collection/config.d.ts +22 -1
  283. package/dest/services/tx_collection/config.d.ts.map +1 -1
  284. package/dest/services/tx_collection/config.js +55 -1
  285. package/dest/services/tx_collection/fast_tx_collection.d.ts +7 -7
  286. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  287. package/dest/services/tx_collection/fast_tx_collection.js +95 -84
  288. package/dest/services/tx_collection/file_store_tx_collection.d.ts +53 -0
  289. package/dest/services/tx_collection/file_store_tx_collection.d.ts.map +1 -0
  290. package/dest/services/tx_collection/file_store_tx_collection.js +167 -0
  291. package/dest/services/tx_collection/file_store_tx_source.d.ts +38 -0
  292. package/dest/services/tx_collection/file_store_tx_source.d.ts.map +1 -0
  293. package/dest/services/tx_collection/file_store_tx_source.js +100 -0
  294. package/dest/services/tx_collection/index.d.ts +3 -1
  295. package/dest/services/tx_collection/index.d.ts.map +1 -1
  296. package/dest/services/tx_collection/index.js +2 -0
  297. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  298. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  299. package/dest/services/tx_collection/instrumentation.js +10 -2
  300. package/dest/services/tx_collection/proposal_tx_collector.d.ts +48 -0
  301. package/dest/services/tx_collection/proposal_tx_collector.d.ts.map +1 -0
  302. package/dest/services/tx_collection/proposal_tx_collector.js +50 -0
  303. package/dest/services/tx_collection/request_tracker.d.ts +53 -0
  304. package/dest/services/tx_collection/request_tracker.d.ts.map +1 -0
  305. package/dest/services/tx_collection/request_tracker.js +84 -0
  306. package/dest/services/tx_collection/slow_tx_collection.d.ts +7 -3
  307. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  308. package/dest/services/tx_collection/slow_tx_collection.js +60 -26
  309. package/dest/services/tx_collection/tx_collection.d.ts +25 -15
  310. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  311. package/dest/services/tx_collection/tx_collection.js +79 -7
  312. package/dest/services/tx_collection/tx_collection_sink.d.ts +18 -8
  313. package/dest/services/tx_collection/tx_collection_sink.d.ts.map +1 -1
  314. package/dest/services/tx_collection/tx_collection_sink.js +26 -29
  315. package/dest/services/tx_collection/tx_source.d.ts +13 -7
  316. package/dest/services/tx_collection/tx_source.d.ts.map +1 -1
  317. package/dest/services/tx_collection/tx_source.js +26 -7
  318. package/dest/services/tx_file_store/config.d.ts +16 -0
  319. package/dest/services/tx_file_store/config.d.ts.map +1 -0
  320. package/dest/services/tx_file_store/config.js +22 -0
  321. package/dest/services/tx_file_store/index.d.ts +4 -0
  322. package/dest/services/tx_file_store/index.d.ts.map +1 -0
  323. package/dest/services/tx_file_store/index.js +3 -0
  324. package/dest/services/tx_file_store/instrumentation.d.ts +15 -0
  325. package/dest/services/tx_file_store/instrumentation.d.ts.map +1 -0
  326. package/dest/services/tx_file_store/instrumentation.js +29 -0
  327. package/dest/services/tx_file_store/tx_file_store.d.ts +48 -0
  328. package/dest/services/tx_file_store/tx_file_store.d.ts.map +1 -0
  329. package/dest/services/tx_file_store/tx_file_store.js +152 -0
  330. package/dest/services/tx_provider.d.ts +4 -4
  331. package/dest/services/tx_provider.d.ts.map +1 -1
  332. package/dest/services/tx_provider.js +9 -8
  333. package/dest/services/tx_provider_instrumentation.d.ts +1 -1
  334. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  335. package/dest/services/tx_provider_instrumentation.js +5 -5
  336. package/dest/test-helpers/index.d.ts +3 -1
  337. package/dest/test-helpers/index.d.ts.map +1 -1
  338. package/dest/test-helpers/index.js +2 -0
  339. package/dest/test-helpers/make-test-p2p-clients.d.ts +7 -8
  340. package/dest/test-helpers/make-test-p2p-clients.d.ts.map +1 -1
  341. package/dest/test-helpers/make-test-p2p-clients.js +1 -2
  342. package/dest/test-helpers/mock-pubsub.d.ts +40 -6
  343. package/dest/test-helpers/mock-pubsub.d.ts.map +1 -1
  344. package/dest/test-helpers/mock-pubsub.js +139 -13
  345. package/dest/test-helpers/reqresp-nodes.d.ts +2 -3
  346. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  347. package/dest/test-helpers/reqresp-nodes.js +5 -5
  348. package/dest/test-helpers/test_tx_provider.d.ts +40 -0
  349. package/dest/test-helpers/test_tx_provider.d.ts.map +1 -0
  350. package/dest/test-helpers/test_tx_provider.js +41 -0
  351. package/dest/test-helpers/testbench-utils.d.ts +163 -0
  352. package/dest/test-helpers/testbench-utils.d.ts.map +1 -0
  353. package/dest/test-helpers/testbench-utils.js +386 -0
  354. package/dest/testbench/p2p_client_testbench_worker.d.ts +28 -2
  355. package/dest/testbench/p2p_client_testbench_worker.d.ts.map +1 -1
  356. package/dest/testbench/p2p_client_testbench_worker.js +276 -143
  357. package/dest/testbench/worker_client_manager.d.ts +60 -6
  358. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  359. package/dest/testbench/worker_client_manager.js +280 -46
  360. package/dest/util.d.ts +3 -3
  361. package/dest/util.d.ts.map +1 -1
  362. package/package.json +14 -14
  363. package/src/bootstrap/bootstrap.ts +7 -4
  364. package/src/client/factory.ts +114 -38
  365. package/src/client/interface.ts +65 -35
  366. package/src/client/p2p_client.ts +217 -269
  367. package/src/client/test/tx_proposal_collector/README.md +227 -0
  368. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker.ts +355 -0
  369. package/src/client/test/tx_proposal_collector/proposal_tx_collector_worker_protocol.ts +43 -0
  370. package/src/config.ts +182 -44
  371. package/src/errors/p2p-service.error.ts +11 -0
  372. package/src/errors/tx-pool.error.ts +12 -0
  373. package/src/index.ts +1 -1
  374. package/src/mem_pools/attestation_pool/attestation_pool.ts +501 -91
  375. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +442 -102
  376. package/src/mem_pools/attestation_pool/index.ts +9 -2
  377. package/src/mem_pools/attestation_pool/mocks.ts +2 -1
  378. package/src/mem_pools/index.ts +2 -2
  379. package/src/mem_pools/instrumentation.ts +19 -14
  380. package/src/mem_pools/interface.ts +4 -4
  381. package/src/mem_pools/tx_pool_v2/README.md +283 -0
  382. package/src/mem_pools/tx_pool_v2/archive/index.ts +1 -0
  383. package/src/mem_pools/tx_pool_v2/archive/tx_archive.ts +120 -0
  384. package/src/mem_pools/tx_pool_v2/deleted_pool.ts +321 -0
  385. package/src/mem_pools/tx_pool_v2/eviction/eviction_manager.ts +160 -0
  386. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_eviction_rule.ts +122 -0
  387. package/src/mem_pools/tx_pool_v2/eviction/fee_payer_balance_pre_add_rule.ts +125 -0
  388. package/src/mem_pools/tx_pool_v2/eviction/index.ts +27 -0
  389. package/src/mem_pools/tx_pool_v2/eviction/interfaces.ts +219 -0
  390. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_mining_rule.ts +74 -0
  391. package/src/mem_pools/tx_pool_v2/eviction/invalid_txs_after_reorg_rule.ts +101 -0
  392. package/src/mem_pools/tx_pool_v2/eviction/low_priority_eviction_rule.ts +91 -0
  393. package/src/mem_pools/tx_pool_v2/eviction/low_priority_pre_add_rule.ts +99 -0
  394. package/src/mem_pools/tx_pool_v2/eviction/nullifier_conflict_rule.ts +32 -0
  395. package/src/mem_pools/tx_pool_v2/index.ts +12 -0
  396. package/src/mem_pools/tx_pool_v2/instrumentation.ts +69 -0
  397. package/src/mem_pools/tx_pool_v2/interfaces.ts +247 -0
  398. package/src/mem_pools/tx_pool_v2/tx_metadata.ts +343 -0
  399. package/src/mem_pools/tx_pool_v2/tx_pool_bench_metrics.ts +77 -0
  400. package/src/mem_pools/tx_pool_v2/tx_pool_indices.ts +430 -0
  401. package/src/mem_pools/tx_pool_v2/tx_pool_v2.ts +238 -0
  402. package/src/mem_pools/tx_pool_v2/tx_pool_v2_impl.ts +1105 -0
  403. package/src/msg_validators/attestation_validator/README.md +49 -0
  404. package/src/msg_validators/attestation_validator/attestation_validator.ts +21 -9
  405. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +14 -5
  406. package/src/msg_validators/clock_tolerance.ts +72 -3
  407. package/src/msg_validators/proposal_validator/README.md +123 -0
  408. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +17 -4
  409. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +23 -7
  410. package/src/msg_validators/proposal_validator/proposal_validator.ts +81 -51
  411. package/src/msg_validators/tx_validator/README.md +119 -0
  412. package/src/msg_validators/tx_validator/aggregate_tx_validator.ts +5 -5
  413. package/src/msg_validators/tx_validator/allowed_public_setup.ts +22 -27
  414. package/src/msg_validators/tx_validator/allowed_setup_helpers.ts +31 -0
  415. package/src/msg_validators/tx_validator/archive_cache.ts +3 -3
  416. package/src/msg_validators/tx_validator/block_header_validator.ts +21 -8
  417. package/src/msg_validators/tx_validator/contract_instance_validator.ts +56 -0
  418. package/src/msg_validators/tx_validator/data_validator.ts +48 -3
  419. package/src/msg_validators/tx_validator/double_spend_validator.ts +15 -9
  420. package/src/msg_validators/tx_validator/factory.ts +413 -56
  421. package/src/msg_validators/tx_validator/fee_payer_balance.ts +6 -2
  422. package/src/msg_validators/tx_validator/gas_validator.ts +154 -36
  423. package/src/msg_validators/tx_validator/index.ts +2 -0
  424. package/src/msg_validators/tx_validator/metadata_validator.ts +18 -7
  425. package/src/msg_validators/tx_validator/nullifier_cache.ts +30 -0
  426. package/src/msg_validators/tx_validator/phases_validator.ts +87 -30
  427. package/src/msg_validators/tx_validator/size_validator.ts +6 -2
  428. package/src/msg_validators/tx_validator/timestamp_validator.ts +29 -21
  429. package/src/msg_validators/tx_validator/tx_permitted_validator.ts +8 -3
  430. package/src/msg_validators/tx_validator/tx_proof_validator.ts +8 -3
  431. package/src/services/data_store.ts +14 -19
  432. package/src/services/discv5/discV5_service.ts +1 -1
  433. package/src/services/dummy_service.ts +66 -3
  434. package/src/services/encoding.ts +18 -10
  435. package/src/services/gossipsub/README.md +641 -0
  436. package/src/services/gossipsub/index.ts +2 -0
  437. package/src/services/gossipsub/scoring.ts +29 -5
  438. package/src/services/gossipsub/topic_score_params.ts +519 -0
  439. package/src/services/index.ts +1 -0
  440. package/src/services/libp2p/instrumentation.ts +15 -2
  441. package/src/services/libp2p/libp2p_service.ts +626 -502
  442. package/src/services/peer-manager/metrics.ts +28 -4
  443. package/src/services/peer-manager/peer_manager.ts +28 -9
  444. package/src/services/peer-manager/peer_scoring.ts +56 -6
  445. package/src/services/reqresp/README.md +229 -0
  446. package/src/services/reqresp/batch-tx-requester/README.md +344 -0
  447. package/src/services/reqresp/batch-tx-requester/batch_tx_requester.ts +673 -0
  448. package/src/services/reqresp/batch-tx-requester/config.ts +40 -0
  449. package/src/services/reqresp/batch-tx-requester/interface.ts +54 -0
  450. package/src/services/reqresp/batch-tx-requester/missing_txs.ts +168 -0
  451. package/src/services/reqresp/batch-tx-requester/peer_collection.ts +249 -0
  452. package/src/services/reqresp/batch-tx-requester/tx_validator.ts +37 -0
  453. package/src/services/reqresp/connection-sampler/batch_connection_sampler.ts +65 -4
  454. package/src/services/reqresp/connection-sampler/connection_sampler.ts +16 -0
  455. package/src/services/reqresp/interface.ts +48 -10
  456. package/src/services/reqresp/metrics.ts +33 -9
  457. package/src/services/reqresp/protocols/block_txs/bitvector.ts +7 -0
  458. package/src/services/reqresp/protocols/block_txs/block_txs_handler.ts +35 -12
  459. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +74 -9
  460. package/src/services/reqresp/protocols/index.ts +0 -1
  461. package/src/services/reqresp/protocols/tx.ts +23 -3
  462. package/src/services/reqresp/rate-limiter/rate_limiter.ts +13 -9
  463. package/src/services/reqresp/rate-limiter/rate_limits.ts +0 -10
  464. package/src/services/reqresp/reqresp.ts +116 -32
  465. package/src/services/service.ts +61 -3
  466. package/src/services/tx_collection/config.ts +83 -1
  467. package/src/services/tx_collection/fast_tx_collection.ts +111 -91
  468. package/src/services/tx_collection/file_store_tx_collection.ts +202 -0
  469. package/src/services/tx_collection/file_store_tx_source.ts +129 -0
  470. package/src/services/tx_collection/index.ts +6 -0
  471. package/src/services/tx_collection/instrumentation.ts +17 -2
  472. package/src/services/tx_collection/proposal_tx_collector.ts +108 -0
  473. package/src/services/tx_collection/request_tracker.ts +127 -0
  474. package/src/services/tx_collection/slow_tx_collection.ts +66 -33
  475. package/src/services/tx_collection/tx_collection.ts +118 -23
  476. package/src/services/tx_collection/tx_collection_sink.ts +30 -34
  477. package/src/services/tx_collection/tx_source.ts +28 -8
  478. package/src/services/tx_file_store/config.ts +37 -0
  479. package/src/services/tx_file_store/index.ts +3 -0
  480. package/src/services/tx_file_store/instrumentation.ts +36 -0
  481. package/src/services/tx_file_store/tx_file_store.ts +175 -0
  482. package/src/services/tx_provider.ts +10 -9
  483. package/src/services/tx_provider_instrumentation.ts +11 -5
  484. package/src/test-helpers/index.ts +2 -0
  485. package/src/test-helpers/make-test-p2p-clients.ts +4 -6
  486. package/src/test-helpers/mock-pubsub.ts +177 -14
  487. package/src/test-helpers/reqresp-nodes.ts +7 -9
  488. package/src/test-helpers/test_tx_provider.ts +64 -0
  489. package/src/test-helpers/testbench-utils.ts +457 -0
  490. package/src/testbench/p2p_client_testbench_worker.ts +393 -134
  491. package/src/testbench/worker_client_manager.ts +367 -48
  492. package/src/util.ts +8 -2
  493. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +0 -40
  494. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +0 -1
  495. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +0 -218
  496. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +0 -31
  497. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +0 -1
  498. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +0 -180
  499. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +0 -125
  500. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +0 -1
  501. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +0 -596
  502. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +0 -32
  503. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +0 -1
  504. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +0 -112
  505. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +0 -157
  506. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +0 -1
  507. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +0 -52
  508. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +0 -16
  509. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +0 -1
  510. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +0 -122
  511. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +0 -17
  512. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +0 -1
  513. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +0 -19
  514. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +0 -1
  515. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +0 -26
  516. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +0 -1
  517. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +0 -84
  518. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +0 -25
  519. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +0 -1
  520. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +0 -57
  521. package/dest/mem_pools/tx_pool/index.d.ts +0 -3
  522. package/dest/mem_pools/tx_pool/index.d.ts.map +0 -1
  523. package/dest/mem_pools/tx_pool/index.js +0 -2
  524. package/dest/mem_pools/tx_pool/priority.d.ts +0 -12
  525. package/dest/mem_pools/tx_pool/priority.d.ts.map +0 -1
  526. package/dest/mem_pools/tx_pool/priority.js +0 -15
  527. package/dest/mem_pools/tx_pool/tx_pool.d.ts +0 -127
  528. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +0 -1
  529. package/dest/mem_pools/tx_pool/tx_pool.js +0 -3
  530. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +0 -7
  531. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +0 -1
  532. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +0 -400
  533. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +0 -23
  534. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +0 -1
  535. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +0 -212
  536. package/dest/services/reqresp/protocols/block.d.ts +0 -9
  537. package/dest/services/reqresp/protocols/block.d.ts.map +0 -1
  538. package/dest/services/reqresp/protocols/block.js +0 -32
  539. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +0 -320
  540. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +0 -264
  541. package/src/mem_pools/tx_pool/README.md +0 -270
  542. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +0 -746
  543. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +0 -132
  544. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +0 -208
  545. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +0 -162
  546. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +0 -104
  547. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +0 -93
  548. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +0 -106
  549. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +0 -75
  550. package/src/mem_pools/tx_pool/index.ts +0 -2
  551. package/src/mem_pools/tx_pool/priority.ts +0 -20
  552. package/src/mem_pools/tx_pool/tx_pool.ts +0 -141
  553. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +0 -319
  554. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +0 -230
  555. package/src/services/reqresp/protocols/block.ts +0 -37
@@ -1,13 +1,17 @@
1
- import { Fr } from '@aztec/foundation/curves/bn254';
2
- import { L2Block } from '@aztec/stdlib/block';
3
1
  import { TxArray, TxHashArray } from '@aztec/stdlib/tx';
4
2
 
5
3
  import type { PeerId } from '@libp2p/interface';
6
4
 
7
5
  import type { P2PReqRespConfig } from './config.js';
6
+ import type { ConnectionSampler } from './connection-sampler/connection_sampler.js';
8
7
  import { AuthRequest, AuthResponse } from './protocols/auth.js';
9
- import { BlockTxsRequest, BlockTxsResponse } from './protocols/block_txs/block_txs_reqresp.js';
8
+ import {
9
+ BlockTxsRequest,
10
+ BlockTxsResponse,
11
+ calculateBlockTxsResponseSize,
12
+ } from './protocols/block_txs/block_txs_reqresp.js';
10
13
  import { StatusMessage } from './protocols/status.js';
14
+ import { calculateTxResponseSize } from './protocols/tx.js';
11
15
  import type { ReqRespStatus } from './status.js';
12
16
 
13
17
  /*
@@ -17,7 +21,6 @@ export const PING_PROTOCOL = '/aztec/req/ping/1.0.0';
17
21
  export const STATUS_PROTOCOL = '/aztec/req/status/1.0.0';
18
22
  export const GOODBYE_PROTOCOL = '/aztec/req/goodbye/1.0.0';
19
23
  export const TX_REQ_PROTOCOL = '/aztec/req/tx/1.0.0';
20
- export const BLOCK_REQ_PROTOCOL = '/aztec/req/block/1.0.0';
21
24
  export const AUTH_PROTOCOL = '/aztec/req/auth/1.0.0';
22
25
  export const BLOCK_TXS_REQ_PROTOCOL = '/aztec/req/block_txs/1.0.0';
23
26
 
@@ -26,7 +29,6 @@ export enum ReqRespSubProtocol {
26
29
  STATUS = STATUS_PROTOCOL,
27
30
  GOODBYE = GOODBYE_PROTOCOL,
28
31
  TX = TX_REQ_PROTOCOL,
29
- BLOCK = BLOCK_REQ_PROTOCOL,
30
32
  AUTH = AUTH_PROTOCOL,
31
33
  BLOCK_TXS = BLOCK_TXS_REQ_PROTOCOL,
32
34
  }
@@ -93,12 +95,29 @@ export type ReqRespSubProtocolValidators = {
93
95
  [S in ReqRespSubProtocol]: ResponseValidator<any, any>;
94
96
  };
95
97
 
98
+ /**
99
+ * Protocols that are always allowed without authentication, even when p2pAllowOnlyValidators is enabled.
100
+ * These are needed for the handshake and connection management flow.
101
+ * All other protocols require the remote peer to be authenticated.
102
+ */
103
+ export const UNAUTHENTICATED_ALLOWED_PROTOCOLS: ReadonlySet<ReqRespSubProtocol> = new Set([
104
+ ReqRespSubProtocol.PING,
105
+ ReqRespSubProtocol.STATUS,
106
+ ReqRespSubProtocol.AUTH,
107
+ ReqRespSubProtocol.GOODBYE,
108
+ ]);
109
+
110
+ /**
111
+ * Callback that checks whether a peer should be rejected from req/resp data protocols.
112
+ * Returns true if the peer should be rejected (i.e. p2pAllowOnlyValidators is on and peer is unauthenticated).
113
+ */
114
+ export type ShouldRejectPeer = (peerId: string) => boolean;
115
+
96
116
  export const DEFAULT_SUB_PROTOCOL_VALIDATORS: ReqRespSubProtocolValidators = {
97
117
  [ReqRespSubProtocol.PING]: noopValidator,
98
118
  [ReqRespSubProtocol.STATUS]: noopValidator,
99
119
  [ReqRespSubProtocol.TX]: noopValidator,
100
120
  [ReqRespSubProtocol.GOODBYE]: noopValidator,
101
- [ReqRespSubProtocol.BLOCK]: noopValidator,
102
121
  [ReqRespSubProtocol.AUTH]: noopValidator,
103
122
  [ReqRespSubProtocol.BLOCK_TXS]: noopValidator,
104
123
  };
@@ -196,10 +215,6 @@ export const subProtocolMap = {
196
215
  request: RequestableBuffer,
197
216
  response: RequestableBuffer,
198
217
  },
199
- [ReqRespSubProtocol.BLOCK]: {
200
- request: Fr, // block number
201
- response: L2Block,
202
- },
203
218
  [ReqRespSubProtocol.AUTH]: {
204
219
  request: AuthRequest,
205
220
  response: AuthResponse,
@@ -210,6 +225,24 @@ export const subProtocolMap = {
210
225
  },
211
226
  };
212
227
 
228
+ /**
229
+ * Type for a function that calculates the expected response size in KB for a given request.
230
+ */
231
+ export type ExpectedResponseSizeCalculator = (requestBuffer: Buffer) => number;
232
+
233
+ /**
234
+ * Map of sub-protocols to their expected response size calculators.
235
+ * These are used to validate that responses don't exceed expected sizes based on request parameters.
236
+ */
237
+ export const subProtocolSizeCalculators: Record<ReqRespSubProtocol, ExpectedResponseSizeCalculator> = {
238
+ [ReqRespSubProtocol.TX]: calculateTxResponseSize,
239
+ [ReqRespSubProtocol.BLOCK_TXS]: calculateBlockTxsResponseSize,
240
+ [ReqRespSubProtocol.STATUS]: () => 1,
241
+ [ReqRespSubProtocol.PING]: () => 1,
242
+ [ReqRespSubProtocol.AUTH]: () => 1,
243
+ [ReqRespSubProtocol.GOODBYE]: () => 1, // No response expected, but provide minimal limit
244
+ };
245
+
213
246
  export interface ReqRespInterface {
214
247
  start(
215
248
  subProtocolHandlers: Partial<ReqRespSubProtocolHandlers>,
@@ -237,4 +270,9 @@ export interface ReqRespInterface {
237
270
  ): Promise<ReqRespResponse>;
238
271
 
239
272
  updateConfig(config: Partial<P2PReqRespConfig>): void;
273
+
274
+ /** Sets the callback used to reject unauthenticated peers on gated req/resp protocols. */
275
+ setShouldRejectPeer(checker: ShouldRejectPeer): void;
276
+
277
+ getConnectionSampler(): Pick<ConnectionSampler, 'getPeerListSortedByConnectionCountAsc'>;
240
278
  }
@@ -1,7 +1,9 @@
1
1
  // Request response metrics
2
- import { Attributes, Metrics } from '@aztec/telemetry-client';
2
+ import { Attributes, Metrics, createUpDownCounterWithDefault } from '@aztec/telemetry-client';
3
3
  import type { TelemetryClient, Tracer, UpDownCounter } from '@aztec/telemetry-client';
4
4
 
5
+ import { ReqRespSubProtocol } from './interface.js';
6
+
5
7
  export class ReqRespMetrics {
6
8
  public readonly tracer: Tracer;
7
9
 
@@ -18,27 +20,49 @@ export class ReqRespMetrics {
18
20
  this.tracer = telemetryClient.getTracer(name);
19
21
 
20
22
  const meter = telemetryClient.getMeter(name);
21
- this.sentRequests = meter.createUpDownCounter(Metrics.P2P_REQ_RESP_SENT_REQUESTS);
22
- this.receivedRequests = meter.createUpDownCounter(Metrics.P2P_REQ_RESP_RECEIVED_REQUESTS);
23
+ const protocolAttrs = {
24
+ [Attributes.P2P_REQ_RESP_PROTOCOL]: [
25
+ ReqRespSubProtocol.PING,
26
+ ReqRespSubProtocol.STATUS,
27
+ ReqRespSubProtocol.GOODBYE,
28
+ ReqRespSubProtocol.TX,
29
+ ReqRespSubProtocol.AUTH,
30
+ ReqRespSubProtocol.BLOCK_TXS,
31
+ ],
32
+ };
33
+ this.sentRequests = createUpDownCounterWithDefault(meter, Metrics.P2P_REQ_RESP_SENT_REQUESTS, protocolAttrs);
34
+ this.receivedRequests = createUpDownCounterWithDefault(
35
+ meter,
36
+ Metrics.P2P_REQ_RESP_RECEIVED_REQUESTS,
37
+ protocolAttrs,
38
+ );
23
39
 
24
- this.failedOutboundRequests = meter.createUpDownCounter(Metrics.P2P_REQ_RESP_FAILED_OUTBOUND_REQUESTS);
40
+ this.failedOutboundRequests = createUpDownCounterWithDefault(
41
+ meter,
42
+ Metrics.P2P_REQ_RESP_FAILED_OUTBOUND_REQUESTS,
43
+ protocolAttrs,
44
+ );
25
45
 
26
- this.failedInboundRequests = meter.createUpDownCounter(Metrics.P2P_REQ_RESP_FAILED_INBOUND_REQUESTS);
46
+ this.failedInboundRequests = createUpDownCounterWithDefault(
47
+ meter,
48
+ Metrics.P2P_REQ_RESP_FAILED_INBOUND_REQUESTS,
49
+ protocolAttrs,
50
+ );
27
51
  }
28
52
 
29
- public recordRequestSent(protocol: string) {
53
+ public recordRequestSent(protocol: ReqRespSubProtocol) {
30
54
  this.sentRequests.add(1, { [Attributes.P2P_REQ_RESP_PROTOCOL]: protocol });
31
55
  }
32
56
 
33
- public recordRequestReceived(protocol: string) {
57
+ public recordRequestReceived(protocol: ReqRespSubProtocol) {
34
58
  this.receivedRequests.add(1, { [Attributes.P2P_REQ_RESP_PROTOCOL]: protocol });
35
59
  }
36
60
 
37
- public recordRequestError(protocol: string) {
61
+ public recordRequestError(protocol: ReqRespSubProtocol) {
38
62
  this.failedOutboundRequests.add(1, { [Attributes.P2P_REQ_RESP_PROTOCOL]: protocol });
39
63
  }
40
64
 
41
- public recordResponseError(protocol: string) {
65
+ public recordResponseError(protocol: ReqRespSubProtocol) {
42
66
  this.failedInboundRequests.add(1, { [Attributes.P2P_REQ_RESP_PROTOCOL]: protocol });
43
67
  }
44
68
  }
@@ -64,6 +64,13 @@ export class BitVector {
64
64
  return Array.from({ length: this.length }, (_, i) => i).filter(i => this.isSet(i));
65
65
  }
66
66
 
67
+ /**
68
+ * Returns true if no indices are set to true
69
+ * */
70
+ isEmpty(): boolean {
71
+ return this.getTrueIndices().length === 0;
72
+ }
73
+
67
74
  /**
68
75
  * Serializes the BitVector object into a Buffer
69
76
  *
@@ -1,9 +1,11 @@
1
+ import { Fr } from '@aztec/foundation/curves/bn254';
2
+ import type { L2BlockSource } from '@aztec/stdlib/block';
1
3
  import { TxArray } from '@aztec/stdlib/tx';
2
4
 
3
5
  import type { PeerId } from '@libp2p/interface';
4
6
 
5
- import type { AttestationPool } from '../../../../mem_pools/attestation_pool/attestation_pool.js';
6
- import type { TxPool } from '../../../../mem_pools/index.js';
7
+ import type { AttestationPoolApi } from '../../../../mem_pools/attestation_pool/attestation_pool.js';
8
+ import type { TxPoolV2 } from '../../../../mem_pools/tx_pool_v2/interfaces.js';
7
9
  import type { ReqRespSubProtocolHandler } from '../../interface.js';
8
10
  import { ReqRespStatus, ReqRespStatusError } from '../../status.js';
9
11
  import { BitVector } from './bitvector.js';
@@ -12,10 +14,15 @@ import { BlockTxsRequest, BlockTxsResponse } from './block_txs_reqresp.js';
12
14
  /**
13
15
  * Handler for block txs requests
14
16
  * @param attestationPool - the attestation pool to check for block proposals
15
- * @param mempools - the mempools containing the tx pool
17
+ * @param archiver - the archiver to look up blocks by archive root
18
+ * @param txPool - the tx pool to fetch transactions from
16
19
  * @returns the BlockTxs request handler
17
20
  */
18
- export function reqRespBlockTxsHandler(attestationPool: AttestationPool, txPool: TxPool): ReqRespSubProtocolHandler {
21
+ export function reqRespBlockTxsHandler(
22
+ attestationPool: AttestationPoolApi,
23
+ archiver: L2BlockSource,
24
+ txPool: TxPoolV2,
25
+ ): ReqRespSubProtocolHandler {
19
26
  /**
20
27
  * Handler for block txs requests
21
28
  * @param msg - the block txs request message
@@ -29,24 +36,40 @@ export function reqRespBlockTxsHandler(attestationPool: AttestationPool, txPool:
29
36
  } catch (err: any) {
30
37
  throw new ReqRespStatusError(ReqRespStatus.BADLY_FORMED_REQUEST, { cause: err });
31
38
  }
39
+ // First try attestation pool, then fall back to archiver
40
+ let txHashes = (await attestationPool.getBlockProposal(request.archiveRoot.toString()))?.txHashes;
41
+ if (!txHashes) {
42
+ txHashes = (await archiver.getL2BlockByArchive(request.archiveRoot))?.body.txEffects.map(effect => effect.txHash);
43
+ }
32
44
 
33
- const blockProposal = await attestationPool.getBlockProposal(request.blockHash.toString());
45
+ let requestedTxsHashes;
46
+ if (request.txHashes.length > 0) {
47
+ requestedTxsHashes = request.txHashes;
48
+ }
34
49
 
35
- if (!blockProposal) {
50
+ // This is scenario in which we don't have this block the peer is requesting from us
51
+ // But peer has sent requested tx hashes, so we can send them the transactions
52
+ if (!txHashes && requestedTxsHashes !== undefined) {
53
+ const responseTxs = (await txPool.getTxsByHash(requestedTxsHashes)).filter(tx => !!tx);
54
+ const response = new BlockTxsResponse(Fr.zero(), new TxArray(...responseTxs), BitVector.init(0, []));
55
+ return response.toBuffer();
56
+ }
57
+
58
+ // If we don't have this block and peer has not sent requested tx hashes
59
+ if (!txHashes) {
36
60
  throw new ReqRespStatusError(ReqRespStatus.NOT_FOUND);
37
61
  }
38
62
 
39
- const txsAvailableInPool = await txPool.hasTxs(blockProposal.txHashes);
40
- //Map txs in the pool to their indices in the block proposal
63
+ const txsAvailableInPool = await txPool.hasTxs(txHashes);
64
+ // Map txs in the pool to their indices in the block
41
65
  const availableIndices = txsAvailableInPool.map((hasTx, idx) => (hasTx ? idx : -1)).filter(idx => idx !== -1);
42
- const responseBitVector = BitVector.init(blockProposal.txHashes.length, availableIndices);
66
+ const responseBitVector = BitVector.init(txHashes.length, availableIndices);
43
67
 
44
68
  const requestedIndices = new Set(request.txIndices.getTrueIndices());
45
- const requestedTxsHashes = blockProposal.txHashes.filter((_, idx) => requestedIndices.has(idx));
69
+ requestedTxsHashes = txHashes.filter((_, idx) => requestedIndices.has(idx));
46
70
 
47
71
  const responseTxs = (await txPool.getTxsByHash(requestedTxsHashes)).filter(tx => !!tx);
48
-
49
- const response = new BlockTxsResponse(request.blockHash, new TxArray(...responseTxs), responseBitVector);
72
+ const response = new BlockTxsResponse(request.archiveRoot, new TxArray(...responseTxs), responseBitVector);
50
73
 
51
74
  return response.toBuffer();
52
75
  };
@@ -1,20 +1,68 @@
1
1
  import { Fr } from '@aztec/foundation/curves/bn254';
2
2
  import { BufferReader, serializeToBuffer } from '@aztec/foundation/serialize';
3
- import { TxArray } from '@aztec/stdlib/tx';
3
+ import { MAX_TX_SIZE_KB } from '@aztec/stdlib/p2p';
4
+ import { TxArray, type TxHash, TxHashArray } from '@aztec/stdlib/tx';
4
5
 
5
6
  import { BitVector } from './bitvector.js';
6
7
 
8
+ /** Minimal interface for a block source that provides tx hashes and an archive root. */
9
+ export interface BlockTxsSource {
10
+ txHashes: TxHash[];
11
+ archive: Fr;
12
+ }
13
+
7
14
  /**
8
15
  * Request message for requesting specific transactions from a block
9
16
  */
10
17
  export class BlockTxsRequest {
11
18
  constructor(
12
- readonly blockHash: Fr, // 32 byte hash of the proposed block header
19
+ // Archive root after the proposed block is applied (proposal identifier)
20
+ readonly archiveRoot: Fr,
21
+ // Hashes of txs we are requesting
22
+ readonly txHashes: TxHashArray,
13
23
  // BitVector indicating which txs from the proposal we are requesting
14
24
  // 1 means we want the tx, 0 means we don't
25
+ // If we know peer has the Block Proposal then we can use this BitVector
26
+ // Otherwise we can use this optimization
15
27
  readonly txIndices: BitVector,
16
28
  ) {}
17
29
 
30
+ /**
31
+ * Creates new BlockTxsRequest given a block txs source and missing tx hashes.
32
+ *
33
+ * @param blockTxsSource - The block or proposal for which we are making the request
34
+ * @param missingTxHashes - Tx hashes from the source we are missing
35
+ * @param includeFullTxHashes - Whether to include full list of missing tx hashes in the request or just Bitvector indices
36
+ *
37
+ * @returns undefined if there were no missingTxHashes matching the source hashes, otherwise
38
+ * returns new BlockTxsRequest
39
+ */
40
+ static fromTxsSourceAndMissingTxs(
41
+ blockTxsSource: BlockTxsSource,
42
+ missingTxHashes: TxHash[],
43
+ includeFullTxHashes = false,
44
+ ): BlockTxsRequest | undefined {
45
+ if (missingTxHashes.length === 0) {
46
+ return undefined; // No missing txs to request
47
+ }
48
+
49
+ const missingHashesSet = new Set(missingTxHashes.map(t => t.toString()));
50
+
51
+ // We cannot request txs that are not part of the block
52
+ if (!missingHashesSet.isSubsetOf(new Set(blockTxsSource.txHashes.map(t => t.toString())))) {
53
+ return undefined;
54
+ }
55
+
56
+ const missingIndices = blockTxsSource.txHashes
57
+ .map((hash, idx) => (missingHashesSet.has(hash.toString()) ? idx : -1))
58
+ .filter(i => i != -1);
59
+
60
+ const requestBitVector = BitVector.init(blockTxsSource.txHashes.length, missingIndices);
61
+ const hashes = includeFullTxHashes ? new TxHashArray(...missingTxHashes) : new TxHashArray();
62
+
63
+ return new BlockTxsRequest(blockTxsSource.archive, hashes, requestBitVector);
64
+ }
65
+
18
66
  /**
19
67
  * Deserializes the BlockTxRequest object from a Buffer
20
68
  * @param buffer - Buffer or BufferReader object to deserialize
@@ -22,10 +70,11 @@ export class BlockTxsRequest {
22
70
  */
23
71
  static fromBuffer(buffer: Buffer | BufferReader): BlockTxsRequest {
24
72
  const reader = BufferReader.asReader(buffer);
25
- const blockHash = Fr.fromBuffer(reader);
73
+ const archiveRoot = Fr.fromBuffer(reader);
74
+ const txHashes = TxHashArray.fromBuffer(reader);
26
75
  const txIndices = BitVector.fromBuffer(reader);
27
76
 
28
- return new BlockTxsRequest(blockHash, txIndices);
77
+ return new BlockTxsRequest(archiveRoot, txHashes, txIndices);
29
78
  }
30
79
 
31
80
  /**
@@ -33,7 +82,7 @@ export class BlockTxsRequest {
33
82
  * @returns Buffer representation of the BlockTxRequest object
34
83
  */
35
84
  toBuffer(): Buffer {
36
- return serializeToBuffer([this.blockHash, this.txIndices.toBuffer()]);
85
+ return serializeToBuffer([this.archiveRoot, this.txHashes.toBuffer(), this.txIndices.toBuffer()]);
37
86
  }
38
87
  }
39
88
 
@@ -42,7 +91,7 @@ export class BlockTxsRequest {
42
91
  */
43
92
  export class BlockTxsResponse {
44
93
  constructor(
45
- readonly blockHash: Fr,
94
+ readonly archiveRoot: Fr,
46
95
  readonly txs: TxArray, // List of transactions we requested and peer has
47
96
  // BitVector indicating which txs from the proposal are available at the peer
48
97
  // 1 means the tx is available, 0 means it is not
@@ -56,11 +105,11 @@ export class BlockTxsResponse {
56
105
  */
57
106
  static fromBuffer(buffer: Buffer | BufferReader): BlockTxsResponse {
58
107
  const reader = BufferReader.asReader(buffer);
59
- const blockHash = Fr.fromBuffer(reader);
108
+ const archiveRoot = Fr.fromBuffer(reader);
60
109
  const txs = TxArray.fromBuffer(reader);
61
110
  const txIndices = BitVector.fromBuffer(reader);
62
111
 
63
- return new BlockTxsResponse(blockHash, txs, txIndices);
112
+ return new BlockTxsResponse(archiveRoot, txs, txIndices);
64
113
  }
65
114
 
66
115
  /**
@@ -70,10 +119,26 @@ export class BlockTxsResponse {
70
119
  * @returns Buffer representation of the BlockTxResponse object
71
120
  */
72
121
  toBuffer(): Buffer {
73
- return serializeToBuffer([this.blockHash, this.txs.toBuffer(), this.txIndices.toBuffer()]);
122
+ return serializeToBuffer([this.archiveRoot, this.txs.toBuffer(), this.txIndices.toBuffer()]);
74
123
  }
75
124
 
76
125
  static empty(): BlockTxsResponse {
77
126
  return new BlockTxsResponse(Fr.ZERO, new TxArray(), BitVector.init(0, []));
78
127
  }
79
128
  }
129
+
130
+ /**
131
+ * Calculate the expected response size for a BLOCK_TXS request.
132
+ * @param requestBuffer - The serialized request buffer containing BlockTxsRequest
133
+ * @returns Expected response size in KB
134
+ */
135
+ export function calculateBlockTxsResponseSize(requestBuffer: Buffer): number {
136
+ try {
137
+ const request = BlockTxsRequest.fromBuffer(requestBuffer);
138
+ const requestedTxCount = request.txIndices.getTrueIndices().length;
139
+ return requestedTxCount * MAX_TX_SIZE_KB + 1; // +1 KB overhead for serialization
140
+ } catch {
141
+ // If we can't parse the request, fall back to allowing a single transaction response
142
+ return MAX_TX_SIZE_KB + 1;
143
+ }
144
+ }
@@ -5,6 +5,5 @@ export * from './ping.js';
5
5
  export * from './status.js';
6
6
  export * from './tx.js';
7
7
  export * from './goodbye.js';
8
- export * from './block.js';
9
8
  export * from './auth.js';
10
9
  export * from './block_txs/index.js';
@@ -1,4 +1,5 @@
1
1
  import { chunk } from '@aztec/foundation/collection';
2
+ import { MAX_TX_SIZE_KB } from '@aztec/stdlib/p2p';
2
3
  import { TxArray, TxHash, TxHashArray } from '@aztec/stdlib/tx';
3
4
 
4
5
  import type { PeerId } from '@libp2p/interface';
@@ -50,8 +51,27 @@ export function reqRespTxHandler(mempools: MemPools): ReqRespSubProtocolHandler
50
51
  * Per: https://github.com/AztecProtocol/aztec-packages/issues/15149#issuecomment-2999054485
51
52
  * we define Q as max number of transactions per batch, the comment explains why we use 8.
52
53
  */
53
- //TODO: (mralj) chunk size should by default be 8, this is just temporary until the protocol is implemented correctly
54
- //more info: https://github.com/AztecProtocol/aztec-packages/pull/15516#pullrequestreview-2995474321
55
- export function chunkTxHashesRequest(hashes: TxHash[], chunkSize = 1): Array<TxHashArray> {
54
+ export function chunkTxHashesRequest(hashes: TxHash[], chunkSize = 8): Array<TxHashArray> {
56
55
  return chunk(hashes, chunkSize).map(chunk => new TxHashArray(...chunk));
57
56
  }
57
+
58
+ /**
59
+ * Calculate the expected response size for a TX request.
60
+ * @param requestBuffer - The serialized request buffer containing TxHashArray
61
+ * @returns Expected response size in KB
62
+ */
63
+ export function calculateTxResponseSize(requestBuffer: Buffer): number {
64
+ try {
65
+ const txHashes = TxHashArray.fromBuffer(requestBuffer);
66
+ // TxHashArray.fromBuffer returns empty array on parse failure, so check for that
67
+ if (txHashes.length === 0 && requestBuffer.length > 0) {
68
+ // If we got an empty array but had a non-empty buffer, parsing likely failed
69
+ // Fall back to allowing a single transaction response
70
+ return MAX_TX_SIZE_KB + 1;
71
+ }
72
+ return Math.max(txHashes.length, 1) * MAX_TX_SIZE_KB + 1; // +1 KB overhead, at least 1 tx
73
+ } catch {
74
+ // If we can't parse the request, fall back to allowing a single transaction response
75
+ return MAX_TX_SIZE_KB + 1;
76
+ }
77
+ }
@@ -97,9 +97,10 @@ export function prettyPrintRateLimitStatus(status: RateLimitStatus) {
97
97
  * 2. Individual rate limits for each peer.
98
98
  *
99
99
  * How it works:
100
- * - When a request comes in, it first checks against the global rate limit.
101
- * - If the global limit allows, it then checks against the specific peer's rate limit.
102
- * - The request is only allowed if both the global and peer-specific limits allow it.
100
+ * - When a request comes in, it first checks against the peer's individual rate limit.
101
+ * - If the peer limit allows, it then checks against the global rate limit.
102
+ * - The request is only allowed if both the peer-specific and global limits allow it.
103
+ * - Checking peer limit first ensures a rate-limited peer cannot exhaust the global quota.
103
104
  * - It automatically creates and manages rate limiters for new peers as they make requests.
104
105
  * - It periodically cleans up rate limiters for inactive peers to conserve memory.
105
106
  *
@@ -119,10 +120,6 @@ export class SubProtocolRateLimiter {
119
120
  }
120
121
 
121
122
  allow(peerId: PeerId): RateLimitStatus {
122
- if (!this.globalLimiter.allow()) {
123
- return RateLimitStatus.DeniedGlobal;
124
- }
125
-
126
123
  const peerIdStr = peerId.toString();
127
124
  let peerLimiter: PeerRateLimiter | undefined = this.peerLimiters.get(peerIdStr);
128
125
  if (!peerLimiter) {
@@ -135,10 +132,17 @@ export class SubProtocolRateLimiter {
135
132
  } else {
136
133
  peerLimiter.lastAccess = Date.now();
137
134
  }
138
- const peerLimitAllowed = peerLimiter.limiter.allow();
139
- if (!peerLimitAllowed) {
135
+
136
+ // Check peer limit first: a rate-limited peer must not consume global quota,
137
+ // otherwise one spamming peer can starve all others by exhausting the global bucket.
138
+ if (!peerLimiter.limiter.allow()) {
140
139
  return RateLimitStatus.DeniedPeer;
141
140
  }
141
+
142
+ if (!this.globalLimiter.allow()) {
143
+ return RateLimitStatus.DeniedGlobal;
144
+ }
145
+
142
146
  return RateLimitStatus.Allowed;
143
147
  }
144
148
 
@@ -42,16 +42,6 @@ export const DEFAULT_RATE_LIMITS: ReqRespSubProtocolRateLimits = {
42
42
  quotaCount: 200,
43
43
  },
44
44
  },
45
- [ReqRespSubProtocol.BLOCK]: {
46
- peerLimit: {
47
- quotaTimeMs: 1000,
48
- quotaCount: 2,
49
- },
50
- globalLimit: {
51
- quotaTimeMs: 1000,
52
- quotaCount: 5,
53
- },
54
- },
55
45
  [ReqRespSubProtocol.GOODBYE]: {
56
46
  peerLimit: {
57
47
  quotaTimeMs: 1000,