@aztec/p2p 0.0.1-commit.fce3e4f → 0.0.1-commit.fffb133c

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 (282) hide show
  1. package/dest/client/factory.d.ts +2 -2
  2. package/dest/client/factory.d.ts.map +1 -1
  3. package/dest/client/factory.js +2 -3
  4. package/dest/client/interface.d.ts +18 -5
  5. package/dest/client/interface.d.ts.map +1 -1
  6. package/dest/client/p2p_client.d.ts +16 -19
  7. package/dest/client/p2p_client.d.ts.map +1 -1
  8. package/dest/client/p2p_client.js +460 -127
  9. package/dest/config.d.ts +4 -7
  10. package/dest/config.d.ts.map +1 -1
  11. package/dest/config.js +10 -13
  12. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts +61 -42
  13. package/dest/mem_pools/attestation_pool/attestation_pool.d.ts.map +1 -1
  14. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts +1 -1
  15. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.d.ts.map +1 -1
  16. package/dest/mem_pools/attestation_pool/attestation_pool_test_suite.js +239 -265
  17. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts +21 -18
  18. package/dest/mem_pools/attestation_pool/kv_attestation_pool.d.ts.map +1 -1
  19. package/dest/mem_pools/attestation_pool/kv_attestation_pool.js +114 -109
  20. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts +17 -16
  21. package/dest/mem_pools/attestation_pool/memory_attestation_pool.d.ts.map +1 -1
  22. package/dest/mem_pools/attestation_pool/memory_attestation_pool.js +89 -128
  23. package/dest/mem_pools/attestation_pool/mocks.d.ts +11 -8
  24. package/dest/mem_pools/attestation_pool/mocks.d.ts.map +1 -1
  25. package/dest/mem_pools/attestation_pool/mocks.js +17 -13
  26. package/dest/mem_pools/instrumentation.d.ts +7 -1
  27. package/dest/mem_pools/instrumentation.d.ts.map +1 -1
  28. package/dest/mem_pools/instrumentation.js +30 -12
  29. package/dest/mem_pools/interface.d.ts +3 -4
  30. package/dest/mem_pools/interface.d.ts.map +1 -1
  31. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts +37 -27
  32. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.d.ts.map +1 -1
  33. package/dest/mem_pools/tx_pool/aztec_kv_tx_pool.js +314 -335
  34. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts +32 -0
  35. package/dest/mem_pools/tx_pool/eviction/eviction_manager.d.ts.map +1 -0
  36. package/dest/mem_pools/tx_pool/eviction/eviction_manager.js +112 -0
  37. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts +157 -0
  38. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.d.ts.map +1 -0
  39. package/dest/mem_pools/tx_pool/eviction/eviction_strategy.js +52 -0
  40. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts +16 -0
  41. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.d.ts.map +1 -0
  42. package/dest/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.js +122 -0
  43. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts +17 -0
  44. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.d.ts.map +1 -0
  45. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.js +84 -0
  46. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts +19 -0
  47. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.d.ts.map +1 -0
  48. package/dest/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.js +78 -0
  49. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts +26 -0
  50. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.d.ts.map +1 -0
  51. package/dest/mem_pools/tx_pool/eviction/low_priority_eviction_rule.js +84 -0
  52. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts +25 -0
  53. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.d.ts.map +1 -0
  54. package/dest/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.js +57 -0
  55. package/dest/mem_pools/tx_pool/index.d.ts +1 -2
  56. package/dest/mem_pools/tx_pool/index.d.ts.map +1 -1
  57. package/dest/mem_pools/tx_pool/index.js +0 -1
  58. package/dest/mem_pools/tx_pool/priority.d.ts +5 -1
  59. package/dest/mem_pools/tx_pool/priority.d.ts.map +1 -1
  60. package/dest/mem_pools/tx_pool/priority.js +6 -1
  61. package/dest/mem_pools/tx_pool/tx_pool.d.ts +11 -6
  62. package/dest/mem_pools/tx_pool/tx_pool.d.ts.map +1 -1
  63. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts +1 -1
  64. package/dest/mem_pools/tx_pool/tx_pool_test_suite.d.ts.map +1 -1
  65. package/dest/mem_pools/tx_pool/tx_pool_test_suite.js +30 -24
  66. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts +4 -4
  67. package/dest/msg_validators/attestation_validator/attestation_validator.d.ts.map +1 -1
  68. package/dest/msg_validators/attestation_validator/attestation_validator.js +52 -19
  69. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts +5 -5
  70. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.d.ts.map +1 -1
  71. package/dest/msg_validators/attestation_validator/fisherman_attestation_validator.js +18 -14
  72. package/dest/msg_validators/clock_tolerance.d.ts +21 -0
  73. package/dest/msg_validators/clock_tolerance.d.ts.map +1 -0
  74. package/dest/msg_validators/clock_tolerance.js +37 -0
  75. package/dest/msg_validators/index.d.ts +2 -2
  76. package/dest/msg_validators/index.d.ts.map +1 -1
  77. package/dest/msg_validators/index.js +1 -1
  78. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +9 -0
  79. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  80. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +6 -0
  81. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +9 -0
  82. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  83. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +6 -0
  84. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  85. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  86. package/dest/msg_validators/proposal_validator/index.js +3 -0
  87. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -0
  88. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  89. package/dest/msg_validators/proposal_validator/proposal_validator.js +104 -0
  90. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +23 -0
  91. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -0
  92. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +212 -0
  93. package/dest/msg_validators/tx_validator/archive_cache.d.ts +2 -2
  94. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  95. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +2 -2
  96. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  97. package/dest/msg_validators/tx_validator/block_header_validator.js +1 -1
  98. package/dest/msg_validators/tx_validator/data_validator.d.ts +1 -1
  99. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  100. package/dest/msg_validators/tx_validator/factory.d.ts +4 -3
  101. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  102. package/dest/msg_validators/tx_validator/factory.js +1 -1
  103. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  104. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  105. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  106. package/dest/msg_validators/tx_validator/gas_validator.d.ts +1 -1
  107. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  108. package/dest/msg_validators/tx_validator/gas_validator.js +8 -14
  109. package/dest/msg_validators/tx_validator/index.d.ts +2 -1
  110. package/dest/msg_validators/tx_validator/index.d.ts.map +1 -1
  111. package/dest/msg_validators/tx_validator/index.js +1 -0
  112. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +2 -2
  113. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  114. package/dest/msg_validators/tx_validator/size_validator.d.ts +6 -0
  115. package/dest/msg_validators/tx_validator/size_validator.d.ts.map +1 -0
  116. package/dest/msg_validators/tx_validator/size_validator.js +20 -0
  117. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  118. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  119. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +3 -2
  120. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  121. package/dest/services/dummy_service.d.ts +6 -2
  122. package/dest/services/dummy_service.d.ts.map +1 -1
  123. package/dest/services/dummy_service.js +3 -0
  124. package/dest/services/encoding.d.ts +1 -1
  125. package/dest/services/encoding.d.ts.map +1 -1
  126. package/dest/services/encoding.js +7 -6
  127. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  128. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  129. package/dest/services/libp2p/instrumentation.js +20 -73
  130. package/dest/services/libp2p/libp2p_service.d.ts +31 -14
  131. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  132. package/dest/services/libp2p/libp2p_service.js +722 -168
  133. package/dest/services/peer-manager/metrics.d.ts +6 -1
  134. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  135. package/dest/services/peer-manager/metrics.js +18 -21
  136. package/dest/services/peer-manager/peer_manager.d.ts +2 -2
  137. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  138. package/dest/services/peer-manager/peer_manager.js +4 -12
  139. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  140. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  141. package/dest/services/peer-manager/peer_scoring.js +2 -5
  142. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +1 -1
  143. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  144. package/dest/services/reqresp/constants.d.ts +12 -0
  145. package/dest/services/reqresp/constants.d.ts.map +1 -0
  146. package/dest/services/reqresp/constants.js +7 -0
  147. package/dest/services/reqresp/interface.d.ts +2 -2
  148. package/dest/services/reqresp/interface.d.ts.map +1 -1
  149. package/dest/services/reqresp/interface.js +1 -1
  150. package/dest/services/reqresp/metrics.d.ts +1 -1
  151. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  152. package/dest/services/reqresp/metrics.js +5 -21
  153. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  154. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  155. package/dest/services/reqresp/protocols/auth.js +2 -2
  156. package/dest/services/reqresp/protocols/block.d.ts +1 -1
  157. package/dest/services/reqresp/protocols/block.d.ts.map +1 -1
  158. package/dest/services/reqresp/protocols/block.js +3 -2
  159. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +1 -1
  160. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  161. package/dest/services/reqresp/protocols/block_txs/bitvector.js +7 -0
  162. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +2 -2
  163. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  164. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +1 -1
  165. package/dest/services/reqresp/protocols/status.d.ts +5 -4
  166. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  167. package/dest/services/reqresp/protocols/status.js +7 -3
  168. package/dest/services/reqresp/protocols/tx.d.ts +2 -3
  169. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  170. package/dest/services/reqresp/reqresp.js +402 -24
  171. package/dest/services/service.d.ts +16 -3
  172. package/dest/services/service.d.ts.map +1 -1
  173. package/dest/services/tx_collection/config.js +1 -1
  174. package/dest/services/tx_collection/fast_tx_collection.d.ts +4 -3
  175. package/dest/services/tx_collection/fast_tx_collection.d.ts.map +1 -1
  176. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  177. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  178. package/dest/services/tx_collection/instrumentation.js +4 -14
  179. package/dest/services/tx_collection/slow_tx_collection.d.ts +4 -3
  180. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  181. package/dest/services/tx_collection/tx_collection.d.ts +7 -6
  182. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  183. package/dest/services/tx_provider.d.ts +4 -2
  184. package/dest/services/tx_provider.d.ts.map +1 -1
  185. package/dest/services/tx_provider.js +11 -2
  186. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  187. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  188. package/dest/services/tx_provider_instrumentation.js +13 -13
  189. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  190. package/dest/test-helpers/reqresp-nodes.d.ts +2 -2
  191. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  192. package/dest/testbench/p2p_client_testbench_worker.js +31 -17
  193. package/dest/testbench/worker_client_manager.d.ts +1 -1
  194. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  195. package/dest/testbench/worker_client_manager.js +6 -1
  196. package/package.json +18 -18
  197. package/src/client/factory.ts +5 -10
  198. package/src/client/interface.ts +19 -4
  199. package/src/client/p2p_client.ts +101 -154
  200. package/src/config.ts +12 -18
  201. package/src/mem_pools/attestation_pool/attestation_pool.ts +68 -41
  202. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +241 -289
  203. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +163 -141
  204. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +141 -164
  205. package/src/mem_pools/attestation_pool/mocks.ts +21 -15
  206. package/src/mem_pools/instrumentation.ts +38 -14
  207. package/src/mem_pools/interface.ts +2 -4
  208. package/src/mem_pools/tx_pool/README.md +270 -0
  209. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +367 -371
  210. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +132 -0
  211. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +208 -0
  212. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +162 -0
  213. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  214. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +93 -0
  215. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  216. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  217. package/src/mem_pools/tx_pool/index.ts +0 -1
  218. package/src/mem_pools/tx_pool/priority.ts +8 -1
  219. package/src/mem_pools/tx_pool/tx_pool.ts +11 -5
  220. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +23 -17
  221. package/src/msg_validators/attestation_validator/attestation_validator.ts +37 -22
  222. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +13 -16
  223. package/src/msg_validators/clock_tolerance.ts +51 -0
  224. package/src/msg_validators/index.ts +1 -1
  225. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +10 -0
  226. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +13 -0
  227. package/src/msg_validators/proposal_validator/index.ts +3 -0
  228. package/src/msg_validators/proposal_validator/proposal_validator.ts +92 -0
  229. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +230 -0
  230. package/src/msg_validators/tx_validator/archive_cache.ts +1 -1
  231. package/src/msg_validators/tx_validator/block_header_validator.ts +4 -2
  232. package/src/msg_validators/tx_validator/data_validator.ts +12 -4
  233. package/src/msg_validators/tx_validator/factory.ts +3 -2
  234. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  235. package/src/msg_validators/tx_validator/gas_validator.ts +8 -25
  236. package/src/msg_validators/tx_validator/index.ts +1 -0
  237. package/src/msg_validators/tx_validator/metadata_validator.ts +13 -5
  238. package/src/msg_validators/tx_validator/size_validator.ts +18 -0
  239. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  240. package/src/msg_validators/tx_validator/timestamp_validator.ts +5 -2
  241. package/src/services/dummy_service.ts +6 -0
  242. package/src/services/encoding.ts +6 -5
  243. package/src/services/libp2p/instrumentation.ts +19 -73
  244. package/src/services/libp2p/libp2p_service.ts +369 -138
  245. package/src/services/peer-manager/metrics.ts +22 -21
  246. package/src/services/peer-manager/peer_manager.ts +5 -4
  247. package/src/services/peer-manager/peer_scoring.ts +1 -5
  248. package/src/services/reqresp/connection-sampler/connection_sampler.ts +3 -1
  249. package/src/services/reqresp/constants.ts +14 -0
  250. package/src/services/reqresp/interface.ts +1 -1
  251. package/src/services/reqresp/metrics.ts +7 -23
  252. package/src/services/reqresp/protocols/auth.ts +2 -2
  253. package/src/services/reqresp/protocols/block.ts +3 -2
  254. package/src/services/reqresp/protocols/block_txs/bitvector.ts +9 -0
  255. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +1 -1
  256. package/src/services/reqresp/protocols/status.ts +16 -12
  257. package/src/services/reqresp/protocols/tx.ts +1 -2
  258. package/src/services/service.ts +19 -4
  259. package/src/services/tx_collection/config.ts +1 -1
  260. package/src/services/tx_collection/fast_tx_collection.ts +3 -2
  261. package/src/services/tx_collection/instrumentation.ts +4 -21
  262. package/src/services/tx_collection/slow_tx_collection.ts +3 -3
  263. package/src/services/tx_collection/tx_collection.ts +6 -5
  264. package/src/services/tx_provider.ts +19 -3
  265. package/src/services/tx_provider_instrumentation.ts +18 -14
  266. package/src/test-helpers/mock-pubsub.ts +1 -1
  267. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  268. package/src/test-helpers/reqresp-nodes.ts +1 -1
  269. package/src/testbench/p2p_client_testbench_worker.ts +42 -22
  270. package/src/testbench/worker_client_manager.ts +6 -1
  271. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -80
  272. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  273. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -238
  274. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  275. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  276. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.js +0 -82
  277. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  278. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  279. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  280. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -283
  281. package/src/msg_validators/block_proposal_validator/block_proposal_validator.ts +0 -97
  282. package/src/msg_validators/block_proposal_validator/index.ts +0 -1
