@lodestar/beacon-node 1.40.0 → 1.41.0-dev.0087e7a664

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 (446) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +123 -4
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/state/index.js +8 -8
  5. package/lib/api/impl/beacon/state/index.js.map +1 -1
  6. package/lib/api/impl/beacon/state/utils.d.ts +3 -4
  7. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  8. package/lib/api/impl/beacon/state/utils.js +5 -24
  9. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  10. package/lib/api/impl/debug/index.d.ts.map +1 -1
  11. package/lib/api/impl/debug/index.js +6 -2
  12. package/lib/api/impl/debug/index.js.map +1 -1
  13. package/lib/api/impl/lightclient/index.d.ts.map +1 -1
  14. package/lib/api/impl/lightclient/index.js +19 -2
  15. package/lib/api/impl/lightclient/index.js.map +1 -1
  16. package/lib/api/impl/node/index.d.ts +1 -1
  17. package/lib/api/impl/node/index.d.ts.map +1 -1
  18. package/lib/api/impl/node/index.js +18 -1
  19. package/lib/api/impl/node/index.js.map +1 -1
  20. package/lib/api/impl/node/utils.d.ts +1 -1
  21. package/lib/api/impl/node/utils.d.ts.map +1 -1
  22. package/lib/api/impl/node/utils.js.map +1 -1
  23. package/lib/api/impl/validator/index.d.ts.map +1 -1
  24. package/lib/api/impl/validator/index.js +130 -16
  25. package/lib/api/impl/validator/index.js.map +1 -1
  26. package/lib/chain/archiveStore/archiveStore.d.ts +1 -0
  27. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  28. package/lib/chain/archiveStore/archiveStore.js +9 -0
  29. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  30. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +5 -6
  31. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  32. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +9 -10
  33. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  34. package/lib/chain/archiveStore/historicalState/worker.js +3 -3
  35. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  36. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts +3 -8
  37. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +1 -1
  38. package/lib/chain/archiveStore/utils/archiveBlocks.js +1 -1
  39. package/lib/chain/archiveStore/utils/archiveBlocks.js.map +1 -1
  40. package/lib/chain/archiveStore/utils/archivePayloads.d.ts +7 -0
  41. package/lib/chain/archiveStore/utils/archivePayloads.d.ts.map +1 -0
  42. package/lib/chain/archiveStore/utils/archivePayloads.js +10 -0
  43. package/lib/chain/archiveStore/utils/archivePayloads.js.map +1 -0
  44. package/lib/chain/archiveStore/utils/updateBackfillRange.js +1 -1
  45. package/lib/chain/archiveStore/utils/updateBackfillRange.js.map +1 -1
  46. package/lib/chain/blocks/blockInput/blockInput.d.ts +25 -2
  47. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  48. package/lib/chain/blocks/blockInput/blockInput.js +71 -0
  49. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  50. package/lib/chain/blocks/blockInput/types.d.ts +18 -1
  51. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  52. package/lib/chain/blocks/blockInput/types.js +1 -0
  53. package/lib/chain/blocks/blockInput/types.js.map +1 -1
  54. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  55. package/lib/chain/blocks/importBlock.js +27 -6
  56. package/lib/chain/blocks/importBlock.js.map +1 -1
  57. package/lib/chain/blocks/index.d.ts.map +1 -1
  58. package/lib/chain/blocks/index.js +2 -1
  59. package/lib/chain/blocks/index.js.map +1 -1
  60. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +1 -1
  61. package/lib/chain/blocks/verifyBlocksDataAvailability.js +3 -0
  62. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  63. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +4 -0
  64. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  65. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +5 -1
  66. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  67. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +1 -1
  68. package/lib/chain/blocks/verifyBlocksSanityChecks.js +4 -1
  69. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  70. package/lib/chain/blocks/writeBlockInputToDb.d.ts +12 -3
  71. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +1 -1
  72. package/lib/chain/blocks/writeBlockInputToDb.js +92 -95
  73. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  74. package/lib/chain/bls/multithread/index.d.ts +3 -3
  75. package/lib/chain/bls/multithread/index.d.ts.map +1 -1
  76. package/lib/chain/bls/multithread/index.js +5 -5
  77. package/lib/chain/bls/multithread/index.js.map +1 -1
  78. package/lib/chain/bls/multithread/jobItem.d.ts +2 -2
  79. package/lib/chain/bls/multithread/jobItem.d.ts.map +1 -1
  80. package/lib/chain/bls/multithread/jobItem.js +2 -2
  81. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  82. package/lib/chain/bls/singleThread.d.ts +4 -4
  83. package/lib/chain/bls/singleThread.d.ts.map +1 -1
  84. package/lib/chain/bls/singleThread.js +4 -4
  85. package/lib/chain/bls/singleThread.js.map +1 -1
  86. package/lib/chain/bls/utils.d.ts +2 -2
  87. package/lib/chain/bls/utils.d.ts.map +1 -1
  88. package/lib/chain/bls/utils.js +7 -4
  89. package/lib/chain/bls/utils.js.map +1 -1
  90. package/lib/chain/chain.d.ts +8 -11
  91. package/lib/chain/chain.d.ts.map +1 -1
  92. package/lib/chain/chain.js +45 -28
  93. package/lib/chain/chain.js.map +1 -1
  94. package/lib/chain/emitter.d.ts +5 -5
  95. package/lib/chain/emitter.d.ts.map +1 -1
  96. package/lib/chain/errors/blockError.d.ts +7 -1
  97. package/lib/chain/errors/blockError.d.ts.map +1 -1
  98. package/lib/chain/errors/blockError.js +2 -0
  99. package/lib/chain/errors/blockError.js.map +1 -1
  100. package/lib/chain/errors/executionPayloadBid.d.ts +1 -1
  101. package/lib/chain/errors/executionPayloadEnvelope.d.ts +2 -2
  102. package/lib/chain/errors/executionPayloadEnvelope.d.ts.map +1 -1
  103. package/lib/chain/errors/executionPayloadEnvelope.js.map +1 -1
  104. package/lib/chain/errors/payloadAttestation.d.ts +1 -1
  105. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  106. package/lib/chain/forkChoice/index.js +30 -24
  107. package/lib/chain/forkChoice/index.js.map +1 -1
  108. package/lib/chain/interface.d.ts +4 -6
  109. package/lib/chain/interface.d.ts.map +1 -1
  110. package/lib/chain/interface.js.map +1 -1
  111. package/lib/chain/lightClient/index.d.ts.map +1 -1
  112. package/lib/chain/lightClient/index.js +1 -1
  113. package/lib/chain/lightClient/index.js.map +1 -1
  114. package/lib/chain/opPools/aggregatedAttestationPool.js +1 -1
  115. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  116. package/lib/chain/options.d.ts.map +1 -1
  117. package/lib/chain/options.js.map +1 -1
  118. package/lib/chain/prepareNextSlot.js +3 -3
  119. package/lib/chain/prepareNextSlot.js.map +1 -1
  120. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +9 -2
  121. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  122. package/lib/chain/produceBlock/computeNewStateRoot.js +25 -2
  123. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  124. package/lib/chain/produceBlock/produceBlockBody.d.ts +22 -7
  125. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  126. package/lib/chain/produceBlock/produceBlockBody.js +109 -10
  127. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  128. package/lib/chain/regen/queued.d.ts.map +1 -1
  129. package/lib/chain/regen/queued.js +4 -1
  130. package/lib/chain/regen/queued.js.map +1 -1
  131. package/lib/chain/regen/regen.d.ts.map +1 -1
  132. package/lib/chain/regen/regen.js +6 -2
  133. package/lib/chain/regen/regen.js.map +1 -1
  134. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +5 -1
  135. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  136. package/lib/chain/seenCache/seenGossipBlockInput.js +36 -15
  137. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  138. package/lib/chain/validation/aggregateAndProof.js +1 -1
  139. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  140. package/lib/chain/validation/attestation.d.ts.map +1 -1
  141. package/lib/chain/validation/attestation.js +7 -4
  142. package/lib/chain/validation/attestation.js.map +1 -1
  143. package/lib/chain/validation/attesterSlashing.d.ts.map +1 -1
  144. package/lib/chain/validation/attesterSlashing.js +9 -2
  145. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  146. package/lib/chain/validation/blobSidecar.js +2 -2
  147. package/lib/chain/validation/blobSidecar.js.map +1 -1
  148. package/lib/chain/validation/block.d.ts.map +1 -1
  149. package/lib/chain/validation/block.js +33 -6
  150. package/lib/chain/validation/block.js.map +1 -1
  151. package/lib/chain/validation/dataColumnSidecar.d.ts +2 -2
  152. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  153. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  154. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  155. package/lib/chain/validation/executionPayloadBid.js +1 -2
  156. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  157. package/lib/chain/validation/executionPayloadEnvelope.js +6 -5
  158. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  159. package/lib/chain/validation/payloadAttestationMessage.js +9 -3
  160. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  161. package/lib/chain/validation/proposerSlashing.js +1 -1
  162. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  163. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  164. package/lib/db/beacon.d.ts +3 -1
  165. package/lib/db/beacon.d.ts.map +1 -1
  166. package/lib/db/beacon.js +5 -1
  167. package/lib/db/beacon.js.map +1 -1
  168. package/lib/db/buckets.d.ts +3 -1
  169. package/lib/db/buckets.d.ts.map +1 -1
  170. package/lib/db/buckets.js +2 -0
  171. package/lib/db/buckets.js.map +1 -1
  172. package/lib/db/index.d.ts +1 -0
  173. package/lib/db/index.d.ts.map +1 -1
  174. package/lib/db/index.js +1 -0
  175. package/lib/db/index.js.map +1 -1
  176. package/lib/db/interface.d.ts +3 -1
  177. package/lib/db/interface.d.ts.map +1 -1
  178. package/lib/db/repositories/blockArchive.d.ts.map +1 -1
  179. package/lib/db/repositories/blockArchive.js +1 -2
  180. package/lib/db/repositories/blockArchive.js.map +1 -1
  181. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  182. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  183. package/lib/db/repositories/dataColumnSidecar.d.ts +5 -3
  184. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  185. package/lib/db/repositories/dataColumnSidecar.js +14 -1
  186. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  187. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +5 -3
  188. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  189. package/lib/db/repositories/dataColumnSidecarArchive.js +14 -1
  190. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  191. package/lib/db/repositories/executionPayloadEnvelope.d.ts +19 -0
  192. package/lib/db/repositories/executionPayloadEnvelope.d.ts.map +1 -0
  193. package/lib/db/repositories/executionPayloadEnvelope.js +22 -0
  194. package/lib/db/repositories/executionPayloadEnvelope.js.map +1 -0
  195. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts +18 -0
  196. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts.map +1 -0
  197. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +28 -0
  198. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -0
  199. package/lib/db/repositories/index.d.ts +2 -0
  200. package/lib/db/repositories/index.d.ts.map +1 -1
  201. package/lib/db/repositories/index.js +2 -0
  202. package/lib/db/repositories/index.js.map +1 -1
  203. package/lib/execution/engine/http.d.ts +1 -0
  204. package/lib/execution/engine/http.d.ts.map +1 -1
  205. package/lib/execution/engine/http.js +3 -0
  206. package/lib/execution/engine/http.js.map +1 -1
  207. package/lib/execution/engine/interface.d.ts +3 -25
  208. package/lib/execution/engine/interface.d.ts.map +1 -1
  209. package/lib/execution/engine/interface.js +2 -20
  210. package/lib/execution/engine/interface.js.map +1 -1
  211. package/lib/metrics/metrics/beacon.d.ts +1 -0
  212. package/lib/metrics/metrics/beacon.d.ts.map +1 -1
  213. package/lib/metrics/metrics/beacon.js +5 -0
  214. package/lib/metrics/metrics/beacon.js.map +1 -1
  215. package/lib/metrics/metrics/lodestar.d.ts +9 -0
  216. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  217. package/lib/metrics/metrics/lodestar.js +18 -0
  218. package/lib/metrics/metrics/lodestar.js.map +1 -1
  219. package/lib/metrics/metrics.d.ts.map +1 -1
  220. package/lib/metrics/metrics.js +8 -3
  221. package/lib/metrics/metrics.js.map +1 -1
  222. package/lib/monitoring/service.d.ts +2 -2
  223. package/lib/monitoring/service.d.ts.map +1 -1
  224. package/lib/monitoring/service.js +3 -2
  225. package/lib/monitoring/service.js.map +1 -1
  226. package/lib/network/core/networkCore.d.ts +3 -3
  227. package/lib/network/core/networkCore.d.ts.map +1 -1
  228. package/lib/network/core/networkCore.js.map +1 -1
  229. package/lib/network/core/networkCoreWorkerHandler.d.ts +3 -3
  230. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +1 -1
  231. package/lib/network/core/types.d.ts +2 -2
  232. package/lib/network/core/types.d.ts.map +1 -1
  233. package/lib/network/events.d.ts +2 -1
  234. package/lib/network/events.d.ts.map +1 -1
  235. package/lib/network/events.js.map +1 -1
  236. package/lib/network/gossip/encoding.d.ts +3 -3
  237. package/lib/network/gossip/encoding.d.ts.map +1 -1
  238. package/lib/network/gossip/encoding.js.map +1 -1
  239. package/lib/network/gossip/gossipsub.d.ts +13 -4
  240. package/lib/network/gossip/gossipsub.d.ts.map +1 -1
  241. package/lib/network/gossip/gossipsub.js +47 -20
  242. package/lib/network/gossip/gossipsub.js.map +1 -1
  243. package/lib/network/gossip/interface.d.ts +6 -6
  244. package/lib/network/gossip/interface.d.ts.map +1 -1
  245. package/lib/network/gossip/scoringParameters.d.ts +1 -1
  246. package/lib/network/gossip/scoringParameters.d.ts.map +1 -1
  247. package/lib/network/gossip/scoringParameters.js +1 -1
  248. package/lib/network/gossip/scoringParameters.js.map +1 -1
  249. package/lib/network/gossip/topic.d.ts +114 -65
  250. package/lib/network/gossip/topic.d.ts.map +1 -1
  251. package/lib/network/gossip/topic.js +2 -2
  252. package/lib/network/gossip/topic.js.map +1 -1
  253. package/lib/network/interface.d.ts +6 -5
  254. package/lib/network/interface.d.ts.map +1 -1
  255. package/lib/network/libp2p/index.d.ts +1 -1
  256. package/lib/network/libp2p/index.d.ts.map +1 -1
  257. package/lib/network/libp2p/index.js +7 -2
  258. package/lib/network/libp2p/index.js.map +1 -1
  259. package/lib/network/network.d.ts +5 -4
  260. package/lib/network/network.d.ts.map +1 -1
  261. package/lib/network/network.js +11 -2
  262. package/lib/network/network.js.map +1 -1
  263. package/lib/network/options.d.ts.map +1 -1
  264. package/lib/network/options.js +3 -0
  265. package/lib/network/options.js.map +1 -1
  266. package/lib/network/peers/datastore.d.ts +7 -5
  267. package/lib/network/peers/datastore.d.ts.map +1 -1
  268. package/lib/network/peers/datastore.js +10 -10
  269. package/lib/network/peers/datastore.js.map +1 -1
  270. package/lib/network/peers/peerManager.d.ts +3 -0
  271. package/lib/network/peers/peerManager.d.ts.map +1 -1
  272. package/lib/network/peers/peerManager.js +103 -53
  273. package/lib/network/peers/peerManager.js.map +1 -1
  274. package/lib/network/peers/utils/prioritizePeers.d.ts +3 -3
  275. package/lib/network/peers/utils/prioritizePeers.d.ts.map +1 -1
  276. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  277. package/lib/network/processor/gossipHandlers.js +9 -2
  278. package/lib/network/processor/gossipHandlers.js.map +1 -1
  279. package/lib/network/processor/gossipValidatorFn.js +1 -1
  280. package/lib/network/processor/types.d.ts +1 -1
  281. package/lib/network/processor/types.d.ts.map +1 -1
  282. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  283. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +3 -2
  284. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  285. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  286. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +3 -2
  287. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  288. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +1 -1
  289. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  290. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  291. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +3 -2
  292. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  293. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js +1 -1
  294. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.js.map +1 -1
  295. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +1 -1
  296. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js +7 -1
  297. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js.map +1 -1
  298. package/lib/network/reqresp/score.d.ts.map +1 -1
  299. package/lib/network/reqresp/score.js +0 -1
  300. package/lib/network/reqresp/score.js.map +1 -1
  301. package/lib/network/reqresp/utils/collect.d.ts +1 -1
  302. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts +1 -1
  303. package/lib/network/util.js +2 -2
  304. package/lib/network/util.js.map +1 -1
  305. package/lib/node/nodejs.d.ts +3 -5
  306. package/lib/node/nodejs.d.ts.map +1 -1
  307. package/lib/node/nodejs.js +6 -4
  308. package/lib/node/nodejs.js.map +1 -1
  309. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  310. package/lib/sync/utils/downloadByRange.js +3 -9
  311. package/lib/sync/utils/downloadByRange.js.map +1 -1
  312. package/lib/sync/utils/downloadByRoot.d.ts +2 -2
  313. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  314. package/lib/sync/utils/downloadByRoot.js +4 -4
  315. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  316. package/lib/sync/utils/remoteSyncType.d.ts +1 -1
  317. package/lib/util/blobs.d.ts +2 -2
  318. package/lib/util/blobs.d.ts.map +1 -1
  319. package/lib/util/blobs.js.map +1 -1
  320. package/lib/util/clock.d.ts +6 -0
  321. package/lib/util/clock.d.ts.map +1 -1
  322. package/lib/util/clock.js +9 -3
  323. package/lib/util/clock.js.map +1 -1
  324. package/lib/util/dataColumns.d.ts +15 -2
  325. package/lib/util/dataColumns.d.ts.map +1 -1
  326. package/lib/util/dataColumns.js +40 -5
  327. package/lib/util/dataColumns.js.map +1 -1
  328. package/lib/util/multifork.d.ts +8 -0
  329. package/lib/util/multifork.d.ts.map +1 -1
  330. package/lib/util/multifork.js +37 -0
  331. package/lib/util/multifork.js.map +1 -1
  332. package/lib/util/serializedCache.d.ts +7 -2
  333. package/lib/util/serializedCache.d.ts.map +1 -1
  334. package/lib/util/serializedCache.js +9 -2
  335. package/lib/util/serializedCache.js.map +1 -1
  336. package/package.json +39 -42
  337. package/src/api/impl/beacon/blocks/index.ts +147 -3
  338. package/src/api/impl/beacon/state/index.ts +8 -8
  339. package/src/api/impl/beacon/state/utils.ts +15 -29
  340. package/src/api/impl/debug/index.ts +9 -5
  341. package/src/api/impl/lightclient/index.ts +19 -2
  342. package/src/api/impl/node/index.ts +22 -1
  343. package/src/api/impl/node/utils.ts +3 -3
  344. package/src/api/impl/validator/index.ts +153 -17
  345. package/src/chain/archiveStore/archiveStore.ts +15 -5
  346. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -11
  347. package/src/chain/archiveStore/historicalState/worker.ts +3 -3
  348. package/src/chain/archiveStore/utils/archiveBlocks.ts +4 -5
  349. package/src/chain/archiveStore/utils/archivePayloads.ts +15 -0
  350. package/src/chain/archiveStore/utils/updateBackfillRange.ts +1 -1
  351. package/src/chain/blocks/blockInput/blockInput.ts +103 -3
  352. package/src/chain/blocks/blockInput/types.ts +18 -0
  353. package/src/chain/blocks/importBlock.ts +35 -7
  354. package/src/chain/blocks/index.ts +2 -1
  355. package/src/chain/blocks/verifyBlocksDataAvailability.ts +3 -0
  356. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +9 -2
  357. package/src/chain/blocks/verifyBlocksSanityChecks.ts +7 -2
  358. package/src/chain/blocks/writeBlockInputToDb.ts +105 -101
  359. package/src/chain/bls/multithread/index.ts +7 -7
  360. package/src/chain/bls/multithread/jobItem.ts +3 -3
  361. package/src/chain/bls/singleThread.ts +5 -5
  362. package/src/chain/bls/utils.ts +8 -5
  363. package/src/chain/chain.ts +82 -45
  364. package/src/chain/emitter.ts +5 -5
  365. package/src/chain/errors/blockError.ts +4 -1
  366. package/src/chain/errors/executionPayloadBid.ts +1 -1
  367. package/src/chain/errors/executionPayloadEnvelope.ts +6 -2
  368. package/src/chain/errors/payloadAttestation.ts +1 -1
  369. package/src/chain/forkChoice/index.ts +39 -21
  370. package/src/chain/interface.ts +4 -11
  371. package/src/chain/lightClient/index.ts +4 -1
  372. package/src/chain/opPools/aggregatedAttestationPool.ts +1 -1
  373. package/src/chain/options.ts +1 -0
  374. package/src/chain/prepareNextSlot.ts +5 -5
  375. package/src/chain/produceBlock/computeNewStateRoot.ts +36 -3
  376. package/src/chain/produceBlock/produceBlockBody.ts +162 -13
  377. package/src/chain/regen/queued.ts +7 -2
  378. package/src/chain/regen/regen.ts +9 -3
  379. package/src/chain/seenCache/seenGossipBlockInput.ts +54 -17
  380. package/src/chain/validation/aggregateAndProof.ts +1 -1
  381. package/src/chain/validation/attestation.ts +7 -4
  382. package/src/chain/validation/attesterSlashing.ts +10 -1
  383. package/src/chain/validation/blobSidecar.ts +2 -2
  384. package/src/chain/validation/block.ts +40 -7
  385. package/src/chain/validation/dataColumnSidecar.ts +3 -6
  386. package/src/chain/validation/executionPayloadBid.ts +1 -2
  387. package/src/chain/validation/executionPayloadEnvelope.ts +6 -5
  388. package/src/chain/validation/payloadAttestationMessage.ts +11 -4
  389. package/src/chain/validation/proposerSlashing.ts +1 -1
  390. package/src/chain/validation/syncCommitteeContributionAndProof.ts +1 -1
  391. package/src/db/beacon.ts +8 -0
  392. package/src/db/buckets.ts +3 -0
  393. package/src/db/index.ts +1 -0
  394. package/src/db/interface.ts +5 -0
  395. package/src/db/repositories/blockArchive.ts +1 -2
  396. package/src/db/repositories/dataColumnSidecar.ts +18 -3
  397. package/src/db/repositories/dataColumnSidecarArchive.ts +18 -3
  398. package/src/db/repositories/executionPayloadEnvelope.ts +26 -0
  399. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +32 -0
  400. package/src/db/repositories/index.ts +2 -0
  401. package/src/execution/engine/http.ts +3 -0
  402. package/src/execution/engine/interface.ts +3 -27
  403. package/src/metrics/metrics/beacon.ts +5 -0
  404. package/src/metrics/metrics/lodestar.ts +18 -0
  405. package/src/metrics/metrics.ts +8 -3
  406. package/src/monitoring/service.ts +3 -2
  407. package/src/network/core/networkCore.ts +3 -3
  408. package/src/network/core/networkCoreWorkerHandler.ts +3 -3
  409. package/src/network/core/types.ts +2 -2
  410. package/src/network/events.ts +2 -1
  411. package/src/network/gossip/encoding.ts +3 -3
  412. package/src/network/gossip/gossipsub.ts +86 -25
  413. package/src/network/gossip/interface.ts +6 -6
  414. package/src/network/gossip/scoringParameters.ts +4 -4
  415. package/src/network/gossip/topic.ts +2 -1
  416. package/src/network/interface.ts +7 -4
  417. package/src/network/libp2p/index.ts +8 -3
  418. package/src/network/network.ts +26 -7
  419. package/src/network/options.ts +3 -0
  420. package/src/network/peers/datastore.ts +13 -10
  421. package/src/network/peers/peerManager.ts +118 -54
  422. package/src/network/peers/utils/prioritizePeers.ts +3 -3
  423. package/src/network/processor/gossipHandlers.ts +19 -4
  424. package/src/network/processor/gossipValidatorFn.ts +2 -2
  425. package/src/network/processor/types.ts +1 -1
  426. package/src/network/reqresp/ReqRespBeaconNode.ts +1 -1
  427. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +4 -3
  428. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +3 -2
  429. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +1 -1
  430. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +4 -3
  431. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +2 -2
  432. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +6 -1
  433. package/src/network/reqresp/score.ts +0 -1
  434. package/src/network/reqresp/utils/collect.ts +1 -1
  435. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +1 -1
  436. package/src/network/util.ts +2 -2
  437. package/src/node/nodejs.ts +8 -9
  438. package/src/sync/utils/downloadByRange.ts +3 -15
  439. package/src/sync/utils/downloadByRoot.ts +6 -12
  440. package/src/sync/utils/remoteSyncType.ts +1 -1
  441. package/src/util/blobs.ts +3 -3
  442. package/src/util/clock.ts +9 -4
  443. package/src/util/dataColumns.ts +54 -5
  444. package/src/util/multifork.ts +45 -0
  445. package/src/util/serializedCache.ts +10 -3
  446. package/src/util/workerEvents.ts +1 -1
