@lodestar/beacon-node 1.22.0 → 1.23.0-dev.06b4c2d324

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 (637) hide show
  1. package/lib/api/impl/api.js.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +27 -28
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/blocks/utils.d.ts +1 -1
  5. package/lib/api/impl/beacon/blocks/utils.js +2 -2
  6. package/lib/api/impl/beacon/blocks/utils.js.map +1 -1
  7. package/lib/api/impl/beacon/index.js +1 -1
  8. package/lib/api/impl/beacon/index.js.map +1 -1
  9. package/lib/api/impl/beacon/pool/index.js +18 -28
  10. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  11. package/lib/api/impl/beacon/state/index.js +39 -5
  12. package/lib/api/impl/beacon/state/index.js.map +1 -1
  13. package/lib/api/impl/beacon/state/utils.d.ts +3 -7
  14. package/lib/api/impl/beacon/state/utils.js +24 -36
  15. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  16. package/lib/api/impl/config/constants.d.ts +0 -1
  17. package/lib/api/impl/config/constants.js +1 -3
  18. package/lib/api/impl/config/constants.js.map +1 -1
  19. package/lib/api/impl/config/index.js.map +1 -1
  20. package/lib/api/impl/debug/index.js +31 -1
  21. package/lib/api/impl/debug/index.js.map +1 -1
  22. package/lib/api/impl/errors.d.ts +8 -0
  23. package/lib/api/impl/errors.js +7 -0
  24. package/lib/api/impl/errors.js.map +1 -1
  25. package/lib/api/impl/events/index.js +1 -2
  26. package/lib/api/impl/events/index.js.map +1 -1
  27. package/lib/api/impl/lightclient/index.js +1 -1
  28. package/lib/api/impl/lightclient/index.js.map +1 -1
  29. package/lib/api/impl/lodestar/index.js +5 -5
  30. package/lib/api/impl/lodestar/index.js.map +1 -1
  31. package/lib/api/impl/node/index.d.ts +1 -1
  32. package/lib/api/impl/node/index.js +2 -4
  33. package/lib/api/impl/node/index.js.map +1 -1
  34. package/lib/api/impl/node/utils.js +1 -0
  35. package/lib/api/impl/node/utils.js.map +1 -1
  36. package/lib/api/impl/proof/index.d.ts +1 -1
  37. package/lib/api/impl/proof/index.js +2 -2
  38. package/lib/api/impl/proof/index.js.map +1 -1
  39. package/lib/api/impl/types.d.ts +2 -2
  40. package/lib/api/impl/validator/index.d.ts +32 -1
  41. package/lib/api/impl/validator/index.js +174 -102
  42. package/lib/api/impl/validator/index.js.map +1 -1
  43. package/lib/api/impl/validator/utils.d.ts +4 -3
  44. package/lib/api/impl/validator/utils.js +17 -9
  45. package/lib/api/impl/validator/utils.js.map +1 -1
  46. package/lib/api/options.js.map +1 -1
  47. package/lib/api/rest/activeSockets.js +1 -1
  48. package/lib/api/rest/activeSockets.js.map +1 -1
  49. package/lib/api/rest/base.d.ts +2 -1
  50. package/lib/api/rest/base.js +34 -7
  51. package/lib/api/rest/base.js.map +1 -1
  52. package/lib/api/rest/index.d.ts +2 -2
  53. package/lib/api/rest/index.js +1 -0
  54. package/lib/api/rest/index.js.map +1 -1
  55. package/lib/api/rest/swaggerUI.js +1 -4
  56. package/lib/api/rest/swaggerUI.js.map +1 -1
  57. package/lib/chain/archiver/archiveBlocks.d.ts +2 -2
  58. package/lib/chain/archiver/archiveBlocks.js +4 -5
  59. package/lib/chain/archiver/archiveBlocks.js.map +1 -1
  60. package/lib/chain/archiver/archiver.d.ts +40 -0
  61. package/lib/chain/archiver/archiver.js +117 -0
  62. package/lib/chain/archiver/archiver.js.map +1 -0
  63. package/lib/chain/archiver/index.d.ts +2 -52
  64. package/lib/chain/archiver/index.js +2 -103
  65. package/lib/chain/archiver/index.js.map +1 -1
  66. package/lib/chain/archiver/interface.d.ts +39 -0
  67. package/lib/chain/archiver/interface.js +8 -0
  68. package/lib/chain/archiver/interface.js.map +1 -0
  69. package/lib/chain/archiver/{archiveStates.d.ts → strategies/frequencyStateArchiveStrategy.d.ts} +18 -15
  70. package/lib/chain/archiver/{archiveStates.js → strategies/frequencyStateArchiveStrategy.js} +16 -10
  71. package/lib/chain/archiver/strategies/frequencyStateArchiveStrategy.js.map +1 -0
  72. package/lib/chain/balancesCache.d.ts +1 -1
  73. package/lib/chain/balancesCache.js +1 -1
  74. package/lib/chain/balancesCache.js.map +1 -1
  75. package/lib/chain/beaconProposerCache.d.ts +1 -1
  76. package/lib/chain/blocks/importBlock.js +12 -18
  77. package/lib/chain/blocks/importBlock.js.map +1 -1
  78. package/lib/chain/blocks/index.d.ts +2 -2
  79. package/lib/chain/blocks/index.js +4 -6
  80. package/lib/chain/blocks/index.js.map +1 -1
  81. package/lib/chain/blocks/types.d.ts +4 -4
  82. package/lib/chain/blocks/types.js +1 -1
  83. package/lib/chain/blocks/types.js.map +1 -1
  84. package/lib/chain/blocks/utils/checkpoint.js +1 -1
  85. package/lib/chain/blocks/utils/checkpoint.js.map +1 -1
  86. package/lib/chain/blocks/verifyBlock.d.ts +2 -2
  87. package/lib/chain/blocks/verifyBlock.js +7 -7
  88. package/lib/chain/blocks/verifyBlock.js.map +1 -1
  89. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts +1 -1
  90. package/lib/chain/blocks/verifyBlocksDataAvailability.js +4 -4
  91. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  92. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts +6 -6
  93. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +7 -6
  94. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  95. package/lib/chain/blocks/verifyBlocksSanityChecks.js +5 -13
  96. package/lib/chain/blocks/verifyBlocksSanityChecks.js.map +1 -1
  97. package/lib/chain/blocks/verifyBlocksSignatures.d.ts +1 -1
  98. package/lib/chain/blocks/verifyBlocksSignatures.js +1 -1
  99. package/lib/chain/blocks/verifyBlocksSignatures.js.map +1 -1
  100. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js +2 -2
  101. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.js.map +1 -1
  102. package/lib/chain/blocks/writeBlockInputToDb.js +1 -1
  103. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  104. package/lib/chain/bls/multithread/index.d.ts +1 -1
  105. package/lib/chain/bls/multithread/index.js +10 -10
  106. package/lib/chain/bls/multithread/index.js.map +1 -1
  107. package/lib/chain/bls/multithread/jobItem.d.ts +3 -3
  108. package/lib/chain/bls/multithread/jobItem.js +4 -14
  109. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  110. package/lib/chain/bls/multithread/poolSize.js +1 -1
  111. package/lib/chain/bls/multithread/poolSize.js.map +1 -1
  112. package/lib/chain/bls/multithread/worker.js +2 -2
  113. package/lib/chain/bls/multithread/worker.js.map +1 -1
  114. package/lib/chain/chain.d.ts +25 -63
  115. package/lib/chain/chain.js +79 -74
  116. package/lib/chain/chain.js.map +1 -1
  117. package/lib/chain/emitter.d.ts +2 -2
  118. package/lib/chain/emitter.js +1 -1
  119. package/lib/chain/emitter.js.map +1 -1
  120. package/lib/chain/errors/attestationError.d.ts +1 -1
  121. package/lib/chain/errors/blobSidecarError.d.ts +1 -1
  122. package/lib/chain/errors/blockError.d.ts +1 -1
  123. package/lib/chain/errors/blockError.js.map +1 -1
  124. package/lib/chain/errors/syncCommitteeError.d.ts +1 -1
  125. package/lib/chain/forkChoice/index.d.ts +5 -1
  126. package/lib/chain/forkChoice/index.js +8 -4
  127. package/lib/chain/forkChoice/index.js.map +1 -1
  128. package/lib/chain/genesis/genesis.d.ts +3 -3
  129. package/lib/chain/genesis/genesis.js +4 -8
  130. package/lib/chain/genesis/genesis.js.map +1 -1
  131. package/lib/chain/genesis/interface.d.ts +1 -1
  132. package/lib/chain/historicalState/getHistoricalState.d.ts +2 -1
  133. package/lib/chain/historicalState/getHistoricalState.js +3 -0
  134. package/lib/chain/historicalState/getHistoricalState.js.map +1 -1
  135. package/lib/chain/historicalState/index.js +1 -1
  136. package/lib/chain/historicalState/index.js.map +1 -1
  137. package/lib/chain/historicalState/worker.js +4 -4
  138. package/lib/chain/historicalState/worker.js.map +1 -1
  139. package/lib/chain/initState.d.ts +4 -8
  140. package/lib/chain/initState.js +3 -31
  141. package/lib/chain/initState.js.map +1 -1
  142. package/lib/chain/interface.d.ts +22 -20
  143. package/lib/chain/interface.js.map +1 -1
  144. package/lib/chain/lightClient/index.d.ts +2 -2
  145. package/lib/chain/lightClient/index.js +9 -11
  146. package/lib/chain/lightClient/index.js.map +1 -1
  147. package/lib/chain/lightClient/proofs.d.ts +2 -2
  148. package/lib/chain/lightClient/proofs.js +3 -2
  149. package/lib/chain/lightClient/proofs.js.map +1 -1
  150. package/lib/chain/opPools/aggregatedAttestationPool.d.ts +3 -3
  151. package/lib/chain/opPools/aggregatedAttestationPool.js +38 -42
  152. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  153. package/lib/chain/opPools/attestationPool.d.ts +2 -2
  154. package/lib/chain/opPools/attestationPool.js +5 -7
  155. package/lib/chain/opPools/attestationPool.js.map +1 -1
  156. package/lib/chain/opPools/opPool.d.ts +2 -2
  157. package/lib/chain/opPools/opPool.js +6 -9
  158. package/lib/chain/opPools/opPool.js.map +1 -1
  159. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +1 -1
  160. package/lib/chain/opPools/syncCommitteeMessagePool.js +4 -6
  161. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  162. package/lib/chain/opPools/syncContributionAndProofPool.d.ts +1 -1
  163. package/lib/chain/opPools/syncContributionAndProofPool.js +4 -6
  164. package/lib/chain/opPools/syncContributionAndProofPool.js.map +1 -1
  165. package/lib/chain/options.d.ts +3 -1
  166. package/lib/chain/options.js +5 -1
  167. package/lib/chain/options.js.map +1 -1
  168. package/lib/chain/prepareNextSlot.d.ts +1 -1
  169. package/lib/chain/prepareNextSlot.js +6 -5
  170. package/lib/chain/prepareNextSlot.js.map +1 -1
  171. package/lib/chain/produceBlock/produceBlockBody.d.ts +4 -4
  172. package/lib/chain/produceBlock/produceBlockBody.js +28 -21
  173. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  174. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts +1 -1
  175. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js +1 -1
  176. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.js.map +1 -1
  177. package/lib/chain/regen/errors.d.ts +1 -1
  178. package/lib/chain/regen/interface.d.ts +2 -2
  179. package/lib/chain/regen/queued.d.ts +3 -3
  180. package/lib/chain/regen/queued.js +2 -2
  181. package/lib/chain/regen/queued.js.map +1 -1
  182. package/lib/chain/regen/regen.d.ts +5 -5
  183. package/lib/chain/regen/regen.js +5 -6
  184. package/lib/chain/regen/regen.js.map +1 -1
  185. package/lib/chain/reprocess.d.ts +1 -1
  186. package/lib/chain/rewards/attestationsRewards.d.ts +3 -3
  187. package/lib/chain/rewards/attestationsRewards.js +3 -2
  188. package/lib/chain/rewards/attestationsRewards.js.map +1 -1
  189. package/lib/chain/rewards/blockRewards.d.ts +1 -1
  190. package/lib/chain/rewards/blockRewards.js +2 -4
  191. package/lib/chain/rewards/blockRewards.js.map +1 -1
  192. package/lib/chain/rewards/syncCommitteeRewards.d.ts +1 -1
  193. package/lib/chain/rewards/syncCommitteeRewards.js +1 -3
  194. package/lib/chain/rewards/syncCommitteeRewards.js.map +1 -1
  195. package/lib/chain/seenCache/seenAttestationData.d.ts +1 -1
  196. package/lib/chain/seenCache/seenCommittee.d.ts +1 -1
  197. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +2 -2
  198. package/lib/chain/seenCache/seenGossipBlockInput.js +23 -27
  199. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  200. package/lib/chain/serializeState.js +63 -10
  201. package/lib/chain/serializeState.js.map +1 -1
  202. package/lib/chain/shufflingCache.d.ts +37 -13
  203. package/lib/chain/shufflingCache.js +88 -79
  204. package/lib/chain/shufflingCache.js.map +1 -1
  205. package/lib/chain/stateCache/blockStateCacheImpl.d.ts +2 -2
  206. package/lib/chain/stateCache/datastore/file.js +5 -5
  207. package/lib/chain/stateCache/datastore/file.js.map +1 -1
  208. package/lib/chain/stateCache/fifoBlockStateCache.d.ts +9 -4
  209. package/lib/chain/stateCache/fifoBlockStateCache.js +7 -2
  210. package/lib/chain/stateCache/fifoBlockStateCache.js.map +1 -1
  211. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts +2 -2
  212. package/lib/chain/stateCache/inMemoryCheckpointsCache.js.map +1 -1
  213. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts +9 -8
  214. package/lib/chain/stateCache/persistentCheckpointsCache.js +35 -39
  215. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  216. package/lib/chain/stateCache/types.d.ts +1 -1
  217. package/lib/chain/validation/aggregateAndProof.d.ts +2 -2
  218. package/lib/chain/validation/aggregateAndProof.js +2 -2
  219. package/lib/chain/validation/aggregateAndProof.js.map +1 -1
  220. package/lib/chain/validation/attestation.d.ts +8 -22
  221. package/lib/chain/validation/attestation.js +34 -59
  222. package/lib/chain/validation/attestation.js.map +1 -1
  223. package/lib/chain/validation/attesterSlashing.d.ts +1 -1
  224. package/lib/chain/validation/attesterSlashing.js +1 -1
  225. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  226. package/lib/chain/validation/blobSidecar.d.ts +1 -1
  227. package/lib/chain/validation/blobSidecar.js +5 -5
  228. package/lib/chain/validation/blobSidecar.js.map +1 -1
  229. package/lib/chain/validation/block.js +3 -3
  230. package/lib/chain/validation/block.js.map +1 -1
  231. package/lib/chain/validation/blsToExecutionChange.d.ts +1 -1
  232. package/lib/chain/validation/blsToExecutionChange.js +1 -1
  233. package/lib/chain/validation/blsToExecutionChange.js.map +1 -1
  234. package/lib/chain/validation/lightClientFinalityUpdate.js +3 -3
  235. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  236. package/lib/chain/validation/lightClientOptimisticUpdate.js +3 -3
  237. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  238. package/lib/chain/validation/proposerSlashing.d.ts +1 -1
  239. package/lib/chain/validation/proposerSlashing.js +1 -1
  240. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  241. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts +2 -2
  242. package/lib/chain/validation/signatureSets/aggregateAndProof.js +1 -1
  243. package/lib/chain/validation/signatureSets/aggregateAndProof.js.map +1 -1
  244. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts +1 -1
  245. package/lib/chain/validation/signatureSets/contributionAndProof.js +1 -1
  246. package/lib/chain/validation/signatureSets/contributionAndProof.js.map +1 -1
  247. package/lib/chain/validation/signatureSets/selectionProof.d.ts +2 -2
  248. package/lib/chain/validation/signatureSets/selectionProof.js +1 -1
  249. package/lib/chain/validation/signatureSets/selectionProof.js.map +1 -1
  250. package/lib/chain/validation/signatureSets/syncCommittee.d.ts +1 -1
  251. package/lib/chain/validation/signatureSets/syncCommittee.js +1 -1
  252. package/lib/chain/validation/signatureSets/syncCommittee.js.map +1 -1
  253. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts +1 -1
  254. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js +2 -2
  255. package/lib/chain/validation/signatureSets/syncCommitteeContribution.js.map +1 -1
  256. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts +1 -1
  257. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js +1 -1
  258. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.js.map +1 -1
  259. package/lib/chain/validation/syncCommittee.js +1 -1
  260. package/lib/chain/validation/syncCommittee.js.map +1 -1
  261. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts +1 -1
  262. package/lib/chain/validation/syncCommitteeContributionAndProof.js +2 -2
  263. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  264. package/lib/chain/validation/voluntaryExit.d.ts +1 -1
  265. package/lib/chain/validation/voluntaryExit.js +2 -2
  266. package/lib/chain/validation/voluntaryExit.js.map +1 -1
  267. package/lib/db/beacon.d.ts +3 -3
  268. package/lib/db/beacon.js +2 -2
  269. package/lib/db/beacon.js.map +1 -1
  270. package/lib/db/buckets.js +3 -5
  271. package/lib/db/buckets.js.map +1 -1
  272. package/lib/db/interface.d.ts +2 -2
  273. package/lib/db/repositories/attesterSlashing.d.ts +1 -1
  274. package/lib/db/repositories/attesterSlashing.js +1 -1
  275. package/lib/db/repositories/attesterSlashing.js.map +1 -1
  276. package/lib/db/repositories/backfilledRanges.d.ts +2 -2
  277. package/lib/db/repositories/backfilledRanges.js +2 -3
  278. package/lib/db/repositories/backfilledRanges.js.map +1 -1
  279. package/lib/db/repositories/blobSidecars.d.ts +1 -1
  280. package/lib/db/repositories/blobSidecars.js.map +1 -1
  281. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  282. package/lib/db/repositories/blockArchive.d.ts +2 -2
  283. package/lib/db/repositories/blockArchive.js +3 -3
  284. package/lib/db/repositories/blockArchive.js.map +1 -1
  285. package/lib/db/repositories/blockArchiveIndex.d.ts +1 -1
  286. package/lib/db/repositories/blockArchiveIndex.js +1 -1
  287. package/lib/db/repositories/blockArchiveIndex.js.map +1 -1
  288. package/lib/db/repositories/blsToExecutionChange.d.ts +1 -1
  289. package/lib/db/repositories/blsToExecutionChange.js.map +1 -1
  290. package/lib/db/repositories/checkpointState.js +1 -1
  291. package/lib/db/repositories/checkpointState.js.map +1 -1
  292. package/lib/db/repositories/depositDataRoot.d.ts +3 -3
  293. package/lib/db/repositories/depositDataRoot.js +3 -4
  294. package/lib/db/repositories/depositDataRoot.js.map +1 -1
  295. package/lib/db/repositories/depositEvent.d.ts +1 -1
  296. package/lib/db/repositories/depositEvent.js +1 -1
  297. package/lib/db/repositories/depositEvent.js.map +1 -1
  298. package/lib/db/repositories/eth1Data.d.ts +2 -2
  299. package/lib/db/repositories/eth1Data.js +2 -3
  300. package/lib/db/repositories/eth1Data.js.map +1 -1
  301. package/lib/db/repositories/lightclientBestUpdate.js.map +1 -1
  302. package/lib/db/repositories/lightclientCheckpointHeader.d.ts +1 -0
  303. package/lib/db/repositories/lightclientCheckpointHeader.js +4 -1
  304. package/lib/db/repositories/lightclientCheckpointHeader.js.map +1 -1
  305. package/lib/db/repositories/proposerSlashing.d.ts +1 -1
  306. package/lib/db/repositories/proposerSlashing.js +1 -1
  307. package/lib/db/repositories/proposerSlashing.js.map +1 -1
  308. package/lib/db/repositories/stateArchive.d.ts +2 -2
  309. package/lib/db/repositories/stateArchive.js +2 -2
  310. package/lib/db/repositories/stateArchive.js.map +1 -1
  311. package/lib/db/repositories/stateArchiveIndex.js.map +1 -1
  312. package/lib/db/repositories/voluntaryExit.d.ts +1 -1
  313. package/lib/db/repositories/voluntaryExit.js +1 -1
  314. package/lib/db/repositories/voluntaryExit.js.map +1 -1
  315. package/lib/db/single/preGenesisState.js.map +1 -1
  316. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts +1 -1
  317. package/lib/db/single/preGenesisStateLastProcessedBlock.js +1 -1
  318. package/lib/db/single/preGenesisStateLastProcessedBlock.js.map +1 -1
  319. package/lib/eth1/eth1DataCache.js +1 -1
  320. package/lib/eth1/eth1DataCache.js.map +1 -1
  321. package/lib/eth1/eth1DepositDataTracker.js +14 -18
  322. package/lib/eth1/eth1DepositDataTracker.js.map +1 -1
  323. package/lib/eth1/eth1DepositsCache.d.ts +2 -2
  324. package/lib/eth1/eth1DepositsCache.js +4 -4
  325. package/lib/eth1/eth1DepositsCache.js.map +1 -1
  326. package/lib/eth1/eth1MergeBlockTracker.d.ts +1 -1
  327. package/lib/eth1/eth1MergeBlockTracker.js +41 -51
  328. package/lib/eth1/eth1MergeBlockTracker.js.map +1 -1
  329. package/lib/eth1/index.d.ts +1 -1
  330. package/lib/eth1/index.js +6 -10
  331. package/lib/eth1/index.js.map +1 -1
  332. package/lib/eth1/interface.d.ts +1 -1
  333. package/lib/eth1/provider/eth1Provider.d.ts +2 -2
  334. package/lib/eth1/provider/eth1Provider.js +6 -7
  335. package/lib/eth1/provider/eth1Provider.js.map +1 -1
  336. package/lib/eth1/provider/jsonRpcHttpClient.d.ts +2 -2
  337. package/lib/eth1/provider/jsonRpcHttpClient.js +6 -12
  338. package/lib/eth1/provider/jsonRpcHttpClient.js.map +1 -1
  339. package/lib/eth1/provider/jwt.js +0 -1
  340. package/lib/eth1/provider/jwt.js.map +1 -1
  341. package/lib/eth1/provider/utils.js +5 -6
  342. package/lib/eth1/provider/utils.js.map +1 -1
  343. package/lib/eth1/stream.d.ts +1 -1
  344. package/lib/eth1/stream.js +1 -1
  345. package/lib/eth1/stream.js.map +1 -1
  346. package/lib/eth1/utils/depositContract.js +5 -5
  347. package/lib/eth1/utils/depositContract.js.map +1 -1
  348. package/lib/eth1/utils/deposits.d.ts +1 -1
  349. package/lib/eth1/utils/deposits.js +4 -4
  350. package/lib/eth1/utils/deposits.js.map +1 -1
  351. package/lib/eth1/utils/eth1Data.js.map +1 -1
  352. package/lib/eth1/utils/eth1Vote.d.ts +1 -1
  353. package/lib/eth1/utils/eth1Vote.js +3 -6
  354. package/lib/eth1/utils/eth1Vote.js.map +1 -1
  355. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.js +1 -3
  356. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.js.map +1 -1
  357. package/lib/execution/builder/http.d.ts +18 -3
  358. package/lib/execution/builder/http.js +33 -8
  359. package/lib/execution/builder/http.js.map +1 -1
  360. package/lib/execution/builder/index.js +1 -0
  361. package/lib/execution/builder/index.js.map +1 -1
  362. package/lib/execution/builder/interface.d.ts +3 -2
  363. package/lib/execution/engine/http.d.ts +7 -6
  364. package/lib/execution/engine/http.js +35 -22
  365. package/lib/execution/engine/http.js.map +1 -1
  366. package/lib/execution/engine/index.d.ts +2 -2
  367. package/lib/execution/engine/index.js +1 -0
  368. package/lib/execution/engine/index.js.map +1 -1
  369. package/lib/execution/engine/interface.d.ts +6 -5
  370. package/lib/execution/engine/interface.js.map +1 -1
  371. package/lib/execution/engine/mock.d.ts +2 -2
  372. package/lib/execution/engine/mock.js +12 -17
  373. package/lib/execution/engine/mock.js.map +1 -1
  374. package/lib/execution/engine/payloadIdCache.d.ts +1 -18
  375. package/lib/execution/engine/payloadIdCache.js.map +1 -1
  376. package/lib/execution/engine/types.d.ts +22 -26
  377. package/lib/execution/engine/types.js +41 -76
  378. package/lib/execution/engine/types.js.map +1 -1
  379. package/lib/execution/engine/utils.d.ts +1 -1
  380. package/lib/execution/engine/utils.js +3 -3
  381. package/lib/execution/engine/utils.js.map +1 -1
  382. package/lib/metrics/metrics/beacon.d.ts +9 -4
  383. package/lib/metrics/metrics/beacon.js +14 -4
  384. package/lib/metrics/metrics/beacon.js.map +1 -1
  385. package/lib/metrics/metrics/lodestar.d.ts +16 -8
  386. package/lib/metrics/metrics/lodestar.js +43 -25
  387. package/lib/metrics/metrics/lodestar.js.map +1 -1
  388. package/lib/metrics/metrics.d.ts +3 -3
  389. package/lib/metrics/metrics.js +1 -1
  390. package/lib/metrics/metrics.js.map +1 -1
  391. package/lib/metrics/nodeJsMetrics.js +1 -1
  392. package/lib/metrics/nodeJsMetrics.js.map +1 -1
  393. package/lib/metrics/server/http.d.ts +1 -1
  394. package/lib/metrics/server/http.js +1 -1
  395. package/lib/metrics/server/http.js.map +1 -1
  396. package/lib/metrics/utils/avgMinMax.d.ts +1 -1
  397. package/lib/metrics/utils/gauge.d.ts +1 -1
  398. package/lib/metrics/utils/gauge.js.map +1 -1
  399. package/lib/metrics/utils/registryMetricCreator.d.ts +1 -1
  400. package/lib/metrics/utils/registryMetricCreator.js +1 -1
  401. package/lib/metrics/utils/registryMetricCreator.js.map +1 -1
  402. package/lib/metrics/validatorMonitor.d.ts +2 -2
  403. package/lib/metrics/validatorMonitor.js +39 -51
  404. package/lib/metrics/validatorMonitor.js.map +1 -1
  405. package/lib/monitoring/properties.js +2 -4
  406. package/lib/monitoring/properties.js.map +1 -1
  407. package/lib/monitoring/service.js +4 -6
  408. package/lib/monitoring/service.js.map +1 -1
  409. package/lib/monitoring/system.js +0 -1
  410. package/lib/monitoring/system.js.map +1 -1
  411. package/lib/network/core/metrics.js +0 -2
  412. package/lib/network/core/metrics.js.map +1 -1
  413. package/lib/network/core/networkCore.d.ts +14 -14
  414. package/lib/network/core/networkCore.js +20 -15
  415. package/lib/network/core/networkCore.js.map +1 -1
  416. package/lib/network/core/networkCoreWorker.js +2 -3
  417. package/lib/network/core/networkCoreWorker.js.map +1 -1
  418. package/lib/network/core/networkCoreWorkerHandler.js +1 -1
  419. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  420. package/lib/network/core/types.d.ts +2 -2
  421. package/lib/network/discv5/index.d.ts +3 -3
  422. package/lib/network/discv5/index.js +3 -3
  423. package/lib/network/discv5/index.js.map +1 -1
  424. package/lib/network/discv5/utils.js +1 -0
  425. package/lib/network/discv5/utils.js.map +1 -1
  426. package/lib/network/discv5/worker.js +8 -9
  427. package/lib/network/discv5/worker.js.map +1 -1
  428. package/lib/network/events.d.ts +3 -3
  429. package/lib/network/events.js +1 -1
  430. package/lib/network/events.js.map +1 -1
  431. package/lib/network/forks.d.ts +1 -1
  432. package/lib/network/forks.js +0 -1
  433. package/lib/network/forks.js.map +1 -1
  434. package/lib/network/gossip/encoding.d.ts +1 -1
  435. package/lib/network/gossip/encoding.js +4 -6
  436. package/lib/network/gossip/encoding.js.map +1 -1
  437. package/lib/network/gossip/gossipsub.d.ts +2 -2
  438. package/lib/network/gossip/gossipsub.js +11 -12
  439. package/lib/network/gossip/gossipsub.js.map +1 -1
  440. package/lib/network/gossip/interface.d.ts +14 -12
  441. package/lib/network/gossip/interface.js.map +1 -1
  442. package/lib/network/gossip/metrics.js +0 -1
  443. package/lib/network/gossip/metrics.js.map +1 -1
  444. package/lib/network/gossip/scoringParameters.js +1 -2
  445. package/lib/network/gossip/scoringParameters.js.map +1 -1
  446. package/lib/network/gossip/topic.d.ts +2 -29
  447. package/lib/network/gossip/topic.js +5 -6
  448. package/lib/network/gossip/topic.js.map +1 -1
  449. package/lib/network/interface.d.ts +6 -10
  450. package/lib/network/libp2p/index.d.ts +1 -1
  451. package/lib/network/libp2p/index.js +2 -2
  452. package/lib/network/libp2p/index.js.map +1 -1
  453. package/lib/network/metadata.d.ts +1 -1
  454. package/lib/network/metadata.js.map +1 -1
  455. package/lib/network/network.d.ts +10 -10
  456. package/lib/network/network.js +10 -10
  457. package/lib/network/network.js.map +1 -1
  458. package/lib/network/options.d.ts +1 -1
  459. package/lib/network/options.js +0 -2
  460. package/lib/network/options.js.map +1 -1
  461. package/lib/network/peers/datastore.d.ts +1 -1
  462. package/lib/network/peers/datastore.js +1 -2
  463. package/lib/network/peers/datastore.js.map +1 -1
  464. package/lib/network/peers/discover.d.ts +2 -2
  465. package/lib/network/peers/discover.js +11 -16
  466. package/lib/network/peers/discover.js.map +1 -1
  467. package/lib/network/peers/peerManager.d.ts +5 -5
  468. package/lib/network/peers/peerManager.js +14 -11
  469. package/lib/network/peers/peerManager.js.map +1 -1
  470. package/lib/network/peers/peersData.d.ts +1 -1
  471. package/lib/network/peers/utils/assertPeerRelevance.js +2 -3
  472. package/lib/network/peers/utils/assertPeerRelevance.js.map +1 -1
  473. package/lib/network/peers/utils/enrSubnetsDeserialize.js +1 -1
  474. package/lib/network/peers/utils/enrSubnetsDeserialize.js.map +1 -1
  475. package/lib/network/peers/utils/prioritizePeers.js.map +1 -1
  476. package/lib/network/processor/extractSlotRootFns.js +1 -1
  477. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  478. package/lib/network/processor/gossipHandlers.d.ts +4 -6
  479. package/lib/network/processor/gossipHandlers.js +25 -72
  480. package/lib/network/processor/gossipHandlers.js.map +1 -1
  481. package/lib/network/processor/gossipQueues/index.d.ts +1 -1
  482. package/lib/network/processor/gossipQueues/index.js +9 -24
  483. package/lib/network/processor/gossipQueues/index.js.map +1 -1
  484. package/lib/network/processor/gossipQueues/indexed.js +1 -3
  485. package/lib/network/processor/gossipQueues/indexed.js.map +1 -1
  486. package/lib/network/processor/gossipQueues/linear.d.ts +1 -1
  487. package/lib/network/processor/gossipQueues/linear.js +5 -7
  488. package/lib/network/processor/gossipQueues/linear.js.map +1 -1
  489. package/lib/network/processor/gossipQueues/types.d.ts +1 -2
  490. package/lib/network/processor/gossipQueues/types.js +0 -6
  491. package/lib/network/processor/gossipQueues/types.js.map +1 -1
  492. package/lib/network/processor/gossipValidatorFn.d.ts +1 -1
  493. package/lib/network/processor/gossipValidatorFn.js +1 -1
  494. package/lib/network/processor/gossipValidatorFn.js.map +1 -1
  495. package/lib/network/processor/index.d.ts +4 -4
  496. package/lib/network/processor/index.js +9 -7
  497. package/lib/network/processor/index.js.map +1 -1
  498. package/lib/network/processor/types.d.ts +1 -1
  499. package/lib/network/reqresp/ReqRespBeaconNode.d.ts +2 -2
  500. package/lib/network/reqresp/ReqRespBeaconNode.js +2 -2
  501. package/lib/network/reqresp/ReqRespBeaconNode.js.map +1 -1
  502. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.d.ts +2 -2
  503. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js +5 -5
  504. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRange.js.map +1 -1
  505. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.d.ts +1 -1
  506. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js +3 -3
  507. package/lib/network/reqresp/beaconBlocksMaybeBlobsByRoot.js.map +1 -1
  508. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +1 -1
  509. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  510. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts +1 -1
  511. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +2 -2
  512. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  513. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +1 -1
  514. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  515. package/lib/network/reqresp/handlers/index.js +1 -1
  516. package/lib/network/reqresp/handlers/index.js.map +1 -1
  517. package/lib/network/reqresp/handlers/lightClientBootstrap.js +3 -5
  518. package/lib/network/reqresp/handlers/lightClientBootstrap.js.map +1 -1
  519. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.js +7 -9
  520. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.js.map +1 -1
  521. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.js +8 -10
  522. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.js.map +1 -1
  523. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts +1 -1
  524. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js +3 -5
  525. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js.map +1 -1
  526. package/lib/network/reqresp/handlers/status.js +1 -1
  527. package/lib/network/reqresp/handlers/status.js.map +1 -1
  528. package/lib/network/reqresp/protocols.js +1 -2
  529. package/lib/network/reqresp/protocols.js.map +1 -1
  530. package/lib/network/reqresp/rateLimit.js +2 -2
  531. package/lib/network/reqresp/rateLimit.js.map +1 -1
  532. package/lib/network/reqresp/score.js +0 -1
  533. package/lib/network/reqresp/score.js.map +1 -1
  534. package/lib/network/reqresp/types.d.ts +5 -5
  535. package/lib/network/reqresp/types.js +4 -8
  536. package/lib/network/reqresp/types.js.map +1 -1
  537. package/lib/network/reqresp/utils/collect.d.ts +1 -1
  538. package/lib/network/reqresp/utils/collect.js +1 -1
  539. package/lib/network/reqresp/utils/collect.js.map +1 -1
  540. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts +1 -2
  541. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.js.map +1 -1
  542. package/lib/network/subnets/attnetsService.d.ts +3 -3
  543. package/lib/network/subnets/attnetsService.js +3 -3
  544. package/lib/network/subnets/attnetsService.js.map +1 -1
  545. package/lib/network/subnets/interface.d.ts +1 -1
  546. package/lib/network/subnets/syncnetsService.d.ts +1 -1
  547. package/lib/network/subnets/syncnetsService.js +1 -1
  548. package/lib/network/subnets/syncnetsService.js.map +1 -1
  549. package/lib/network/util.js +1 -1
  550. package/lib/network/util.js.map +1 -1
  551. package/lib/node/nodejs.d.ts +7 -7
  552. package/lib/node/nodejs.js +9 -9
  553. package/lib/node/nodejs.js.map +1 -1
  554. package/lib/node/notifier.js +18 -28
  555. package/lib/node/notifier.js.map +1 -1
  556. package/lib/node/options.d.ts +3 -3
  557. package/lib/node/options.js +3 -3
  558. package/lib/node/options.js.map +1 -1
  559. package/lib/node/utils/interop/deposits.d.ts +1 -1
  560. package/lib/node/utils/interop/deposits.js +3 -3
  561. package/lib/node/utils/interop/deposits.js.map +1 -1
  562. package/lib/node/utils/interop/state.d.ts +1 -1
  563. package/lib/node/utils/interop/state.js +3 -2
  564. package/lib/node/utils/interop/state.js.map +1 -1
  565. package/lib/node/utils/state.d.ts +3 -0
  566. package/lib/node/utils/state.js +3 -0
  567. package/lib/node/utils/state.js.map +1 -1
  568. package/lib/sync/backfill/backfill.d.ts +6 -6
  569. package/lib/sync/backfill/backfill.js +7 -6
  570. package/lib/sync/backfill/backfill.js.map +1 -1
  571. package/lib/sync/backfill/errors.d.ts +1 -1
  572. package/lib/sync/backfill/errors.js.map +1 -1
  573. package/lib/sync/backfill/verify.d.ts +2 -3
  574. package/lib/sync/backfill/verify.js +1 -1
  575. package/lib/sync/backfill/verify.js.map +1 -1
  576. package/lib/sync/interface.d.ts +5 -5
  577. package/lib/sync/range/batch.d.ts +2 -2
  578. package/lib/sync/range/batch.js +1 -1
  579. package/lib/sync/range/batch.js.map +1 -1
  580. package/lib/sync/range/chain.d.ts +1 -1
  581. package/lib/sync/range/chain.js +1 -1
  582. package/lib/sync/range/chain.js.map +1 -1
  583. package/lib/sync/range/range.d.ts +3 -3
  584. package/lib/sync/range/range.js +5 -9
  585. package/lib/sync/range/range.js.map +1 -1
  586. package/lib/sync/range/utils/batches.js +1 -3
  587. package/lib/sync/range/utils/batches.js.map +1 -1
  588. package/lib/sync/range/utils/hashBlocks.d.ts +1 -1
  589. package/lib/sync/sync.d.ts +1 -1
  590. package/lib/sync/sync.js +31 -30
  591. package/lib/sync/sync.js.map +1 -1
  592. package/lib/sync/unknownBlock.d.ts +1 -1
  593. package/lib/sync/unknownBlock.js +9 -14
  594. package/lib/sync/unknownBlock.js.map +1 -1
  595. package/lib/sync/utils/pendingBlocksTree.js +1 -1
  596. package/lib/sync/utils/pendingBlocksTree.js.map +1 -1
  597. package/lib/sync/utils/remoteSyncType.d.ts +1 -1
  598. package/lib/sync/utils/remoteSyncType.js +25 -36
  599. package/lib/sync/utils/remoteSyncType.js.map +1 -1
  600. package/lib/util/asyncIterableToEvents.js +0 -2
  601. package/lib/util/asyncIterableToEvents.js.map +1 -1
  602. package/lib/util/binarySearch.js +1 -1
  603. package/lib/util/binarySearch.js.map +1 -1
  604. package/lib/util/bitArray.js +1 -2
  605. package/lib/util/bitArray.js.map +1 -1
  606. package/lib/util/blobs.d.ts +2 -2
  607. package/lib/util/blobs.js +2 -2
  608. package/lib/util/blobs.js.map +1 -1
  609. package/lib/util/clock.d.ts +2 -2
  610. package/lib/util/clock.js +1 -1
  611. package/lib/util/clock.js.map +1 -1
  612. package/lib/util/kzg.js +4 -5
  613. package/lib/util/kzg.js.map +1 -1
  614. package/lib/util/map.js +0 -1
  615. package/lib/util/map.js.map +1 -1
  616. package/lib/util/multifork.d.ts +1 -1
  617. package/lib/util/multifork.js.map +1 -1
  618. package/lib/util/peerId.js +1 -1
  619. package/lib/util/peerId.js.map +1 -1
  620. package/lib/util/profile.js +1 -1
  621. package/lib/util/profile.js.map +1 -1
  622. package/lib/util/queue/errors.d.ts +0 -1
  623. package/lib/util/queue/errors.js +0 -3
  624. package/lib/util/queue/errors.js.map +1 -1
  625. package/lib/util/queue/fnQueue.d.ts +1 -1
  626. package/lib/util/queue/fnQueue.js +1 -1
  627. package/lib/util/queue/fnQueue.js.map +1 -1
  628. package/lib/util/queue/itemQueue.d.ts +1 -1
  629. package/lib/util/queue/itemQueue.js +3 -3
  630. package/lib/util/queue/itemQueue.js.map +1 -1
  631. package/lib/util/sszBytes.d.ts +1 -1
  632. package/lib/util/sszBytes.js.map +1 -1
  633. package/package.json +24 -23
  634. package/lib/chain/archiver/archiveStates.js.map +0 -1
  635. package/lib/network/processor/gossipQueues/indexedAvgTime.d.ts +0 -31
  636. package/lib/network/processor/gossipQueues/indexedAvgTime.js +0 -115
  637. package/lib/network/processor/gossipQueues/indexedAvgTime.js.map +0 -1