@@ -1,23 +1,390 @@
1
- function _ts_decorate(decorators, target, key, desc) {
2
- var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;
3
- if (typeof Reflect === "object" && typeof Reflect.decorate === "function") r = Reflect.decorate(decorators, target, key, desc);
4
- else for(var i = decorators.length - 1; i >= 0; i--)if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;
5
- return c > 3 && r && Object.defineProperty(target, key, r), r;
1
+ function applyDecs2203RFactory() {
2
+ function createAddInitializerMethod(initializers, decoratorFinishedRef) {
3
+ return function addInitializer(initializer) {
4
+ assertNotFinished(decoratorFinishedRef, "addInitializer");
5
+ assertCallable(initializer, "An initializer");
6
+ initializers.push(initializer);
7
+ };
8
+ }
9
+ function memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value) {
10
+ var kindStr;
11
+ switch(kind){
12
+ case 1:
13
+ kindStr = "accessor";
14
+ break;
15
+ case 2:
16
+ kindStr = "method";
17
+ break;
18
+ case 3:
19
+ kindStr = "getter";
20
+ break;
21
+ case 4:
22
+ kindStr = "setter";
23
+ break;
24
+ default:
25
+ kindStr = "field";
26
+ }
27
+ var ctx = {
28
+ kind: kindStr,
29
+ name: isPrivate ? "#" + name : name,
30
+ static: isStatic,
31
+ private: isPrivate,
32
+ metadata: metadata
33
+ };
34
+ var decoratorFinishedRef = {
35
+ v: false
36
+ };
37
+ ctx.addInitializer = createAddInitializerMethod(initializers, decoratorFinishedRef);
38
+ var get, set;
39
+ if (kind === 0) {
40
+ if (isPrivate) {
41
+ get = desc.get;
42
+ set = desc.set;
43
+ } else {
44
+ get = function() {
45
+ return this[name];
46
+ };
47
+ set = function(v) {
48
+ this[name] = v;
49
+ };
50
+ }
51
+ } else if (kind === 2) {
52
+ get = function() {
53
+ return desc.value;
54
+ };
55
+ } else {
56
+ if (kind === 1 || kind === 3) {
57
+ get = function() {
58
+ return desc.get.call(this);
59
+ };
60
+ }
61
+ if (kind === 1 || kind === 4) {
62
+ set = function(v) {
63
+ desc.set.call(this, v);
64
+ };
65
+ }
66
+ }
67
+ ctx.access = get && set ? {
68
+ get: get,
69
+ set: set
70
+ } : get ? {
71
+ get: get
72
+ } : {
73
+ set: set
74
+ };
75
+ try {
76
+ return dec(value, ctx);
77
+ } finally{
78
+ decoratorFinishedRef.v = true;
79
+ }
80
+ }
81
+ function assertNotFinished(decoratorFinishedRef, fnName) {
82
+ if (decoratorFinishedRef.v) {
83
+ throw new Error("attempted to call " + fnName + " after decoration was finished");
84
+ }
85
+ }
86
+ function assertCallable(fn, hint) {
87
+ if (typeof fn !== "function") {
88
+ throw new TypeError(hint + " must be a function");
89
+ }
90
+ }
91
+ function assertValidReturnValue(kind, value) {
92
+ var type = typeof value;
93
+ if (kind === 1) {
94
+ if (type !== "object" || value === null) {
95
+ throw new TypeError("accessor decorators must return an object with get, set, or init properties or void 0");
96
+ }
97
+ if (value.get !== undefined) {
98
+ assertCallable(value.get, "accessor.get");
99
+ }
100
+ if (value.set !== undefined) {
101
+ assertCallable(value.set, "accessor.set");
102
+ }
103
+ if (value.init !== undefined) {
104
+ assertCallable(value.init, "accessor.init");
105
+ }
106
+ } else if (type !== "function") {
107
+ var hint;
108
+ if (kind === 0) {
109
+ hint = "field";
110
+ } else if (kind === 10) {
111
+ hint = "class";
112
+ } else {
113
+ hint = "method";
114
+ }
115
+ throw new TypeError(hint + " decorators must return a function or void 0");
116
+ }
117
+ }
118
+ function applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata) {
119
+ var decs = decInfo[0];
120
+ var desc, init, value;
121
+ if (isPrivate) {
122
+ if (kind === 0 || kind === 1) {
123
+ desc = {
124
+ get: decInfo[3],
125
+ set: decInfo[4]
126
+ };
127
+ } else if (kind === 3) {
128
+ desc = {
129
+ get: decInfo[3]
130
+ };
131
+ } else if (kind === 4) {
132
+ desc = {
133
+ set: decInfo[3]
134
+ };
135
+ } else {
136
+ desc = {
137
+ value: decInfo[3]
138
+ };
139
+ }
140
+ } else if (kind !== 0) {
141
+ desc = Object.getOwnPropertyDescriptor(base, name);
142
+ }
143
+ if (kind === 1) {
144
+ value = {
145
+ get: desc.get,
146
+ set: desc.set
147
+ };
148
+ } else if (kind === 2) {
149
+ value = desc.value;
150
+ } else if (kind === 3) {
151
+ value = desc.get;
152
+ } else if (kind === 4) {
153
+ value = desc.set;
154
+ }
155
+ var newValue, get, set;
156
+ if (typeof decs === "function") {
157
+ newValue = memberDec(decs, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
158
+ if (newValue !== void 0) {
159
+ assertValidReturnValue(kind, newValue);
160
+ if (kind === 0) {
161
+ init = newValue;
162
+ } else if (kind === 1) {
163
+ init = newValue.init;
164
+ get = newValue.get || value.get;
165
+ set = newValue.set || value.set;
166
+ value = {
167
+ get: get,
168
+ set: set
169
+ };
170
+ } else {
171
+ value = newValue;
172
+ }
173
+ }
174
+ } else {
175
+ for(var i = decs.length - 1; i >= 0; i--){
176
+ var dec = decs[i];
177
+ newValue = memberDec(dec, name, desc, initializers, kind, isStatic, isPrivate, metadata, value);
178
+ if (newValue !== void 0) {
179
+ assertValidReturnValue(kind, newValue);
180
+ var newInit;
181
+ if (kind === 0) {
182
+ newInit = newValue;
183
+ } else if (kind === 1) {
184
+ newInit = newValue.init;
185
+ get = newValue.get || value.get;
186
+ set = newValue.set || value.set;
187
+ value = {
188
+ get: get,
189
+ set: set
190
+ };
191
+ } else {
192
+ value = newValue;
193
+ }
194
+ if (newInit !== void 0) {
195
+ if (init === void 0) {
196
+ init = newInit;
197
+ } else if (typeof init === "function") {
198
+ init = [
199
+ init,
200
+ newInit
201
+ ];
202
+ } else {
203
+ init.push(newInit);
204
+ }
205
+ }
206
+ }
207
+ }
208
+ }
209
+ if (kind === 0 || kind === 1) {
210
+ if (init === void 0) {
211
+ init = function(instance, init) {
212
+ return init;
213
+ };
214
+ } else if (typeof init !== "function") {
215
+ var ownInitializers = init;
216
+ init = function(instance, init) {
217
+ var value = init;
218
+ for(var i = 0; i < ownInitializers.length; i++){
219
+ value = ownInitializers[i].call(instance, value);
220
+ }
221
+ return value;
222
+ };
223
+ } else {
224
+ var originalInitializer = init;
225
+ init = function(instance, init) {
226
+ return originalInitializer.call(instance, init);
227
+ };
228
+ }
229
+ ret.push(init);
230
+ }
231
+ if (kind !== 0) {
232
+ if (kind === 1) {
233
+ desc.get = value.get;
234
+ desc.set = value.set;
235
+ } else if (kind === 2) {
236
+ desc.value = value;
237
+ } else if (kind === 3) {
238
+ desc.get = value;
239
+ } else if (kind === 4) {
240
+ desc.set = value;
241
+ }
242
+ if (isPrivate) {
243
+ if (kind === 1) {
244
+ ret.push(function(instance, args) {
245
+ return value.get.call(instance, args);
246
+ });
247
+ ret.push(function(instance, args) {
248
+ return value.set.call(instance, args);
249
+ });
250
+ } else if (kind === 2) {
251
+ ret.push(value);
252
+ } else {
253
+ ret.push(function(instance, args) {
254
+ return value.call(instance, args);
255
+ });
256
+ }
257
+ } else {
258
+ Object.defineProperty(base, name, desc);
259
+ }
260
+ }
261
+ }
262
+ function applyMemberDecs(Class, decInfos, metadata) {
263
+ var ret = [];
264
+ var protoInitializers;
265
+ var staticInitializers;
266
+ var existingProtoNonFields = new Map();
267
+ var existingStaticNonFields = new Map();
268
+ for(var i = 0; i < decInfos.length; i++){
269
+ var decInfo = decInfos[i];
270
+ if (!Array.isArray(decInfo)) continue;
271
+ var kind = decInfo[1];
272
+ var name = decInfo[2];
273
+ var isPrivate = decInfo.length > 3;
274
+ var isStatic = kind >= 5;
275
+ var base;
276
+ var initializers;
277
+ if (isStatic) {
278
+ base = Class;
279
+ kind = kind - 5;
280
+ staticInitializers = staticInitializers || [];
281
+ initializers = staticInitializers;
282
+ } else {
283
+ base = Class.prototype;
284
+ protoInitializers = protoInitializers || [];
285
+ initializers = protoInitializers;
286
+ }
287
+ if (kind !== 0 && !isPrivate) {
288
+ var existingNonFields = isStatic ? existingStaticNonFields : existingProtoNonFields;
289
+ var existingKind = existingNonFields.get(name) || 0;
290
+ if (existingKind === true || existingKind === 3 && kind !== 4 || existingKind === 4 && kind !== 3) {
291
+ throw new Error("Attempted to decorate a public method/accessor that has the same name as a previously decorated public method/accessor. This is not currently supported by the decorators plugin. Property name was: " + name);
292
+ } else if (!existingKind && kind > 2) {
293
+ existingNonFields.set(name, kind);
294
+ } else {
295
+ existingNonFields.set(name, true);
296
+ }
297
+ }
298
+ applyMemberDec(ret, base, decInfo, name, kind, isStatic, isPrivate, initializers, metadata);
299
+ }
300
+ pushInitializers(ret, protoInitializers);
301
+ pushInitializers(ret, staticInitializers);
302
+ return ret;
303
+ }
304
+ function pushInitializers(ret, initializers) {
305
+ if (initializers) {
306
+ ret.push(function(instance) {
307
+ for(var i = 0; i < initializers.length; i++){
308
+ initializers[i].call(instance);
309
+ }
310
+ return instance;
311
+ });
312
+ }
313
+ }
314
+ function applyClassDecs(targetClass, classDecs, metadata) {
315
+ if (classDecs.length > 0) {
316
+ var initializers = [];
317
+ var newClass = targetClass;
318
+ var name = targetClass.name;
319
+ for(var i = classDecs.length - 1; i >= 0; i--){
320
+ var decoratorFinishedRef = {
321
+ v: false
322
+ };
323
+ try {
324
+ var nextNewClass = classDecs[i](newClass, {
325
+ kind: "class",
326
+ name: name,
327
+ addInitializer: createAddInitializerMethod(initializers, decoratorFinishedRef),
328
+ metadata
329
+ });
330
+ } finally{
331
+ decoratorFinishedRef.v = true;
332
+ }
333
+ if (nextNewClass !== undefined) {
334
+ assertValidReturnValue(10, nextNewClass);
335
+ newClass = nextNewClass;
336
+ }
337
+ }
338
+ return [
339
+ defineMetadata(newClass, metadata),
340
+ function() {
341
+ for(var i = 0; i < initializers.length; i++){
342
+ initializers[i].call(newClass);
343
+ }
344
+ }
345
+ ];
346
+ }
347
+ }
348
+ function defineMetadata(Class, metadata) {
349
+ return Object.defineProperty(Class, Symbol.metadata || Symbol.for("Symbol.metadata"), {
350
+ configurable: true,
351
+ enumerable: true,
352
+ value: metadata
353
+ });
354
+ }
355
+ return function applyDecs2203R(targetClass, memberDecs, classDecs, parentClass) {
356
+ if (parentClass !== void 0) {
357
+ var parentMetadata = parentClass[Symbol.metadata || Symbol.for("Symbol.metadata")];
358
+ }
359
+ var metadata = Object.create(parentMetadata === void 0 ? null : parentMetadata);
360
+ var e = applyMemberDecs(targetClass, memberDecs, metadata);
361
+ if (!classDecs.length) defineMetadata(targetClass, metadata);
362
+ return {
363
+ e: e,
364
+ get c () {
365
+ return applyClassDecs(targetClass, classDecs, metadata);
366
+ }
367
+ };
368
+ };
6
369
  }
