@aztec/p2p 0.0.1-commit.d3ec352c → 0.0.1-commit.f295ac2

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 (263) 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 +11 -14
  7. package/dest/client/p2p_client.d.ts.map +1 -1
  8. package/dest/client/p2p_client.js +456 -124
  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 +36 -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 +31 -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 +156 -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 +115 -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 +76 -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 +8 -4
  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 +25 -20
  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 +13 -11
  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 +7 -10
  72. package/dest/msg_validators/index.d.ts +2 -2
  73. package/dest/msg_validators/index.d.ts.map +1 -1
  74. package/dest/msg_validators/index.js +1 -1
  75. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts +9 -0
  76. package/dest/msg_validators/proposal_validator/block_proposal_validator.d.ts.map +1 -0
  77. package/dest/msg_validators/proposal_validator/block_proposal_validator.js +6 -0
  78. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts +9 -0
  79. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.d.ts.map +1 -0
  80. package/dest/msg_validators/proposal_validator/checkpoint_proposal_validator.js +6 -0
  81. package/dest/msg_validators/proposal_validator/index.d.ts +4 -0
  82. package/dest/msg_validators/proposal_validator/index.d.ts.map +1 -0
  83. package/dest/msg_validators/proposal_validator/index.js +3 -0
  84. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts +13 -0
  85. package/dest/msg_validators/proposal_validator/proposal_validator.d.ts.map +1 -0
  86. package/dest/msg_validators/{block_proposal_validator/block_proposal_validator.js → proposal_validator/proposal_validator.js} +20 -22
  87. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts +23 -0
  88. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.d.ts.map +1 -0
  89. package/dest/msg_validators/proposal_validator/proposal_validator_test_suite.js +183 -0
  90. package/dest/msg_validators/tx_validator/archive_cache.d.ts +2 -2
  91. package/dest/msg_validators/tx_validator/archive_cache.d.ts.map +1 -1
  92. package/dest/msg_validators/tx_validator/block_header_validator.d.ts +2 -2
  93. package/dest/msg_validators/tx_validator/block_header_validator.d.ts.map +1 -1
  94. package/dest/msg_validators/tx_validator/data_validator.d.ts +1 -1
  95. package/dest/msg_validators/tx_validator/data_validator.d.ts.map +1 -1
  96. package/dest/msg_validators/tx_validator/factory.d.ts +2 -2
  97. package/dest/msg_validators/tx_validator/factory.d.ts.map +1 -1
  98. package/dest/msg_validators/tx_validator/factory.js +1 -1
  99. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts +10 -0
  100. package/dest/msg_validators/tx_validator/fee_payer_balance.d.ts.map +1 -0
  101. package/dest/msg_validators/tx_validator/fee_payer_balance.js +20 -0
  102. package/dest/msg_validators/tx_validator/gas_validator.d.ts +1 -1
  103. package/dest/msg_validators/tx_validator/gas_validator.d.ts.map +1 -1
  104. package/dest/msg_validators/tx_validator/gas_validator.js +8 -14
  105. package/dest/msg_validators/tx_validator/metadata_validator.d.ts +2 -2
  106. package/dest/msg_validators/tx_validator/metadata_validator.d.ts.map +1 -1
  107. package/dest/msg_validators/tx_validator/test_utils.d.ts +2 -2
  108. package/dest/msg_validators/tx_validator/test_utils.d.ts.map +1 -1
  109. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts +1 -1
  110. package/dest/msg_validators/tx_validator/timestamp_validator.d.ts.map +1 -1
  111. package/dest/services/dummy_service.d.ts +6 -2
  112. package/dest/services/dummy_service.d.ts.map +1 -1
  113. package/dest/services/dummy_service.js +3 -0
  114. package/dest/services/encoding.d.ts +1 -1
  115. package/dest/services/encoding.d.ts.map +1 -1
  116. package/dest/services/encoding.js +5 -3
  117. package/dest/services/libp2p/instrumentation.d.ts +1 -1
  118. package/dest/services/libp2p/instrumentation.d.ts.map +1 -1
  119. package/dest/services/libp2p/instrumentation.js +20 -73
  120. package/dest/services/libp2p/libp2p_service.d.ts +30 -13
  121. package/dest/services/libp2p/libp2p_service.d.ts.map +1 -1
  122. package/dest/services/libp2p/libp2p_service.js +703 -149
  123. package/dest/services/peer-manager/metrics.d.ts +6 -1
  124. package/dest/services/peer-manager/metrics.d.ts.map +1 -1
  125. package/dest/services/peer-manager/metrics.js +18 -21
  126. package/dest/services/peer-manager/peer_manager.d.ts +2 -2
  127. package/dest/services/peer-manager/peer_manager.d.ts.map +1 -1
  128. package/dest/services/peer-manager/peer_manager.js +4 -12
  129. package/dest/services/peer-manager/peer_scoring.d.ts +1 -1
  130. package/dest/services/peer-manager/peer_scoring.d.ts.map +1 -1
  131. package/dest/services/peer-manager/peer_scoring.js +2 -5
  132. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts +1 -1
  133. package/dest/services/reqresp/connection-sampler/connection_sampler.d.ts.map +1 -1
  134. package/dest/services/reqresp/constants.d.ts +12 -0
  135. package/dest/services/reqresp/constants.d.ts.map +1 -0
  136. package/dest/services/reqresp/constants.js +7 -0
  137. package/dest/services/reqresp/interface.d.ts +4 -4
  138. package/dest/services/reqresp/interface.d.ts.map +1 -1
  139. package/dest/services/reqresp/interface.js +3 -3
  140. package/dest/services/reqresp/metrics.d.ts +1 -1
  141. package/dest/services/reqresp/metrics.d.ts.map +1 -1
  142. package/dest/services/reqresp/metrics.js +5 -21
  143. package/dest/services/reqresp/protocols/auth.d.ts +2 -2
  144. package/dest/services/reqresp/protocols/auth.d.ts.map +1 -1
  145. package/dest/services/reqresp/protocols/auth.js +2 -2
  146. package/dest/services/reqresp/protocols/block.js +1 -1
  147. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts +1 -1
  148. package/dest/services/reqresp/protocols/block_txs/bitvector.d.ts.map +1 -1
  149. package/dest/services/reqresp/protocols/block_txs/bitvector.js +7 -0
  150. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts +2 -2
  151. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.d.ts.map +1 -1
  152. package/dest/services/reqresp/protocols/block_txs/block_txs_reqresp.js +1 -1
  153. package/dest/services/reqresp/protocols/status.d.ts +1 -1
  154. package/dest/services/reqresp/protocols/status.d.ts.map +1 -1
  155. package/dest/services/reqresp/protocols/status.js +4 -1
  156. package/dest/services/reqresp/protocols/tx.d.ts +2 -3
  157. package/dest/services/reqresp/protocols/tx.d.ts.map +1 -1
  158. package/dest/services/reqresp/reqresp.js +402 -24
  159. package/dest/services/service.d.ts +16 -3
  160. package/dest/services/service.d.ts.map +1 -1
  161. package/dest/services/tx_collection/config.js +1 -1
  162. package/dest/services/tx_collection/instrumentation.d.ts +1 -1
  163. package/dest/services/tx_collection/instrumentation.d.ts.map +1 -1
  164. package/dest/services/tx_collection/instrumentation.js +4 -14
  165. package/dest/services/tx_collection/slow_tx_collection.d.ts +3 -3
  166. package/dest/services/tx_collection/slow_tx_collection.d.ts.map +1 -1
  167. package/dest/services/tx_collection/tx_collection.d.ts +4 -4
  168. package/dest/services/tx_collection/tx_collection.d.ts.map +1 -1
  169. package/dest/services/tx_collection/tx_collection.js +1 -1
  170. package/dest/services/tx_provider.d.ts +2 -1
  171. package/dest/services/tx_provider.d.ts.map +1 -1
  172. package/dest/services/tx_provider.js +11 -2
  173. package/dest/services/tx_provider_instrumentation.d.ts +5 -2
  174. package/dest/services/tx_provider_instrumentation.d.ts.map +1 -1
  175. package/dest/services/tx_provider_instrumentation.js +13 -13
  176. package/dest/test-helpers/mock-tx-helpers.js +1 -1
  177. package/dest/test-helpers/reqresp-nodes.d.ts +2 -2
  178. package/dest/test-helpers/reqresp-nodes.d.ts.map +1 -1
  179. package/dest/testbench/p2p_client_testbench_worker.js +28 -12
  180. package/dest/testbench/worker_client_manager.d.ts +1 -1
  181. package/dest/testbench/worker_client_manager.d.ts.map +1 -1
  182. package/dest/testbench/worker_client_manager.js +6 -1
  183. package/package.json +16 -16
  184. package/src/client/factory.ts +5 -10
  185. package/src/client/interface.ts +19 -4
  186. package/src/client/p2p_client.ts +92 -147
  187. package/src/config.ts +12 -18
  188. package/src/mem_pools/attestation_pool/attestation_pool.ts +68 -41
  189. package/src/mem_pools/attestation_pool/attestation_pool_test_suite.ts +241 -289
  190. package/src/mem_pools/attestation_pool/kv_attestation_pool.ts +163 -141
  191. package/src/mem_pools/attestation_pool/memory_attestation_pool.ts +141 -164
  192. package/src/mem_pools/attestation_pool/mocks.ts +21 -15
  193. package/src/mem_pools/instrumentation.ts +38 -14
  194. package/src/mem_pools/interface.ts +2 -4
  195. package/src/mem_pools/tx_pool/README.md +270 -0
  196. package/src/mem_pools/tx_pool/aztec_kv_tx_pool.ts +363 -368
  197. package/src/mem_pools/tx_pool/eviction/eviction_manager.ts +131 -0
  198. package/src/mem_pools/tx_pool/eviction/eviction_strategy.ts +207 -0
  199. package/src/mem_pools/tx_pool/eviction/fee_payer_balance_eviction_rule.ts +159 -0
  200. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_mining_rule.ts +104 -0
  201. package/src/mem_pools/tx_pool/eviction/invalid_txs_after_reorg_rule.ts +91 -0
  202. package/src/mem_pools/tx_pool/eviction/low_priority_eviction_rule.ts +106 -0
  203. package/src/mem_pools/tx_pool/eviction/nullifier_conflict_pre_add_rule.ts +75 -0
  204. package/src/mem_pools/tx_pool/index.ts +0 -1
  205. package/src/mem_pools/tx_pool/priority.ts +8 -1
  206. package/src/mem_pools/tx_pool/tx_pool.ts +8 -3
  207. package/src/mem_pools/tx_pool/tx_pool_test_suite.ts +18 -13
  208. package/src/msg_validators/attestation_validator/attestation_validator.ts +17 -14
  209. package/src/msg_validators/attestation_validator/fisherman_attestation_validator.ts +9 -12
  210. package/src/msg_validators/index.ts +1 -1
  211. package/src/msg_validators/proposal_validator/block_proposal_validator.ts +10 -0
  212. package/src/msg_validators/proposal_validator/checkpoint_proposal_validator.ts +13 -0
  213. package/src/msg_validators/proposal_validator/index.ts +3 -0
  214. package/src/msg_validators/{block_proposal_validator/block_proposal_validator.ts → proposal_validator/proposal_validator.ts} +24 -29
  215. package/src/msg_validators/proposal_validator/proposal_validator_test_suite.ts +206 -0
  216. package/src/msg_validators/tx_validator/archive_cache.ts +1 -1
  217. package/src/msg_validators/tx_validator/block_header_validator.ts +1 -1
  218. package/src/msg_validators/tx_validator/data_validator.ts +12 -4
  219. package/src/msg_validators/tx_validator/factory.ts +1 -1
  220. package/src/msg_validators/tx_validator/fee_payer_balance.ts +40 -0
  221. package/src/msg_validators/tx_validator/gas_validator.ts +8 -25
  222. package/src/msg_validators/tx_validator/metadata_validator.ts +13 -5
  223. package/src/msg_validators/tx_validator/test_utils.ts +1 -1
  224. package/src/msg_validators/tx_validator/timestamp_validator.ts +3 -1
  225. package/src/services/dummy_service.ts +6 -0
  226. package/src/services/encoding.ts +4 -2
  227. package/src/services/libp2p/instrumentation.ts +19 -73
  228. package/src/services/libp2p/libp2p_service.ts +336 -117
  229. package/src/services/peer-manager/metrics.ts +22 -21
  230. package/src/services/peer-manager/peer_manager.ts +5 -4
  231. package/src/services/peer-manager/peer_scoring.ts +1 -5
  232. package/src/services/reqresp/connection-sampler/connection_sampler.ts +3 -1
  233. package/src/services/reqresp/constants.ts +14 -0
  234. package/src/services/reqresp/interface.ts +3 -3
  235. package/src/services/reqresp/metrics.ts +7 -23
  236. package/src/services/reqresp/protocols/auth.ts +2 -2
  237. package/src/services/reqresp/protocols/block.ts +1 -1
  238. package/src/services/reqresp/protocols/block_txs/bitvector.ts +9 -0
  239. package/src/services/reqresp/protocols/block_txs/block_txs_reqresp.ts +1 -1
  240. package/src/services/reqresp/protocols/status.ts +7 -4
  241. package/src/services/reqresp/protocols/tx.ts +1 -2
  242. package/src/services/service.ts +19 -4
  243. package/src/services/tx_collection/config.ts +1 -1
  244. package/src/services/tx_collection/instrumentation.ts +4 -21
  245. package/src/services/tx_collection/slow_tx_collection.ts +2 -2
  246. package/src/services/tx_collection/tx_collection.ts +4 -4
  247. package/src/services/tx_provider.ts +17 -2
  248. package/src/services/tx_provider_instrumentation.ts +18 -14
  249. package/src/test-helpers/mock-pubsub.ts +1 -1
  250. package/src/test-helpers/mock-tx-helpers.ts +1 -1
  251. package/src/test-helpers/reqresp-nodes.ts +1 -1
  252. package/src/testbench/p2p_client_testbench_worker.ts +37 -13
  253. package/src/testbench/worker_client_manager.ts +6 -1
  254. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts +0 -81
  255. package/dest/mem_pools/tx_pool/memory_tx_pool.d.ts.map +0 -1
  256. package/dest/mem_pools/tx_pool/memory_tx_pool.js +0 -239
  257. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts +0 -12
  258. package/dest/msg_validators/block_proposal_validator/block_proposal_validator.d.ts.map +0 -1
  259. package/dest/msg_validators/block_proposal_validator/index.d.ts +0 -2
  260. package/dest/msg_validators/block_proposal_validator/index.d.ts.map +0 -1
  261. package/dest/msg_validators/block_proposal_validator/index.js +0 -1
  262. package/src/mem_pools/tx_pool/memory_tx_pool.ts +0 -285
  263. 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
