@lodestar/beacon-node 1.35.0-dev.e18102ed8c → 1.35.0-dev.f2a741bbe4

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 (978) hide show
  1. package/lib/api/impl/api.d.ts.map +1 -0
  2. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -0
  3. package/lib/api/impl/beacon/blocks/index.js +8 -2
  4. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  5. package/lib/api/impl/beacon/blocks/utils.d.ts.map +1 -0
  6. package/lib/api/impl/beacon/index.d.ts.map +1 -0
  7. package/lib/api/impl/beacon/pool/index.d.ts.map +1 -0
  8. package/lib/api/impl/beacon/rewards/index.d.ts.map +1 -0
  9. package/lib/api/impl/beacon/state/index.d.ts.map +1 -0
  10. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -0
  11. package/lib/api/impl/config/constants.d.ts +9 -9
  12. package/lib/api/impl/config/constants.d.ts.map +1 -0
  13. package/lib/api/impl/config/constants.js +16 -9
  14. package/lib/api/impl/config/constants.js.map +1 -1
  15. package/lib/api/impl/config/index.d.ts.map +1 -0
  16. package/lib/api/impl/debug/index.d.ts.map +1 -0
  17. package/lib/api/impl/errors.d.ts.map +1 -0
  18. package/lib/api/impl/events/index.d.ts.map +1 -0
  19. package/lib/api/impl/index.d.ts.map +1 -0
  20. package/lib/api/impl/lightclient/index.d.ts.map +1 -0
  21. package/lib/api/impl/lodestar/index.d.ts.map +1 -0
  22. package/lib/api/impl/lodestar/index.js +1 -1
  23. package/lib/api/impl/lodestar/index.js.map +1 -1
  24. package/lib/api/impl/node/index.d.ts.map +1 -0
  25. package/lib/api/impl/node/utils.d.ts.map +1 -0
  26. package/lib/api/impl/proof/index.d.ts.map +1 -0
  27. package/lib/api/impl/types.d.ts.map +1 -0
  28. package/lib/api/impl/utils.d.ts.map +1 -0
  29. package/lib/api/impl/validator/index.d.ts.map +1 -0
  30. package/lib/api/impl/validator/index.js +24 -33
  31. package/lib/api/impl/validator/index.js.map +1 -1
  32. package/lib/api/impl/validator/utils.d.ts.map +1 -0
  33. package/lib/api/index.d.ts.map +1 -0
  34. package/lib/api/options.d.ts.map +1 -0
  35. package/lib/api/rest/activeSockets.d.ts.map +1 -0
  36. package/lib/api/rest/base.d.ts.map +1 -0
  37. package/lib/api/rest/index.d.ts.map +1 -0
  38. package/lib/api/rest/swaggerUI.d.ts.map +1 -0
  39. package/lib/bun-wrappers/prometheus-gc-stats.d.ts.map +1 -0
  40. package/lib/chain/ColumnReconstructionTracker.d.ts.map +1 -0
  41. package/lib/chain/GetBlobsTracker.d.ts.map +1 -0
  42. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -0
  43. package/lib/chain/archiveStore/constants.d.ts.map +1 -0
  44. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -0
  45. package/lib/chain/archiveStore/historicalState/historicalStateRegen.d.ts.map +1 -0
  46. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js +1 -0
  47. package/lib/chain/archiveStore/historicalState/historicalStateRegen.js.map +1 -1
  48. package/lib/chain/archiveStore/historicalState/metrics.d.ts.map +1 -0
  49. package/lib/chain/archiveStore/historicalState/types.d.ts.map +1 -0
  50. package/lib/chain/archiveStore/historicalState/worker.d.ts.map +1 -0
  51. package/lib/chain/archiveStore/historicalState/worker.js +1 -1
  52. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  53. package/lib/chain/archiveStore/index.d.ts.map +1 -0
  54. package/lib/chain/archiveStore/interface.d.ts.map +1 -0
  55. package/lib/chain/archiveStore/strategies/frequencyStateArchiveStrategy.d.ts.map +1 -0
  56. package/lib/chain/archiveStore/utils/archiveBlocks.d.ts.map +1 -0
  57. package/lib/chain/archiveStore/utils/pruneHistory.d.ts.map +1 -0
  58. package/lib/chain/archiveStore/utils/updateBackfillRange.d.ts.map +1 -0
  59. package/lib/chain/balancesCache.d.ts.map +1 -0
  60. package/lib/chain/beaconProposerCache.d.ts.map +1 -0
  61. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -0
  62. package/lib/chain/blocks/blockInput/blockInput.js +3 -2
  63. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  64. package/lib/chain/blocks/blockInput/errors.d.ts.map +1 -0
  65. package/lib/chain/blocks/blockInput/index.d.ts.map +1 -0
  66. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -0
  67. package/lib/chain/blocks/blockInput/utils.d.ts.map +1 -0
  68. package/lib/chain/blocks/importBlock.d.ts.map +1 -0
  69. package/lib/chain/blocks/importBlock.js +7 -6
  70. package/lib/chain/blocks/importBlock.js.map +1 -1
  71. package/lib/chain/blocks/index.d.ts.map +1 -0
  72. package/lib/chain/blocks/types.d.ts.map +1 -0
  73. package/lib/chain/blocks/utils/blowfishBanner.d.ts.map +1 -0
  74. package/lib/chain/blocks/utils/chainSegment.d.ts.map +1 -0
  75. package/lib/chain/blocks/utils/checkpoint.d.ts.map +1 -0
  76. package/lib/chain/blocks/utils/giraffeBanner.d.ts.map +1 -0
  77. package/lib/chain/blocks/utils/ownBanner.d.ts.map +1 -0
  78. package/lib/chain/blocks/utils/pandaMergeTransitionBanner.d.ts.map +1 -0
  79. package/lib/chain/blocks/utils/zebraBanner.d.ts.map +1 -0
  80. package/lib/chain/blocks/verifyBlock.d.ts.map +1 -0
  81. package/lib/chain/blocks/verifyBlocksDataAvailability.d.ts.map +1 -0
  82. package/lib/chain/blocks/verifyBlocksDataAvailability.js +8 -1
  83. package/lib/chain/blocks/verifyBlocksDataAvailability.js.map +1 -1
  84. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -0
  85. package/lib/chain/blocks/verifyBlocksSanityChecks.d.ts.map +1 -0
  86. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +1 -0
  87. package/lib/chain/blocks/verifyBlocksStateTransitionOnly.d.ts.map +1 -0
  88. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +1 -0
  89. package/lib/chain/blocks/writeBlockInputToDb.js +1 -7
  90. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  91. package/lib/chain/bls/index.d.ts.map +1 -0
  92. package/lib/chain/bls/interface.d.ts.map +1 -0
  93. package/lib/chain/bls/maybeBatch.d.ts.map +1 -0
  94. package/lib/chain/bls/multithread/index.d.ts.map +1 -0
  95. package/lib/chain/bls/multithread/index.js +1 -0
  96. package/lib/chain/bls/multithread/index.js.map +1 -1
  97. package/lib/chain/bls/multithread/jobItem.d.ts.map +1 -0
  98. package/lib/chain/bls/multithread/poolSize.d.ts.map +1 -0
  99. package/lib/chain/bls/multithread/types.d.ts.map +1 -0
  100. package/lib/chain/bls/multithread/utils.d.ts.map +1 -0
  101. package/lib/chain/bls/multithread/worker.d.ts.map +1 -0
  102. package/lib/chain/bls/singleThread.d.ts.map +1 -0
  103. package/lib/chain/bls/utils.d.ts.map +1 -0
  104. package/lib/chain/chain.d.ts +1 -1
  105. package/lib/chain/chain.d.ts.map +1 -0
  106. package/lib/chain/chain.js +4 -6
  107. package/lib/chain/chain.js.map +1 -1
  108. package/lib/chain/emitter.d.ts +2 -2
  109. package/lib/chain/emitter.d.ts.map +1 -0
  110. package/lib/chain/errors/attestationError.d.ts.map +1 -0
  111. package/lib/chain/errors/attesterSlashingError.d.ts.map +1 -0
  112. package/lib/chain/errors/blobSidecarError.d.ts.map +1 -0
  113. package/lib/chain/errors/blockError.d.ts.map +1 -0
  114. package/lib/chain/errors/blsToExecutionChangeError.d.ts.map +1 -0
  115. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +1 -0
  116. package/lib/chain/errors/gossipValidation.d.ts.map +1 -0
  117. package/lib/chain/errors/index.d.ts.map +1 -0
  118. package/lib/chain/errors/lightClientError.d.ts.map +1 -0
  119. package/lib/chain/errors/proposerSlashingError.d.ts.map +1 -0
  120. package/lib/chain/errors/syncCommitteeError.d.ts.map +1 -0
  121. package/lib/chain/errors/voluntaryExitError.d.ts.map +1 -0
  122. package/lib/chain/forkChoice/index.d.ts.map +1 -0
  123. package/lib/chain/genesis/genesis.d.ts.map +1 -0
  124. package/lib/chain/genesis/interface.d.ts.map +1 -0
  125. package/lib/chain/index.d.ts.map +1 -0
  126. package/lib/chain/initState.d.ts.map +1 -0
  127. package/lib/chain/interface.d.ts.map +1 -0
  128. package/lib/chain/lightClient/index.d.ts +2 -2
  129. package/lib/chain/lightClient/index.d.ts.map +1 -0
  130. package/lib/chain/lightClient/index.js +2 -0
  131. package/lib/chain/lightClient/index.js.map +1 -1
  132. package/lib/chain/lightClient/proofs.d.ts.map +1 -0
  133. package/lib/chain/lightClient/types.d.ts.map +1 -0
  134. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +1 -0
  135. package/lib/chain/opPools/attestationPool.d.ts +2 -3
  136. package/lib/chain/opPools/attestationPool.d.ts.map +1 -0
  137. package/lib/chain/opPools/attestationPool.js +3 -5
  138. package/lib/chain/opPools/attestationPool.js.map +1 -1
  139. package/lib/chain/opPools/index.d.ts.map +1 -0
  140. package/lib/chain/opPools/opPool.d.ts.map +1 -0
  141. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts +3 -2
  142. package/lib/chain/opPools/syncCommitteeMessagePool.d.ts.map +1 -0
  143. package/lib/chain/opPools/syncCommitteeMessagePool.js +6 -5
  144. package/lib/chain/opPools/syncCommitteeMessagePool.js.map +1 -1
  145. package/lib/chain/opPools/syncContributionAndProofPool.d.ts.map +1 -0
  146. package/lib/chain/opPools/types.d.ts +1 -1
  147. package/lib/chain/opPools/types.d.ts.map +1 -0
  148. package/lib/chain/opPools/types.js +1 -1
  149. package/lib/chain/opPools/types.js.map +1 -1
  150. package/lib/chain/opPools/utils.d.ts.map +1 -0
  151. package/lib/chain/options.d.ts.map +1 -0
  152. package/lib/chain/prepareNextSlot.d.ts +3 -3
  153. package/lib/chain/prepareNextSlot.d.ts.map +1 -0
  154. package/lib/chain/prepareNextSlot.js +8 -8
  155. package/lib/chain/prepareNextSlot.js.map +1 -1
  156. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -0
  157. package/lib/chain/produceBlock/index.d.ts.map +1 -0
  158. package/lib/chain/produceBlock/produceBlockBody.d.ts +1 -4
  159. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -0
  160. package/lib/chain/produceBlock/produceBlockBody.js +13 -4
  161. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  162. package/lib/chain/produceBlock/validateBlobsAndKzgCommitments.d.ts.map +1 -0
  163. package/lib/chain/regen/errors.d.ts.map +1 -0
  164. package/lib/chain/regen/index.d.ts.map +1 -0
  165. package/lib/chain/regen/interface.d.ts +1 -0
  166. package/lib/chain/regen/interface.d.ts.map +1 -0
  167. package/lib/chain/regen/interface.js +1 -0
  168. package/lib/chain/regen/interface.js.map +1 -1
  169. package/lib/chain/regen/queued.d.ts.map +1 -0
  170. package/lib/chain/regen/regen.d.ts.map +1 -0
  171. package/lib/chain/reprocess.d.ts.map +1 -0
  172. package/lib/chain/rewards/attestationsRewards.d.ts.map +1 -0
  173. package/lib/chain/rewards/blockRewards.d.ts.map +1 -0
  174. package/lib/chain/rewards/syncCommitteeRewards.d.ts.map +1 -0
  175. package/lib/chain/seenCache/index.d.ts.map +1 -0
  176. package/lib/chain/seenCache/seenAggregateAndProof.d.ts.map +1 -0
  177. package/lib/chain/seenCache/seenAttestationData.d.ts.map +1 -0
  178. package/lib/chain/seenCache/seenAttesters.d.ts.map +1 -0
  179. package/lib/chain/seenCache/seenBlockAttesters.d.ts.map +1 -0
  180. package/lib/chain/seenCache/seenBlockProposers.d.ts.map +1 -0
  181. package/lib/chain/seenCache/seenCommittee.d.ts.map +1 -0
  182. package/lib/chain/seenCache/seenCommitteeContribution.d.ts.map +1 -0
  183. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -0
  184. package/lib/chain/seenCache/seenGossipBlockInput.js +8 -1
  185. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  186. package/lib/chain/serializeState.d.ts.map +1 -0
  187. package/lib/chain/shufflingCache.d.ts.map +1 -0
  188. package/lib/chain/stateCache/blockStateCacheImpl.d.ts.map +1 -0
  189. package/lib/chain/stateCache/datastore/db.d.ts.map +1 -0
  190. package/lib/chain/stateCache/datastore/file.d.ts.map +1 -0
  191. package/lib/chain/stateCache/datastore/index.d.ts.map +1 -0
  192. package/lib/chain/stateCache/datastore/types.d.ts.map +1 -0
  193. package/lib/chain/stateCache/fifoBlockStateCache.d.ts.map +1 -0
  194. package/lib/chain/stateCache/inMemoryCheckpointsCache.d.ts.map +1 -0
  195. package/lib/chain/stateCache/index.d.ts.map +1 -0
  196. package/lib/chain/stateCache/mapMetrics.d.ts.map +1 -0
  197. package/lib/chain/stateCache/persistentCheckpointsCache.d.ts.map +1 -0
  198. package/lib/chain/stateCache/persistentCheckpointsCache.js +9 -8
  199. package/lib/chain/stateCache/persistentCheckpointsCache.js.map +1 -1
  200. package/lib/chain/stateCache/types.d.ts.map +1 -0
  201. package/lib/chain/validation/aggregateAndProof.d.ts.map +1 -0
  202. package/lib/chain/validation/attestation.d.ts.map +1 -0
  203. package/lib/chain/validation/attesterSlashing.d.ts.map +1 -0
  204. package/lib/chain/validation/blobSidecar.d.ts.map +1 -0
  205. package/lib/chain/validation/block.d.ts.map +1 -0
  206. package/lib/chain/validation/blsToExecutionChange.d.ts.map +1 -0
  207. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -0
  208. package/lib/chain/validation/dataColumnSidecar.js +1 -1
  209. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  210. package/lib/chain/validation/index.d.ts.map +1 -0
  211. package/lib/chain/validation/lightClientFinalityUpdate.d.ts.map +1 -0
  212. package/lib/chain/validation/lightClientFinalityUpdate.js +4 -3
  213. package/lib/chain/validation/lightClientFinalityUpdate.js.map +1 -1
  214. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts +6 -4
  215. package/lib/chain/validation/lightClientOptimisticUpdate.d.ts.map +1 -0
  216. package/lib/chain/validation/lightClientOptimisticUpdate.js +11 -11
  217. package/lib/chain/validation/lightClientOptimisticUpdate.js.map +1 -1
  218. package/lib/chain/validation/proposerSlashing.d.ts.map +1 -0
  219. package/lib/chain/validation/signatureSets/aggregateAndProof.d.ts.map +1 -0
  220. package/lib/chain/validation/signatureSets/contributionAndProof.d.ts.map +1 -0
  221. package/lib/chain/validation/signatureSets/index.d.ts.map +1 -0
  222. package/lib/chain/validation/signatureSets/selectionProof.d.ts.map +1 -0
  223. package/lib/chain/validation/signatureSets/syncCommittee.d.ts.map +1 -0
  224. package/lib/chain/validation/signatureSets/syncCommitteeContribution.d.ts.map +1 -0
  225. package/lib/chain/validation/signatureSets/syncCommitteeSelectionProof.d.ts.map +1 -0
  226. package/lib/chain/validation/syncCommittee.d.ts.map +1 -0
  227. package/lib/chain/validation/syncCommitteeContributionAndProof.d.ts.map +1 -0
  228. package/lib/chain/validation/voluntaryExit.d.ts.map +1 -0
  229. package/lib/chain/validatorMonitor.d.ts.map +1 -0
  230. package/lib/chain/validatorMonitor.js +21 -15
  231. package/lib/chain/validatorMonitor.js.map +1 -1
  232. package/lib/constants/constants.d.ts.map +1 -0
  233. package/lib/constants/index.d.ts.map +1 -0
  234. package/lib/constants/network.d.ts.map +1 -0
  235. package/lib/db/beacon.d.ts.map +1 -0
  236. package/lib/db/buckets.d.ts +4 -4
  237. package/lib/db/buckets.d.ts.map +1 -0
  238. package/lib/db/buckets.js +4 -4
  239. package/lib/db/buckets.js.map +1 -1
  240. package/lib/db/index.d.ts.map +1 -0
  241. package/lib/db/interface.d.ts.map +1 -0
  242. package/lib/db/options.d.ts.map +1 -0
  243. package/lib/db/repositories/attesterSlashing.d.ts.map +1 -0
  244. package/lib/db/repositories/backfilledRanges.d.ts.map +1 -0
  245. package/lib/db/repositories/blobSidecars.d.ts.map +1 -0
  246. package/lib/db/repositories/blobSidecars.js +1 -1
  247. package/lib/db/repositories/blobSidecars.js.map +1 -1
  248. package/lib/db/repositories/blobSidecarsArchive.d.ts.map +1 -0
  249. package/lib/db/repositories/blobSidecarsArchive.js +1 -1
  250. package/lib/db/repositories/blobSidecarsArchive.js.map +1 -1
  251. package/lib/db/repositories/block.d.ts.map +1 -0
  252. package/lib/db/repositories/blockArchive.d.ts.map +1 -0
  253. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  254. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -0
  255. package/lib/db/repositories/blsToExecutionChange.d.ts.map +1 -0
  256. package/lib/db/repositories/checkpointState.d.ts.map +1 -0
  257. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -0
  258. package/lib/db/repositories/dataColumnSidecar.js +1 -1
  259. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  260. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -0
  261. package/lib/db/repositories/dataColumnSidecarArchive.js +1 -1
  262. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  263. package/lib/db/repositories/depositDataRoot.d.ts.map +1 -0
  264. package/lib/db/repositories/depositEvent.d.ts.map +1 -0
  265. package/lib/db/repositories/eth1Data.d.ts.map +1 -0
  266. package/lib/db/repositories/index.d.ts.map +1 -0
  267. package/lib/db/repositories/lightclientBestUpdate.d.ts.map +1 -0
  268. package/lib/db/repositories/lightclientCheckpointHeader.d.ts.map +1 -0
  269. package/lib/db/repositories/lightclientSyncCommittee.d.ts.map +1 -0
  270. package/lib/db/repositories/lightclientSyncCommitteeWitness.d.ts.map +1 -0
  271. package/lib/db/repositories/proposerSlashing.d.ts.map +1 -0
  272. package/lib/db/repositories/stateArchive.d.ts.map +1 -0
  273. package/lib/db/repositories/stateArchiveIndex.d.ts.map +1 -0
  274. package/lib/db/repositories/voluntaryExit.d.ts.map +1 -0
  275. package/lib/db/single/index.d.ts.map +1 -0
  276. package/lib/db/single/preGenesisState.d.ts.map +1 -0
  277. package/lib/db/single/preGenesisStateLastProcessedBlock.d.ts.map +1 -0
  278. package/lib/eth1/errors.d.ts.map +1 -0
  279. package/lib/eth1/eth1DataCache.d.ts.map +1 -0
  280. package/lib/eth1/eth1DepositDataTracker.d.ts.map +1 -0
  281. package/lib/eth1/eth1DepositsCache.d.ts.map +1 -0
  282. package/lib/eth1/eth1MergeBlockTracker.d.ts.map +1 -0
  283. package/lib/eth1/index.d.ts.map +1 -0
  284. package/lib/eth1/interface.d.ts.map +1 -0
  285. package/lib/eth1/options.d.ts.map +1 -0
  286. package/lib/eth1/provider/eth1Provider.d.ts.map +1 -0
  287. package/lib/eth1/provider/jsonRpcHttpClient.d.ts.map +1 -0
  288. package/lib/eth1/provider/jwt.d.ts.map +1 -0
  289. package/lib/eth1/provider/utils.d.ts.map +1 -0
  290. package/lib/eth1/stream.d.ts.map +1 -0
  291. package/lib/eth1/utils/depositContract.d.ts.map +1 -0
  292. package/lib/eth1/utils/deposits.d.ts.map +1 -0
  293. package/lib/eth1/utils/eth1Data.d.ts.map +1 -0
  294. package/lib/eth1/utils/eth1DepositEvent.d.ts.map +1 -0
  295. package/lib/eth1/utils/eth1Vote.d.ts.map +1 -0
  296. package/lib/eth1/utils/groupDepositEventsByBlock.d.ts.map +1 -0
  297. package/lib/eth1/utils/optimizeNextBlockDiffForGenesis.d.ts.map +1 -0
  298. package/lib/execution/builder/cache.d.ts.map +1 -0
  299. package/lib/execution/builder/http.d.ts.map +1 -0
  300. package/lib/execution/builder/index.d.ts.map +1 -0
  301. package/lib/execution/builder/interface.d.ts.map +1 -0
  302. package/lib/execution/builder/utils.d.ts.map +1 -0
  303. package/lib/execution/engine/disabled.d.ts.map +1 -0
  304. package/lib/execution/engine/http.d.ts.map +1 -0
  305. package/lib/execution/engine/index.d.ts.map +1 -0
  306. package/lib/execution/engine/interface.d.ts.map +1 -0
  307. package/lib/execution/engine/mock.d.ts.map +1 -0
  308. package/lib/execution/engine/payloadIdCache.d.ts.map +1 -0
  309. package/lib/execution/engine/types.d.ts.map +1 -0
  310. package/lib/execution/engine/utils.d.ts.map +1 -0
  311. package/lib/execution/index.d.ts.map +1 -0
  312. package/lib/index.d.ts.map +1 -0
  313. package/lib/metrics/index.d.ts.map +1 -0
  314. package/lib/metrics/metrics/beacon.d.ts.map +1 -0
  315. package/lib/metrics/metrics/lodestar.d.ts +1 -1
  316. package/lib/metrics/metrics/lodestar.d.ts.map +1 -0
  317. package/lib/metrics/metrics/lodestar.js +3 -3
  318. package/lib/metrics/metrics/lodestar.js.map +1 -1
  319. package/lib/metrics/metrics.d.ts.map +1 -0
  320. package/lib/metrics/nodeJsMetrics.d.ts.map +1 -0
  321. package/lib/metrics/options.d.ts.map +1 -0
  322. package/lib/metrics/server/http.d.ts.map +1 -0
  323. package/lib/metrics/server/index.d.ts.map +1 -0
  324. package/lib/metrics/utils/avgMinMax.d.ts.map +1 -0
  325. package/lib/metrics/utils/gauge.d.ts.map +1 -0
  326. package/lib/metrics/utils/registryMetricCreator.d.ts.map +1 -0
  327. package/lib/monitoring/clientStats.d.ts.map +1 -0
  328. package/lib/monitoring/index.d.ts.map +1 -0
  329. package/lib/monitoring/options.d.ts.map +1 -0
  330. package/lib/monitoring/properties.d.ts.map +1 -0
  331. package/lib/monitoring/service.d.ts.map +1 -0
  332. package/lib/monitoring/system.d.ts.map +1 -0
  333. package/lib/monitoring/types.d.ts.map +1 -0
  334. package/lib/network/core/events.d.ts.map +1 -0
  335. package/lib/network/core/index.d.ts.map +1 -0
  336. package/lib/network/core/metrics.d.ts.map +1 -0
  337. package/lib/network/core/networkCore.d.ts.map +1 -0
  338. package/lib/network/core/networkCoreWorker.d.ts.map +1 -0
  339. package/lib/network/core/networkCoreWorkerHandler.d.ts.map +1 -0
  340. package/lib/network/core/networkCoreWorkerHandler.js +9 -3
  341. package/lib/network/core/networkCoreWorkerHandler.js.map +1 -1
  342. package/lib/network/core/types.d.ts.map +1 -0
  343. package/lib/network/discv5/index.d.ts.map +1 -0
  344. package/lib/network/discv5/index.js +4 -1
  345. package/lib/network/discv5/index.js.map +1 -1
  346. package/lib/network/discv5/types.d.ts.map +1 -0
  347. package/lib/network/discv5/utils.d.ts.map +1 -0
  348. package/lib/network/discv5/worker.d.ts.map +1 -0
  349. package/lib/network/events.d.ts.map +1 -0
  350. package/lib/network/forks.d.ts.map +1 -0
  351. package/lib/network/gossip/constants.d.ts.map +1 -0
  352. package/lib/network/gossip/encoding.d.ts.map +1 -0
  353. package/lib/network/gossip/errors.d.ts.map +1 -0
  354. package/lib/network/gossip/gossipsub.d.ts +1 -0
  355. package/lib/network/gossip/gossipsub.d.ts.map +1 -0
  356. package/lib/network/gossip/gossipsub.js +36 -17
  357. package/lib/network/gossip/gossipsub.js.map +1 -1
  358. package/lib/network/gossip/index.d.ts.map +1 -0
  359. package/lib/network/gossip/interface.d.ts.map +1 -0
  360. package/lib/network/gossip/metrics.d.ts +15 -7
  361. package/lib/network/gossip/metrics.d.ts.map +1 -0
  362. package/lib/network/gossip/metrics.js +16 -6
  363. package/lib/network/gossip/metrics.js.map +1 -1
  364. package/lib/network/gossip/scoringParameters.d.ts.map +1 -0
  365. package/lib/network/gossip/scoringParameters.js +4 -4
  366. package/lib/network/gossip/scoringParameters.js.map +1 -1
  367. package/lib/network/gossip/topic.d.ts.map +1 -0
  368. package/lib/network/gossip/topic.js +2 -2
  369. package/lib/network/gossip/topic.js.map +1 -1
  370. package/lib/network/index.d.ts.map +1 -0
  371. package/lib/network/interface.d.ts.map +1 -0
  372. package/lib/network/libp2p/error.d.ts.map +1 -0
  373. package/lib/network/libp2p/index.d.ts.map +1 -0
  374. package/lib/network/libp2p/index.js +9 -1
  375. package/lib/network/libp2p/index.js.map +1 -1
  376. package/lib/network/metadata.d.ts.map +1 -0
  377. package/lib/network/metadata.js +2 -1
  378. package/lib/network/metadata.js.map +1 -1
  379. package/lib/network/network.d.ts +1 -1
  380. package/lib/network/network.d.ts.map +1 -0
  381. package/lib/network/network.js +11 -13
  382. package/lib/network/network.js.map +1 -1
  383. package/lib/network/networkConfig.d.ts.map +1 -0
  384. package/lib/network/options.d.ts.map +1 -0
  385. package/lib/network/peers/client.d.ts.map +1 -0
  386. package/lib/network/peers/datastore.d.ts +2 -2
  387. package/lib/network/peers/datastore.d.ts.map +1 -0
  388. package/lib/network/peers/datastore.js +2 -2
  389. package/lib/network/peers/datastore.js.map +1 -1
  390. package/lib/network/peers/discover.d.ts.map +1 -0
  391. package/lib/network/peers/index.d.ts.map +1 -0
  392. package/lib/network/peers/peerManager.d.ts.map +1 -0
  393. package/lib/network/peers/peerManager.js +2 -1
  394. package/lib/network/peers/peerManager.js.map +1 -1
  395. package/lib/network/peers/peersData.d.ts.map +1 -0
  396. package/lib/network/peers/score/constants.d.ts.map +1 -0
  397. package/lib/network/peers/score/index.d.ts.map +1 -0
  398. package/lib/network/peers/score/interface.d.ts.map +1 -0
  399. package/lib/network/peers/score/score.d.ts.map +1 -0
  400. package/lib/network/peers/score/store.d.ts.map +1 -0
  401. package/lib/network/peers/score/utils.d.ts.map +1 -0
  402. package/lib/network/peers/utils/assertPeerRelevance.d.ts.map +1 -0
  403. package/lib/network/peers/utils/enrSubnetsDeserialize.d.ts.map +1 -0
  404. package/lib/network/peers/utils/getConnectedPeerIds.d.ts.map +1 -0
  405. package/lib/network/peers/utils/index.d.ts.map +1 -0
  406. package/lib/network/peers/utils/prioritizePeers.d.ts.map +1 -0
  407. package/lib/network/peers/utils/subnetMap.d.ts.map +1 -0
  408. package/lib/network/processor/aggregatorTracker.d.ts.map +1 -0
  409. package/lib/network/processor/extractSlotRootFns.d.ts.map +1 -0
  410. package/lib/network/processor/gossipHandlers.d.ts.map +1 -0
  411. package/lib/network/processor/gossipHandlers.js +1 -1
  412. package/lib/network/processor/gossipHandlers.js.map +1 -1
  413. package/lib/network/processor/gossipQueues/index.d.ts.map +1 -0
  414. package/lib/network/processor/gossipQueues/indexed.d.ts.map +1 -0
  415. package/lib/network/processor/gossipQueues/linear.d.ts.map +1 -0
  416. package/lib/network/processor/gossipQueues/types.d.ts.map +1 -0
  417. package/lib/network/processor/gossipValidatorFn.d.ts.map +1 -0
  418. package/lib/network/processor/index.d.ts +1 -1
  419. package/lib/network/processor/index.d.ts.map +1 -0
  420. package/lib/network/processor/index.js +2 -3
  421. package/lib/network/processor/index.js.map +1 -1
  422. package/lib/network/processor/types.d.ts.map +1 -0
  423. package/lib/network/reqresp/ReqRespBeaconNode.d.ts.map +1 -0
  424. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -0
  425. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +1 -0
  426. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -0
  427. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +1 -0
  428. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -0
  429. package/lib/network/reqresp/handlers/dataColumnSidecarsByRoot.d.ts.map +1 -0
  430. package/lib/network/reqresp/handlers/index.d.ts.map +1 -0
  431. package/lib/network/reqresp/handlers/lightClientBootstrap.d.ts.map +1 -0
  432. package/lib/network/reqresp/handlers/lightClientFinalityUpdate.d.ts.map +1 -0
  433. package/lib/network/reqresp/handlers/lightClientOptimisticUpdate.d.ts.map +1 -0
  434. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +1 -0
  435. package/lib/network/reqresp/index.d.ts.map +1 -0
  436. package/lib/network/reqresp/interface.d.ts.map +1 -0
  437. package/lib/network/reqresp/protocols.d.ts.map +1 -0
  438. package/lib/network/reqresp/rateLimit.d.ts.map +1 -0
  439. package/lib/network/reqresp/score.d.ts.map +1 -0
  440. package/lib/network/reqresp/types.d.ts.map +1 -0
  441. package/lib/network/reqresp/utils/collect.d.ts.map +1 -0
  442. package/lib/network/reqresp/utils/collectSequentialBlocksInRange.d.ts.map +1 -0
  443. package/lib/network/reqresp/utils/dataColumnResponseValidation.d.ts.map +1 -0
  444. package/lib/network/statusCache.d.ts.map +1 -0
  445. package/lib/network/subnets/attnetsService.d.ts.map +1 -0
  446. package/lib/network/subnets/attnetsService.js +1 -1
  447. package/lib/network/subnets/attnetsService.js.map +1 -1
  448. package/lib/network/subnets/index.d.ts.map +1 -0
  449. package/lib/network/subnets/interface.d.ts.map +1 -0
  450. package/lib/network/subnets/syncnetsService.d.ts.map +1 -0
  451. package/lib/network/subnets/util.d.ts.map +1 -0
  452. package/lib/network/util.d.ts.map +1 -0
  453. package/lib/node/index.d.ts.map +1 -0
  454. package/lib/node/nodejs.d.ts.map +1 -0
  455. package/lib/node/notifier.d.ts.map +1 -0
  456. package/lib/node/notifier.js +1 -1
  457. package/lib/node/notifier.js.map +1 -1
  458. package/lib/node/options.d.ts.map +1 -0
  459. package/lib/node/utils/interop/deposits.d.ts.map +1 -0
  460. package/lib/node/utils/interop/state.d.ts.map +1 -0
  461. package/lib/node/utils/lightclient.d.ts.map +1 -0
  462. package/lib/node/utils/state.d.ts.map +1 -0
  463. package/lib/sync/backfill/backfill.d.ts.map +1 -0
  464. package/lib/sync/backfill/errors.d.ts.map +1 -0
  465. package/lib/sync/backfill/index.d.ts.map +1 -0
  466. package/lib/sync/backfill/verify.d.ts.map +1 -0
  467. package/lib/sync/constants.d.ts.map +1 -0
  468. package/lib/sync/index.d.ts.map +1 -0
  469. package/lib/sync/interface.d.ts.map +1 -0
  470. package/lib/sync/options.d.ts.map +1 -0
  471. package/lib/sync/range/batch.d.ts.map +1 -0
  472. package/lib/sync/range/chain.d.ts.map +1 -0
  473. package/lib/sync/range/range.d.ts.map +1 -0
  474. package/lib/sync/range/utils/batches.d.ts.map +1 -0
  475. package/lib/sync/range/utils/chainTarget.d.ts.map +1 -0
  476. package/lib/sync/range/utils/hashBlocks.d.ts.map +1 -0
  477. package/lib/sync/range/utils/index.d.ts.map +1 -0
  478. package/lib/sync/range/utils/peerBalancer.d.ts.map +1 -0
  479. package/lib/sync/range/utils/updateChains.d.ts.map +1 -0
  480. package/lib/sync/sync.d.ts.map +1 -0
  481. package/lib/sync/types.d.ts +0 -1
  482. package/lib/sync/types.d.ts.map +1 -0
  483. package/lib/sync/types.js.map +1 -1
  484. package/lib/sync/unknownBlock.d.ts +0 -1
  485. package/lib/sync/unknownBlock.d.ts.map +1 -0
  486. package/lib/sync/unknownBlock.js +19 -20
  487. package/lib/sync/unknownBlock.js.map +1 -1
  488. package/lib/sync/utils/downloadByRange.d.ts +2 -1
  489. package/lib/sync/utils/downloadByRange.d.ts.map +1 -0
  490. package/lib/sync/utils/downloadByRange.js +8 -3
  491. package/lib/sync/utils/downloadByRange.js.map +1 -1
  492. package/lib/sync/utils/downloadByRoot.d.ts +3 -1
  493. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -0
  494. package/lib/sync/utils/downloadByRoot.js +34 -6
  495. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  496. package/lib/sync/utils/pendingBlocksTree.d.ts.map +1 -0
  497. package/lib/sync/utils/remoteSyncType.d.ts.map +1 -0
  498. package/lib/util/address.d.ts.map +1 -0
  499. package/lib/util/array.d.ts.map +1 -0
  500. package/lib/util/asyncIterableToEvents.d.ts.map +1 -0
  501. package/lib/util/binarySearch.d.ts.map +1 -0
  502. package/lib/util/bitArray.d.ts.map +1 -0
  503. package/lib/util/blobs.d.ts.map +1 -0
  504. package/lib/util/blobs.js +5 -3
  505. package/lib/util/blobs.js.map +1 -1
  506. package/lib/util/bufferPool.d.ts.map +1 -0
  507. package/lib/util/bytes.d.ts.map +1 -0
  508. package/lib/util/chunkify.d.ts.map +1 -0
  509. package/lib/util/clock.d.ts +8 -3
  510. package/lib/util/clock.d.ts.map +1 -0
  511. package/lib/util/clock.js +8 -5
  512. package/lib/util/clock.js.map +1 -1
  513. package/lib/util/dataColumns.d.ts.map +1 -0
  514. package/lib/util/dataColumns.js +4 -2
  515. package/lib/util/dataColumns.js.map +1 -1
  516. package/lib/util/dependentRoot.d.ts.map +1 -0
  517. package/lib/util/enum.d.ts.map +1 -0
  518. package/lib/util/error.d.ts.map +1 -0
  519. package/lib/util/eventLoop.d.ts.map +1 -0
  520. package/lib/util/execution.d.ts.map +1 -0
  521. package/lib/util/execution.js +19 -2
  522. package/lib/util/execution.js.map +1 -1
  523. package/lib/util/file.d.ts.map +1 -0
  524. package/lib/util/forkChoice.d.ts.map +1 -0
  525. package/lib/util/forkName.d.ts.map +1 -0
  526. package/lib/util/graffiti.d.ts.map +1 -0
  527. package/lib/util/hex.d.ts.map +1 -0
  528. package/lib/util/index.d.ts.map +1 -0
  529. package/lib/util/ip.d.ts.map +1 -0
  530. package/lib/util/itTrigger.d.ts.map +1 -0
  531. package/lib/util/kzg.d.ts.map +1 -0
  532. package/lib/util/map.d.ts.map +1 -0
  533. package/lib/util/metadata.d.ts.map +1 -0
  534. package/lib/util/multifork.d.ts.map +1 -0
  535. package/lib/util/numpy.d.ts.map +1 -0
  536. package/lib/util/peerId.d.ts.map +1 -0
  537. package/lib/util/profile.d.ts.map +1 -0
  538. package/lib/util/promises.d.ts.map +1 -0
  539. package/lib/util/queue/errors.d.ts.map +1 -0
  540. package/lib/util/queue/fnQueue.d.ts.map +1 -0
  541. package/lib/util/queue/index.d.ts.map +1 -0
  542. package/lib/util/queue/itemQueue.d.ts.map +1 -0
  543. package/lib/util/queue/options.d.ts.map +1 -0
  544. package/lib/util/serializedCache.d.ts.map +1 -0
  545. package/lib/util/set.d.ts.map +1 -0
  546. package/lib/util/shuffle.d.ts.map +1 -0
  547. package/lib/util/sortBy.d.ts.map +1 -0
  548. package/lib/util/sszBytes.d.ts.map +1 -0
  549. package/lib/util/strictEvents.d.ts.map +1 -0
  550. package/lib/util/time.d.ts.map +1 -0
  551. package/lib/util/timeSeries.d.ts.map +1 -0
  552. package/lib/util/types.d.ts.map +1 -0
  553. package/lib/util/workerEvents.d.ts.map +1 -0
  554. package/lib/util/wrapError.d.ts.map +1 -0
  555. package/package.json +32 -22
  556. package/src/api/impl/api.ts +26 -0
  557. package/src/api/impl/beacon/blocks/index.ts +753 -0
  558. package/src/api/impl/beacon/blocks/utils.ts +75 -0
  559. package/src/api/impl/beacon/index.ts +35 -0
  560. package/src/api/impl/beacon/pool/index.ts +314 -0
  561. package/src/api/impl/beacon/rewards/index.ts +30 -0
  562. package/src/api/impl/beacon/state/index.ts +406 -0
  563. package/src/api/impl/beacon/state/utils.ts +189 -0
  564. package/src/api/impl/config/constants.ts +135 -0
  565. package/src/api/impl/config/index.ts +59 -0
  566. package/src/api/impl/debug/index.ts +131 -0
  567. package/src/api/impl/errors.ts +50 -0
  568. package/src/api/impl/events/index.ts +33 -0
  569. package/src/api/impl/index.ts +6 -0
  570. package/src/api/impl/lightclient/index.ts +64 -0
  571. package/src/api/impl/lodestar/index.ts +257 -0
  572. package/src/api/impl/node/index.ts +88 -0
  573. package/src/api/impl/node/utils.ts +51 -0
  574. package/src/api/impl/proof/index.ts +60 -0
  575. package/src/api/impl/types.ts +17 -0
  576. package/src/api/impl/utils.ts +25 -0
  577. package/src/api/impl/validator/index.ts +1526 -0
  578. package/src/api/impl/validator/utils.ts +85 -0
  579. package/src/api/index.ts +2 -0
  580. package/src/api/options.ts +16 -0
  581. package/src/api/rest/activeSockets.ts +109 -0
  582. package/src/api/rest/base.ts +216 -0
  583. package/src/api/rest/index.ts +63 -0
  584. package/src/api/rest/swaggerUI.ts +80 -0
  585. package/src/bun-wrappers/prometheus-gc-stats.ts +7 -0
  586. package/src/chain/ColumnReconstructionTracker.ts +90 -0
  587. package/src/chain/GetBlobsTracker.ts +115 -0
  588. package/src/chain/archiveStore/archiveStore.ts +222 -0
  589. package/src/chain/archiveStore/constants.ts +5 -0
  590. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +116 -0
  591. package/src/chain/archiveStore/historicalState/historicalStateRegen.ts +68 -0
  592. package/src/chain/archiveStore/historicalState/metrics.ts +214 -0
  593. package/src/chain/archiveStore/historicalState/types.ts +41 -0
  594. package/src/chain/archiveStore/historicalState/worker.ts +77 -0
  595. package/src/chain/archiveStore/index.ts +3 -0
  596. package/src/chain/archiveStore/interface.ts +75 -0
  597. package/src/chain/archiveStore/strategies/frequencyStateArchiveStrategy.ts +138 -0
  598. package/src/chain/archiveStore/utils/archiveBlocks.ts +437 -0
  599. package/src/chain/archiveStore/utils/pruneHistory.ts +56 -0
  600. package/src/chain/archiveStore/utils/updateBackfillRange.ts +50 -0
  601. package/src/chain/balancesCache.ts +52 -0
  602. package/src/chain/beaconProposerCache.ts +43 -0
  603. package/src/chain/blocks/blockInput/blockInput.ts +854 -0
  604. package/src/chain/blocks/blockInput/errors.ts +48 -0
  605. package/src/chain/blocks/blockInput/index.ts +4 -0
  606. package/src/chain/blocks/blockInput/types.ts +145 -0
  607. package/src/chain/blocks/blockInput/utils.ts +21 -0
  608. package/src/chain/blocks/importBlock.ts +599 -0
  609. package/src/chain/blocks/index.ts +179 -0
  610. package/src/chain/blocks/types.ts +101 -0
  611. package/src/chain/blocks/utils/blowfishBanner.ts +28 -0
  612. package/src/chain/blocks/utils/chainSegment.ts +29 -0
  613. package/src/chain/blocks/utils/checkpoint.ts +25 -0
  614. package/src/chain/blocks/utils/giraffeBanner.ts +30 -0
  615. package/src/chain/blocks/utils/ownBanner.ts +20 -0
  616. package/src/chain/blocks/utils/pandaMergeTransitionBanner.ts +43 -0
  617. package/src/chain/blocks/utils/zebraBanner.ts +45 -0
  618. package/src/chain/blocks/verifyBlock.ts +242 -0
  619. package/src/chain/blocks/verifyBlocksDataAvailability.ts +42 -0
  620. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +438 -0
  621. package/src/chain/blocks/verifyBlocksSanityChecks.ts +129 -0
  622. package/src/chain/blocks/verifyBlocksSignatures.ts +105 -0
  623. package/src/chain/blocks/verifyBlocksStateTransitionOnly.ts +114 -0
  624. package/src/chain/blocks/writeBlockInputToDb.ts +120 -0
  625. package/src/chain/bls/index.ts +4 -0
  626. package/src/chain/bls/interface.ts +68 -0
  627. package/src/chain/bls/maybeBatch.ts +45 -0
  628. package/src/chain/bls/multithread/index.ts +582 -0
  629. package/src/chain/bls/multithread/jobItem.ts +119 -0
  630. package/src/chain/bls/multithread/poolSize.ts +16 -0
  631. package/src/chain/bls/multithread/types.ts +38 -0
  632. package/src/chain/bls/multithread/utils.ts +19 -0
  633. package/src/chain/bls/multithread/worker.ts +114 -0
  634. package/src/chain/bls/singleThread.ts +87 -0
  635. package/src/chain/bls/utils.ts +30 -0
  636. package/src/chain/chain.ts +1352 -0
  637. package/src/chain/emitter.ts +113 -0
  638. package/src/chain/errors/attestationError.ts +194 -0
  639. package/src/chain/errors/attesterSlashingError.ts +11 -0
  640. package/src/chain/errors/blobSidecarError.ts +60 -0
  641. package/src/chain/errors/blockError.ts +166 -0
  642. package/src/chain/errors/blsToExecutionChangeError.ts +13 -0
  643. package/src/chain/errors/dataColumnSidecarError.ts +80 -0
  644. package/src/chain/errors/gossipValidation.ts +20 -0
  645. package/src/chain/errors/index.ts +10 -0
  646. package/src/chain/errors/lightClientError.ts +30 -0
  647. package/src/chain/errors/proposerSlashingError.ts +11 -0
  648. package/src/chain/errors/syncCommitteeError.ts +36 -0
  649. package/src/chain/errors/voluntaryExitError.ts +13 -0
  650. package/src/chain/forkChoice/index.ts +112 -0
  651. package/src/chain/genesis/genesis.ts +190 -0
  652. package/src/chain/genesis/interface.ts +14 -0
  653. package/src/chain/index.ts +6 -0
  654. package/src/chain/initState.ts +221 -0
  655. package/src/chain/interface.ts +280 -0
  656. package/src/chain/lightClient/index.ts +772 -0
  657. package/src/chain/lightClient/proofs.ts +85 -0
  658. package/src/chain/lightClient/types.ts +33 -0
  659. package/src/chain/opPools/aggregatedAttestationPool.ts +1063 -0
  660. package/src/chain/opPools/attestationPool.ts +282 -0
  661. package/src/chain/opPools/index.ts +5 -0
  662. package/src/chain/opPools/opPool.ts +462 -0
  663. package/src/chain/opPools/syncCommitteeMessagePool.ts +169 -0
  664. package/src/chain/opPools/syncContributionAndProofPool.ts +240 -0
  665. package/src/chain/opPools/types.ts +35 -0
  666. package/src/chain/opPools/utils.ts +65 -0
  667. package/src/chain/options.ts +138 -0
  668. package/src/chain/prepareNextSlot.ts +277 -0
  669. package/src/chain/produceBlock/computeNewStateRoot.ts +55 -0
  670. package/src/chain/produceBlock/index.ts +2 -0
  671. package/src/chain/produceBlock/produceBlockBody.ts +799 -0
  672. package/src/chain/produceBlock/validateBlobsAndKzgCommitments.ts +54 -0
  673. package/src/chain/regen/errors.ts +30 -0
  674. package/src/chain/regen/index.ts +4 -0
  675. package/src/chain/regen/interface.ts +94 -0
  676. package/src/chain/regen/queued.ts +317 -0
  677. package/src/chain/regen/regen.ts +424 -0
  678. package/src/chain/reprocess.ts +161 -0
  679. package/src/chain/rewards/attestationsRewards.ts +196 -0
  680. package/src/chain/rewards/blockRewards.ts +150 -0
  681. package/src/chain/rewards/syncCommitteeRewards.ts +58 -0
  682. package/src/chain/seenCache/index.ts +5 -0
  683. package/src/chain/seenCache/seenAggregateAndProof.ts +120 -0
  684. package/src/chain/seenCache/seenAttestationData.ts +145 -0
  685. package/src/chain/seenCache/seenAttesters.ts +58 -0
  686. package/src/chain/seenCache/seenBlockAttesters.ts +18 -0
  687. package/src/chain/seenCache/seenBlockProposers.ts +48 -0
  688. package/src/chain/seenCache/seenCommittee.ts +43 -0
  689. package/src/chain/seenCache/seenCommitteeContribution.ts +104 -0
  690. package/src/chain/seenCache/seenGossipBlockInput.ts +381 -0
  691. package/src/chain/serializeState.ts +32 -0
  692. package/src/chain/shufflingCache.ts +238 -0
  693. package/src/chain/stateCache/blockStateCacheImpl.ts +150 -0
  694. package/src/chain/stateCache/datastore/db.ts +36 -0
  695. package/src/chain/stateCache/datastore/file.ts +53 -0
  696. package/src/chain/stateCache/datastore/index.ts +2 -0
  697. package/src/chain/stateCache/datastore/types.ts +13 -0
  698. package/src/chain/stateCache/fifoBlockStateCache.ts +208 -0
  699. package/src/chain/stateCache/inMemoryCheckpointsCache.ts +198 -0
  700. package/src/chain/stateCache/index.ts +3 -0
  701. package/src/chain/stateCache/mapMetrics.ts +52 -0
  702. package/src/chain/stateCache/persistentCheckpointsCache.ts +837 -0
  703. package/src/chain/stateCache/types.ts +86 -0
  704. package/src/chain/validation/aggregateAndProof.ts +258 -0
  705. package/src/chain/validation/attestation.ts +885 -0
  706. package/src/chain/validation/attesterSlashing.ts +61 -0
  707. package/src/chain/validation/blobSidecar.ts +301 -0
  708. package/src/chain/validation/block.ts +188 -0
  709. package/src/chain/validation/blsToExecutionChange.ts +61 -0
  710. package/src/chain/validation/dataColumnSidecar.ts +381 -0
  711. package/src/chain/validation/index.ts +9 -0
  712. package/src/chain/validation/lightClientFinalityUpdate.ts +46 -0
  713. package/src/chain/validation/lightClientOptimisticUpdate.ts +68 -0
  714. package/src/chain/validation/proposerSlashing.ts +54 -0
  715. package/src/chain/validation/signatureSets/aggregateAndProof.ts +38 -0
  716. package/src/chain/validation/signatureSets/contributionAndProof.ts +27 -0
  717. package/src/chain/validation/signatureSets/index.ts +6 -0
  718. package/src/chain/validation/signatureSets/selectionProof.ts +27 -0
  719. package/src/chain/validation/signatureSets/syncCommittee.ts +22 -0
  720. package/src/chain/validation/signatureSets/syncCommitteeContribution.ts +18 -0
  721. package/src/chain/validation/signatureSets/syncCommitteeSelectionProof.ts +27 -0
  722. package/src/chain/validation/syncCommittee.ts +165 -0
  723. package/src/chain/validation/syncCommitteeContributionAndProof.ts +122 -0
  724. package/src/chain/validation/voluntaryExit.ts +58 -0
  725. package/src/chain/validatorMonitor.ts +1310 -0
  726. package/src/constants/constants.ts +15 -0
  727. package/src/constants/index.ts +2 -0
  728. package/src/constants/network.ts +52 -0
  729. package/src/db/beacon.ts +113 -0
  730. package/src/db/buckets.ts +80 -0
  731. package/src/db/index.ts +2 -0
  732. package/src/db/interface.ts +76 -0
  733. package/src/db/options.ts +7 -0
  734. package/src/db/repositories/attesterSlashing.ts +38 -0
  735. package/src/db/repositories/backfilledRanges.ts +29 -0
  736. package/src/db/repositories/blobSidecars.ts +37 -0
  737. package/src/db/repositories/blobSidecarsArchive.ts +28 -0
  738. package/src/db/repositories/block.ts +33 -0
  739. package/src/db/repositories/blockArchive.ts +170 -0
  740. package/src/db/repositories/blockArchiveIndex.ts +45 -0
  741. package/src/db/repositories/blsToExecutionChange.ts +16 -0
  742. package/src/db/repositories/checkpointState.ts +31 -0
  743. package/src/db/repositories/dataColumnSidecar.ts +49 -0
  744. package/src/db/repositories/dataColumnSidecarArchive.ts +56 -0
  745. package/src/db/repositories/depositDataRoot.ts +80 -0
  746. package/src/db/repositories/depositEvent.ts +32 -0
  747. package/src/db/repositories/eth1Data.ts +33 -0
  748. package/src/db/repositories/index.ts +20 -0
  749. package/src/db/repositories/lightclientBestUpdate.ts +41 -0
  750. package/src/db/repositories/lightclientCheckpointHeader.ts +32 -0
  751. package/src/db/repositories/lightclientSyncCommittee.ts +16 -0
  752. package/src/db/repositories/lightclientSyncCommitteeWitness.ts +77 -0
  753. package/src/db/repositories/proposerSlashing.ts +15 -0
  754. package/src/db/repositories/stateArchive.ts +69 -0
  755. package/src/db/repositories/stateArchiveIndex.ts +18 -0
  756. package/src/db/repositories/voluntaryExit.ts +15 -0
  757. package/src/db/single/index.ts +2 -0
  758. package/src/db/single/preGenesisState.ts +37 -0
  759. package/src/db/single/preGenesisStateLastProcessedBlock.ts +34 -0
  760. package/src/eth1/errors.ts +40 -0
  761. package/src/eth1/eth1DataCache.ts +26 -0
  762. package/src/eth1/eth1DepositDataTracker.ts +410 -0
  763. package/src/eth1/eth1DepositsCache.ts +141 -0
  764. package/src/eth1/eth1MergeBlockTracker.ts +328 -0
  765. package/src/eth1/index.ts +157 -0
  766. package/src/eth1/interface.ts +131 -0
  767. package/src/eth1/options.ts +28 -0
  768. package/src/eth1/provider/eth1Provider.ts +229 -0
  769. package/src/eth1/provider/jsonRpcHttpClient.ts +390 -0
  770. package/src/eth1/provider/jwt.ts +36 -0
  771. package/src/eth1/provider/utils.ts +136 -0
  772. package/src/eth1/stream.ts +75 -0
  773. package/src/eth1/utils/depositContract.ts +37 -0
  774. package/src/eth1/utils/deposits.ts +70 -0
  775. package/src/eth1/utils/eth1Data.ts +100 -0
  776. package/src/eth1/utils/eth1DepositEvent.ts +12 -0
  777. package/src/eth1/utils/eth1Vote.ts +142 -0
  778. package/src/eth1/utils/groupDepositEventsByBlock.ts +19 -0
  779. package/src/eth1/utils/optimizeNextBlockDiffForGenesis.ts +18 -0
  780. package/src/execution/builder/cache.ts +39 -0
  781. package/src/execution/builder/http.ts +229 -0
  782. package/src/execution/builder/index.ts +27 -0
  783. package/src/execution/builder/interface.ts +49 -0
  784. package/src/execution/builder/utils.ts +19 -0
  785. package/src/execution/engine/disabled.ts +35 -0
  786. package/src/execution/engine/http.ts +644 -0
  787. package/src/execution/engine/index.ts +63 -0
  788. package/src/execution/engine/interface.ts +199 -0
  789. package/src/execution/engine/mock.ts +493 -0
  790. package/src/execution/engine/payloadIdCache.ts +54 -0
  791. package/src/execution/engine/types.ts +640 -0
  792. package/src/execution/engine/utils.ts +136 -0
  793. package/src/execution/index.ts +4 -0
  794. package/src/index.ts +20 -0
  795. package/src/metrics/index.ts +4 -0
  796. package/src/metrics/metrics/beacon.ts +390 -0
  797. package/src/metrics/metrics/lodestar.ts +1870 -0
  798. package/src/metrics/metrics.ts +43 -0
  799. package/src/metrics/nodeJsMetrics.ts +19 -0
  800. package/src/metrics/options.ts +22 -0
  801. package/src/metrics/server/http.ts +114 -0
  802. package/src/metrics/server/index.ts +1 -0
  803. package/src/metrics/utils/avgMinMax.ts +87 -0
  804. package/src/metrics/utils/gauge.ts +22 -0
  805. package/src/metrics/utils/registryMetricCreator.ts +41 -0
  806. package/src/monitoring/clientStats.ts +297 -0
  807. package/src/monitoring/index.ts +2 -0
  808. package/src/monitoring/options.ts +19 -0
  809. package/src/monitoring/properties.ts +152 -0
  810. package/src/monitoring/service.ts +235 -0
  811. package/src/monitoring/system.ts +146 -0
  812. package/src/monitoring/types.ts +21 -0
  813. package/src/network/core/events.ts +59 -0
  814. package/src/network/core/index.ts +3 -0
  815. package/src/network/core/metrics.ts +304 -0
  816. package/src/network/core/networkCore.ts +599 -0
  817. package/src/network/core/networkCoreWorker.ts +176 -0
  818. package/src/network/core/networkCoreWorkerHandler.ts +284 -0
  819. package/src/network/core/types.ts +119 -0
  820. package/src/network/discv5/index.ts +132 -0
  821. package/src/network/discv5/types.ts +74 -0
  822. package/src/network/discv5/utils.ts +50 -0
  823. package/src/network/discv5/worker.ts +137 -0
  824. package/src/network/events.ts +51 -0
  825. package/src/network/forks.ts +94 -0
  826. package/src/network/gossip/constants.ts +15 -0
  827. package/src/network/gossip/encoding.ts +111 -0
  828. package/src/network/gossip/errors.ts +7 -0
  829. package/src/network/gossip/gossipsub.ts +384 -0
  830. package/src/network/gossip/index.ts +4 -0
  831. package/src/network/gossip/interface.ts +215 -0
  832. package/src/network/gossip/metrics.ts +71 -0
  833. package/src/network/gossip/scoringParameters.ts +333 -0
  834. package/src/network/gossip/topic.ts +332 -0
  835. package/src/network/index.ts +8 -0
  836. package/src/network/interface.ts +134 -0
  837. package/src/network/libp2p/error.ts +55 -0
  838. package/src/network/libp2p/index.ts +153 -0
  839. package/src/network/metadata.ts +162 -0
  840. package/src/network/network.ts +767 -0
  841. package/src/network/networkConfig.ts +12 -0
  842. package/src/network/options.ts +70 -0
  843. package/src/network/peers/client.ts +29 -0
  844. package/src/network/peers/datastore.ts +188 -0
  845. package/src/network/peers/discover.ts +647 -0
  846. package/src/network/peers/index.ts +2 -0
  847. package/src/network/peers/peerManager.ts +900 -0
  848. package/src/network/peers/peersData.ts +65 -0
  849. package/src/network/peers/score/constants.ts +34 -0
  850. package/src/network/peers/score/index.ts +4 -0
  851. package/src/network/peers/score/interface.ts +74 -0
  852. package/src/network/peers/score/score.ts +200 -0
  853. package/src/network/peers/score/store.ts +95 -0
  854. package/src/network/peers/score/utils.ts +37 -0
  855. package/src/network/peers/utils/assertPeerRelevance.ts +99 -0
  856. package/src/network/peers/utils/enrSubnetsDeserialize.ts +27 -0
  857. package/src/network/peers/utils/getConnectedPeerIds.ts +33 -0
  858. package/src/network/peers/utils/index.ts +4 -0
  859. package/src/network/peers/utils/prioritizePeers.ts +627 -0
  860. package/src/network/peers/utils/subnetMap.ts +88 -0
  861. package/src/network/processor/aggregatorTracker.ts +38 -0
  862. package/src/network/processor/extractSlotRootFns.ts +64 -0
  863. package/src/network/processor/gossipHandlers.ts +951 -0
  864. package/src/network/processor/gossipQueues/index.ts +114 -0
  865. package/src/network/processor/gossipQueues/indexed.ts +219 -0
  866. package/src/network/processor/gossipQueues/linear.ts +162 -0
  867. package/src/network/processor/gossipQueues/types.ts +57 -0
  868. package/src/network/processor/gossipValidatorFn.ts +142 -0
  869. package/src/network/processor/index.ts +496 -0
  870. package/src/network/processor/types.ts +27 -0
  871. package/src/network/reqresp/ReqRespBeaconNode.ts +373 -0
  872. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +101 -0
  873. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +49 -0
  874. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +114 -0
  875. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +62 -0
  876. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +144 -0
  877. package/src/network/reqresp/handlers/dataColumnSidecarsByRoot.ts +88 -0
  878. package/src/network/reqresp/handlers/index.ts +78 -0
  879. package/src/network/reqresp/handlers/lightClientBootstrap.ts +31 -0
  880. package/src/network/reqresp/handlers/lightClientFinalityUpdate.ts +21 -0
  881. package/src/network/reqresp/handlers/lightClientOptimisticUpdate.ts +21 -0
  882. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +39 -0
  883. package/src/network/reqresp/index.ts +2 -0
  884. package/src/network/reqresp/interface.ts +45 -0
  885. package/src/network/reqresp/protocols.ts +146 -0
  886. package/src/network/reqresp/rateLimit.ts +112 -0
  887. package/src/network/reqresp/score.ts +70 -0
  888. package/src/network/reqresp/types.ts +174 -0
  889. package/src/network/reqresp/utils/collect.ts +84 -0
  890. package/src/network/reqresp/utils/collectSequentialBlocksInRange.ts +57 -0
  891. package/src/network/reqresp/utils/dataColumnResponseValidation.ts +99 -0
  892. package/src/network/statusCache.ts +17 -0
  893. package/src/network/subnets/attnetsService.ts +382 -0
  894. package/src/network/subnets/index.ts +2 -0
  895. package/src/network/subnets/interface.ts +66 -0
  896. package/src/network/subnets/syncnetsService.ts +147 -0
  897. package/src/network/subnets/util.ts +63 -0
  898. package/src/network/util.ts +29 -0
  899. package/src/node/index.ts +2 -0
  900. package/src/node/nodejs.ts +349 -0
  901. package/src/node/notifier.ts +206 -0
  902. package/src/node/options.ts +51 -0
  903. package/src/node/utils/interop/deposits.ts +53 -0
  904. package/src/node/utils/interop/state.ts +59 -0
  905. package/src/node/utils/lightclient.ts +7 -0
  906. package/src/node/utils/state.ts +37 -0
  907. package/src/sync/backfill/backfill.ts +893 -0
  908. package/src/sync/backfill/errors.ts +23 -0
  909. package/src/sync/backfill/index.ts +1 -0
  910. package/src/sync/backfill/verify.ts +58 -0
  911. package/src/sync/constants.ts +71 -0
  912. package/src/sync/index.ts +2 -0
  913. package/src/sync/interface.ts +55 -0
  914. package/src/sync/options.ts +45 -0
  915. package/src/sync/range/batch.ts +455 -0
  916. package/src/sync/range/chain.ts +715 -0
  917. package/src/sync/range/range.ts +354 -0
  918. package/src/sync/range/utils/batches.ts +119 -0
  919. package/src/sync/range/utils/chainTarget.ts +62 -0
  920. package/src/sync/range/utils/hashBlocks.ts +27 -0
  921. package/src/sync/range/utils/index.ts +5 -0
  922. package/src/sync/range/utils/peerBalancer.ts +184 -0
  923. package/src/sync/range/utils/updateChains.ts +66 -0
  924. package/src/sync/sync.ts +290 -0
  925. package/src/sync/types.ts +57 -0
  926. package/src/sync/unknownBlock.ts +860 -0
  927. package/src/sync/utils/downloadByRange.ts +814 -0
  928. package/src/sync/utils/downloadByRoot.ts +568 -0
  929. package/src/sync/utils/pendingBlocksTree.ts +97 -0
  930. package/src/sync/utils/remoteSyncType.ts +144 -0
  931. package/src/util/address.ts +3 -0
  932. package/src/util/array.ts +311 -0
  933. package/src/util/asyncIterableToEvents.ts +164 -0
  934. package/src/util/binarySearch.ts +48 -0
  935. package/src/util/bitArray.ts +84 -0
  936. package/src/util/blobs.ts +210 -0
  937. package/src/util/bufferPool.ts +95 -0
  938. package/src/util/bytes.ts +11 -0
  939. package/src/util/chunkify.ts +27 -0
  940. package/src/util/clock.ts +212 -0
  941. package/src/util/dataColumns.ts +424 -0
  942. package/src/util/dependentRoot.ts +47 -0
  943. package/src/util/enum.ts +17 -0
  944. package/src/util/error.ts +56 -0
  945. package/src/util/eventLoop.ts +22 -0
  946. package/src/util/execution.ts +223 -0
  947. package/src/util/file.ts +52 -0
  948. package/src/util/forkChoice.ts +5 -0
  949. package/src/util/forkName.ts +20 -0
  950. package/src/util/graffiti.ts +39 -0
  951. package/src/util/hex.ts +9 -0
  952. package/src/util/index.ts +2 -0
  953. package/src/util/ip.ts +6 -0
  954. package/src/util/itTrigger.ts +49 -0
  955. package/src/util/kzg.ts +3 -0
  956. package/src/util/map.ts +77 -0
  957. package/src/util/metadata.ts +22 -0
  958. package/src/util/multifork.ts +69 -0
  959. package/src/util/numpy.ts +8 -0
  960. package/src/util/peerId.ts +16 -0
  961. package/src/util/profile.ts +54 -0
  962. package/src/util/promises.ts +14 -0
  963. package/src/util/queue/errors.ts +14 -0
  964. package/src/util/queue/fnQueue.ts +16 -0
  965. package/src/util/queue/index.ts +4 -0
  966. package/src/util/queue/itemQueue.ts +128 -0
  967. package/src/util/queue/options.ts +37 -0
  968. package/src/util/serializedCache.ts +20 -0
  969. package/src/util/set.ts +62 -0
  970. package/src/util/shuffle.ts +21 -0
  971. package/src/util/sortBy.ts +19 -0
  972. package/src/util/sszBytes.ts +481 -0
  973. package/src/util/strictEvents.ts +8 -0
  974. package/src/util/time.ts +13 -0
  975. package/src/util/timeSeries.ts +118 -0
  976. package/src/util/types.ts +31 -0
  977. package/src/util/workerEvents.ts +142 -0
  978. package/src/util/wrapError.ts +27 -0