7
- import { SlotNumber } from '@aztec/foundation/branded-types';
8
- import { randomInt } from '@aztec/foundation/crypto';
9
- import { Fr } from '@aztec/foundation/fields';
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
372
+ }
373
+ var _dec, _dec1, _dec2, _dec3, _dec4, _dec5, _dec6, _dec7, _dec8, _initProto;
374
+ import { BlockNumber } from '@aztec/foundation/branded-types';
375
+ import { randomInt } from '@aztec/foundation/crypto/random';
376
+ import { Fr } from '@aztec/foundation/curves/bn254';
10
377
  import { createLibp2pComponentLogger, createLogger } from '@aztec/foundation/log';
11
378
  import { RunningPromise } from '@aztec/foundation/running-promise';
12
379
  import { Timer } from '@aztec/foundation/timer';
13
380
  import { getVKTreeRoot } from '@aztec/noir-protocol-circuits-types/vk-tree';
14
381
  import { protocolContractsHash } from '@aztec/protocol-contracts';
15
382
  import { GasFees } from '@aztec/stdlib/gas';
16
- import { BlockAttestation, BlockProposal, P2PClientType, P2PMessage, PeerErrorSeverity, TopicType, createTopicString, getTopicsForClientAndConfig, metricsTopicStrToLabels } from '@aztec/stdlib/p2p';
383
+ import { BlockProposal, CheckpointAttestation, CheckpointProposal, P2PClientType, P2PMessage, PeerErrorSeverity, TopicType, createTopicString, getTopicsForClientAndConfig, metricsTopicStrToLabels } from '@aztec/stdlib/p2p';
17
384
  import { MerkleTreeId } from '@aztec/stdlib/trees';