+ };
369
+ }
370
+ function _apply_decs_2203_r(targetClass, memberDecs, classDecs, parentClass) {
371
+ return (_apply_decs_2203_r = applyDecs2203RFactory())(targetClass, memberDecs, classDecs, parentClass);
6
372
  }
7
- import { BlockNumber, SlotNumber } from '@aztec/foundation/branded-types';
8
- import { randomInt } from '@aztec/foundation/crypto';
9
- import { Fr } from '@aztec/foundation/fields';
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 } 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({
266
724
  topicWeight: 1,
267
725
  invalidMessageDeliveriesWeight: -20,
268
726
  invalidMessageDeliveriesDecay: 0.5
269
727
  }),
270
- [blockProposalTopic]: createTopicScoreParams({
728
+ [checkpointProposalTopic]: createTopicScoreParams({
729
+ topicWeight: 1,
730
+ invalidMessageDeliveriesWeight: -20,
731
+ invalidMessageDeliveriesDecay: 0.5
732
+ }),
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,24 +1098,22 @@ 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 isValid = await this.validateCheckpointAttestation(source, attestation);
1108
+ const exists = isValid && await pool.hasCheckpointAttestation(attestation);
600
1109
  let canAdd = true;
601
1110
  if (isValid && !exists) {
602
1111
  const slot = attestation.payload.header.slotNumber;
603
1112
  const { committee } = await this.epochCache.getCommittee(slot);
604
1113
  const committeeSize = committee?.length ?? 0;
605
- canAdd = await pool.canAddAttestation(attestation, committeeSize);
1114
+ canAdd = await pool.canAddCheckpointAttestation(attestation, committeeSize);
606
1115
  }
607
- this.logger.trace(`Validate propagated block attestation`, {
1116
+ this.logger.trace(`Validate propagated checkpoint attestation`, {
608
1117
  isValid,
609
1118
  exists,
610
1119
  canAdd,
@@ -621,7 +1130,7 @@ import { P2PInstrumentation } from './instrumentation.js';
621
1130
  obj: attestation
622
1131
  };
623
1132
  } else if (!canAdd) {
624
- this.logger.warn(`Dropping block attestation due to per-(slot, proposalId) attestation cap`, {
1133
+ this.logger.warn(`Dropping checkpoint attestation due to per-(slot, proposalId) attestation cap`, {
625
1134
  slot: attestation.payload.header.slotNumber.toString(),
626
1135
  archive: attestation.archive.toString(),
627
1136
  source: source.toString()
@@ -637,17 +1146,17 @@ import { P2PInstrumentation } from './instrumentation.js';
637
1146
  };
638
1147
  }
639
1148
  };
640
- const { result, obj: attestation } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.block_attestation);
1149
+ const { result, obj: attestation } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.checkpoint_attestation);
641
1150
  if (result !== TopicValidatorResult.Accept || !attestation) {
642
1151
  return;
643
1152
  }
644
- this.logger.debug(`Received attestation for slot ${attestation.slotNumber} from external peer ${source.toString()}`, {
1153
+ this.logger.debug(`Received checkpoint attestation for slot ${attestation.slotNumber} from external peer ${source.toString()}`, {
645
1154
  p2pMessageIdentifier: await attestation.p2pMessageLoggingIdentifier(),
646
1155
  slot: attestation.slotNumber,
647
1156
  archive: attestation.archive.toString(),
648
1157
  source: source.toString()
649
1158
  });
650
- await this.mempools.attestationPool.addAttestations([
1159
+ await this.mempools.attestationPool.addCheckpointAttestations([
651
1160
  attestation
652
1161
  ]);
653
1162
  }
@@ -656,15 +1165,13 @@ import { P2PInstrumentation } from './instrumentation.js';
656
1165
  const block = BlockProposal.fromBuffer(payloadData);
657
1166
  const isValid = await this.validateBlockProposal(source, block);
658
1167
  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);
1168
+ const exists = isValid && await pool.hasBlockProposal(block);
1169
+ const canAdd = isValid && await pool.canAddProposal(block);
663
1170
  this.logger.trace(`Validate propagated block proposal`, {
664
1171
  isValid,
665
1172
  exists,
666
1173
  canAdd,
667
- [Attributes.SLOT_NUMBER]: block.payload.header.slotNumber.toString(),
1174
+ [Attributes.SLOT_NUMBER]: block.slotNumber.toString(),
668
1175
  [Attributes.P2P_ID]: source.toString()
669
1176
  });
670
1177
  if (!isValid) {
@@ -700,22 +1207,18 @@ import { P2PInstrumentation } from './instrumentation.js';
700
1207
  await this.processValidBlockProposal(block, source);
701
1208
  }
702
1209
  // REVIEW: callback pattern https://github.com/AztecProtocol/aztec-packages/issues/7963
1210
+ // REFACTOR(palla): This method should be moved to the p2p_client or to a separate component,
1211
+ // should not be here as it does not deal with p2p networking.
703
1212
  async processValidBlockProposal(block, sender) {
704
1213
  const slot = block.slotNumber;
705
- const previousSlot = SlotNumber(slot - 1);
706
1214
  this.logger.verbose(`Received block proposal for slot ${slot} from external peer ${sender.toString()}.`, {
707
1215
  p2pMessageIdentifier: await block.p2pMessageLoggingIdentifier(),
708
- slot: block.slotNumber,
709
- archive: block.archive.toString(),
710
- source: sender.toString()
1216
+ source: sender.toString(),
1217
+ ...block.toBlockInfo()
711
1218
  });
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
1219
+ // Attempt to add proposal
717
1220
  try {
718
- await this.mempools.attestationPool?.addBlockProposal(block);
1221
+ await this.mempools.attestationPool.addBlockProposal(block);
719
1222
  } catch (err) {
720
1223
  // Drop proposals if we hit per-slot cap in the attestation pool; rethrow unknown errors
721
1224
  if (err instanceof ProposalSlotCapExceededError) {
@@ -728,26 +1231,108 @@ import { P2PInstrumentation } from './instrumentation.js';
728
1231
  }
729
1232
  throw err;
730
1233
  }
1234
+ // Mark the txs in this proposal as non-evictable
731
1235
  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()
1236
+ // Call the block received callback to validate the proposal.
1237
+ // Note: Validators do NOT attest to individual blocks, only to checkpoint proposals.
1238
+ const isValid = await this.blockReceivedCallback(block, sender);
1239
+ if (!isValid) {
1240
+ this.logger.warn(`Block proposal validation failed for block ${block.blockNumber}`, block.toBlockInfo());
1241
+ }
1242
+ }
1243
+ /**
1244
+ * Handle a gossiped checkpoint proposal.
1245
+ * Validates and processes the checkpoint proposal, then triggers the callback for attestation.
1246
+ */ async handleGossipedCheckpointProposal(payloadData, msgId, source) {
1247
+ // TODO(palla/mbps): This pattern is repeated across multiple message handlers, consider abstracting it.
1248
+ const validationFunc = async ()=>{
1249
+ const checkpoint = CheckpointProposal.fromBuffer(payloadData);
1250
+ const isValid = await this.validateCheckpointProposal(source, checkpoint);
1251
+ const pool = this.mempools.attestationPool;
1252
+ const exists = isValid && await pool.hasCheckpointProposal(checkpoint);
1253
+ const canAdd = isValid && await pool.canAddCheckpointProposal(checkpoint);
1254
+ this.logger.trace(`Validate propagated checkpoint proposal`, {
1255
+ isValid,
1256
+ exists,
1257
+ canAdd,
1258
+ [Attributes.SLOT_NUMBER]: checkpoint.slotNumber.toString(),
1259
+ [Attributes.P2P_ID]: source.toString()
1260
+ });
1261
+ if (!isValid) {
1262
+ return {
1263
+ result: TopicValidatorResult.Reject
1264
+ };
1265
+ } else if (exists) {
1266
+ return {
1267
+ result: TopicValidatorResult.Ignore,
1268
+ obj: checkpoint
1269
+ };
1270
+ } else if (!canAdd) {
1271
+ this.peerManager.penalizePeer(source, PeerErrorSeverity.MidToleranceError);
1272
+ this.logger.warn(`Penalizing peer for checkpoint proposal exceeding per-slot cap`, {
1273
+ slot: checkpoint.slotNumber.toString(),
1274
+ archive: checkpoint.archive.toString(),
1275
+ source: source.toString()
741
1276
  });
742
- await this.broadcastAttestation(attestation);
1277
+ return {
1278
+ result: TopicValidatorResult.Reject
1279
+ };
1280
+ } else {
1281
+ return {
1282
+ result: TopicValidatorResult.Accept,
1283
+ obj: checkpoint
1284
+ };
743
1285
  }
1286
+ };
1287
+ const { result, obj: checkpoint } = await this.validateReceivedMessage(validationFunc, msgId, source, TopicType.checkpoint_proposal);
1288
+ if (result !== TopicValidatorResult.Accept || !checkpoint) {
1289
+ return;
744
1290
  }
1291
+ await this.processValidCheckpointProposal(checkpoint, source);
745
1292
  }
746
1293
  /**
747
- * Broadcast an attestation to all peers.
748
- * @param attestation - The attestation to broadcast.
749
- */ async broadcastAttestation(attestation) {
750
- await this.propagate(attestation);
1294
+ * Process a validated checkpoint proposal.
1295
+ * Extracts and processes the last block proposal (if present) first, then processes the checkpoint.
1296
+ * The block callback is invoked before the checkpoint callback.
1297
+ */ async processValidCheckpointProposal(checkpoint, sender) {
1298
+ const slot = checkpoint.slotNumber;
1299
+ this.logger.verbose(`Received checkpoint proposal for slot ${slot} from external peer ${sender.toString()}.`, {
1300
+ p2pMessageIdentifier: await checkpoint.p2pMessageLoggingIdentifier(),
1301
+ slot: checkpoint.slotNumber,
1302
+ archive: checkpoint.archive.toString(),
1303
+ source: sender.toString()
1304
+ });
1305
+ // Extract block proposal before adding to pool (pool stores them separately)
1306
+ const blockProposal = checkpoint.getBlockProposal();
1307
+ // Add proposal to the pool (this extracts and stores block proposal separately)
1308
+ await this.mempools.attestationPool.addCheckpointProposal(checkpoint);
1309
+ // Mark txs as non-evictable if present (from the last block)
1310
+ if (checkpoint.txHashes.length > 0) {
1311
+ await this.mempools.txPool.markTxsAsNonEvictable(checkpoint.txHashes);
1312
+ }
1313
+ // If there was a last block proposal, invoke the block callback first for validation.
1314
+ // Note: The block proposal is already stored in the pool by addCheckpointProposal.
1315
+ if (blockProposal) {
1316
+ const isValid = await this.blockReceivedCallback(blockProposal, sender);
1317
+ if (!isValid) {
1318
+ this.logger.warn(`Block proposal from checkpoint failed validation`, {
1319
+ slot: slot.toString(),
1320
+ archive: checkpoint.archive.toString(),
1321
+ blockNumber: blockProposal.blockNumber.toString()
1322
+ });
1323
+ return;
1324
+ }
1325
+ }
1326
+ // Call the checkpoint received callback with the core version (without lastBlock)
1327
+ // to validate and potentially generate attestations
1328
+ const attestations = await this.checkpointReceivedCallback(checkpoint.toCore(), sender);
1329
+ if (attestations && attestations.length > 0) {
1330
+ // If the callback returned attestations, add them to the pool and propagate them
1331
+ await this.mempools.attestationPool.addCheckpointAttestations(attestations);
1332
+ for (const attestation of attestations){
1333
+ await this.propagate(attestation);
1334
+ }
1335
+ }
751
1336
  }
752
1337
  /**
753
1338
  * Propagates provided message to peers.
@@ -797,7 +1382,7 @@ import { P2PInstrumentation } from './instrumentation.js';
797
1382
  throw new ValidationError(`Received more txs (${response.txs.length}) than requested-and-available (${maxReturnable})`);
798
1383
  }
799
1384
  // 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());
1385
+ const proposal = await this.mempools.attestationPool.getBlockProposal(request.blockHash.toString());
801
1386
  if (proposal) {
802
1387
  // Build intersected indices
803
1388
  const intersectIdx = request.txIndices.getTrueIndices().filter((i)=>response.txIndices.isSet(i));
@@ -1055,13 +1640,14 @@ import { P2PInstrumentation } from './instrumentation.js';
1055
1640
  return PeerErrorSeverity.HighToleranceError;
1056
1641
  }
1057
1642
  /**
1058
- * Validate an attestation.
1643
+ * Validate a checkpoint attestation.
1059
1644
  *
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);
1645
+ * @param attestation - The checkpoint attestation to validate.
1646
+ * @returns True if the checkpoint attestation is valid, false otherwise.
1647
+ */ async validateCheckpointAttestation(peerId, attestation) {
1648
+ const severity = await this.checkpointAttestationValidator.validate(attestation);
1064
1649
  if (severity) {
1650
+ this.logger.debug(`Penalizing peer ${peerId} for checkpoint attestation validation failure`);
1065
1651
  this.peerManager.penalizePeer(peerId, severity);
1066
1652
  return false;
1067
1653
  }
@@ -1081,6 +1667,20 @@ import { P2PInstrumentation } from './instrumentation.js';
1081
1667
  }
1082
1668
  return true;
1083
1669
  }
1670
+ /**
1671
+ * Validate a checkpoint proposal.
1672
+ *
1673
+ * @param checkpoint - The checkpoint proposal to validate.
1674
+ * @returns True if the checkpoint proposal is valid, false otherwise.
1675
+ */ async validateCheckpointProposal(peerId, checkpoint) {
1676
+ const severity = await this.checkpointProposalValidator.validate(checkpoint);
1677
+ if (severity) {
1678
+ this.logger.debug(`Penalizing peer ${peerId} for checkpoint proposal validation failure`);
1679
+ this.peerManager.penalizePeer(peerId, severity);
1680
+ return false;
1681
+ }
1682
+ return true;
1683
+ }
1084
1684
  getPeerScore(peerId) {
1085
1685
  return this.node.services.pubsub.score.score(peerId.toString());
1086
1686
  }
@@ -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);