@@ -1,24 +1,18 @@
1
1
  import {routes} from "@lodestar/api";
2
2
  import {ChainForkConfig} from "@lodestar/config";
3
- import {
4
- ForkPostDeneb,
5
- ForkPostFulu,
6
- ForkPreFulu,
7
- ForkPreGloas,
8
- isForkPostDeneb,
9
- isForkPostFulu,
10
- } from "@lodestar/params";
11
- import {BeaconBlockBody, BlobIndex, ColumnIndex, SignedBeaconBlock, Slot, deneb, fulu} from "@lodestar/types";
3
+ import {ForkPostDeneb, ForkPostFulu, ForkPreFulu, isForkPostDeneb, isForkPostFulu} from "@lodestar/params";
4
+ import {BlobIndex, ColumnIndex, SignedBeaconBlock, Slot, deneb, fulu} from "@lodestar/types";
12
5
  import {LodestarError, byteArrayEquals, fromHex, prettyPrintIndices, toHex, toRootHex} from "@lodestar/utils";
13
6
  import {isBlockInputBlobs, isBlockInputColumns} from "../../chain/blocks/blockInput/blockInput.js";
14
7
  import {BlockInputSource, IBlockInput} from "../../chain/blocks/blockInput/types.js";
15
8
  import {ChainEventEmitter} from "../../chain/emitter.js";