18
385
  import { Tx } from '@aztec/stdlib/tx';
19
386
  import { compressComponentVersions } from '@aztec/stdlib/versioning';
20
- import { Attributes, OtelMetricsAdapter, WithTracer, trackSpan } from '@aztec/telemetry-client';
387
+ import { Attributes, OtelMetricsAdapter, SpanStatusCode, WithTracer, trackSpan } from '@aztec/telemetry-client';
21
388
  import { gossipsub } from '@chainsafe/libp2p-gossipsub';
22
389
  import { createPeerScoreParams, createTopicScoreParams } from '@chainsafe/libp2p-gossipsub/score';
23
390
  import { SignaturePolicy } from '@chainsafe/libp2p-gossipsub/types';
@@ -31,7 +398,7 @@ import { tcp } from '@libp2p/tcp';
31
398
  import { ENR } from '@nethermindeth/enr';
32
399
  import { createLibp2p } from 'libp2p';
33
400
  import { ProposalSlotCapExceededError } from '../../errors/attestation-pool.error.js';
34
- import { AttestationValidator, BlockProposalValidator, FishermanAttestationValidator } from '../../msg_validators/index.js';
401
+ import { BlockProposalValidator, CheckpointAttestationValidator, CheckpointProposalValidator, FishermanAttestationValidator, SizeTxValidator } from '../../msg_validators/index.js';
35
402
  import { MessageSeenValidator } from '../../msg_validators/msg_seen_validator/msg_seen_validator.js';
36
403
  import { getDefaultAllowedSetupFunctions } from '../../msg_validators/tx_validator/allowed_public_setup.js';
37
404
  import { createTxMessageValidators } from '../../msg_validators/tx_validator/factory.js';
@@ -51,6 +418,31 @@ import { reqGoodbyeHandler } from '../reqresp/protocols/goodbye.js';
51
418
  import { pingHandler, reqRespBlockHandler, reqRespStatusHandler, reqRespTxHandler } from '../reqresp/protocols/index.js';
52
419
  import { ReqResp } from '../reqresp/reqresp.js';
53
420
  import { P2PInstrumentation } from './instrumentation.js';