@@ -1,7 +1,7 @@
1
- import { deneb, RootHex, SignedBeaconBlock } from "@lodestar/types";
2
1
  import { ChainForkConfig } from "@lodestar/config";
3
- import { BlockInput, NullBlockInput, GossipedInputType } from "../blocks/types.js";
2
+ import { RootHex, SignedBeaconBlock, deneb } from "@lodestar/types";
4
3
  import { Metrics } from "../../metrics/index.js";
4
+ import { BlockInput, GossipedInputType, NullBlockInput } from "../blocks/types.js";
5
5
  export declare enum BlockInputAvailabilitySource {
6
6
  GOSSIP = "gossip",
7
7
  UNKNOWN_SYNC = "unknown_sync"
@@ -1,7 +1,7 @@
1
+ import { BLOBSIDECAR_FIXED_SIZE, isForkBlobs } from "@lodestar/params";
1
2
  import { ssz } from "@lodestar/types";
2
3
  import { pruneSetToMax, toRootHex } from "@lodestar/utils";
3
- import { BLOBSIDECAR_FIXED_SIZE, isForkBlobs } from "@lodestar/params";
4
- import { getBlockInput, BlockSource, GossipedInputType, getBlockInputBlobs, BlobsSource, } from "../blocks/types.js";
4
+ import { BlobsSource, BlockSource, GossipedInputType, getBlockInput, getBlockInputBlobs, } from "../blocks/types.js";
5
5
  export var BlockInputAvailabilitySource;
6
6
  (function (BlockInputAvailabilitySource) {
7
7
  BlockInputAvailabilitySource["GOSSIP"] = "gossip";
@@ -88,35 +88,31 @@ export class SeenGossipBlockInput {
88
88
  blockInputMeta: { pending: null, haveBlobs: allBlobs.blobs.length, expectedBlobs: blobKzgCommitments.length },
89
89
  };
90
90
  }
91
- else {
92
- const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, blockBytes ?? null, cachedData);
93
- resolveBlockInput(blockInput);
94
- return {
95
- blockInput,
96
- blockInputMeta: {
97
- pending: GossipedInputType.blob,
98
- haveBlobs: blobsCache.size,
99
- expectedBlobs: blobKzgCommitments.length,
100
- },
101
- };
102
- }
103
- }
104
- else {
105
- // will need to wait for the block to showup
106
- if (cachedData === undefined) {
107
- throw Error("Missing cachedData for deneb+ blobs");
108
- }
109
- const { blobsCache } = cachedData;
91
+ const blockInput = getBlockInput.dataPromise(config, signedBlock, BlockSource.gossip, blockBytes ?? null, cachedData);
92
+ resolveBlockInput(blockInput);
110
93
  return {
111
- blockInput: {
112
- block: null,
113
- blockRootHex: blockHex,
114
- cachedData,
115
- blockInputPromise,
94
+ blockInput,
95
+ blockInputMeta: {
96
+ pending: GossipedInputType.blob,
97
+ haveBlobs: blobsCache.size,
98
+ expectedBlobs: blobKzgCommitments.length,
116
99
  },
117
- blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
118
100
  };
119
101
  }
102
+ // will need to wait for the block to showup
103
+ if (cachedData === undefined) {
104
+ throw Error("Missing cachedData for deneb+ blobs");
105
+ }
106
+ const { blobsCache } = cachedData;
107
+ return {
108
+ blockInput: {
109
+ block: null,
110
+ blockRootHex: blockHex,
111
+ cachedData,
112
+ blockInputPromise,
113
+ },
114
+ blockInputMeta: { pending: GossipedInputType.block, haveBlobs: blobsCache.size, expectedBlobs: null },
115
+ };
120
116
  }