@@ -0,0 +1,196 @@
1
+ import {routes} from "@lodestar/api";
2
+ import {BeaconConfig} from "@lodestar/config";
3
+ import {
4
+ EFFECTIVE_BALANCE_INCREMENT,
5
+ ForkName,
6
+ INACTIVITY_PENALTY_QUOTIENT_ALTAIR,
7
+ MAX_EFFECTIVE_BALANCE,
8
+ MAX_EFFECTIVE_BALANCE_ELECTRA,
9
+ PARTICIPATION_FLAG_WEIGHTS,
10
+ TIMELY_HEAD_FLAG_INDEX,
11
+ TIMELY_SOURCE_FLAG_INDEX,
12
+ TIMELY_TARGET_FLAG_INDEX,
13
+ WEIGHT_DENOMINATOR,
14
+ isForkPostElectra,
15
+ } from "@lodestar/params";
16
+ import {
17
+ CachedBeaconStateAllForks,
18
+ CachedBeaconStateAltair,
19
+ EpochTransitionCache,
20
+ FLAG_ELIGIBLE_ATTESTER,
21
+ FLAG_PREV_HEAD_ATTESTER_UNSLASHED,
22
+ FLAG_PREV_SOURCE_ATTESTER_UNSLASHED,
23
+ FLAG_PREV_TARGET_ATTESTER_UNSLASHED,
24
+ beforeProcessEpoch,
25
+ hasMarkers,
26
+ isInInactivityLeak,
27
+ } from "@lodestar/state-transition";
28
+ import {Epoch, ValidatorIndex} from "@lodestar/types";
29
+ import {fromHex} from "@lodestar/utils";
30
+
31
+ export type AttestationsRewards = routes.beacon.AttestationsRewards;
32
+ type IdealAttestationsReward = routes.beacon.IdealAttestationsReward;
33
+ type TotalAttestationsReward = routes.beacon.TotalAttestationsReward;
34
+ /** Attestations penalty with respect to effective balance in Gwei */
35
+ type AttestationsPenalty = {target: number; source: number; effectiveBalance: number};
36
+
37
+ const defaultAttestationsReward = {head: 0, target: 0, source: 0, inclusionDelay: 0, inactivity: 0};
38
+ const defaultAttestationsPenalty = {target: 0, source: 0};
39
+
40
+ export async function computeAttestationsRewards(
41
+ _epoch: Epoch,
42
+ state: CachedBeaconStateAllForks,
43
+ _config: BeaconConfig,
44
+ validatorIds?: (ValidatorIndex | string)[]
45
+ ): Promise<AttestationsRewards> {
46
+ const fork = state.config.getForkName(state.slot);
47
+ if (fork === ForkName.phase0) {
48
+ throw Error("Unsupported fork. Attestations rewards calculation is not available in phase0");
49
+ }
50
+
51
+ const stateAltair = state as CachedBeaconStateAltair;
52
+ const transitionCache = beforeProcessEpoch(stateAltair);
53
+
54
+ const [idealRewards, penalties] = computeIdealAttestationsRewardsAndPenaltiesAltair(stateAltair, transitionCache);
55
+ const totalRewards = computeTotalAttestationsRewardsAltair(
56
+ stateAltair,
57
+ transitionCache,
58
+ idealRewards,
59
+ penalties,
60
+ validatorIds
61
+ );
62
+
63
+ return {idealRewards, totalRewards};
64
+ }
65
+
66
+ function computeIdealAttestationsRewardsAndPenaltiesAltair(
67
+ state: CachedBeaconStateAllForks,
68
+ transitionCache: EpochTransitionCache
69
+ ): [IdealAttestationsReward[], AttestationsPenalty[]] {
70
+ const baseRewardPerIncrement = transitionCache.baseRewardPerIncrement;
71
+ const activeBalanceByIncrement = transitionCache.totalActiveStakeByIncrement;
72
+ const fork = state.config.getForkName(state.slot);
73
+ const maxEffectiveBalance = isForkPostElectra(fork) ? MAX_EFFECTIVE_BALANCE_ELECTRA : MAX_EFFECTIVE_BALANCE;
74
+ const maxEffectiveBalanceByIncrement = Math.floor(maxEffectiveBalance / EFFECTIVE_BALANCE_INCREMENT);
75
+
76
+ const idealRewards = Array.from({length: maxEffectiveBalanceByIncrement + 1}, (_, effectiveBalanceByIncrement) => ({
77
+ ...defaultAttestationsReward,
78
+ effectiveBalance: effectiveBalanceByIncrement * EFFECTIVE_BALANCE_INCREMENT,
79
+ }));
80
+
81
+ const attestationsPenalties: AttestationsPenalty[] = Array.from(
82
+ {length: maxEffectiveBalanceByIncrement + 1},
83
+ (_, effectiveBalanceByIncrement) => ({
84
+ ...defaultAttestationsPenalty,
85
+ effectiveBalance: effectiveBalanceByIncrement * EFFECTIVE_BALANCE_INCREMENT,
86
+ })
87
+ );
88
+
89
+ for (let i = 0; i < PARTICIPATION_FLAG_WEIGHTS.length; i++) {
90
+ const weight = PARTICIPATION_FLAG_WEIGHTS[i];
91
+
92
+ let unslashedStakeByIncrement: number;
93
+ let flagName: keyof IdealAttestationsReward;
94
+
95
+ switch (i) {
96
+ case TIMELY_SOURCE_FLAG_INDEX: {
97
+ unslashedStakeByIncrement = transitionCache.prevEpochUnslashedStake.sourceStakeByIncrement;
98
+ flagName = "source";
99
+ break;
100
+ }
101
+ case TIMELY_TARGET_FLAG_INDEX: {
102
+ unslashedStakeByIncrement = transitionCache.prevEpochUnslashedStake.targetStakeByIncrement;
103
+ flagName = "target";
104
+ break;
105
+ }
106
+ case TIMELY_HEAD_FLAG_INDEX: {
107
+ unslashedStakeByIncrement = transitionCache.prevEpochUnslashedStake.headStakeByIncrement;
108
+ flagName = "head";
109
+ break;
110
+ }
111
+ default: {
112
+ throw Error(`Unable to retrieve unslashed stake. Unknown participation flag index: ${i}`);
113
+ }
114
+ }
115
+
116
+ for (
117
+ let effectiveBalanceByIncrement = 0;
118
+ effectiveBalanceByIncrement <= maxEffectiveBalanceByIncrement;
119
+ effectiveBalanceByIncrement++
120
+ ) {
121
+ const baseReward = effectiveBalanceByIncrement * baseRewardPerIncrement;
122
+ const rewardNumerator = baseReward * weight * unslashedStakeByIncrement;
123
+ // Both idealReward and penalty are rounded to nearest integer. Loss of precision is minimal as unit is gwei
124
+ const idealReward = Math.round(rewardNumerator / activeBalanceByIncrement / WEIGHT_DENOMINATOR);
125
+ const penalty = Math.round((baseReward * weight) / WEIGHT_DENOMINATOR); // Positive number indicates penalty
126
+
127
+ const idealAttestationsReward = idealRewards[effectiveBalanceByIncrement];
128
+ idealAttestationsReward[flagName] = isInInactivityLeak(state) ? 0 : idealReward; // No attestations rewards during inactivity leak
129
+
130
+ if (flagName !== "head") {
131
+ const attestationPenalty = attestationsPenalties[effectiveBalanceByIncrement];
132
+ attestationPenalty[flagName] = penalty;
133
+ }
134
+ }
135
+ }
136
+
137
+ return [idealRewards, attestationsPenalties];
138
+ }
139
+
140
+ // Same calculation as `getRewardsAndPenaltiesAltair` but returns the breakdown of rewards instead of aggregated
141
+ function computeTotalAttestationsRewardsAltair(
142
+ state: CachedBeaconStateAltair,
143
+ transitionCache: EpochTransitionCache,
144
+ idealRewards: IdealAttestationsReward[],
145
+ penalties: AttestationsPenalty[],
146
+ validatorIds: (ValidatorIndex | string)[] = []
147
+ ): TotalAttestationsReward[] {
148
+ const rewards = [];
149
+ const {flags} = transitionCache;
150
+ const {epochCtx, config} = state;
151
+ const validatorIndices = validatorIds
152
+ .map((id) => (typeof id === "number" ? id : epochCtx.pubkey2index.get(fromHex(id))))
153
+ .filter((index) => index !== undefined); // Validator indices to include in the result
154
+
155
+ const inactivityPenaltyDenominator = config.INACTIVITY_SCORE_BIAS * INACTIVITY_PENALTY_QUOTIENT_ALTAIR;
156
+
157
+ for (let i = 0; i < flags.length; i++) {
158
+ if (validatorIndices.length && !validatorIndices.includes(i)) {
159
+ continue;
160
+ }
161
+
162
+ const flag = flags[i];
163
+ if (!hasMarkers(flag, FLAG_ELIGIBLE_ATTESTER)) {
164
+ continue;
165
+ }
166
+
167
+ const effectiveBalanceIncrement = epochCtx.effectiveBalanceIncrements[i];
168
+
169
+ const currentRewards = {...defaultAttestationsReward, validatorIndex: i};
170
+
171
+ if (hasMarkers(flag, FLAG_PREV_SOURCE_ATTESTER_UNSLASHED)) {
172
+ currentRewards.source = idealRewards[effectiveBalanceIncrement].source;
173
+ } else {
174
+ currentRewards.source = penalties[effectiveBalanceIncrement].source * -1; // Negative reward to indicate penalty
175
+ }
176
+
177
+ if (hasMarkers(flag, FLAG_PREV_TARGET_ATTESTER_UNSLASHED)) {
178
+ currentRewards.target = idealRewards[effectiveBalanceIncrement].target;
179
+ } else {
180
+ currentRewards.target = penalties[effectiveBalanceIncrement].target * -1;
181
+
182
+ // Also incur inactivity penalty if not voting target correctly
183
+ const inactivityPenaltyNumerator =
184
+ effectiveBalanceIncrement * EFFECTIVE_BALANCE_INCREMENT * state.inactivityScores.get(i);
185
+ currentRewards.inactivity = Math.floor(inactivityPenaltyNumerator / inactivityPenaltyDenominator) * -1;
186
+ }
187
+
188
+ if (hasMarkers(flag, FLAG_PREV_HEAD_ATTESTER_UNSLASHED)) {
189
+ currentRewards.head = idealRewards[effectiveBalanceIncrement].head;
190
+ }
191
+
192
+ rewards.push(currentRewards);
193
+ }
194
+
195
+ return rewards;
196
+ }
@@ -0,0 +1,150 @@
1
+ import {routes} from "@lodestar/api";
2
+ import {
3
+ ForkName,
4
+ WHISTLEBLOWER_REWARD_QUOTIENT,
5
+ WHISTLEBLOWER_REWARD_QUOTIENT_ELECTRA,
6
+ isForkPostElectra,
7
+ } from "@lodestar/params";
8
+ import {
9
+ CachedBeaconStateAllForks,
10
+ CachedBeaconStateAltair,
11
+ CachedBeaconStatePhase0,
12
+ getAttesterSlashableIndices,
13
+ processAttestationsAltair,
14
+ } from "@lodestar/state-transition";
15
+ import {BeaconBlock, altair, phase0} from "@lodestar/types";
16
+
17
+ export type BlockRewards = routes.beacon.BlockRewards;
18
+ type SubRewardValue = number; // All reward values should be integer
19
+
20
+ /**
21
+ * Calculate total proposer block rewards given block and the beacon state of the same slot before the block is applied (preState)
22
+ * postState can be passed in to read reward cache if available
23
+ * Standard (Non MEV) rewards for proposing a block consists of:
24
+ * 1) Including attestations from (beacon) committee
25
+ * 2) Including attestations from sync committee
26
+ * 3) Reporting slashable behaviours from proposer and attester
27
+ */
28
+ export async function computeBlockRewards(
29
+ block: BeaconBlock,
30
+ preState: CachedBeaconStateAllForks,
31
+ postState?: CachedBeaconStateAllForks
32
+ ): Promise<BlockRewards> {
33
+ const fork = preState.config.getForkName(block.slot);
34
+ const {attestations: cachedAttestationsReward = 0, syncAggregate: cachedSyncAggregateReward = 0} =
35
+ postState?.proposerRewards ?? {};
36
+ let blockAttestationReward = cachedAttestationsReward;
37
+ let syncAggregateReward = cachedSyncAggregateReward;
38
+
39
+ if (blockAttestationReward === 0) {
40
+ blockAttestationReward =
41
+ fork === ForkName.phase0
42
+ ? computeBlockAttestationRewardPhase0(block as phase0.BeaconBlock, preState as CachedBeaconStatePhase0)
43
+ : computeBlockAttestationRewardAltair(block as altair.BeaconBlock, preState as CachedBeaconStateAltair);
44
+ }
45
+
46
+ if (syncAggregateReward === 0) {
47
+ syncAggregateReward = computeSyncAggregateReward(block as altair.BeaconBlock, preState as CachedBeaconStateAltair);
48
+ }
49
+
50
+ const blockProposerSlashingReward = computeBlockProposerSlashingReward(fork, block, preState);
51
+ const blockAttesterSlashingReward = computeBlockAttesterSlashingReward(fork, block, preState);
52
+
53
+ const total =
54
+ blockAttestationReward + syncAggregateReward + blockProposerSlashingReward + blockAttesterSlashingReward;
55
+
56
+ return {
57
+ proposerIndex: block.proposerIndex,
58
+ total,
59
+ attestations: blockAttestationReward,
60
+ syncAggregate: syncAggregateReward,
61
+ proposerSlashings: blockProposerSlashingReward,
62
+ attesterSlashings: blockAttesterSlashingReward,
63
+ };
64
+ }
65
+
66
+ /**
67
+ * TODO: Calculate rewards received by block proposer for including attestations.
68
+ */
69
+ function computeBlockAttestationRewardPhase0(
70
+ _block: phase0.BeaconBlock,
71
+ _preState: CachedBeaconStatePhase0
72
+ ): SubRewardValue {
73
+ throw new Error("Unsupported fork! Block attestation reward calculation is not available in phase0");
74
+ }
75
+
76
+ /**
77
+ * Calculate rewards received by block proposer for including attestations since Altair.
78
+ * Reuses `processAttestationsAltair()`. Has dependency on RewardCache
79
+ */
80
+ function computeBlockAttestationRewardAltair(
81
+ block: altair.BeaconBlock,
82
+ preState: CachedBeaconStateAltair
83
+ ): SubRewardValue {
84
+ const fork = preState.config.getForkSeq(block.slot);
85
+ const {attestations} = block.body;
86
+
87
+ processAttestationsAltair(fork, preState, attestations, false);
88
+
89
+ return preState.proposerRewards.attestations;
90
+ }
91
+
92
+ function computeSyncAggregateReward(block: altair.BeaconBlock, preState: CachedBeaconStateAltair): SubRewardValue {
93
+ if (block.body.syncAggregate !== undefined) {
94
+ const {syncCommitteeBits} = block.body.syncAggregate;
95
+ const {syncProposerReward} = preState.epochCtx;
96
+
97
+ return syncCommitteeBits.getTrueBitIndexes().length * Math.floor(syncProposerReward); // syncProposerReward should already be integer
98
+ }
99
+
100
+ return 0; // phase0 block does not have syncAggregate
101
+ }
102
+
103
+ /**
104
+ * Calculate rewards received by block proposer for including proposer slashings.
105
+ * All proposer slashing rewards go to block proposer and none to whistleblower as of Deneb
106
+ */
107
+ function computeBlockProposerSlashingReward(
108
+ fork: ForkName,
109
+ block: BeaconBlock,
110
+ state: CachedBeaconStateAllForks
111
+ ): SubRewardValue {
112
+ let proposerSlashingReward = 0;
113
+
114
+ for (const proposerSlashing of block.body.proposerSlashings) {
115
+ const offendingProposerIndex = proposerSlashing.signedHeader1.message.proposerIndex;
116
+ const offendingProposerBalance = state.validators.getReadonly(offendingProposerIndex).effectiveBalance;
117
+ const whistleblowerRewardQuotient = isForkPostElectra(fork)
118
+ ? WHISTLEBLOWER_REWARD_QUOTIENT_ELECTRA
119
+ : WHISTLEBLOWER_REWARD_QUOTIENT;
120
+
121
+ proposerSlashingReward += Math.floor(offendingProposerBalance / whistleblowerRewardQuotient);
122
+ }
123
+
124
+ return proposerSlashingReward;
125
+ }
126
+
127
+ /**
128
+ * Calculate rewards received by block proposer for including attester slashings.
129
+ * All attester slashing rewards go to block proposer and none to whistleblower as of Deneb
130
+ */
131
+ function computeBlockAttesterSlashingReward(
132
+ fork: ForkName,
133
+ block: BeaconBlock,
134
+ preState: CachedBeaconStateAllForks
135
+ ): SubRewardValue {
136
+ let attesterSlashingReward = 0;
137
+
138
+ for (const attesterSlashing of block.body.attesterSlashings) {
139
+ for (const offendingAttesterIndex of getAttesterSlashableIndices(attesterSlashing)) {
140
+ const offendingAttesterBalance = preState.validators.getReadonly(offendingAttesterIndex).effectiveBalance;
141
+ const whistleblowerRewardQuotient = isForkPostElectra(fork)
142
+ ? WHISTLEBLOWER_REWARD_QUOTIENT_ELECTRA
143
+ : WHISTLEBLOWER_REWARD_QUOTIENT;
144
+
145
+ attesterSlashingReward += Math.floor(offendingAttesterBalance / whistleblowerRewardQuotient);
146
+ }
147
+ }
148
+
149
+ return attesterSlashingReward;
150
+ }
@@ -0,0 +1,58 @@
1
+ import {routes} from "@lodestar/api";
2
+ import {ForkName, SYNC_COMMITTEE_SIZE} from "@lodestar/params";
3
+ import {CachedBeaconStateAllForks, CachedBeaconStateAltair} from "@lodestar/state-transition";
4
+ import {BeaconBlock, ValidatorIndex, altair} from "@lodestar/types";
5
+
6
+ export type SyncCommitteeRewards = routes.beacon.SyncCommitteeRewards;
7
+ type BalanceRecord = {val: number}; // Use val for convenient way to increment/decrement balance
8
+
9
+ export async function computeSyncCommitteeRewards(
10
+ block: BeaconBlock,
11
+ preState: CachedBeaconStateAllForks,
12
+ validatorIds: (ValidatorIndex | string)[] = []
13
+ ): Promise<SyncCommitteeRewards> {
14
+ const fork = preState.config.getForkName(block.slot);
15
+ if (fork === ForkName.phase0) {
16
+ throw Error("Cannot get sync rewards as phase0 block does not have sync committee");
17
+ }
18
+
19
+ const altairBlock = block as altair.BeaconBlock;
20
+ const preStateAltair = preState as CachedBeaconStateAltair;
21
+ const {index2pubkey} = preStateAltair.epochCtx;
22
+
23
+ // Bound syncCommitteeValidatorIndices in case it goes beyond SYNC_COMMITTEE_SIZE just to be safe
24
+ const syncCommitteeValidatorIndices = preStateAltair.epochCtx.currentSyncCommitteeIndexed.validatorIndices.slice(
25
+ 0,
26
+ SYNC_COMMITTEE_SIZE
27
+ );
28
+ const {syncParticipantReward} = preStateAltair.epochCtx;
29
+ const {syncCommitteeBits} = altairBlock.body.syncAggregate;
30
+
31
+ // Use balance of each committee as starting point such that we cap the penalty to avoid balance dropping below 0
32
+ const balances: Map<ValidatorIndex, BalanceRecord> = new Map();
33
+ for (const i of syncCommitteeValidatorIndices) {
34
+ balances.set(i, {val: preStateAltair.balances.get(i)});
35
+ }
36
+
37
+ for (const i of syncCommitteeValidatorIndices) {
38
+ const balanceRecord = balances.get(i) as BalanceRecord;
39
+ if (syncCommitteeBits.get(i)) {
40
+ // Positive rewards for participants
41
+ balanceRecord.val += syncParticipantReward;
42
+ } else {
43
+ // Negative rewards for non participants
44
+ balanceRecord.val = Math.max(0, balanceRecord.val - syncParticipantReward);
45
+ }
46
+ }
47
+
48
+ const rewards = Array.from(balances, ([validatorIndex, v]) => ({validatorIndex, reward: v.val}));
49
+
50
+ if (validatorIds.length) {
51
+ const filtersSet = new Set(validatorIds);
52
+ return rewards.filter(
53
+ (reward) => filtersSet.has(reward.validatorIndex) || filtersSet.has(index2pubkey[reward.validatorIndex].toHex())
54
+ );
55
+ }
56
+
57
+ return rewards;
58
+ }
@@ -0,0 +1,5 @@
1
+ export {SeenAggregators, SeenAttesters} from "./seenAttesters.js";
2
+ export {SeenBlockProposers} from "./seenBlockProposers.js";
3
+ export {SeenSyncCommitteeMessages} from "./seenCommittee.js";
4
+ export {SeenContributionAndProof} from "./seenCommitteeContribution.js";
5
+ export {SeenBlockInput} from "./seenGossipBlockInput.js";
@@ -0,0 +1,120 @@
1
+ import {BitArray} from "@chainsafe/ssz";
2
+ import {CommitteeIndex, Epoch, RootHex} from "@lodestar/types";
3
+ import {MapDef} from "@lodestar/utils";
4
+ import {Metrics} from "../../metrics/index.js";
5
+ import {isSuperSetOrEqual} from "../../util/bitArray.js";
6
+
7
+ /**
8
+ * With this gossip validation condition:
9
+ * pre-deneb:
10
+ * - [IGNORE] aggregate.data.slot is within the last ATTESTATION_PROPAGATION_SLOT_RANGE slots (with a MAXIMUM_GOSSIP_CLOCK_DISPARITY allowance)
11
+ * post-deneb:
12
+ * - [IGNORE] the epoch of `aggregate.data.slot` is either the current or previous epoch
13
+ * - [IGNORE] `aggregate.data.slot` is equal to or earlier than the `current_slot` (with a `MAXIMUM_GOSSIP_CLOCK_DISPARITY` allowance)
14
+ *
15
+ * We keep seen AggregateAndProof in the last 2 epochs pre and post deneb.
16
+ */
17
+ const EPOCH_LOOKBACK_LIMIT = 2;
18
+
19
+ export type AggregationInfo = {
20
+ aggregationBits: BitArray;
21
+ trueBitCount: number;
22
+ };
23
+
24
+ /**
25
+ * Although there are up to TARGET_AGGREGATORS_PER_COMMITTEE (16 for mainnet) AggregateAndProof messages per slot,
26
+ * they tend to have the same aggregate attestation, or one attestation is non-strict superset of another,
27
+ * the gossipsub messages-ids are different because they are really different SignedAggregateAndProof object.
28
+ * This is used to address the following spec in p2p-interface gossipsub:
29
+ * _[IGNORE]_ A valid aggregate attestation defined by `hash_tree_root(aggregate.data)` whose `aggregation_bits` is a
30
+ * non-strict superset has _not_ already been seen.
31
+ *
32
+ * We have AggregatedAttestationPool op pool, however aggregated attestations are not added to that place while this does.
33
+ */
34
+ export class SeenAggregatedAttestations {
35
+ /**
36
+ * Array of AttestingIndices by same attestation data root by epoch.
37
+ * Note that there are at most TARGET_AGGREGATORS_PER_COMMITTEE (16) per attestation data.
38
+ * */
39
+ private readonly aggregateRootsByEpoch = new MapDef<
40
+ Epoch,
41
+ MapDef<CommitteeIndex, MapDef<RootHex, AggregationInfo[]>>
42
+ >(
43
+ () =>
44
+ new MapDef<CommitteeIndex, MapDef<RootHex, AggregationInfo[]>>(
45
+ () => new MapDef<RootHex, AggregationInfo[]>(() => [])
46
+ )
47
+ );
48
+ private lowestPermissibleEpoch: Epoch = 0;
49
+
50
+ constructor(private readonly metrics: Metrics | null) {}
51
+
52
+ isKnown(
53
+ targetEpoch: Epoch,
54
+ committeeIndex: CommitteeIndex,
55
+ attDataRoot: RootHex,
56
+ aggregationBits: BitArray
57
+ ): boolean {
58
+ const seenAggregationInfoArr = this.aggregateRootsByEpoch
59
+ .getOrDefault(targetEpoch)
60
+ .getOrDefault(committeeIndex)
61
+ .getOrDefault(attDataRoot);
62
+ this.metrics?.seenCache.aggregatedAttestations.isKnownCalls.inc();
63
+
64
+ for (let i = 0; i < seenAggregationInfoArr.length; i++) {
65
+ if (isSuperSetOrEqual(seenAggregationInfoArr[i].aggregationBits, aggregationBits)) {
66
+ this.metrics?.seenCache.aggregatedAttestations.superSetCheckTotal.observe(i + 1);
67
+ this.metrics?.seenCache.aggregatedAttestations.isKnownHits.inc();
68
+ return true;
69
+ }
70
+ }
71
+
72
+ this.metrics?.seenCache.aggregatedAttestations.superSetCheckTotal.observe(seenAggregationInfoArr.length);
73
+ return false;
74
+ }
75
+
76
+ add(
77
+ targetEpoch: Epoch,
78
+ committeeIndex: CommitteeIndex,
79
+ attDataRoot: RootHex,
80
+ newItem: AggregationInfo,
81
+ checkIsKnown: boolean
82
+ ): void {
83
+ const {aggregationBits} = newItem;
84
+ if (checkIsKnown && this.isKnown(targetEpoch, committeeIndex, attDataRoot, aggregationBits)) {
85
+ return;
86
+ }
87
+
88
+ const seenAggregationInfoArr = this.aggregateRootsByEpoch
89
+ .getOrDefault(targetEpoch)
90
+ .getOrDefault(committeeIndex)
91
+ .getOrDefault(attDataRoot);
92
+ insertDesc(seenAggregationInfoArr, newItem);
93
+ }
94
+
95
+ prune(currentEpoch: Epoch): void {
96
+ this.lowestPermissibleEpoch = Math.max(currentEpoch - EPOCH_LOOKBACK_LIMIT, 0);
97
+ for (const epoch of this.aggregateRootsByEpoch.keys()) {
98
+ if (epoch < this.lowestPermissibleEpoch) {
99
+ this.aggregateRootsByEpoch.delete(epoch);
100
+ }
101
+ }
102
+ }
103
+ }
104
+
105
+ /**
106
+ * Make sure seenAggregationInfoArr is always in desc order based on trueBitCount so that isKnown can be faster
107
+ */
108
+ export function insertDesc(seenAggregationInfoArr: AggregationInfo[], newItem: AggregationInfo): void {
109
+ const {trueBitCount} = newItem;
110
+ let found = false;
111
+ for (let i = 0; i < seenAggregationInfoArr.length; i++) {
112
+ if (trueBitCount >= seenAggregationInfoArr[i].trueBitCount) {
113
+ seenAggregationInfoArr.splice(i, 0, newItem);
114
+ found = true;
115
+ break;
116
+ }
117
+ }
118
+
119
+ if (!found) seenAggregationInfoArr.push(newItem);
120
+ }
@@ -0,0 +1,145 @@
1
+ import {CommitteeIndex, RootHex, Slot, SubnetID, phase0} from "@lodestar/types";
2
+ import {MapDef} from "@lodestar/utils";
3
+ import {Metrics} from "../../metrics/metrics.js";
4
+ import {InsertOutcome} from "../opPools/types.js";
5
+
6
+ export type SeenAttDataKey = AttDataBase64;
7
+ // AttestationData is used to cache attestations
8
+ type AttDataBase64 = string;
9
+
10
+ export type AttestationDataCacheEntry = {
11
+ // part of shuffling data, so this does not take memory
12
+ committeeValidatorIndices: Uint32Array;
13
+ committeeIndex: CommitteeIndex;
14
+ // IndexedAttestationData signing root, 32 bytes
15
+ signingRoot: Uint8Array;
16
+ // to be consumed by forkchoice and oppool
17
+ attDataRootHex: RootHex;
18
+ // caching this for 3 slots take 600 instances max, this is nothing compared to attestations processed per slot
19
+ // for example in a mainnet node subscribing to all subnets, attestations are processed up to 20k per slot
20
+ attestationData: phase0.AttestationData;
21
+ subnet: SubnetID;
22
+ };
23
+
24
+ export enum RejectReason {
25
+ // attestation data reaches MAX_CACHE_SIZE_PER_SLOT
26
+ reached_limit = "reached_limit",
27
+ // attestation data is too old
28
+ too_old = "too_old",
29
+ // attestation data is already known
30
+ already_known = "already_known",
31
+ }
32
+
33
+ // For pre-electra, there is no committeeIndex in SingleAttestation, so we hard code it to 0
34
+ // AttDataBase64 has committeeIndex instead
35
+ export const PRE_ELECTRA_SINGLE_ATTESTATION_COMMITTEE_INDEX = 0;
36
+
37
+ /**
38
+ * There are maximum 64 committees per slot, assuming 1 committee may have up to 3 different data due to some nodes
39
+ * are not up to date, we can have up to 192 different attestation data per slot.
40
+ */
41
+ const DEFAULT_MAX_CACHE_SIZE_PER_SLOT = 200;
42
+
43
+ /**
44
+ * It takes less than 300kb to cache 200 attestation data per slot, so we can cache 3 slots worth of attestation data.
45
+ */
46
+ const DEFAULT_CACHE_SLOT_DISTANCE = 2;
47
+
48
+ /**
49
+ * Cached seen AttestationData to improve gossip validation. For Electra, this still take into account attestationIndex
50
+ * even through it is moved outside of AttestationData.
51
+ * As of April 2023, validating gossip attestation takes ~12% of cpu time for a node subscribing to all subnets on mainnet.
52
+ * Having this cache help saves a lot of cpu time since most of the gossip attestations are on the same slot.
53
+ */
54
+ export class SeenAttestationDatas {
55
+ private cacheEntryByAttDataByIndexBySlot = new MapDef<
56
+ Slot,
57
+ MapDef<CommitteeIndex, Map<AttDataBase64, AttestationDataCacheEntry>>
58
+ >(
59
+ () =>
60
+ new MapDef<CommitteeIndex, Map<AttDataBase64, AttestationDataCacheEntry>>(
61
+ () => new Map<AttDataBase64, AttestationDataCacheEntry>()
62
+ )
63
+ );
64
+ private lowestPermissibleSlot = 0;
65
+
66
+ constructor(
67
+ private readonly metrics: Metrics | null,
68
+ private readonly cacheSlotDistance = DEFAULT_CACHE_SLOT_DISTANCE,
69
+ // mainly for unit test
70
+ private readonly maxCacheSizePerSlot = DEFAULT_MAX_CACHE_SIZE_PER_SLOT
71
+ ) {
72
+ metrics?.seenCache.attestationData.totalSlot.addCollect(() => this.onScrapeLodestarMetrics(metrics));
73
+ }
74
+
75
+ /**
76
+ * Add an AttestationDataCacheEntry to the cache.
77
+ * - preElectra: add(slot, PRE_ELECTRA_SINGLE_ATTESTATION_COMMITTEE_INDEX, attDataBase64, cacheEntry)
78
+ * - electra: add(slot, committeeIndex, attDataBase64, cacheEntry)
79
+ */
80
+ add(
81
+ slot: Slot,
82
+ committeeIndex: CommitteeIndex,
83
+ attDataBase64: AttDataBase64,
84
+ cacheEntry: AttestationDataCacheEntry
85
+ ): InsertOutcome {
86
+ if (slot < this.lowestPermissibleSlot) {
87
+ this.metrics?.seenCache.attestationData.reject.inc({reason: RejectReason.too_old});
88
+ return InsertOutcome.Old;
89
+ }
90
+
91
+ const cacheEntryByAttDataByIndex = this.cacheEntryByAttDataByIndexBySlot.getOrDefault(slot);
92
+ const cacheEntryByAttData = cacheEntryByAttDataByIndex.getOrDefault(committeeIndex);
93
+ if (cacheEntryByAttData.has(attDataBase64)) {
94
+ this.metrics?.seenCache.attestationData.reject.inc({reason: RejectReason.already_known});
95
+ return InsertOutcome.AlreadyKnown;
96
+ }
97
+
98
+ if (cacheEntryByAttData.size >= this.maxCacheSizePerSlot) {
99
+ this.metrics?.seenCache.attestationData.reject.inc({reason: RejectReason.reached_limit});
100
+ return InsertOutcome.ReachLimit;
101
+ }
102
+
103
+ cacheEntryByAttData.set(attDataBase64, cacheEntry);
104
+ return InsertOutcome.NewData;
105
+ }
106
+
107
+ /**
108
+ * Get an AttestationDataCacheEntry from the cache.
109
+ * - preElectra: get(slot, PRE_ELECTRA_SINGLE_ATTESTATION_COMMITTEE_INDEX, attDataBase64)
110
+ * - electra: get(slot, committeeIndex, attDataBase64)
111
+ */
112
+ get(slot: Slot, committeeIndex: CommitteeIndex, attDataBase64: SeenAttDataKey): AttestationDataCacheEntry | null {
113
+ const cacheEntryByAttDataByIndex = this.cacheEntryByAttDataByIndexBySlot.get(slot);
114
+ const cacheEntryByAttData = cacheEntryByAttDataByIndex?.get(committeeIndex);
115
+ const cacheEntry = cacheEntryByAttData?.get(attDataBase64);
116
+ if (cacheEntry) {
117
+ this.metrics?.seenCache.attestationData.hit.inc();
118
+ } else {
119
+ this.metrics?.seenCache.attestationData.miss.inc();
120
+ }
121
+ return cacheEntry ?? null;
122
+ }
123
+
124
+ onSlot(clockSlot: Slot): void {
125
+ this.lowestPermissibleSlot = Math.max(clockSlot - this.cacheSlotDistance, 0);
126
+ for (const slot of this.cacheEntryByAttDataByIndexBySlot.keys()) {
127
+ if (slot < this.lowestPermissibleSlot) {
128
+ this.cacheEntryByAttDataByIndexBySlot.delete(slot);
129
+ }
130
+ }
131
+ }
132
+
133
+ private onScrapeLodestarMetrics(metrics: Metrics): void {
134
+ metrics?.seenCache.attestationData.totalSlot.set(this.cacheEntryByAttDataByIndexBySlot.size);
135
+ // tracking number of attestation data at current slot may not be correct if scrape time is not at the end of slot
136
+ // so we track it at the previous slot
137
+ const previousSlot = this.lowestPermissibleSlot + this.cacheSlotDistance - 1;
138
+ const cacheEntryByAttDataByIndex = this.cacheEntryByAttDataByIndexBySlot.get(previousSlot);
139
+ let count = 0;
140
+ for (const cacheEntryByAttDataBase64 of cacheEntryByAttDataByIndex?.values() ?? []) {
141
+ count += cacheEntryByAttDataBase64.size;
142
+ }
143
+ metrics?.seenCache.attestationData.countPerSlot.set(count);
144
+ }
145
+ }