421
+ _dec = trackSpan('Libp2pService.processValidBlockProposal', async (block)=>({
422
+ [Attributes.SLOT_NUMBER]: block.slotNumber,
423
+ [Attributes.BLOCK_ARCHIVE]: block.archive.toString(),
424
+ [Attributes.P2P_ID]: await block.p2pMessageLoggingIdentifier().then((i)=>i.toString())
425
+ })), _dec1 = trackSpan('Libp2pService.processValidCheckpointProposal', async (checkpoint)=>({
426
+ [Attributes.SLOT_NUMBER]: checkpoint.slotNumber,
427
+ [Attributes.BLOCK_ARCHIVE]: checkpoint.archive.toString(),
428
+ [Attributes.P2P_ID]: await checkpoint.p2pMessageLoggingIdentifier().then((i)=>i.toString())
429
+ })), _dec2 = trackSpan('Libp2pService.validateRequestedBlockTxs', (request)=>({
430
+ [Attributes.BLOCK_HASH]: request.blockHash.toString()
431
+ })), _dec3 = trackSpan('Libp2pService.validateRequestedTx', (requestedTxHash, _responseTx)=>({
432
+ [Attributes.TX_HASH]: requestedTxHash.toString()
433
+ })), _dec4 = trackSpan('Libp2pService.validateRequestedBlock', (requestedBlockNumber, _responseBlock)=>({
434
+ [Attributes.BLOCK_NUMBER]: requestedBlockNumber.toString()
435
+ })), _dec5 = trackSpan('Libp2pService.validatePropagatedTx', (tx)=>({
436
+ [Attributes.TX_HASH]: tx.getTxHash().toString()
437
+ })), _dec6 = trackSpan('Libp2pService.validateCheckpointAttestation', async (_, attestation)=>({
438
+ [Attributes.SLOT_NUMBER]: attestation.payload.header.slotNumber,
439
+ [Attributes.BLOCK_ARCHIVE]: attestation.archive.toString(),
440
+ [Attributes.P2P_ID]: await attestation.p2pMessageLoggingIdentifier().then((i)=>i.toString())
441
+ })), _dec7 = trackSpan('Libp2pService.validateBlockProposal', (_peerId, block)=>({
442
+ [Attributes.SLOT_NUMBER]: block.slotNumber.toString()
443
+ })), _dec8 = trackSpan('Libp2pService.validateCheckpointProposal', (_peerId, checkpoint)=>({
444
+ [Attributes.SLOT_NUMBER]: checkpoint.slotNumber.toString()
445
+ }));
54
446
  /**
55
447
  * Lib P2P implementation of the P2PService interface.
56
448
  */ export class LibP2PService extends WithTracer {
@@ -65,11 +457,61 @@ import { P2PInstrumentation } from './instrumentation.js';
65
457
  epochCache;
66
458
  proofVerifier;
67
459
  worldStateSynchronizer;
460
+ static{
461
+ ({ e: [_initProto] } = _apply_decs_2203_r(this, [
462
+ [
463
+ _dec,
464
+ 2,
465
+ "processValidBlockProposal"
466
+ ],
467
+ [
468
+ _dec1,
469
+ 2,
470
+ "processValidCheckpointProposal"
471
+ ],
472
+ [
473
+ _dec2,
474
+ 2,
475
+ "validateRequestedBlockTxs"
476
+ ],
477
+ [
478
+ _dec3,
479
+ 2,
480
+ "validateRequestedTxs"
481
+ ],
482
+ [
483
+ _dec4,
484
+ 2,
485
+ "validateRequestedBlock"
486
+ ],
487
+ [
488
+ _dec5,
489
+ 2,
490
+ "validatePropagatedTx"
491
+ ],
492
+ [
493
+ _dec6,
494
+ 2,
495
+ "validateCheckpointAttestation"
496
+ ],
497
+ [
498
+ _dec7,
499
+ 2,
500
+ "validateBlockProposal"
501
+ ],
502
+ [
503
+ _dec8,
504
+ 2,
505
+ "validateCheckpointProposal"
506
+ ]
507
+ ], []));
508
+ }
68
509
  discoveryRunningPromise;
69
510
  msgIdSeenValidators;
70
511
  // Message validators
71
- attestationValidator;
72
512
  blockProposalValidator;
513
+ checkpointProposalValidator;
514
+ checkpointAttestationValidator;
73
515
  protocolVersion;
74
516
  topicStrings;
75
517
  feesCache;
@@ -78,34 +520,49 @@ import { P2PInstrumentation } from './instrumentation.js';
78
520
  * @param block - The block received from the peer.
79
521
  * @returns The attestation for the block, if any.
80
522
  */ blockReceivedCallback;
523
+ /**
524
+ * Callback for when a checkpoint proposal is received from a peer.
525
+ * @param checkpoint - The checkpoint proposal received from the peer.
526
+ * @returns The attestations for the checkpoint, if any.
527
+ */ checkpointReceivedCallback;
81
528
  gossipSubEventHandler;
82
529
  instrumentation;
530
+ telemetry;
83
531
  logger;
84
532
  constructor(clientType, config, node, peerDiscoveryService, reqresp, peerManager, mempools, archiver, epochCache, proofVerifier, worldStateSynchronizer, telemetry, logger = createLogger('p2p:libp2p_service')){
85
- super(telemetry, 'LibP2PService'), this.clientType = clientType, this.config = config, this.node = node, this.peerDiscoveryService = peerDiscoveryService, this.reqresp = reqresp, this.peerManager = peerManager, this.mempools = mempools, this.archiver = archiver, this.epochCache = epochCache, this.proofVerifier = proofVerifier, this.worldStateSynchronizer = worldStateSynchronizer, this.msgIdSeenValidators = {}, this.protocolVersion = '', this.topicStrings = {};
533
+ super(telemetry, 'LibP2PService'), this.clientType = clientType, this.config = config, this.node = node, this.peerDiscoveryService = peerDiscoveryService, this.reqresp = reqresp, this.peerManager = peerManager, this.mempools = mempools, this.archiver = archiver, this.epochCache = epochCache, this.proofVerifier = proofVerifier, this.worldStateSynchronizer = worldStateSynchronizer, this.msgIdSeenValidators = (_initProto(this), {}), this.protocolVersion = '', this.topicStrings = {};
534
+ this.telemetry = telemetry;
86
535
  // Create child logger with fisherman prefix if in fisherman mode
87
536
  this.logger = config.fishermanMode ? logger.createChild('[FISHERMAN]') : logger;
88
537
  this.instrumentation = new P2PInstrumentation(telemetry, 'LibP2PService');
89
538
  this.msgIdSeenValidators[TopicType.tx] = new MessageSeenValidator(config.seenMessageCacheSize);
90
539
  this.msgIdSeenValidators[TopicType.block_proposal] = new MessageSeenValidator(config.seenMessageCacheSize);
91
- this.msgIdSeenValidators[TopicType.block_attestation] = new MessageSeenValidator(config.seenMessageCacheSize);
540
+ this.msgIdSeenValidators[TopicType.checkpoint_proposal] = new MessageSeenValidator(config.seenMessageCacheSize);
541
+ this.msgIdSeenValidators[TopicType.checkpoint_attestation] = new MessageSeenValidator(config.seenMessageCacheSize);
92
542
  const versions = getVersions(config);
93
543
  this.protocolVersion = compressComponentVersions(versions);
94
544
  logger.info(`Started libp2p service with protocol version ${this.protocolVersion}`);
95
545
  this.topicStrings[TopicType.tx] = createTopicString(TopicType.tx, this.protocolVersion);
96
546
  this.topicStrings[TopicType.block_proposal] = createTopicString(TopicType.block_proposal, this.protocolVersion);
97
- this.topicStrings[TopicType.block_attestation] = createTopicString(TopicType.block_attestation, this.protocolVersion);
98
- // Use FishermanAttestationValidator in fisherman mode to validate attestation payloads against proposals
99
- this.attestationValidator = config.fishermanMode ? new FishermanAttestationValidator(epochCache, mempools.attestationPool, telemetry) : new AttestationValidator(epochCache);
547
+ this.topicStrings[TopicType.checkpoint_proposal] = createTopicString(TopicType.checkpoint_proposal, this.protocolVersion);
548
+ this.topicStrings[TopicType.checkpoint_attestation] = createTopicString(TopicType.checkpoint_attestation, this.protocolVersion);
100
549
  this.blockProposalValidator = new BlockProposalValidator(epochCache, {
101
550
  txsPermitted: !config.disableTransactions
102
551
  });
552
+ this.checkpointProposalValidator = new CheckpointProposalValidator(epochCache, {
553
+ txsPermitted: !config.disableTransactions
554
+ });
555
+ this.checkpointAttestationValidator = config.fishermanMode ? new FishermanAttestationValidator(epochCache, mempools.attestationPool, telemetry) : new CheckpointAttestationValidator(epochCache);
103
556
  this.gossipSubEventHandler = this.handleGossipSubEvent.bind(this);
104
557
  this.blockReceivedCallback = async (block)=>{
105
558
  this.logger.debug(`Handler not yet registered: Block received callback not set. Received block for slot ${block.slotNumber} from peer.`, {
106
559
  p2pMessageIdentifier: await block.p2pMessageLoggingIdentifier()
107
560
  });
108
- return undefined;
561
+ return false;
562
+ };
563
+ this.checkpointReceivedCallback = (checkpoint)=>{
564
+ this.logger.debug(`Handler not yet registered: Checkpoint received callback not set. Received checkpoint for slot ${checkpoint.slotNumber} from peer.`);
565
+ return Promise.resolve(undefined);
109
566
  };
110
567
  }
111
568
  updateConfig(config) {
@@ -138,7 +595,8 @@ import { P2PInstrumentation } from './instrumentation.js';
138
595
  const protocolVersion = compressComponentVersions(versions);
139
596
  const txTopic = createTopicString(TopicType.tx, protocolVersion);
140
597
  const blockProposalTopic = createTopicString(TopicType.block_proposal, protocolVersion);
141
- const blockAttestationTopic = createTopicString(TopicType.block_attestation, protocolVersion);
598
+ const checkpointProposalTopic = createTopicString(TopicType.checkpoint_proposal, protocolVersion);
599
+ const checkpointAttestationTopic = createTopicString(TopicType.checkpoint_attestation, protocolVersion);
142
600
  const preferredPeersEnrs = config.preferredPeers.map((enr)=>ENR.decodeTxt(enr));
143
601
  const directPeers = (await Promise.all(preferredPeersEnrs.map(async (enr)=>{
144
602
  const peerId = await enr.peerId();
@@ -262,12 +720,17 @@ import { P2PInstrumentation } from './instrumentation.js';
262
720
  invalidMessageDeliveriesWeight: -20,
263
721
  invalidMessageDeliveriesDecay: 0.5
264
722
  }),
265
- [blockAttestationTopic]: createTopicScoreParams({
723
+ [blockProposalTopic]: createTopicScoreParams({
724
+ topicWeight: 1,
725
+ invalidMessageDeliveriesWeight: -20,
726
+ invalidMessageDeliveriesDecay: 0.5
727
+ }),
728
+ [checkpointProposalTopic]: createTopicScoreParams({
266
729
  topicWeight: 1,
267
730
  invalidMessageDeliveriesWeight: -20,
268
731
  invalidMessageDeliveriesDecay: 0.5
269
732
  }),
270
- [blockProposalTopic]: createTopicScoreParams({
733
+ [checkpointAttestationTopic]: createTopicScoreParams({
271
734
  topicWeight: 1,
272
735
  invalidMessageDeliveriesWeight: -20,
273
736
  invalidMessageDeliveriesDecay: 0.5
@@ -303,15 +766,6 @@ import { P2PInstrumentation } from './instrumentation.js';
303
766
  throw new Error('Announce address not provided.');
304
767
  }
305
768
  const announceTcpMultiaddr = convertToMultiaddr(p2pIp, p2pPort, 'tcp');
306
- await this.peerManager.initializePeers();
307
- if (!this.config.p2pDiscoveryDisabled) {
308
- await this.peerDiscoveryService.start();
309
- }
310
- await this.node.start();
311
- // Subscribe to standard GossipSub topics by default
312
- for (const topic of getTopicsForClientAndConfig(this.clientType, this.config.disableTransactions)){
313
- this.subscribeToTopic(this.topicStrings[topic]);
314
- }
315
769
  // Create request response protocol handlers
316
770
  const txHandler = reqRespTxHandler(this.mempools);
317
771
  const goodbyeHandler = reqGoodbyeHandler(this.peerManager);
@@ -323,21 +777,13 @@ import { P2PInstrumentation } from './instrumentation.js';
323
777
  [ReqRespSubProtocol.GOODBYE]: goodbyeHandler.bind(this),
324
778
  [ReqRespSubProtocol.BLOCK]: blockHandler.bind(this)
325
779
  };
326
- // Only handle block transactions request if attestation pool is available to the client
327
- if (this.mempools.attestationPool && !this.config.disableTransactions) {
780
+ if (!this.config.disableTransactions) {
328
781
  const blockTxsHandler = reqRespBlockTxsHandler(this.mempools.attestationPool, this.mempools.txPool);
329
782
  requestResponseHandlers[ReqRespSubProtocol.BLOCK_TXS] = blockTxsHandler.bind(this);
330
783
  }
331
784
  if (!this.config.disableTransactions) {
332
785
  requestResponseHandlers[ReqRespSubProtocol.TX] = txHandler.bind(this);
333
786
  }
334
- // add GossipSub listener
335
- this.node.services.pubsub.addEventListener(GossipSubEvent.MESSAGE, this.gossipSubEventHandler);
336
- // Start running promise for peer discovery and metrics collection
337
- this.discoveryRunningPromise = new RunningPromise(async ()=>{
338
- await this.peerManager.heartbeat();
339
- }, this.logger, this.config.peerCheckIntervalMS);
340
- this.discoveryRunningPromise.start();
341
787
  // Define the sub protocol validators - This is done within this start() method to gain a callback to the existing validateTx function
342
788
  const reqrespSubProtocolValidators = {
343
789
  ...DEFAULT_SUB_PROTOCOL_VALIDATORS,
@@ -345,7 +791,23 @@ import { P2PInstrumentation } from './instrumentation.js';
345
791
  [ReqRespSubProtocol.BLOCK_TXS]: this.validateRequestedBlockTxs.bind(this),
346
792
  [ReqRespSubProtocol.BLOCK]: this.validateRequestedBlock.bind(this)
347
793
  };
794
+ await this.peerManager.initializePeers();
348
795
  await this.reqresp.start(requestResponseHandlers, reqrespSubProtocolValidators);
796
+ await this.node.start();
797
+ // Subscribe to standard GossipSub topics by default
798
+ for (const topic of getTopicsForClientAndConfig(this.clientType, this.config.disableTransactions)){
799
+ this.subscribeToTopic(this.topicStrings[topic]);
800
+ }
801
+ // add GossipSub listener
802
+ this.node.services.pubsub.addEventListener(GossipSubEvent.MESSAGE, this.gossipSubEventHandler);
803
+ // Start running promise for peer discovery and metrics collection
804
+ if (!this.config.p2pDiscoveryDisabled) {
805
+ await this.peerDiscoveryService.start();
806
+ }
807
+ this.discoveryRunningPromise = new RunningPromise(async ()=>{
808
+ await this.peerManager.heartbeat();
809
+ }, this.logger, this.config.peerCheckIntervalMS);
810
+ this.discoveryRunningPromise.start();
349
811
  this.logger.info(`Started P2P service`, {
350
812
  listen: this.config.listenAddress,
351
813
  port: this.config.p2pPort,
@@ -409,6 +871,9 @@ import { P2PInstrumentation } from './instrumentation.js';
409
871
  registerBlockReceivedCallback(callback) {
410
872
  this.blockReceivedCallback = callback;
411
873
  }
874
+ registerCheckpointReceivedCallback(callback) {
875
+ this.checkpointReceivedCallback = callback;
876
+ }
412
877
  /**
413
878
  * Subscribes to a topic.
414
879
  * @param topic - The topic to subscribe to.
@@ -427,7 +892,9 @@ import { P2PInstrumentation } from './instrumentation.js';
427
892
  if (!this.node.services.pubsub) {
428
893
  throw new Error('Pubsub service not available.');
429
894
  }
430
- const p2pMessage = P2PMessage.fromGossipable(message, this.config.debugP2PInstrumentMessages);
895
+ const isBlockProposal = topic === this.topicStrings[TopicType.block_proposal];
896
+ const traceContext = this.config.debugP2PInstrumentMessages && isBlockProposal ? this.telemetry.getTraceContext() : undefined;
897
+ const p2pMessage = P2PMessage.fromGossipable(message, this.config.debugP2PInstrumentMessages, traceContext);
431
898
  const result = await this.node.services.pubsub.publish(topic, p2pMessage.toMessageData());
432
899
  return result.recipients.length;
433
900
  }
@@ -441,12 +908,15 @@ import { P2PInstrumentation } from './instrumentation.js';
441
908
  case this.topicStrings[TopicType.tx]:
442
909
  topicType = TopicType.tx;
443
910
  break;
444
- case this.topicStrings[TopicType.block_attestation]:
445
- topicType = TopicType.block_attestation;
446
- break;
447
911
  case this.topicStrings[TopicType.block_proposal]:
448
912
  topicType = TopicType.block_proposal;
449
913
  break;
914
+ case this.topicStrings[TopicType.checkpoint_proposal]:
915
+ topicType = TopicType.checkpoint_proposal;
916
+ break;
917
+ case this.topicStrings[TopicType.checkpoint_attestation]:
918
+ topicType = TopicType.checkpoint_attestation;
919
+ break;
450
920
  default:
451
921
  this.logger.error(`Received message on unknown topic: ${msg.topic}`);
452
922
  break;
@@ -500,22 +970,63 @@ import { P2PInstrumentation } from './instrumentation.js';
500
970
  if (!preValidationResult.result) {
501
971
  return;
502
972
  }
973
+ // Determine topic type for attributes
503
974
  if (msg.topic === this.topicStrings[TopicType.tx]) {
504
975
  topicType = TopicType.tx;
505
- await this.handleGossipedTx(p2pMessage.payload, msgId, source);
976
+ } else if (msg.topic === this.topicStrings[TopicType.checkpoint_attestation]) {
977
+ topicType = TopicType.checkpoint_attestation;
978
+ } else if (msg.topic === this.topicStrings[TopicType.block_proposal]) {
979
+ topicType = TopicType.block_proposal;
980
+ } else if (msg.topic === this.topicStrings[TopicType.checkpoint_proposal]) {
981
+ topicType = TopicType.checkpoint_proposal;
506
982
  }
507
- if (msg.topic === this.topicStrings[TopicType.block_attestation]) {
508
- topicType = TopicType.block_attestation;
509
- if (this.clientType === P2PClientType.Full) {
510
- await this.processAttestationFromPeer(p2pMessage.payload, msgId, source);
983
+ // Process the message, optionally within a linked span for trace propagation
984
+ const processMessage = async ()=>{
985
+ if (msg.topic === this.topicStrings[TopicType.tx]) {
986
+ await this.handleGossipedTx(p2pMessage.payload, msgId, source);
987
+ } else if (msg.topic === this.topicStrings[TopicType.checkpoint_attestation]) {
988
+ if (this.clientType === P2PClientType.Full) {
989
+ await this.processCheckpointAttestationFromPeer(p2pMessage.payload, msgId, source);
990
+ }
991
+ } else if (msg.topic === this.topicStrings[TopicType.block_proposal]) {
992
+ await this.processBlockFromPeer(p2pMessage.payload, msgId, source);
993
+ } else if (msg.topic === this.topicStrings[TopicType.checkpoint_proposal]) {
994
+ await this.handleGossipedCheckpointProposal(p2pMessage.payload, msgId, source);
995
+ } else {
996
+ this.logger.error(`Received message on unknown topic: ${msg.topic}`);
511
997
  }
998
+ };
999
+ const latency = p2pMessage.timestamp !== undefined ? msgReceivedTime - p2pMessage.timestamp.getTime() : undefined;
1000
+ const propagatedContext = p2pMessage.traceContext ? this.telemetry.extractPropagatedContext(p2pMessage.traceContext) : undefined;
1001
+ if (propagatedContext) {
1002
+ await this.tracer.startActiveSpan('LibP2PService.processMessage', {
1003
+ attributes: {
1004
+ [Attributes.TOPIC_NAME]: topicType,
1005
+ [Attributes.PEER_ID]: source.toString()
1006
+ }
1007
+ }, propagatedContext, async (span)=>{
1008
+ try {
1009
+ await processMessage();
1010
+ span.setStatus({
1011
+ code: SpanStatusCode.OK
1012
+ });
1013
+ } catch (err) {
1014
+ span.setStatus({
1015
+ code: SpanStatusCode.ERROR,
1016
+ message: String(err)
1017
+ });
1018
+ if (typeof err === 'string' || err && err instanceof Error) {
1019
+ span.recordException(err);
1020
+ }
1021
+ throw err;
1022
+ } finally{
1023
+ span.end();
1024
+ }
1025
+ });
1026
+ } else {
1027
+ await processMessage();
512
1028
  }
513
- if (msg.topic === this.topicStrings[TopicType.block_proposal]) {
514
- topicType = TopicType.block_proposal;
515
- await this.processBlockFromPeer(p2pMessage.payload, msgId, source);
516
- }
517
- if (p2pMessage.timestamp !== undefined && topicType !== undefined) {
518
- const latency = msgReceivedTime - p2pMessage.timestamp.getTime();
1029
+ if (latency !== undefined && topicType !== undefined) {
519
1030
  this.instrumentation.recordMessageLatency(topicType, latency);
520
1031
  }
521
1032
  return;
@@ -587,41 +1098,40 @@ import { P2PInstrumentation } from './instrumentation.js';
587
1098
  ]);
588
1099
  }
589
1100
  /**
590
- * Process Attestation From Peer
591
- * When a proposal is received from a peer, we add it to the attestation pool, so it can be accessed by other services.
592
- *
593
- * @param attestation - The attestation to process.
594
- */ async processAttestationFromPeer(payloadData, msgId, source) {
1101
+ * Process a checkpoint attestation from a peer.
1102
+ * Validates the attestation and adds it to the pool.
1103
+ */ async processCheckpointAttestationFromPeer(payloadData, msgId, source) {
595
1104
  const validationFunc = async ()=>{
596
- const attestation = BlockAttestation.fromBuffer(payloadData);
1105
+ const attestation = CheckpointAttestation.fromBuffer(payloadData);
597
1106
  const pool = this.mempools.attestationPool;
598
- const isValid = await this.validateAttestation(source, attestation);
599
- const exists = isValid && await pool.hasAttestation(attestation);
1107
+ const validationResult = await this.validateCheckpointAttestation(source, attestation);
1108
+ const isValid = validationResult.result === 'accept';
1109
+ const exists = isValid && await pool.hasCheckpointAttestation(attestation);
600
1110
  let canAdd = true;
601
1111
  if (isValid && !exists) {
602
1112
  const slot = attestation.payload.header.slotNumber;
603
1113
  const { committee } = await this.epochCache.getCommittee(slot);
604
1114
  const committeeSize = committee?.length ?? 0;
605
- canAdd = await pool.canAddAttestation(attestation, committeeSize);
1115
+ canAdd = await pool.canAddCheckpointAttestation(attestation, committeeSize);
606
1116
  }
607
- this.logger.trace(`Validate propagated block attestation`, {
1117
+ this.logger.trace(`Validate propagated checkpoint attestation`, {
608
1118
  isValid,
609
1119
  exists,
610
1120
  canAdd,
611
1121
  [Attributes.SLOT_NUMBER]: attestation.payload.header.slotNumber.toString(),
612
1122
  [Attributes.P2P_ID]: source.toString()
613
1123
  });
614
- if (!isValid) {
1124
+ if (validationResult.result === 'reject') {
615
1125
  return {
616
1126
  result: TopicValidatorResult.Reject
617
1127
  };
618
- } else if (exists) {
1128
+ } else if (validationResult.result === 'ignore' || exists) {
619
1129
  return {
620
1130
  result: TopicValidatorResult.Ignore,
621
1131
  obj: attestation
622
1132
  };
623
1133
  } else if (!canAdd) {
624
- this.logger.warn(`Dropping block attestation due to per-(slot, proposalId) attestation cap`, {
1134
+ this.logger.warn(`Dropping checkpoint attestation due to per-(slot, proposalId) attestation cap`, {
625
1135
  slot: attestation.payload.header.slotNumber.toString(),
626
1136
  archive: attestation.archive.toString(),
627
1137
  source: source.toString()
@@ -637,41 +1147,40 @@ import { P2PInstrumentation } from './instrumentation.js';
637
1147
  };
638
1148
  }
639
1149
  };
640
- const { result, obj: attestation } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.block_attestation);
1150
+ const { result, obj: attestation } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.checkpoint_attestation);
641
1151
  if (result !== TopicValidatorResult.Accept || !attestation) {
642
1152
  return;
643
1153
  }
644
- this.logger.debug(`Received attestation for slot ${attestation.slotNumber} from external peer ${source.toString()}`, {
1154
+ this.logger.debug(`Received checkpoint attestation for slot ${attestation.slotNumber} from external peer ${source.toString()}`, {
645
1155
  p2pMessageIdentifier: await attestation.p2pMessageLoggingIdentifier(),
646
1156
  slot: attestation.slotNumber,
647
1157
  archive: attestation.archive.toString(),
648
1158
  source: source.toString()
649
1159
  });
650
- await this.mempools.attestationPool.addAttestations([
1160
+ await this.mempools.attestationPool.addCheckpointAttestations([
651
1161
  attestation
652
1162
  ]);
653
1163
  }
654
1164
  async processBlockFromPeer(payloadData, msgId, source) {
655
1165
  const validationFunc = async ()=>{
656
1166
  const block = BlockProposal.fromBuffer(payloadData);
657
- const isValid = await this.validateBlockProposal(source, block);
1167
+ const validationResult = await this.validateBlockProposal(source, block);
1168
+ const isValid = validationResult.result === 'accept';
658
1169
  const pool = this.mempools.attestationPool;
659
- // Note that we dont have an attestation pool if we're a prover node, but we still
660
- // subscribe to block proposal topics in order to prevent their txs from being cleared.
661
- const exists = isValid && await pool?.hasBlockProposal(block);
662
- const canAdd = isValid && await pool?.canAddProposal(block);
1170
+ const exists = isValid && await pool.hasBlockProposal(block);
1171
+ const canAdd = isValid && await pool.canAddProposal(block);
663
1172
  this.logger.trace(`Validate propagated block proposal`, {
664
1173
  isValid,
665
1174
  exists,
666
1175
  canAdd,
667
- [Attributes.SLOT_NUMBER]: block.payload.header.slotNumber.toString(),
1176
+ [Attributes.SLOT_NUMBER]: block.slotNumber.toString(),
668
1177
  [Attributes.P2P_ID]: source.toString()
669
1178
  });
670
- if (!isValid) {
1179
+ if (validationResult.result === 'reject') {
671
1180
  return {
672
1181
  result: TopicValidatorResult.Reject
673
1182
  };
674
- } else if (exists) {
1183
+ } else if (validationResult.result === 'ignore' || exists) {
675
1184
  return {
676
1185
  result: TopicValidatorResult.Ignore,
677
1186
  obj: block
@@ -700,22 +1209,18 @@ import { P2PInstrumentation } from './instrumentation.js';
700
1209
  await this.processValidBlockProposal(block, source);
701
1210
  }
702
1211
  // REVIEW: callback pattern https://github.com/AztecProtocol/aztec-packages/issues/7963
1212
+ // REFACTOR(palla): This method should be moved to the p2p_client or to a separate component,
1213
+ // should not be here as it does not deal with p2p networking.
703
1214
  async processValidBlockProposal(block, sender) {
704
1215
  const slot = block.slotNumber;
705
- const previousSlot = SlotNumber(slot - 1);
706
1216
  this.logger.verbose(`Received block proposal for slot ${slot} from external peer ${sender.toString()}.`, {
707
1217
  p2pMessageIdentifier: await block.p2pMessageLoggingIdentifier(),
708
- slot: block.slotNumber,
709
- archive: block.archive.toString(),
710
- source: sender.toString()
1218
+ source: sender.toString(),
1219
+ ...block.toBlockInfo()
711
1220
  });
712
- const attestationsForPreviousSlot = await this.mempools.attestationPool?.getAttestationsForSlot(previousSlot);
713
- if (attestationsForPreviousSlot !== undefined) {
714
- this.logger.verbose(`Received ${attestationsForPreviousSlot.length} attestations for slot ${previousSlot}`);
715
- }
716
- // Attempt to add proposal, then mark the txs in this proposal as non-evictable
1221
+ // Attempt to add proposal
717
1222
  try {
718
- await this.mempools.attestationPool?.addBlockProposal(block);
1223
+ await this.mempools.attestationPool.addBlockProposal(block);
719
1224
  } catch (err) {
720
1225
  // Drop proposals if we hit per-slot cap in the attestation pool; rethrow unknown errors
721
1226
  if (err instanceof ProposalSlotCapExceededError) {
@@ -728,26 +1233,109 @@ import { P2PInstrumentation } from './instrumentation.js';
728
1233
  }
729
1234
  throw err;
730
1235
  }
1236
+ // Mark the txs in this proposal as non-evictable
731
1237
  await this.mempools.txPool.markTxsAsNonEvictable(block.txHashes);
732
- const attestations = await this.blockReceivedCallback(block, sender);
733
- // TODO: fix up this pattern - the abstraction is not nice
734
- // The attestation can be undefined if no handler is registered / the validator deems the block invalid / in fisherman mode
735
- if (attestations?.length) {
736
- for (const attestation of attestations){
737
- this.logger.verbose(`Broadcasting attestation for slot ${attestation.slotNumber}`, {
738
- p2pMessageIdentifier: await attestation.p2pMessageLoggingIdentifier(),
739
- slot: attestation.slotNumber,
740
- archive: attestation.archive.toString()
1238
+ // Call the block received callback to validate the proposal.
1239
+ // Note: Validators do NOT attest to individual blocks, only to checkpoint proposals.
1240
+ const isValid = await this.blockReceivedCallback(block, sender);
1241
+ if (!isValid) {
1242
+ this.logger.warn(`Block proposal validation failed for block ${block.blockNumber}`, block.toBlockInfo());
1243
+ }
1244
+ }
1245
+ /**
1246
+ * Handle a gossiped checkpoint proposal.
1247
+ * Validates and processes the checkpoint proposal, then triggers the callback for attestation.
1248
+ */ async handleGossipedCheckpointProposal(payloadData, msgId, source) {
1249
+ // TODO(palla/mbps): This pattern is repeated across multiple message handlers, consider abstracting it.
1250
+ const validationFunc = async ()=>{
1251
+ const checkpoint = CheckpointProposal.fromBuffer(payloadData);
1252
+ const validationResult = await this.validateCheckpointProposal(source, checkpoint);
1253
+ const isValid = validationResult.result === 'accept';
1254
+ const pool = this.mempools.attestationPool;
1255
+ const exists = isValid && await pool.hasCheckpointProposal(checkpoint);
1256
+ const canAdd = isValid && await pool.canAddCheckpointProposal(checkpoint);
1257
+ this.logger.trace(`Validate propagated checkpoint proposal`, {
1258
+ isValid,
1259
+ exists,
1260
+ canAdd,
1261
+ [Attributes.SLOT_NUMBER]: checkpoint.slotNumber.toString(),
1262
+ [Attributes.P2P_ID]: source.toString()
1263
+ });
1264
+ if (validationResult.result === 'reject') {
1265
+ return {
1266
+ result: TopicValidatorResult.Reject
1267
+ };
1268
+ } else if (validationResult.result === 'ignore' || exists) {
1269
+ return {
1270
+ result: TopicValidatorResult.Ignore,
1271
+ obj: checkpoint
1272
+ };
1273
+ } else if (!canAdd) {
1274
+ this.peerManager.penalizePeer(source, PeerErrorSeverity.MidToleranceError);
1275
+ this.logger.warn(`Penalizing peer for checkpoint proposal exceeding per-slot cap`, {
1276
+ slot: checkpoint.slotNumber.toString(),
1277
+ archive: checkpoint.archive.toString(),
1278
+ source: source.toString()
741
1279
  });
742
- await this.broadcastAttestation(attestation);
1280
+ return {
1281
+ result: TopicValidatorResult.Reject
1282
+ };
1283
+ } else {
1284
+ return {
1285
+ result: TopicValidatorResult.Accept,
1286
+ obj: checkpoint
1287
+ };
743
1288
  }
1289
+ };
1290
+ const { result, obj: checkpoint } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.checkpoint_proposal);
1291
+ if (result !== TopicValidatorResult.Accept || !checkpoint) {
1292
+ return;
744
1293
  }
1294
+ await this.processValidCheckpointProposal(checkpoint, source);
745
1295
  }
746
1296
  /**
747
- * Broadcast an attestation to all peers.
748
- * @param attestation - The attestation to broadcast.
749
- */ async broadcastAttestation(attestation) {
750
- await this.propagate(attestation);
1297
+ * Process a validated checkpoint proposal.
1298
+ * Extracts and processes the last block proposal (if present) first, then processes the checkpoint.
1299
+ * The block callback is invoked before the checkpoint callback.
1300
+ */ async processValidCheckpointProposal(checkpoint, sender) {
1301
+ const slot = checkpoint.slotNumber;
1302
+ this.logger.verbose(`Received checkpoint proposal for slot ${slot} from external peer ${sender.toString()}.`, {
1303
+ p2pMessageIdentifier: await checkpoint.p2pMessageLoggingIdentifier(),
1304
+ slot: checkpoint.slotNumber,
1305
+ archive: checkpoint.archive.toString(),
1306
+ source: sender.toString()
1307
+ });
1308
+ // Extract block proposal before adding to pool (pool stores them separately)
1309
+ const blockProposal = checkpoint.getBlockProposal();
1310
+ // Add proposal to the pool (this extracts and stores block proposal separately)
1311
+ await this.mempools.attestationPool.addCheckpointProposal(checkpoint);
1312
+ // Mark txs as non-evictable if present (from the last block)
1313
+ if (checkpoint.txHashes.length > 0) {
1314
+ await this.mempools.txPool.markTxsAsNonEvictable(checkpoint.txHashes);
1315
+ }
1316
+ // If there was a last block proposal, invoke the block callback first for validation.
1317
+ // Note: The block proposal is already stored in the pool by addCheckpointProposal.
1318
+ if (blockProposal) {
1319
+ const isValid = await this.blockReceivedCallback(blockProposal, sender);
1320
+ if (!isValid) {
1321
+ this.logger.warn(`Block proposal from checkpoint failed validation`, {
1322
+ slot: slot.toString(),
1323
+ archive: checkpoint.archive.toString(),
1324
+ blockNumber: blockProposal.blockNumber.toString()
1325
+ });
1326
+ return;
1327
+ }
1328
+ }
1329
+ // Call the checkpoint received callback with the core version (without lastBlock)
1330
+ // to validate and potentially generate attestations
1331
+ const attestations = await this.checkpointReceivedCallback(checkpoint.toCore(), sender);
1332
+ if (attestations && attestations.length > 0) {
1333
+ // If the callback returned attestations, add them to the pool and propagate them
1334
+ await this.mempools.attestationPool.addCheckpointAttestations(attestations);
1335
+ for (const attestation of attestations){
1336
+ await this.propagate(attestation);
1337
+ }
1338
+ }
751
1339
  }
752
1340
  /**
753
1341
  * Propagates provided message to peers.
@@ -797,7 +1385,7 @@ import { P2PInstrumentation } from './instrumentation.js';
797
1385
  throw new ValidationError(`Received more txs (${response.txs.length}) than requested-and-available (${maxReturnable})`);
798
1386
  }
799
1387
  // Given proposal (should have locally), ensure returned txs are valid subset and match request indices
800
- const proposal = await this.mempools.attestationPool?.getBlockProposal(request.blockHash.toString());
1388
+ const proposal = await this.mempools.attestationPool.getBlockProposal(request.blockHash.toString());
801
1389
  if (proposal) {
802
1390
  // Build intersected indices
803
1391
  const intersectIdx = request.txIndices.getTrueIndices().filter((i)=>response.txIndices.isSet(i));
@@ -877,7 +1465,7 @@ import { P2PInstrumentation } from './instrumentation.js';
877
1465
  this.peerManager.penalizePeer(peerId, PeerErrorSeverity.LowToleranceError);
878
1466
  return false;
879
1467
  }
880
- const local = await this.archiver.getBlock(reqNum);
1468
+ const local = await this.archiver.getBlock(BlockNumber(reqNum));
881
1469
  if (!local) {
882
1470
  // We are missing the local block; we cannot verify the hash yet. Reject without penalizing.
883
1471
  // TODO: Consider extending this validator to accept an expected hash or
@@ -900,7 +1488,7 @@ import { P2PInstrumentation } from './instrumentation.js';
900
1488
  }
901
1489
  }
902
1490
  createRequestedTxValidator() {
903
- return new AggregateTxValidator(new DataTxValidator(), new MetadataTxValidator({
1491
+ return new AggregateTxValidator(new DataTxValidator(), new SizeTxValidator(), new MetadataTxValidator({
904
1492
  l1ChainId: new Fr(this.config.l1ChainId),
905
1493
  rollupVersion: new Fr(this.config.rollupVersion),
906
1494
  protocolContractsHash,
@@ -937,7 +1525,7 @@ import { P2PInstrumentation } from './instrumentation.js';
937
1525
  let { severity } = outcome.failure;
938
1526
  // Double spend validator has a special case handler
939
1527
  if (name === 'doubleSpendValidator') {
940
- const txBlockNumber = currentBlockNumber + 1; // tx is expected to be in the next block
1528
+ const txBlockNumber = BlockNumber(currentBlockNumber + 1); // tx is expected to be in the next block
941
1529
  severity = await this.handleDoubleSpendFailure(tx, txBlockNumber);
942
1530
  }
943
1531
  this.peerManager.penalizePeer(peerId, severity);
@@ -987,7 +1575,7 @@ import { P2PInstrumentation } from './instrumentation.js';
987
1575
  */ async createMessageValidators(currentBlockNumber, nextSlotTimestamp) {
988
1576
  const gasFees = await this.getGasFees(currentBlockNumber);
989
1577
  const allowedInSetup = this.config.txPublicSetupAllowList ?? await getDefaultAllowedSetupFunctions();
990
- const blockNumberInWhichTheTxIsConsideredToBeIncluded = currentBlockNumber + 1;
1578
+ const blockNumberInWhichTheTxIsConsideredToBeIncluded = BlockNumber(currentBlockNumber + 1);
991
1579
  return createTxMessageValidators(nextSlotTimestamp, blockNumberInWhichTheTxIsConsideredToBeIncluded, this.worldStateSynchronizer, gasFees, this.config.l1ChainId, this.config.rollupVersion, protocolContractsHash, this.archiver, this.proofVerifier, !this.config.disableTransactions, allowedInSetup);
992
1580
  }
993
1581
  /**
@@ -1043,7 +1631,7 @@ import { P2PInstrumentation } from './instrumentation.js';
1043
1631
  }
1044
1632
  const snapshotValidator = new DoubleSpendTxValidator({
1045
1633
  nullifiersExist: async (nullifiers)=>{
1046
- const merkleTree = this.worldStateSynchronizer.getSnapshot(blockNumber - this.config.doubleSpendSeverePeerPenaltyWindow);
1634
+ const merkleTree = this.worldStateSynchronizer.getSnapshot(BlockNumber(blockNumber - this.config.doubleSpendSeverePeerPenaltyWindow));
1047
1635
  const indices = await merkleTree.findLeafIndices(MerkleTreeId.NULLIFIER_TREE, nullifiers);
1048
1636
  return indices.map((index)=>index !== undefined);
1049
1637
  }
@@ -1055,17 +1643,17 @@ import { P2PInstrumentation } from './instrumentation.js';
1055
1643
  return PeerErrorSeverity.HighToleranceError;
1056
1644
  }
1057
1645
  /**
1058
- * Validate an attestation.
1646
+ * Validate a checkpoint attestation.
1059
1647
  *
1060
- * @param attestation - The attestation to validate.
1061
- * @returns True if the attestation is valid, false otherwise.
1062
- */ async validateAttestation(peerId, attestation) {
1063
- const severity = await this.attestationValidator.validate(attestation);
1064
- if (severity) {
1065
- this.peerManager.penalizePeer(peerId, severity);
1066
- return false;
1648
+ * @param attestation - The checkpoint attestation to validate.
1649
+ * @returns True if the checkpoint attestation is valid, false otherwise.
1650
+ */ async validateCheckpointAttestation(peerId, attestation) {
1651
+ const result = await this.checkpointAttestationValidator.validate(attestation);
1652
+ if (result.result === 'reject') {
1653
+ this.logger.debug(`Penalizing peer ${peerId} for checkpoint attestation validation failure`);
1654
+ this.peerManager.penalizePeer(peerId, result.severity);
1067
1655
  }
1068
- return true;
1656
+ return result;
1069
1657
  }
1070
1658
  /**
1071
1659
  * Validate a block proposal.
@@ -1073,13 +1661,25 @@ import { P2PInstrumentation } from './instrumentation.js';
1073
1661
  * @param block - The block proposal to validate.
1074
1662
  * @returns True if the block proposal is valid, false otherwise.
1075
1663
  */ async validateBlockProposal(peerId, block) {
1076
- const severity = await this.blockProposalValidator.validate(block);
1077
- if (severity) {
1664
+ const result = await this.blockProposalValidator.validate(block);
1665
+ if (result.result === 'reject') {
1078
1666
  this.logger.debug(`Penalizing peer ${peerId} for block proposal validation failure`);
1079
- this.peerManager.penalizePeer(peerId, severity);
1080
- return false;
1667
+ this.peerManager.penalizePeer(peerId, result.severity);
1081
1668
  }
1082
- return true;
1669
+ return result;
1670
+ }
1671
+ /**
1672
+ * Validate a checkpoint proposal.
1673
+ *
1674
+ * @param checkpoint - The checkpoint proposal to validate.
1675
+ * @returns True if the checkpoint proposal is valid, false otherwise.
1676
+ */ async validateCheckpointProposal(peerId, checkpoint) {
1677
+ const result = await this.checkpointProposalValidator.validate(checkpoint);
1678
+ if (result.result === 'reject') {
1679
+ this.logger.debug(`Penalizing peer ${peerId} for checkpoint proposal validation failure`);
1680
+ this.peerManager.penalizePeer(peerId, result.severity);
1681
+ }
1682
+ return result;
1083
1683
  }
1084
1684
  getPeerScore(peerId) {
1085
1685
  return this.node.services.pubsub.score.score(peerId.toString());
@@ -1116,49 +1716,3 @@ import { P2PInstrumentation } from './instrumentation.js';
1116
1716
  }
1117
1717
  }
1118
1718
  }
1119
- _ts_decorate([
1120
- trackSpan('Libp2pService.processValidBlockProposal', async (block)=>({
1121
- [Attributes.SLOT_NUMBER]: block.slotNumber,
1122
- [Attributes.BLOCK_ARCHIVE]: block.archive.toString(),
1123
- [Attributes.P2P_ID]: await block.p2pMessageLoggingIdentifier().then((i)=>i.toString())
1124
- }))
1125
- ], LibP2PService.prototype, "processValidBlockProposal", null);
1126
- _ts_decorate([
1127
- trackSpan('Libp2pService.broadcastAttestation', async (attestation)=>({
1128
- [Attributes.SLOT_NUMBER]: attestation.payload.header.slotNumber,
1129
- [Attributes.BLOCK_ARCHIVE]: attestation.archive.toString(),
1130
- [Attributes.P2P_ID]: await attestation.p2pMessageLoggingIdentifier().then((i)=>i.toString())
1131
- }))
1132
- ], LibP2PService.prototype, "broadcastAttestation", null);
1133
- _ts_decorate([
1134
- trackSpan('Libp2pService.validateRequestedBlockTxs', (request)=>({
1135
- [Attributes.BLOCK_HASH]: request.blockHash.toString()
1136
- }))
1137
- ], LibP2PService.prototype, "validateRequestedBlockTxs", null);
1138
- _ts_decorate([
1139
- trackSpan('Libp2pService.validateRequestedTx', (requestedTxHash, _responseTx)=>({
1140
- [Attributes.TX_HASH]: requestedTxHash.toString()
1141
- }))
1142
- ], LibP2PService.prototype, "validateRequestedTxs", null);
1143
- _ts_decorate([
1144
- trackSpan('Libp2pService.validateRequestedBlock', (requestedBlockNumber, _responseBlock)=>({
1145
- [Attributes.BLOCK_NUMBER]: requestedBlockNumber.toString()
1146
- }))
1147
- ], LibP2PService.prototype, "validateRequestedBlock", null);
1148
- _ts_decorate([
1149
- trackSpan('Libp2pService.validatePropagatedTx', (tx)=>({
1150
- [Attributes.TX_HASH]: tx.getTxHash().toString()
1151
- }))
1152
- ], LibP2PService.prototype, "validatePropagatedTx", null);
1153
- _ts_decorate([
1154
- trackSpan('Libp2pService.validateAttestation', async (_, attestation)=>({
1155
- [Attributes.SLOT_NUMBER]: attestation.payload.header.slotNumber,
1156
- [Attributes.BLOCK_ARCHIVE]: attestation.archive.toString(),
1157
- [Attributes.P2P_ID]: await attestation.p2pMessageLoggingIdentifier().then((i)=>i.toString())
1158
- }))
1159
- ], LibP2PService.prototype, "validateAttestation", null);
1160
- _ts_decorate([
1161
- trackSpan('Libp2pService.validateBlockProposal', (_peerId, block)=>({
1162
- [Attributes.SLOT_NUMBER]: block.payload.header.slotNumber.toString()
1163
- }))
1164
- ], LibP2PService.prototype, "validateBlockProposal", null);