121
117
  }
122
118
  function getEmptyBlockInputCacheEntry(fork) {
@@ -1 +1 @@
1
- {"version":3,"file":"seenGossipBlockInput.js","sourceRoot":"","sources":["../../../src/chain/seenCache/seenGossipBlockInput.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"seenGossipBlockInput.js","sourceRoot":"","sources":["../../../src/chain/seenCache/seenGossipBlockInput.ts"],"names":[],"mappings":"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"}
@@ -1,3 +1,48 @@
1
+ var __addDisposableResource = (this && this.__addDisposableResource) || function (env, value, async) {
2
+ if (value !== null && value !== void 0) {
3
+ if (typeof value !== "object" && typeof value !== "function") throw new TypeError("Object expected.");
4
+ var dispose;
5
+ if (async) {
6
+ if (!Symbol.asyncDispose) throw new TypeError("Symbol.asyncDispose is not defined.");
7
+ dispose = value[Symbol.asyncDispose];
8
+ }
9
+ if (dispose === void 0) {
10
+ if (!Symbol.dispose) throw new TypeError("Symbol.dispose is not defined.");
11
+ dispose = value[Symbol.dispose];
12
+ }
13
+ if (typeof dispose !== "function") throw new TypeError("Object not disposable.");
14
+ env.stack.push({ value: value, dispose: dispose, async: async });
15
+ }
16
+ else if (async) {
17
+ env.stack.push({ async: true });
18
+ }
19
+ return value;
20
+ };
21
+ var __disposeResources = (this && this.__disposeResources) || (function (SuppressedError) {
22
+ return function (env) {
23
+ function fail(e) {
24
+ env.error = env.hasError ? new SuppressedError(e, env.error, "An error was suppressed during disposal.") : e;
25
+ env.hasError = true;
26
+ }
27
+ function next() {
28
+ while (env.stack.length) {
29
+ var rec = env.stack.pop();
30
+ try {
31
+ var result = rec.dispose && rec.dispose.call(rec.value);
32
+ if (rec.async) return Promise.resolve(result).then(next, function(e) { fail(e); return next(); });
33
+ }
34
+ catch (e) {
35
+ fail(e);
36
+ }
37
+ }
38
+ if (env.hasError) throw env.error;
39
+ }
40
+ return next();
41
+ };
42
+ })(typeof SuppressedError === "function" ? SuppressedError : function (error, suppressed, message) {
43
+ var e = new Error(message);
44
+ return e.name = "SuppressedError", e.error = error, e.suppressed = suppressed, e;
45
+ });
1
46
  /*
2
47
  * Serialize state using the BufferPool if provided.
3
48
  */
@@ -5,18 +50,26 @@ export async function serializeState(state, source, processFn, bufferPool) {
5
50
  const size = state.type.tree_serializedSize(state.node);
6
51
  let stateBytes = null;
7
52
  if (bufferPool) {
8
- const bufferWithKey = bufferPool.alloc(size, source);
9
- if (bufferWithKey) {
10
- stateBytes = bufferWithKey.buffer;
11
- const dataView = new DataView(stateBytes.buffer, stateBytes.byteOffset, stateBytes.byteLength);
12
- state.serializeToBytes({ uint8Array: stateBytes, dataView }, 0);
53
+ const env_1 = { stack: [], error: void 0, hasError: false };
54
+ try {
55
+ const bufferWithKey = __addDisposableResource(env_1, bufferPool.alloc(size, source), false);
56
+ if (bufferWithKey) {
57
+ stateBytes = bufferWithKey.buffer;
58
+ const dataView = new DataView(stateBytes.buffer, stateBytes.byteOffset, stateBytes.byteLength);
59
+ state.serializeToBytes({ uint8Array: stateBytes, dataView }, 0);
60
+ return processFn(stateBytes);
61
+ }
62
+ }
63
+ catch (e_1) {
64
+ env_1.error = e_1;
65
+ env_1.hasError = true;
66
+ }
67
+ finally {
68
+ __disposeResources(env_1);
13
69
  }
14
70
  }
15
- if (!stateBytes) {
16
- // we already have metrics in BufferPool so no need to do it here
17
- stateBytes = state.serialize();
18
- }
71
+ // we already have metrics in BufferPool so no need to do it here
72
+ stateBytes = state.serialize();
19
73
  return processFn(stateBytes);
20
- // release the buffer back to the pool automatically
21
74
  }
22
75
  //# sourceMappingURL=serializeState.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"serializeState.js","sourceRoot":"","sources":["../../src/chain/serializeState.ts"],"names":[],"mappings":"AAKA;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAgC,EAChC,MAAmB,EACnB,SAAiC,EACjC,UAA8B;IAE9B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACxD,IAAI,UAAU,GAAsB,IAAI,CAAC;IACzC,IAAI,UAAU,EAAE,CAAC;QACf,MAAM,aAAa,GAAG,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,CAAC;QACrD,IAAI,aAAa,EAAE,CAAC;YAClB,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC;YAClC,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;YAC/F,KAAK,CAAC,gBAAgB,CAAC,EAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAC,EAAE,CAAC,CAAC,CAAC;QAChE,CAAC;IACH,CAAC;IAED,IAAI,CAAC,UAAU,EAAE,CAAC;QAChB,iEAAiE;QACjE,UAAU,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;IACjC,CAAC;IAED,OAAO,SAAS,CAAC,UAAU,CAAC,CAAC;IAC7B,oDAAoD;AACtD,CAAC"}
1
+ {"version":3,"file":"serializeState.js","sourceRoot":"","sources":["../../src/chain/serializeState.ts"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAKA;;GAEG;AACH,MAAM,CAAC,KAAK,UAAU,cAAc,CAClC,KAAgC,EAChC,MAAmB,EACnB,SAAiC,EACjC,UAA8B;IAE9B,MAAM,IAAI,GAAG,KAAK,CAAC,IAAI,CAAC,mBAAmB,CAAC,KAAK,CAAC,IAAI,CAAC,CAAC;IACxD,IAAI,UAAU,GAAsB,IAAI,CAAC;IACzC,IAAI,UAAU,EAAE,CAAC;;;YACf,MAAM,aAAa,kCAAG,UAAU,CAAC,KAAK,CAAC,IAAI,EAAE,MAAM,CAAC,QAAA,CAAC;YACrD,IAAI,aAAa,EAAE,CAAC;gBAClB,UAAU,GAAG,aAAa,CAAC,MAAM,CAAC;gBAClC,MAAM,QAAQ,GAAG,IAAI,QAAQ,CAAC,UAAU,CAAC,MAAM,EAAE,UAAU,CAAC,UAAU,EAAE,UAAU,CAAC,UAAU,CAAC,CAAC;gBAC/F,KAAK,CAAC,gBAAgB,CAAC,EAAC,UAAU,EAAE,UAAU,EAAE,QAAQ,EAAC,EAAE,CAAC,CAAC,CAAC;gBAC9D,OAAO,SAAS,CAAC,UAAU,CAAC,CAAC;YAC/B,CAAC;;;;;;;;;KAEF;IAED,iEAAiE;IACjE,UAAU,GAAG,KAAK,CAAC,SAAS,EAAE,CAAC;IAE/B,OAAO,SAAS,CAAC,UAAU,CAAC,CAAC;AAC/B,CAAC"}
@@ -1,5 +1,6 @@
1
- import { CachedBeaconStateAllForks, EpochShuffling } from "@lodestar/state-transition";
1
+ import { BeaconStateAllForks, EpochShuffling, IShufflingCache, ShufflingBuildProps } from "@lodestar/state-transition";
2
2
  import { Epoch, RootHex } from "@lodestar/types";
3
+ import { LodestarError, Logger } from "@lodestar/utils";
3
4
  import { Metrics } from "../metrics/metrics.js";
4
5
  export type ShufflingCacheOpts = {
5
6
  maxShufflingCacheEpochs?: number;
@@ -10,31 +11,54 @@ export type ShufflingCacheOpts = {
10
11
  * - if a shuffling is not available (which does not happen with default chain option of maxSkipSlots = 32), track a promise to make sure we don't compute the same shuffling twice
11
12
  * - skip computing shuffling when loading state bytes from disk
12
13
  */
13
- export declare class ShufflingCache {
14
- private readonly metrics;
14
+ export declare class ShufflingCache implements IShufflingCache {
15
+ readonly metrics: Metrics | null;
16
+ readonly logger: Logger | null;
15
17
  /** LRU cache implemented as a map, pruned every time we add an item */
16
18
  private readonly itemsByDecisionRootByEpoch;
17
19
  private readonly maxEpochs;
18
- constructor(metrics?: Metrics | null, opts?: ShufflingCacheOpts);
19
- /**
20
- * Extract shuffling from state and add to cache
21
- */
22
- processState(state: CachedBeaconStateAllForks, shufflingEpoch: Epoch): EpochShuffling;
20
+ constructor(metrics?: Metrics | null, logger?: Logger | null, opts?: ShufflingCacheOpts, precalculatedShufflings?: {
21
+ shuffling: EpochShuffling | null;
22
+ decisionRoot: RootHex;
23
+ }[]);
23
24
  /**
24
25
  * Insert a promise to make sure we don't regen state for the same shuffling.
25
26
  * Bound by MAX_SHUFFLING_PROMISE to make sure our node does not blow up.
26
27
  */
27
- insertPromise(shufflingEpoch: Epoch, decisionRootHex: RootHex): void;
28
+ insertPromise(epoch: Epoch, decisionRoot: RootHex): void;
28
29
  /**
29
30
  * Most of the time, this should return a shuffling immediately.
30
31
  * If there's a promise, it means we are computing the same shuffling, so we wait for the promise to resolve.
31
32
  * Return null if we don't have a shuffling for this epoch and dependentRootHex.
32
33
  */
33
- get(shufflingEpoch: Epoch, decisionRootHex: RootHex): Promise<EpochShuffling | null>;
34
+ get(epoch: Epoch, decisionRoot: RootHex): Promise<EpochShuffling | null>;
34
35
  /**
35
- * Same to get() function but synchronous.
36
+ * Gets a cached shuffling via the epoch and decision root. If the shuffling is not
37
+ * available it will build it synchronously and return the shuffling.
38
+ *
39
+ * NOTE: If a shuffling is already queued and not calculated it will build and resolve
40
+ * the promise but the already queued build will happen at some later time
36
41
  */
37
- getSync(shufflingEpoch: Epoch, decisionRootHex: RootHex): EpochShuffling | null;
38
- private add;
42
+ getSync<T extends ShufflingBuildProps | undefined>(epoch: Epoch, decisionRoot: RootHex, buildProps?: T): T extends ShufflingBuildProps ? EpochShuffling : EpochShuffling | null;
43
+ /**
44
+ * Queue asynchronous build for an EpochShuffling, triggered from state-transition
45
+ */
46
+ build(epoch: number, decisionRoot: string, state: BeaconStateAllForks, activeIndices: Uint32Array): void;
47
+ /**
48
+ * Add an EpochShuffling to the ShufflingCache. If a promise for the shuffling is present it will
49
+ * resolve the promise with the built shuffling
50
+ */
51
+ private set;
52
+ }
53
+ export declare enum ShufflingCacheErrorCode {
54
+ NO_SHUFFLING_FOUND = "SHUFFLING_CACHE_ERROR_NO_SHUFFLING_FOUND"
55
+ }
56
+ type ShufflingCacheErrorType = {
57
+ code: ShufflingCacheErrorCode.NO_SHUFFLING_FOUND;
58
+ epoch: Epoch;
59
+ decisionRoot: RootHex;
60
+ };
61
+ export declare class ShufflingCacheError extends LodestarError<ShufflingCacheErrorType> {
39
62
  }
63
+ export {};
40
64
  //# sourceMappingURL=shufflingCache.d.ts.map
@@ -1,8 +1,5 @@
1
- import { getShufflingDecisionBlock } from "@lodestar/state-transition";
2
- import { ssz } from "@lodestar/types";
3
- import { MapDef, pruneSetToMax, toRootHex } from "@lodestar/utils";
4
- import { GENESIS_SLOT } from "@lodestar/params";
5
- import { computeAnchorCheckpoint } from "./initState.js";
1
+ import { computeEpochShuffling, computeEpochShufflingAsync, } from "@lodestar/state-transition";
2
+ import { LodestarError, MapDef, pruneSetToMax } from "@lodestar/utils";
6
3
  /**
7
4
  * Same value to CheckpointBalancesCache, with the assumption that we don't have to use it for old epochs. In the worse case:
8
5
  * - when loading state bytes from disk, we need to compute shuffling for all epochs (~1s as of Sep 2023)
@@ -27,71 +24,31 @@ var CacheItemType;
27
24
  * - skip computing shuffling when loading state bytes from disk
28
25
  */
29
26
  export class ShufflingCache {
30
- constructor(metrics = null, opts = {}) {
27
+ constructor(metrics = null, logger = null, opts = {}, precalculatedShufflings) {
31
28
  this.metrics = metrics;
29
+ this.logger = logger;
32
30
  /** LRU cache implemented as a map, pruned every time we add an item */
33
31
  this.itemsByDecisionRootByEpoch = new MapDef(() => new Map());
34
32
  if (metrics) {
35
33
  metrics.shufflingCache.size.addCollect(() => metrics.shufflingCache.size.set(Array.from(this.itemsByDecisionRootByEpoch.values()).reduce((total, innerMap) => total + innerMap.size, 0)));
36
34
  }
37
35
  this.maxEpochs = opts.maxShufflingCacheEpochs ?? MAX_EPOCHS;
38
- }
39
- /**
40
- * Extract shuffling from state and add to cache
41
- */
42
- processState(state, shufflingEpoch) {
43
- const decisionBlockHex = getDecisionBlock(state, shufflingEpoch);
44
- let shuffling;
45
- switch (shufflingEpoch) {
46
- case state.epochCtx.nextShuffling.epoch:
47
- shuffling = state.epochCtx.nextShuffling;
48
- break;
49
- case state.epochCtx.currentShuffling.epoch:
50
- shuffling = state.epochCtx.currentShuffling;
51
- break;
52
- case state.epochCtx.previousShuffling.epoch:
53
- shuffling = state.epochCtx.previousShuffling;
54
- break;
55
- default:
56
- throw new Error(`Shuffling not found from state ${state.slot} for epoch ${shufflingEpoch}`);
57
- }
58
- let cacheItem = this.itemsByDecisionRootByEpoch.getOrDefault(shufflingEpoch).get(decisionBlockHex);
59
- if (cacheItem !== undefined) {
60
- // update existing promise
61
- if (isPromiseCacheItem(cacheItem)) {
62
- // unblock consumers of this promise
63
- cacheItem.resolveFn(shuffling);
64
- // then update item type to shuffling
65
- cacheItem = {
66
- type: CacheItemType.shuffling,
67
- shuffling,
68
- };
69
- this.add(shufflingEpoch, decisionBlockHex, cacheItem);
70
- // we updated type to CacheItemType.shuffling so the above fields are not used anyway
71
- this.metrics?.shufflingCache.processStateUpdatePromise.inc();
72
- }
73
- else {
74
- // ShufflingCacheItem, do nothing
75
- this.metrics?.shufflingCache.processStateNoOp.inc();
36
+ precalculatedShufflings?.map(({ shuffling, decisionRoot }) => {
37
+ if (shuffling !== null) {
38
+ this.set(shuffling, decisionRoot);
76
39
  }
77
- }
78
- else {
79
- // not found, new shuffling
80
- this.add(shufflingEpoch, decisionBlockHex, { type: CacheItemType.shuffling, shuffling });
81
- this.metrics?.shufflingCache.processStateInsertNew.inc();
82
- }
83
- return shuffling;
40
+ });
84
41
  }
85
42
  /**
86
43
  * Insert a promise to make sure we don't regen state for the same shuffling.
87
44
  * Bound by MAX_SHUFFLING_PROMISE to make sure our node does not blow up.
88
45
  */
89
- insertPromise(shufflingEpoch, decisionRootHex) {
46
+ insertPromise(epoch, decisionRoot) {
90
47
  const promiseCount = Array.from(this.itemsByDecisionRootByEpoch.values())
91
48
  .flatMap((innerMap) => Array.from(innerMap.values()))
92
49
  .filter((item) => isPromiseCacheItem(item)).length;
93
50
  if (promiseCount >= MAX_PROMISES) {
94
- throw new Error(`Too many shuffling promises: ${promiseCount}, shufflingEpoch: ${shufflingEpoch}, decisionRootHex: ${decisionRootHex}`);
51
+ throw new Error(`Too many shuffling promises: ${promiseCount}, shufflingEpoch: ${epoch}, decisionRootHex: ${decisionRoot}`);
95
52
  }
96
53
  let resolveFn = null;
97
54
  const promise = new Promise((resolve) => {
@@ -102,10 +59,11 @@ export class ShufflingCache {
102
59
  }
103
60
  const cacheItem = {
104
61
  type: CacheItemType.promise,
62
+ timeInsertedMs: Date.now(),
105
63
  promise,
106
64
  resolveFn,
107
65
  };
108
- this.add(shufflingEpoch, decisionRootHex, cacheItem);
66
+ this.itemsByDecisionRootByEpoch.getOrDefault(epoch).set(decisionRoot, cacheItem);
109
67
  this.metrics?.shufflingCache.insertPromiseCount.inc();
110
68
  }
111
69
  /**
@@ -113,35 +71,90 @@ export class ShufflingCache {
113
71
  * If there's a promise, it means we are computing the same shuffling, so we wait for the promise to resolve.
114
72
  * Return null if we don't have a shuffling for this epoch and dependentRootHex.
115
73
  */
116
- async get(shufflingEpoch, decisionRootHex) {
117
- const cacheItem = this.itemsByDecisionRootByEpoch.getOrDefault(shufflingEpoch).get(decisionRootHex);
74
+ async get(epoch, decisionRoot) {
75
+ const cacheItem = this.itemsByDecisionRootByEpoch.getOrDefault(epoch).get(decisionRoot);
118
76
  if (cacheItem === undefined) {
77
+ this.metrics?.shufflingCache.miss.inc();
119
78
  return null;
120
79
  }
121
80
  if (isShufflingCacheItem(cacheItem)) {
81
+ this.metrics?.shufflingCache.hit.inc();
122
82
  return cacheItem.shuffling;
123
83
  }
124
- else {
125
- // promise
126
- return cacheItem.promise;
127
- }
84
+ this.metrics?.shufflingCache.shufflingPromiseNotResolved.inc();
85
+ return cacheItem.promise;
128
86
  }
129
87
  /**
130
- * Same to get() function but synchronous.
88
+ * Gets a cached shuffling via the epoch and decision root. If the shuffling is not
89
+ * available it will build it synchronously and return the shuffling.
90
+ *
91
+ * NOTE: If a shuffling is already queued and not calculated it will build and resolve
92
+ * the promise but the already queued build will happen at some later time
131
93
  */
132
- getSync(shufflingEpoch, decisionRootHex) {
133
- const cacheItem = this.itemsByDecisionRootByEpoch.getOrDefault(shufflingEpoch).get(decisionRootHex);
134
- if (cacheItem === undefined) {
135
- return null;
94
+ getSync(epoch, decisionRoot, buildProps) {
95
+ const cacheItem = this.itemsByDecisionRootByEpoch.getOrDefault(epoch).get(decisionRoot);
96
+ if (!cacheItem) {
97
+ this.metrics?.shufflingCache.miss.inc();
136
98
  }
137
- if (isShufflingCacheItem(cacheItem)) {
99
+ else if (isShufflingCacheItem(cacheItem)) {
100
+ this.metrics?.shufflingCache.hit.inc();
138
101
  return cacheItem.shuffling;
139
102
  }
140
- // ignore promise
141
- return null;
103
+ else if (buildProps) {
104
+ // TODO: (@matthewkeil) This should possible log a warning??
105
+ this.metrics?.shufflingCache.shufflingPromiseNotResolvedAndThrownAway.inc();
106
+ }
107
+ else {
108
+ this.metrics?.shufflingCache.shufflingPromiseNotResolved.inc();
109
+ }
110
+ let shuffling = null;
111
+ if (buildProps) {
112
+ const timer = this.metrics?.shufflingCache.shufflingCalculationTime.startTimer({ source: "getSync" });
113
+ shuffling = computeEpochShuffling(buildProps.state, buildProps.activeIndices, epoch);
114
+ timer?.();
115
+ this.set(shuffling, decisionRoot);
116
+ }
117
+ return shuffling;
142
118
  }
143
- add(shufflingEpoch, decisionBlock, cacheItem) {
144
- this.itemsByDecisionRootByEpoch.getOrDefault(shufflingEpoch).set(decisionBlock, cacheItem);
119
+ /**
120
+ * Queue asynchronous build for an EpochShuffling, triggered from state-transition
121
+ */
122
+ build(epoch, decisionRoot, state, activeIndices) {
123
+ this.insertPromise(epoch, decisionRoot);
124
+ /**
125
+ * TODO: (@matthewkeil) This will get replaced by a proper build queue and a worker to do calculations
126
+ * on a NICE thread
127
+ */
128
+ const timer = this.metrics?.shufflingCache.shufflingCalculationTime.startTimer({ source: "build" });
129
+ computeEpochShufflingAsync(state, activeIndices, epoch)
130
+ .then((shuffling) => {
131
+ this.set(shuffling, decisionRoot);
132
+ })
133
+ .catch((err) => this.logger?.error(`error building shuffling for epoch ${epoch} at decisionRoot ${decisionRoot}`, {}, err))
134
+ .finally(() => {
135
+ timer?.();
136
+ });
137
+ }
138
+ /**
139
+ * Add an EpochShuffling to the ShufflingCache. If a promise for the shuffling is present it will
140
+ * resolve the promise with the built shuffling
141
+ */
142
+ set(shuffling, decisionRoot) {
143
+ const shufflingAtEpoch = this.itemsByDecisionRootByEpoch.getOrDefault(shuffling.epoch);
144
+ // if a pending shuffling promise exists, resolve it
145
+ const cacheItem = shufflingAtEpoch.get(decisionRoot);
146
+ if (cacheItem) {
147
+ if (isPromiseCacheItem(cacheItem)) {
148
+ cacheItem.resolveFn(shuffling);
149
+ this.metrics?.shufflingCache.shufflingPromiseResolutionTime.observe((Date.now() - cacheItem.timeInsertedMs) / 1000);
150
+ }
151
+ else {
152
+ this.metrics?.shufflingCache.shufflingBuiltMultipleTimes.inc();
153
+ }
154
+ }
155
+ // set the shuffling
156
+ shufflingAtEpoch.set(decisionRoot, { type: CacheItemType.shuffling, shuffling });
157
+ // prune the cache
145
158
  pruneSetToMax(this.itemsByDecisionRootByEpoch, this.maxEpochs);
146
159
  }
147
160
  }
@@ -151,14 +164,10 @@ function isShufflingCacheItem(item) {
151
164
  function isPromiseCacheItem(item) {
152
165
  return item.type === CacheItemType.promise;
153
166
  }
154
- /**
155
- * Get the shuffling decision block root for the given epoch of given state
156
- * - Special case close to genesis block, return the genesis block root
157
- * - This is similar to forkchoice.getDependentRoot() function, otherwise we cannot get cached shuffing in attestation verification when syncing from genesis.
158
- */
159
- function getDecisionBlock(state, epoch) {
160
- return state.slot > GENESIS_SLOT
161
- ? getShufflingDecisionBlock(state, epoch)
162
- : toRootHex(ssz.phase0.BeaconBlockHeader.hashTreeRoot(computeAnchorCheckpoint(state.config, state).blockHeader));
167
+ export var ShufflingCacheErrorCode;
168
+ (function (ShufflingCacheErrorCode) {
169
+ ShufflingCacheErrorCode["NO_SHUFFLING_FOUND"] = "SHUFFLING_CACHE_ERROR_NO_SHUFFLING_FOUND";
170
+ })(ShufflingCacheErrorCode || (ShufflingCacheErrorCode = {}));
171
+ export class ShufflingCacheError extends LodestarError {
163
172
  }
164
173
  //# sourceMappingURL=shufflingCache.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"shufflingCache.js","sourceRoot":"","sources":["../../src/chain/shufflingCache.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"shufflingCache.js","sourceRoot":"","sources":["../../src/chain/shufflingCache.ts"],"names":[],"mappings":"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"}
@@ -1,6 +1,6 @@
1
- import { Epoch, RootHex } from "@lodestar/types";
2
- import { CachedBeaconStateAllForks } from "@lodestar/state-transition";
3
1
  import { routes } from "@lodestar/api";
2
+ import { CachedBeaconStateAllForks } from "@lodestar/state-transition";
3
+ import { Epoch, RootHex } from "@lodestar/types";
4
4
  import { Metrics } from "../../metrics/index.js";
5
5
  import { StateCloneOpts } from "../regen/interface.js";
6
6
  import { BlockStateCache } from "./types.js";
@@ -1,6 +1,6 @@
1
1
  import path from "node:path";
2
- import { toHexString, fromHexString } from "@chainsafe/ssz";
3
2
  import { ssz } from "@lodestar/types";
3
+ import { fromHex, toHex } from "@lodestar/utils";
4
4
  import { ensureDir, readFile, readFileNames, removeFile, writeIfNotExist } from "../../../util/file.js";
5
5
  const CHECKPOINT_STATES_FOLDER = "checkpoint_states";
6
6
  const CHECKPOINT_FILE_NAME_LENGTH = 82;
@@ -22,23 +22,23 @@ export class FileCPStateDatastore {
22
22
  }
23
23
  async write(cpKey, stateBytes) {
24
24
  const serializedCheckpoint = ssz.phase0.Checkpoint.serialize(cpKey);
25
- const filePath = path.join(this.folderPath, toHexString(serializedCheckpoint));
25
+ const filePath = path.join(this.folderPath, toHex(serializedCheckpoint));
26
26
  await writeIfNotExist(filePath, stateBytes);
27
27
  return serializedCheckpoint;
28
28
  }
29
29
  async remove(serializedCheckpoint) {
30
- const filePath = path.join(this.folderPath, toHexString(serializedCheckpoint));
30
+ const filePath = path.join(this.folderPath, toHex(serializedCheckpoint));
31
31
  await removeFile(filePath);
32
32
  }
33
33
  async read(serializedCheckpoint) {
34
- const filePath = path.join(this.folderPath, toHexString(serializedCheckpoint));
34
+ const filePath = path.join(this.folderPath, toHex(serializedCheckpoint));
35
35
  return readFile(filePath);
36
36
  }
37
37
  async readKeys() {
38
38
  const fileNames = await readFileNames(this.folderPath);
39
39
  return fileNames
40
40
  .filter((fileName) => fileName.startsWith("0x") && fileName.length === CHECKPOINT_FILE_NAME_LENGTH)
41
- .map((fileName) => fromHexString(fileName));
41
+ .map((fileName) => fromHex(fileName));
42
42
  }
43
43
  }
44
44
  //# sourceMappingURL=file.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"file.js","sourceRoot":"","sources":["../../../../src/chain/stateCache/datastore/file.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAC,WAAW,EAAE,aAAa,EAAC,MAAM,gBAAgB,CAAC;AAC1D,OAAO,EAAS,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAC,SAAS,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,eAAe,EAAC,MAAM,uBAAuB,CAAC;AAGtG,MAAM,wBAAwB,GAAG,mBAAmB,CAAC;AACrD,MAAM,2BAA2B,GAAG,EAAE,CAAC;AAEvC;;GAEG;AACH,MAAM,OAAO,oBAAoB;IAG/B,YAAY,YAAoB,GAAG;QACjC,+DAA+D;QAC/D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAC;IACnE,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACnC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,aAAa;QACf,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,KAAwB,EAAE,UAAsB;QAC1D,MAAM,oBAAoB,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,oBAAoB,CAAC,CAAC,CAAC;QAC/E,MAAM,eAAe,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAC5C,OAAO,oBAAoB,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,oBAAkC;QAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,oBAAoB,CAAC,CAAC,CAAC;QAC/E,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,oBAAkC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,WAAW,CAAC,oBAAoB,CAAC,CAAC,CAAC;QAC/E,OAAO,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvD,OAAO,SAAS;aACb,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,2BAA2B,CAAC;aAClG,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC,CAAC;IAChD,CAAC;CACF"}
1
+ {"version":3,"file":"file.js","sourceRoot":"","sources":["../../../../src/chain/stateCache/datastore/file.ts"],"names":[],"mappings":"AAAA,OAAO,IAAI,MAAM,WAAW,CAAC;AAC7B,OAAO,EAAS,GAAG,EAAC,MAAM,iBAAiB,CAAC;AAC5C,OAAO,EAAC,OAAO,EAAE,KAAK,EAAC,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAC,SAAS,EAAE,QAAQ,EAAE,aAAa,EAAE,UAAU,EAAE,eAAe,EAAC,MAAM,uBAAuB,CAAC;AAGtG,MAAM,wBAAwB,GAAG,mBAAmB,CAAC;AACrD,MAAM,2BAA2B,GAAG,EAAE,CAAC;AAEvC;;GAEG;AACH,MAAM,OAAO,oBAAoB;IAG/B,YAAY,SAAS,GAAG,GAAG;QACzB,+DAA+D;QAC/D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,wBAAwB,CAAC,CAAC;IACnE,CAAC;IAED,KAAK,CAAC,IAAI;QACR,IAAI,CAAC;YACH,MAAM,SAAS,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACnC,CAAC;QAAC,OAAO,CAAC,EAAE,CAAC;YACX,aAAa;QACf,CAAC;IACH,CAAC;IAED,KAAK,CAAC,KAAK,CAAC,KAAwB,EAAE,UAAsB;QAC1D,MAAM,oBAAoB,GAAG,GAAG,CAAC,MAAM,CAAC,UAAU,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC;QACpE,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACzE,MAAM,eAAe,CAAC,QAAQ,EAAE,UAAU,CAAC,CAAC;QAC5C,OAAO,oBAAoB,CAAC;IAC9B,CAAC;IAED,KAAK,CAAC,MAAM,CAAC,oBAAkC;QAC7C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACzE,MAAM,UAAU,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,KAAK,CAAC,IAAI,CAAC,oBAAkC;QAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,KAAK,CAAC,oBAAoB,CAAC,CAAC,CAAC;QACzE,OAAO,QAAQ,CAAC,QAAQ,CAAC,CAAC;IAC5B,CAAC;IAED,KAAK,CAAC,QAAQ;QACZ,MAAM,SAAS,GAAG,MAAM,aAAa,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;QACvD,OAAO,SAAS;aACb,MAAM,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,QAAQ,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,QAAQ,CAAC,MAAM,KAAK,2BAA2B,CAAC;aAClG,GAAG,CAAC,CAAC,QAAQ,EAAE,EAAE,CAAC,OAAO,CAAC,QAAQ,CAAC,CAAC,CAAC;IAC1C,CAAC;CACF"}
@@ -1,6 +1,6 @@
1
- import { RootHex } from "@lodestar/types";
2
- import { CachedBeaconStateAllForks } from "@lodestar/state-transition";
3
1
  import { routes } from "@lodestar/api";
2
+ import { CachedBeaconStateAllForks } from "@lodestar/state-transition";
3
+ import { RootHex } from "@lodestar/types";
4
4
  import { Metrics } from "../../metrics/index.js";
5
5
  import { StateCloneOpts } from "../regen/interface.js";
6
6
  import { BlockStateCache } from "./types.js";
@@ -8,9 +8,14 @@ export type FIFOBlockStateCacheOpts = {
8
8
  maxBlockStates?: number;
9
9
  };
10
10
  /**
11
- * Regen state if there's a reorg distance > 32 slots.
11
+ * Given `maxSkipSlots` = 32 and `DEFAULT_EARLIEST_PERMISSIBLE_SLOT_DISTANCE` = 32, lodestar doesn't need to
12
+ * reload states in order to process a gossip block.
13
+ *
14
+ * |-----------------------------------------------|-----------------------------------------------|
15
+ * maxSkipSlots DEFAULT_EARLIEST_PERMISSIBLE_SLOT_DISTANCE ^
16
+ * clock slot
12
17
  */
13
- export declare const DEFAULT_MAX_BLOCK_STATES = 32;
18
+ export declare const DEFAULT_MAX_BLOCK_STATES = 64;
14
19
  /**
15
20
  * New implementation of BlockStateCache that keeps the most recent n states consistently
16
21
  * - Maintain a linked list (FIFO) with special handling for head state, which is always the first item in the list