16
- import {IBeaconChain} from "../../chain/interface.ts";
9
+ import {IBeaconChain} from "../../chain/interface.js";
17
10
  import {validateBlockBlobSidecars} from "../../chain/validation/blobSidecar.js";
18
11
  import {validateBlockDataColumnSidecars} from "../../chain/validation/dataColumnSidecar.js";
19
12
  import {INetwork} from "../../network/interface.js";
20
13
  import {PeerSyncMeta} from "../../network/peers/peersData.js";
21
14
  import {prettyPrintPeerIdStr} from "../../network/util.js";
15
+ import {getBlobKzgCommitments} from "../../util/dataColumns.js";
22
16
  import {PeerIdStr} from "../../util/peerId.js";
23
17
  import {WarnResult} from "../../util/wrapError.js";
24
18
  import {
@@ -378,14 +372,14 @@ export async function fetchAndValidateColumns({
378
372
  chain,
379
373
  network,
380
374
  peerMeta,
375
+ forkName,
381
376
  block,
382
377
  blockRoot,
383
378
  missing,
384
379
  }: FetchByRootAndValidateColumnsProps): Promise<WarnResult<fulu.DataColumnSidecars, DownloadByRootError>> {
385
380
  const {peerId: peerIdStr} = peerMeta;
386
381
  const slot = block.message.slot;
387
- // TODO GLOAS: Get blob count from somewhere else since blobKzgCommitments is absent from block body
388
- const blobCount = (block.message.body as BeaconBlockBody<ForkPostFulu & ForkPreGloas>).blobKzgCommitments.length;
382
+ const blobCount = getBlobKzgCommitments(forkName, block).length;
389
383
  if (blobCount === 0) {
390
384
  return {result: [], warnings: null};
391
385
  }
@@ -1,7 +1,7 @@
1
1
  import {IForkChoice} from "@lodestar/fork-choice";
2
2
  import {computeEpochAtSlot, computeStartSlotAtEpoch} from "@lodestar/state-transition";
3
3
  import {Slot, Status} from "@lodestar/types";
4
- import {IBeaconChain} from "../../chain/interface.ts";
4
+ import {IBeaconChain} from "../../chain/interface.js";
5
5
  import {ChainTarget} from "../range/utils/index.js";
6
6
 
7
7
  /** The type of peer relative to our current state */
package/src/util/blobs.ts CHANGED
@@ -13,7 +13,7 @@ import {
13
13
  VERSIONED_HASH_VERSION_KZG,
14
14
  } from "@lodestar/params";
15
15
  import {signedBlockToSignedHeader} from "@lodestar/state-transition";
16
- import {BeaconBlockBody, SSZTypesFor, SignedBeaconBlock, deneb, fulu, ssz} from "@lodestar/types";
16
+ import {BeaconBlockBody, DataColumnSidecars, SSZTypesFor, SignedBeaconBlock, deneb, fulu, ssz} from "@lodestar/types";
17
17
  import {kzg} from "./kzg.js";
18
18
 
19
19
  type VersionHash = Uint8Array;
@@ -149,7 +149,7 @@ export async function dataColumnMatrixRecovery(
149
149
  * Reconstruct blobs from a set of data columns, at least 50%+ of all the columns
150
150
  * must be provided to allow to reconstruct the full data matrix
151
151
  */
152
- export async function reconstructBlobs(sidecars: fulu.DataColumnSidecars, indices?: number[]): Promise<deneb.Blobs> {
152
+ export async function reconstructBlobs(sidecars: DataColumnSidecars, indices?: number[]): Promise<deneb.Blobs> {
153
153
  if (sidecars.length < NUMBER_OF_COLUMNS / 2) {
154
154
  throw Error(
155
155
  `Expected at least ${NUMBER_OF_COLUMNS / 2} data columns to reconstruct blobs, received ${sidecars.length}`
@@ -188,7 +188,7 @@ export async function reconstructBlobs(sidecars: fulu.DataColumnSidecars, indice
188
188
  * Recover cells for specific blob indices from a set of data columns
189
189
  */
190
190
  async function recoverBlobCells(
191
- partialSidecars: fulu.DataColumnSidecar[],
191
+ partialSidecars: DataColumnSidecars,
192
192
  blobIndices: number[]
193
193
  ): Promise<Map<number, fulu.Cell[]> | null> {
194
194
  const columnCount = partialSidecars.length;
package/src/util/clock.ts CHANGED
@@ -92,15 +92,17 @@ export class Clock extends EventEmitter implements IClock {
92
92
  }
93
93
  return slot;
94
94
  }
95
-
96
95
  /**
97
96
  * If it's too close to next slot given MAXIMUM_GOSSIP_CLOCK_DISPARITY, return currentSlot + 1.
98
97
  * Otherwise return currentSlot
98
+ *
99
+ * Spec: phase0/p2p-interface.md - gossip validation uses `current_time + MAXIMUM_GOSSIP_CLOCK_DISPARITY < message_time`
100
+ * to reject future messages (strict `<`), so the boundary (exactly equal) is accepted, hence `<=` here.
99
101
  */
100
102
  get currentSlotWithGossipDisparity(): Slot {
101
103
  const currentSlot = this.currentSlot;
102
104
  const nextSlotTime = computeTimeAtSlot(this.config, currentSlot + 1, this.genesisTime) * 1000;
103
- return nextSlotTime - Date.now() < this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY ? currentSlot + 1 : currentSlot;
105
+ return nextSlotTime - Date.now() <= this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY ? currentSlot + 1 : currentSlot;
104
106
  }
105
107
 
106
108
  get currentEpoch(): Epoch {
@@ -121,6 +123,9 @@ export class Clock extends EventEmitter implements IClock {
121
123
 
122
124
  /**
123
125
  * Check if a slot is current slot given MAXIMUM_GOSSIP_CLOCK_DISPARITY.
126
+ *
127
+ * Uses `<=` for disparity checks because the spec rejects with strict `<`
128
+ * (phase0/p2p-interface.md), meaning the boundary (exactly equal) is accepted.
124
129
  */
125
130
  isCurrentSlotGivenGossipDisparity(slot: Slot): boolean {
126
131
  const currentSlot = this.currentSlot;
@@ -129,12 +134,12 @@ export class Clock extends EventEmitter implements IClock {
129
134
  }
130
135
  const nextSlotTime = computeTimeAtSlot(this.config, currentSlot + 1, this.genesisTime) * 1000;
131
136
  // we're too close to next slot, accept next slot
132
- if (nextSlotTime - Date.now() < this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY) {
137
+ if (nextSlotTime - Date.now() <= this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY) {
133
138
  return slot === currentSlot + 1;
134
139
  }
135
140
  const currentSlotTime = computeTimeAtSlot(this.config, currentSlot, this.genesisTime) * 1000;
136
141
  // we've just passed the current slot, accept previous slot
137
- if (Date.now() - currentSlotTime < this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY) {
142
+ if (Date.now() - currentSlotTime <= this.config.MAXIMUM_GOSSIP_CLOCK_DISPARITY) {
138
143
  return slot === currentSlot - 1;
139
144
  }
140
145
  return false;
@@ -4,21 +4,26 @@ import {ChainForkConfig} from "@lodestar/config";
4
4
  import {
5
5
  ForkAll,
6
6
  ForkName,
7
+ ForkPostDeneb,
7
8
  ForkPostFulu,
8
9
  ForkPreGloas,
9
10
  KZG_COMMITMENTS_GINDEX,
10
11
  NUMBER_OF_COLUMNS,
12
+ isForkPostGloas,
11
13
  } from "@lodestar/params";
12
14
  import {signedBlockToSignedHeader} from "@lodestar/state-transition";
13
15
  import {
14
16
  BeaconBlockBody,
15
17
  ColumnIndex,
16
18
  CustodyIndex,
19
+ Root,
17
20
  SSZTypesFor,
18
21
  SignedBeaconBlock,
19
22
  SignedBeaconBlockHeader,
23
+ Slot,
20
24
  deneb,
21
25
  fulu,
26
+ gloas,
22
27
  ssz,
23
28
  } from "@lodestar/types";
24
29
  import {bytesToBigInt} from "@lodestar/utils";
@@ -261,6 +266,20 @@ export async function getCellsAndProofs(
261
266
  return blobsAndProofs;
262
267
  }
263
268
 
269
+ /**
270
+ * Get blob KZG commitments from a signed block, handling the different locations
271
+ * in pre-Gloas (directly in block body) vs post-Gloas (in execution payload bid).
272
+ */
273
+ export function getBlobKzgCommitments(
274
+ fork: ForkName,
275
+ signedBlock: SignedBeaconBlock<ForkPostDeneb>
276
+ ): deneb.KZGCommitment[] {
277
+ if (isForkPostGloas(fork)) {
278
+ return (signedBlock as gloas.SignedBeaconBlock).message.body.signedExecutionPayloadBid.message.blobKzgCommitments;
279
+ }
280
+ return (signedBlock.message.body as BeaconBlockBody<ForkPostFulu & ForkPreGloas>).blobKzgCommitments;
281
+ }
282
+
264
283
  /**
265
284
  * Given a signed block header and the commitments, inclusion proof, cells/proofs associated with
266
285
  * each blob in the block, assemble the sidecars which can be distributed to peers.
@@ -310,16 +329,13 @@ export function getDataColumnSidecarsFromBlock(
310
329
  signedBlock: SignedBeaconBlock<ForkPostFulu>,
311
330
  cellsAndKzgProofs: {cells: Uint8Array[]; proofs: Uint8Array[]}[]
312
331
  ): fulu.DataColumnSidecars {
313
- // TODO GLOAS: Need to get blobKzgCommitments from somewhere else
314
- const blobKzgCommitments = (signedBlock.message.body as BeaconBlockBody<ForkPostFulu & ForkPreGloas>)
315
- .blobKzgCommitments;
332
+ const fork = config.getForkName(signedBlock.message.slot);
333
+ const blobKzgCommitments = getBlobKzgCommitments(fork, signedBlock);
316
334
 
317
335
  // No need to create data column sidecars if there are no blobs
318
336
  if (blobKzgCommitments.length === 0) {
319
337
  return [];
320
338
  }
321
-
322
- const fork = config.getForkName(signedBlock.message.slot);
323
339
  const signedBlockHeader = signedBlockToSignedHeader(config, signedBlock);
324
340
 
325
341
  const kzgCommitmentsInclusionProof = computePostFuluKzgCommitmentsInclusionProof(fork, signedBlock.message.body);
@@ -346,6 +362,39 @@ export function getDataColumnSidecarsFromColumnSidecar(
346
362
  );
347
363
  }
348
364
 
365
+ /**
366
+ * In Gloas, data column sidecars have a simplified structure with `slot` and `beaconBlockRoot`
367
+ * instead of `signedBlockHeader`, `kzgCommitments`, and `kzgCommitmentsInclusionProof`.
368
+ */
369
+ export function getDataColumnSidecarsForGloas(
370
+ slot: Slot,
371
+ beaconBlockRoot: Root,
372
+ cellsAndKzgProofs: {cells: Uint8Array[]; proofs: Uint8Array[]}[]
373
+ ): gloas.DataColumnSidecars {
374
+ // No need to create data column sidecars if there are no blobs
375
+ if (cellsAndKzgProofs.length === 0) {
376
+ return [];
377
+ }
378
+
379
+ const sidecars: gloas.DataColumnSidecars = [];
380
+ for (let columnIndex = 0; columnIndex < NUMBER_OF_COLUMNS; columnIndex++) {
381
+ const column: Uint8Array[] = [];
382
+ const kzgProofs: Uint8Array[] = [];
383
+ for (const {cells, proofs} of cellsAndKzgProofs) {
384
+ column.push(cells[columnIndex]);
385
+ kzgProofs.push(proofs[columnIndex]);
386
+ }
387
+ sidecars.push({
388
+ index: columnIndex,
389
+ column,
390
+ kzgProofs,
391
+ slot,
392
+ beaconBlockRoot,
393
+ });
394
+ }
395
+ return sidecars;
396
+ }
397
+
349
398
  /**
350
399
  * If we receive more than half of NUMBER_OF_COLUMNS (64) we should recover all remaining columns
351
400
  */
@@ -9,6 +9,11 @@ import {getSlotFromSignedBeaconBlockSerialized} from "./sszBytes.js";
9
9
  */
10
10
  const SLOT_BYTE_COUNT = 8;
11
11
 
12
+ /**
13
+ * SSZ offset uint32
14
+ */
15
+ const OFFSET_BYTE_COUNT = 4;
16
+
12
17
  /**
13
18
  * 8 + 32 = 40
14
19
  * ```
@@ -67,3 +72,43 @@ export function getLightClientHeaderTypeFromBytes(
67
72
  );
68
73
  return config.getPostAltairForkTypes(slot).LightClientHeader;
69
74
  }
75
+
76
+ /**
77
+ * Position of first offset in DataColumnSidecar (after index field)
78
+ *
79
+ * Fulu DataColumnSidecar (6 fields):
80
+ * index: uint64 [fixed - 8 bytes]
81
+ * column: List [variable - 4-byte offset]
82
+ * kzgCommitments: List [variable - 4-byte offset]
83
+ * kzgProofs: List [variable - 4-byte offset]
84
+ * signedBlockHeader: Container [fixed - 208 bytes]
85
+ * kzgCommitmentsInclusionProof: Vector[Bytes32, 4] [fixed - 128 bytes]
86
+ * => First offset value = 8 + 4 + 4 + 4 + 208 + 128 = 356
87
+ *
88
+ * Gloas DataColumnSidecar (5 fields):
89
+ * index: uint64 [fixed - 8 bytes]
90
+ * column: List [variable - 4-byte offset]
91
+ * kzgProofs: List [variable - 4-byte offset]
92
+ * slot: uint64 [fixed - 8 bytes]
93
+ * beaconBlockRoot: Bytes32 [fixed - 32 bytes]
94
+ * => First offset value = 8 + 4 + 4 + 8 + 32 = 56
95
+ */
96
+ const FIRST_OFFSET_POSITION_IN_DATA_COLUMN_SIDECAR = 8;
97
+ const GLOAS_DATA_COLUMN_SIDECAR_FIRST_OFFSET = 56;
98
+
99
+ /**
100
+ * Determines if DataColumnSidecar bytes are from Gloas fork by checking the SSZ offset structure.
101
+ *
102
+ * The first offset (bytes 8-12) indicates where variable-size data begins:
103
+ * - Gloas: 56 (small fixed section)
104
+ * - Fulu: 356
105
+ */
106
+ export function isGloasDataColumnSidecarBytes(bytes: Uint8Array): boolean {
107
+ const firstOffset = bytesToInt(
108
+ bytes.subarray(
109
+ FIRST_OFFSET_POSITION_IN_DATA_COLUMN_SIDECAR,
110
+ FIRST_OFFSET_POSITION_IN_DATA_COLUMN_SIDECAR + OFFSET_BYTE_COUNT
111
+ )
112
+ );
113
+ return firstOffset === GLOAS_DATA_COLUMN_SIDECAR_FIRST_OFFSET;
114
+ }
@@ -4,7 +4,7 @@
4
4
  * This is a thin wrapper around WeakMap
5
5
  */
6
6
  export class SerializedCache {
7
- map: WeakMap<object, Uint8Array> = new WeakMap();
7
+ private map: WeakMap<object, Uint8Array> = new WeakMap();
8
8
 
9
9
  get(obj: object): Uint8Array | undefined {
10
10
  return this.map.get(obj);
@@ -14,7 +14,14 @@ export class SerializedCache {
14
14
  this.map.set(obj, serialized);
15
15
  }
16
16
 
17
- clear(): void {
18
- this.map = new WeakMap();
17
+ /**
18
+ * Delete cached serialized entries for the provided object references.
19
+ * Must only be called after all DB writes that read from this cache for these objects have completed,
20
+ * otherwise cached serialized bytes will be unavailable and data will be re-serialized unnecessarily.
21
+ */
22
+ delete(objs: object[]): void {
23
+ for (const obj of objs) {
24
+ this.map.delete(obj);
25
+ }
19
26
  }
20
27
  }
@@ -1,5 +1,5 @@
1
1
  import {MessagePort, Worker} from "node:worker_threads";
2
- import {Message} from "@libp2p/interface";
2
+ import type {Message} from "@libp2p/gossipsub";
3
3
  import {Thread} from "@chainsafe/threads";
4
4
  import {Logger} from "@lodestar/logger";
5
5
  import {sleep} from "@lodestar/utils";