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

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,647 @@
1
+ import type {PeerId, PeerInfo, PrivateKey} from "@libp2p/interface";
2
+ import {Multiaddr} from "@multiformats/multiaddr";
3
+ import {ENR} from "@chainsafe/enr";
4
+ import {BeaconConfig} from "@lodestar/config";
5
+ import {LoggerNode} from "@lodestar/logger/node";
6
+ import {ATTESTATION_SUBNET_COUNT, ForkSeq, SYNC_COMMITTEE_SUBNET_COUNT} from "@lodestar/params";
7
+ import {CustodyIndex, SubnetID} from "@lodestar/types";
8
+ import {bytesToInt, pruneSetToMax, sleep, toHex} from "@lodestar/utils";
9
+ import {IClock} from "../../util/clock.js";
10
+ import {getCustodyGroups} from "../../util/dataColumns.js";
11
+ import {NetworkCoreMetrics} from "../core/metrics.js";
12
+ import {Discv5Worker} from "../discv5/index.js";
13
+ import {LodestarDiscv5Opts} from "../discv5/types.js";
14
+ import {Libp2p} from "../interface.js";
15
+ import {getLibp2pError} from "../libp2p/error.js";
16
+ import {ENRKey, SubnetType} from "../metadata.js";
17
+ import {NetworkConfig} from "../networkConfig.js";
18
+ import {computeNodeId} from "../subnets/interface.js";
19
+ import {getConnectionsMap, prettyPrintPeerId} from "../util.js";
20
+ import {IPeerRpcScoreStore, ScoreState} from "./score/index.js";
21
+ import {deserializeEnrSubnets, zeroAttnets, zeroSyncnets} from "./utils/enrSubnetsDeserialize.js";
22
+ import {type CustodyGroupQueries} from "./utils/prioritizePeers.js";
23
+
24
+ /** Max number of cached ENRs after discovering a good peer */
25
+ const MAX_CACHED_ENRS = 100;
26
+ /** Max age a cached ENR will be considered for dial */
27
+ const MAX_CACHED_ENR_AGE_MS = 5 * 60 * 1000;
28
+
29
+ export type PeerDiscoveryOpts = {
30
+ discv5FirstQueryDelayMs: number;
31
+ discv5: LodestarDiscv5Opts;
32
+ connectToDiscv5Bootnodes?: boolean;
33
+ };
34
+
35
+ export type PeerDiscoveryModules = {
36
+ privateKey: PrivateKey;
37
+ networkConfig: NetworkConfig;
38
+ libp2p: Libp2p;
39
+ clock: IClock;
40
+ peerRpcScores: IPeerRpcScoreStore;
41
+ metrics: NetworkCoreMetrics | null;
42
+ logger: LoggerNode;
43
+ };
44
+
45
+ type PeerIdStr = string;
46
+
47
+ enum QueryStatusCode {
48
+ NotActive,
49
+ Active,
50
+ }
51
+ type QueryStatus = {code: QueryStatusCode.NotActive} | {code: QueryStatusCode.Active; count: number};
52
+
53
+ export enum DiscoveredPeerStatus {
54
+ bad_score = "bad_score",
55
+ already_connected = "already_connected",
56
+ already_dialing = "already_dialing",
57
+ error = "error",
58
+ attempt_dial = "attempt_dial",
59
+ cached = "cached",
60
+ dropped = "dropped",
61
+ no_multiaddrs = "no_multiaddrs",
62
+ peer_cooling_down = "peer_cooling_down",
63
+ }
64
+
65
+ export enum NotDialReason {
66
+ not_contain_requested_sampling_groups = "not_contain_requested_sampling_groups",
67
+ not_contain_requested_attnet_syncnet_subnets = "not_contain_requested_attnet_syncnet_subnets",
68
+ no_multiaddrs = "no_multiaddrs",
69
+ }
70
+
71
+ type UnixMs = number;
72
+ /**
73
+ * Maintain peersToConnect to avoid having too many topic peers at some point.
74
+ * See https://github.com/ChainSafe/lodestar/issues/5741#issuecomment-1643113577
75
+ */
76
+ type SubnetRequestInfo = {
77
+ toUnixMs: UnixMs;
78
+ // when node is stable this should be 0
79
+ peersToConnect: number;
80
+ };
81
+
82
+ export type SubnetDiscvQueryMs = {
83
+ subnet: SubnetID;
84
+ type: SubnetType;
85
+ toUnixMs: UnixMs;
86
+ maxPeersToDiscover: number;
87
+ };
88
+
89
+ type CachedENR = {
90
+ peerId: PeerId;
91
+ multiaddrTCP: Multiaddr;
92
+ subnets: Record<SubnetType, boolean[]>;
93
+ addedUnixMs: number;
94
+ // custodyGroups is null for pre-fulu
95
+ custodyGroups: number[] | null;
96
+ };
97
+
98
+ /**
99
+ * PeerDiscovery discovers and dials new peers, and executes discv5 queries.
100
+ * Currently relies on discv5 automatic periodic queries.
101
+ */
102
+ export class PeerDiscovery {
103
+ readonly discv5: Discv5Worker;
104
+ private libp2p: Libp2p;
105
+ private readonly clock: IClock;
106
+ private peerRpcScores: IPeerRpcScoreStore;
107
+ private metrics: NetworkCoreMetrics | null;
108
+ private logger: LoggerNode;
109
+ private config: BeaconConfig;
110
+ private cachedENRs = new Map<PeerIdStr, CachedENR>();
111
+ private randomNodeQuery: QueryStatus = {code: QueryStatusCode.NotActive};
112
+ private peersToConnect = 0;
113
+ private subnetRequests: Record<SubnetType, Map<number, SubnetRequestInfo>> = {
114
+ attnets: new Map(),
115
+ syncnets: new Map(),
116
+ };
117
+
118
+ private custodyGroupQueries: CustodyGroupQueries;
119
+
120
+ private discv5StartMs: number;
121
+ private discv5FirstQueryDelayMs: number;
122
+
123
+ private connectToDiscv5BootnodesOnStart: boolean | undefined = false;
124
+
125
+ constructor(modules: PeerDiscoveryModules, opts: PeerDiscoveryOpts, discv5: Discv5Worker) {
126
+ const {libp2p, clock, peerRpcScores, metrics, logger, networkConfig} = modules;
127
+ this.libp2p = libp2p;
128
+ this.clock = clock;
129
+ this.peerRpcScores = peerRpcScores;
130
+ this.metrics = metrics;
131
+ this.logger = logger;
132
+ this.config = networkConfig.config;
133
+ this.discv5 = discv5;
134
+ this.custodyGroupQueries = new Map();
135
+
136
+ this.discv5StartMs = 0;
137
+ this.discv5StartMs = Date.now();
138
+ this.discv5FirstQueryDelayMs = opts.discv5FirstQueryDelayMs;
139
+ this.connectToDiscv5BootnodesOnStart = opts.connectToDiscv5Bootnodes;
140
+
141
+ this.libp2p.addEventListener("peer:discovery", this.onDiscoveredPeer);
142
+ this.discv5.on("discovered", this.onDiscoveredENR);
143
+
144
+ const numBootEnrs = opts.discv5.bootEnrs.length;
145
+ if (numBootEnrs === 0) {
146
+ this.logger.error("PeerDiscovery: discv5 has no boot enr");
147
+ } else {
148
+ this.logger.verbose("PeerDiscovery: number of bootEnrs", {bootEnrs: numBootEnrs});
149
+ }
150
+
151
+ if (this.connectToDiscv5BootnodesOnStart) {
152
+ // In devnet scenarios, especially, we want more control over which peers we connect to.
153
+ // Only dial the discv5.bootEnrs if the option
154
+ // network.connectToDiscv5Bootnodes has been set to true.
155
+ for (const bootENR of opts.discv5.bootEnrs) {
156
+ this.onDiscoveredENR(ENR.decodeTxt(bootENR)).catch((e) =>
157
+ this.logger.error("error onDiscoveredENR bootENR", {}, e)
158
+ );
159
+ }
160
+ }
161
+
162
+ if (metrics) {
163
+ metrics.discovery.cachedENRsSize.addCollect(() => {
164
+ metrics.discovery.cachedENRsSize.set(this.cachedENRs.size);
165
+ metrics.discovery.peersToConnect.set(this.peersToConnect);
166
+
167
+ // PeerDAS metrics
168
+ const groupsToConnect = Array.from(this.custodyGroupQueries.values());
169
+ const groupPeersToConnect = groupsToConnect.reduce((acc, elem) => acc + elem, 0);
170
+ metrics.discovery.custodyGroupPeersToConnect.set(groupPeersToConnect);
171
+ metrics.discovery.custodyGroupsToConnect.set(groupsToConnect.filter((elem) => elem > 0).length);
172
+
173
+ for (const type of [SubnetType.attnets, SubnetType.syncnets]) {
174
+ const subnetPeersToConnect = Array.from(this.subnetRequests[type].values()).reduce(
175
+ (acc, {peersToConnect}) => acc + peersToConnect,
176
+ 0
177
+ );
178
+ metrics.discovery.subnetPeersToConnect.set({type}, subnetPeersToConnect);
179
+ metrics.discovery.subnetsToConnect.set({type}, this.subnetRequests[type].size);
180
+ }
181
+ });
182
+ }
183
+ }
184
+
185
+ static async init(modules: PeerDiscoveryModules, opts: PeerDiscoveryOpts): Promise<PeerDiscovery> {
186
+ const discv5 = await Discv5Worker.init({
187
+ discv5: opts.discv5,
188
+ privateKey: modules.privateKey,
189
+ metrics: modules.metrics ?? undefined,
190
+ logger: modules.logger,
191
+ config: modules.networkConfig.config,
192
+ genesisTime: modules.clock.genesisTime,
193
+ });
194
+
195
+ return new PeerDiscovery(modules, opts, discv5);
196
+ }
197
+
198
+ async stop(): Promise<void> {
199
+ this.libp2p.removeEventListener("peer:discovery", this.onDiscoveredPeer);
200
+ this.discv5.off("discovered", this.onDiscoveredENR);
201
+ await this.discv5.close();
202
+ }
203
+
204
+ /**
205
+ * Request to find peers, both on specific subnets and in general
206
+ * pre-fulu custodyGroupRequests is empty
207
+ */
208
+ discoverPeers(
209
+ peersToConnect: number,
210
+ custodyGroupRequests: CustodyGroupQueries,
211
+ subnetRequests: SubnetDiscvQueryMs[] = []
212
+ ): void {
213
+ const subnetsToDiscoverPeers: SubnetDiscvQueryMs[] = [];
214
+ const cachedENRsToDial = new Map<PeerIdStr, CachedENR>();
215
+ // Iterate in reverse to consider first the most recent ENRs
216
+ const cachedENRsReverse: CachedENR[] = [];
217
+ const pendingDials = new Set(
218
+ this.libp2p.services.components.connectionManager
219
+ .getDialQueue()
220
+ .map((pendingDial) => pendingDial.peerId?.toString())
221
+ );
222
+ for (const [id, cachedENR] of this.cachedENRs.entries()) {
223
+ if (
224
+ // time expired or
225
+ Date.now() - cachedENR.addedUnixMs > MAX_CACHED_ENR_AGE_MS ||
226
+ // already dialing
227
+ pendingDials.has(id)
228
+ ) {
229
+ this.cachedENRs.delete(id);
230
+ } else if (!this.peerRpcScores.isCoolingDown(id)) {
231
+ cachedENRsReverse.push(cachedENR);
232
+ }
233
+ }
234
+ cachedENRsReverse.reverse();
235
+
236
+ this.peersToConnect += peersToConnect;
237
+
238
+ // starting from PeerDAS, we need to prioritize column subnet peers first in order to have stable subnet sampling
239
+ const groupsToDiscover = new Set<CustodyIndex>();
240
+ let groupPeersToDiscover = 0;
241
+
242
+ const forkSeq = this.config.getForkSeq(this.clock.currentSlot);
243
+ if (forkSeq >= ForkSeq.fulu) {
244
+ group: for (const [group, maxPeersToConnect] of custodyGroupRequests) {
245
+ let cachedENRsInGroup = 0;
246
+ for (const cachedENR of cachedENRsReverse) {
247
+ if (cachedENR.custodyGroups?.includes(group)) {
248
+ cachedENRsToDial.set(cachedENR.peerId.toString(), cachedENR);
249
+
250
+ if (++cachedENRsInGroup >= maxPeersToConnect) {
251
+ continue group;
252
+ }
253
+ }
254
+
255
+ const groupPeersToConnect = Math.max(maxPeersToConnect - cachedENRsInGroup, 0);
256
+ this.custodyGroupQueries.set(group, groupPeersToConnect);
257
+ groupsToDiscover.add(group);
258
+ groupPeersToDiscover += groupPeersToConnect;
259
+ }
260
+ }
261
+ }
262
+
263
+ subnet: for (const subnetRequest of subnetRequests) {
264
+ // Get cached ENRs from the discovery service that are in the requested `subnetId`, but not connected yet
265
+ let cachedENRsInSubnet = 0;
266
+
267
+ // only dial attnet/syncnet peers if subnet sampling peers are stable
268
+ if (groupPeersToDiscover === 0) {
269
+ for (const cachedENR of cachedENRsReverse) {
270
+ if (cachedENR.subnets[subnetRequest.type][subnetRequest.subnet]) {
271
+ cachedENRsToDial.set(cachedENR.peerId.toString(), cachedENR);
272
+
273
+ if (++cachedENRsInSubnet >= subnetRequest.maxPeersToDiscover) {
274
+ continue subnet;
275
+ }
276
+ }
277
+ }
278
+ }
279
+
280
+ const subnetPeersToConnect = Math.max(subnetRequest.maxPeersToDiscover - cachedENRsInSubnet, 0);
281
+
282
+ // Extend the toUnixMs for this subnet
283
+ const prevUnixMs = this.subnetRequests[subnetRequest.type].get(subnetRequest.subnet)?.toUnixMs;
284
+ const newUnixMs =
285
+ prevUnixMs !== undefined && prevUnixMs > subnetRequest.toUnixMs ? prevUnixMs : subnetRequest.toUnixMs;
286
+ this.subnetRequests[subnetRequest.type].set(subnetRequest.subnet, {
287
+ toUnixMs: newUnixMs,
288
+ peersToConnect: subnetPeersToConnect,
289
+ });
290
+
291
+ // Query a discv5 query if more peers are needed
292
+ subnetsToDiscoverPeers.push(subnetRequest);
293
+ }
294
+
295
+ // If subnetRequests won't connect enough peers for peersToConnect, add more
296
+ if (cachedENRsToDial.size < peersToConnect) {
297
+ for (const cachedENR of cachedENRsReverse) {
298
+ cachedENRsToDial.set(cachedENR.peerId.toString(), cachedENR);
299
+ if (cachedENRsToDial.size >= peersToConnect) {
300
+ break;
301
+ }
302
+ }
303
+ }
304
+
305
+ // Queue an outgoing connection request to the cached peers that are on `s.subnet_id`.
306
+ // If we connect to the cached peers before the discovery query starts, then we potentially
307
+ // save a costly discovery query.
308
+ for (const [id, cachedENRToDial] of cachedENRsToDial) {
309
+ this.cachedENRs.delete(id);
310
+ void this.dialPeer(cachedENRToDial);
311
+ }
312
+
313
+ // Run a discv5 subnet query to try to discover new peers
314
+ const shouldRunFindRandomNodeQuery = subnetsToDiscoverPeers.length > 0 || cachedENRsToDial.size < peersToConnect;
315
+ if (shouldRunFindRandomNodeQuery) {
316
+ void this.runFindRandomNodeQuery();
317
+ }
318
+
319
+ this.logger.debug("Discover peers outcome", {
320
+ peersToConnect,
321
+ peersAvailableToDial: cachedENRsToDial.size,
322
+ subnetsToDiscover: subnetsToDiscoverPeers.length,
323
+ groupsToDiscover: Array.from(groupsToDiscover).join(","),
324
+ groupPeersToDiscover,
325
+ shouldRunFindRandomNodeQuery,
326
+ });
327
+ }
328
+
329
+ /**
330
+ * Request discv5 to find peers if there is no query in progress
331
+ */
332
+ private async runFindRandomNodeQuery(): Promise<void> {
333
+ // Delay the 1st query after starting discv5
334
+ // See https://github.com/ChainSafe/lodestar/issues/3423
335
+ const msSinceDiscv5Start = Date.now() - this.discv5StartMs;
336
+ if (msSinceDiscv5Start <= this.discv5FirstQueryDelayMs) {
337
+ await sleep(this.discv5FirstQueryDelayMs - msSinceDiscv5Start);
338
+ }
339
+
340
+ // Run a general discv5 query if one is not already in progress
341
+ if (this.randomNodeQuery.code === QueryStatusCode.Active) {
342
+ this.metrics?.discovery.findNodeQueryRequests.inc({action: "ignore"});
343
+ return;
344
+ }
345
+ this.metrics?.discovery.findNodeQueryRequests.inc({action: "start"});
346
+
347
+ // Use async version to prevent blocking the event loop
348
+ // Time to completion of this function is not critical, in case this async call add extra lag
349
+ this.randomNodeQuery = {code: QueryStatusCode.Active, count: 0};
350
+ const timer = this.metrics?.discovery.findNodeQueryTime.startTimer();
351
+
352
+ try {
353
+ const enrs = await this.discv5.findRandomNode();
354
+ this.metrics?.discovery.findNodeQueryEnrCount.inc(enrs.length);
355
+ } catch (e) {
356
+ this.logger.error("Error on discv5.findNode()", {}, e as Error);
357
+ } finally {
358
+ this.randomNodeQuery = {code: QueryStatusCode.NotActive};
359
+ timer?.();
360
+ }
361
+ }
362
+
363
+ /**
364
+ * Progressively called by libp2p as a result of peer discovery or updates to its peer store
365
+ */
366
+ private onDiscoveredPeer = (evt: CustomEvent<PeerInfo>): void => {
367
+ const {id, multiaddrs} = evt.detail;
368
+
369
+ // libp2p may send us PeerInfos without multiaddrs https://github.com/libp2p/js-libp2p/issues/1873
370
+ if (!multiaddrs || multiaddrs.length === 0) {
371
+ this.metrics?.discovery.discoveredStatus.inc({status: DiscoveredPeerStatus.no_multiaddrs});
372
+ return;
373
+ }
374
+
375
+ const attnets = zeroAttnets;
376
+ const syncnets = zeroSyncnets;
377
+
378
+ const status = this.handleDiscoveredPeer(id, multiaddrs[0], attnets, syncnets, undefined);
379
+ this.logger.debug("Discovered peer via libp2p", {peer: prettyPrintPeerId(id), status});
380
+ this.metrics?.discovery.discoveredStatus.inc({status});
381
+ };
382
+
383
+ /**
384
+ * Progressively called by discv5 as a result of any query.
385
+ */
386
+ private onDiscoveredENR = async (enr: ENR): Promise<void> => {
387
+ if (this.randomNodeQuery.code === QueryStatusCode.Active) {
388
+ this.randomNodeQuery.count++;
389
+ }
390
+ const peerId = enr.peerId;
391
+ // tcp multiaddr is known to be be present, checked inside the worker
392
+ const multiaddrTCP = enr.getLocationMultiaddr(ENRKey.tcp);
393
+ if (!multiaddrTCP) {
394
+ this.logger.error("Discv5 worker sent enr without tcp multiaddr", {enr: enr.encodeTxt()});
395
+ this.metrics?.discovery.discoveredStatus.inc({status: DiscoveredPeerStatus.error});
396
+ return;
397
+ }
398
+ // Are this fields mandatory?
399
+ const attnetsBytes = enr.kvs.get(ENRKey.attnets); // 64 bits
400
+ const syncnetsBytes = enr.kvs.get(ENRKey.syncnets); // 4 bits
401
+ const custodyGroupCountBytes = enr.kvs.get(ENRKey.cgc); // not preserialized value, is byte representation of number
402
+ if (custodyGroupCountBytes === undefined) {
403
+ this.logger.debug("peer discovered with no cgc, using default/miniumn", {
404
+ custodyRequirement: this.config.CUSTODY_REQUIREMENT,
405
+ peer: prettyPrintPeerId(peerId),
406
+ });
407
+ }
408
+
409
+ // Use faster version than ssz's implementation that leverages pre-cached.
410
+ // Some nodes don't serialize the bitfields properly, encoding the syncnets as attnets,
411
+ // which cause the ssz implementation to throw on validation. deserializeEnrSubnets() will
412
+ // never throw and treat too long or too short bitfields as zero-ed
413
+ const attnets = attnetsBytes ? deserializeEnrSubnets(attnetsBytes, ATTESTATION_SUBNET_COUNT) : zeroAttnets;
414
+ const syncnets = syncnetsBytes ? deserializeEnrSubnets(syncnetsBytes, SYNC_COMMITTEE_SUBNET_COUNT) : zeroSyncnets;
415
+ const custodyGroupCount = custodyGroupCountBytes ? bytesToInt(custodyGroupCountBytes, "be") : undefined;
416
+
417
+ const status = this.handleDiscoveredPeer(peerId, multiaddrTCP, attnets, syncnets, custodyGroupCount);
418
+ this.logger.debug("Discovered peer via discv5", {
419
+ peer: prettyPrintPeerId(peerId),
420
+ status,
421
+ cgc: custodyGroupCount,
422
+ });
423
+ this.metrics?.discovery.discoveredStatus.inc({status});
424
+ };
425
+
426
+ /**
427
+ * Progressively called by peer discovery as a result of any query.
428
+ */
429
+ private handleDiscoveredPeer(
430
+ peerId: PeerId,
431
+ multiaddrTCP: Multiaddr,
432
+ attnets: boolean[],
433
+ syncnets: boolean[],
434
+ custodySubnetCount?: number
435
+ ): DiscoveredPeerStatus {
436
+ const nodeId = computeNodeId(peerId);
437
+ this.logger.debug("handleDiscoveredPeer", {nodeId: toHex(nodeId), peerId: peerId.toString()});
438
+ try {
439
+ // Check if peer is not banned or disconnected
440
+ if (this.peerRpcScores.getScoreState(peerId) !== ScoreState.Healthy) {
441
+ return DiscoveredPeerStatus.bad_score;
442
+ }
443
+
444
+ const peerIdStr = peerId.toString();
445
+ // check if peer has a cool-down period applied for reconnection. Is possible that a peer has a
446
+ // "healthy" score but has disconnected us and we are letting the reconnection cool-down before
447
+ // they are eligible for reconnection
448
+ if (this.peerRpcScores.isCoolingDown(peerIdStr)) {
449
+ return DiscoveredPeerStatus.peer_cooling_down;
450
+ }
451
+
452
+ // Ignore connected peers. TODO: Is this check necessary?
453
+ if (this.isPeerConnected(peerIdStr)) {
454
+ return DiscoveredPeerStatus.already_connected;
455
+ }
456
+
457
+ // Ignore dialing peers
458
+ if (
459
+ this.libp2p.services.components.connectionManager
460
+ .getDialQueue()
461
+ .find((pendingDial) => pendingDial.peerId?.equals(peerId))
462
+ ) {
463
+ return DiscoveredPeerStatus.already_dialing;
464
+ }
465
+
466
+ const forkSeq = this.config.getForkSeq(this.clock.currentSlot);
467
+
468
+ // Should dial peer?
469
+ const cachedPeer: CachedENR = {
470
+ peerId,
471
+ multiaddrTCP,
472
+ subnets: {attnets, syncnets},
473
+ addedUnixMs: Date.now(),
474
+ // for pre-fulu, custodyGroups is null
475
+ custodyGroups:
476
+ forkSeq >= ForkSeq.fulu
477
+ ? getCustodyGroups(this.config, nodeId, custodySubnetCount ?? this.config.CUSTODY_REQUIREMENT)
478
+ : null,
479
+ };
480
+
481
+ // Only dial peer if necessary
482
+ if (this.shouldDialPeer(cachedPeer)) {
483
+ void this.dialPeer(cachedPeer);
484
+ return DiscoveredPeerStatus.attempt_dial;
485
+ }
486
+
487
+ // Add to pending good peers with a last seen time
488
+ this.cachedENRs.set(peerId.toString(), cachedPeer);
489
+ const dropped = pruneSetToMax(this.cachedENRs, MAX_CACHED_ENRS);
490
+ // If the cache was already full, count the peer as dropped
491
+ return dropped > 0 ? DiscoveredPeerStatus.dropped : DiscoveredPeerStatus.cached;
492
+ } catch (e) {
493
+ this.logger.error("Error onDiscovered", {}, e as Error);
494
+ return DiscoveredPeerStatus.error;
495
+ }
496
+ }
497
+
498
+ private shouldDialPeer(peer: CachedENR): boolean {
499
+ const forkSeq = this.config.getForkSeq(this.clock.currentSlot);
500
+ if (forkSeq >= ForkSeq.fulu && peer.custodyGroups !== null) {
501
+ // pre-fulu `this.custodyGroupQueries` is empty
502
+ // starting from fulu, we need to make sure we have stable subnet sampling peers first
503
+ // given SAMPLES_PER_SLOT = 8 and 100 peers, we have 800 custody columns from peers
504
+ // with NUMBER_OF_CUSTODY_GROUPS = 128, we have 800 / 128 = 6.25 peers per column in average
505
+ // it would not be hard to find TARGET_SUBNET_PEERS(6) peers per sampling columns columns and TARGET_GROUP_PEERS_PER_SUBNET(4) peers per non-sampling columns
506
+ // after some first heartbeats, we should have no more column requested, then go with conditions of prior forks
507
+ let hasMatchingGroup = false;
508
+ let custodyGroupRequestCount = 0;
509
+ for (const [group, peersToConnect] of this.custodyGroupQueries.entries()) {
510
+ if (peersToConnect <= 0) {
511
+ this.custodyGroupQueries.delete(group);
512
+ } else if (peer.custodyGroups.includes(group)) {
513
+ this.custodyGroupQueries.set(group, Math.max(0, peersToConnect - 1));
514
+ hasMatchingGroup = true;
515
+ custodyGroupRequestCount += peersToConnect;
516
+ }
517
+ }
518
+
519
+ // if subnet sampling peers are not stable and this peer is not in the requested columns, ignore it
520
+ if (custodyGroupRequestCount > 0 && !hasMatchingGroup) {
521
+ this.metrics?.discovery.notDialReason.inc({reason: NotDialReason.not_contain_requested_sampling_groups});
522
+ return false;
523
+ }
524
+ }
525
+
526
+ // logics up to Deneb fork
527
+ for (const type of [SubnetType.attnets, SubnetType.syncnets]) {
528
+ for (const [subnet, {toUnixMs, peersToConnect}] of this.subnetRequests[type].entries()) {
529
+ if (toUnixMs < Date.now() || peersToConnect === 0) {
530
+ // Prune all requests so that we don't have to loop again
531
+ // if we have low subnet peers then PeerManager will update us again with subnet + toUnixMs + peersToConnect
532
+ this.subnetRequests[type].delete(subnet);
533
+ } else {
534
+ // not expired and peersToConnect > 0
535
+ // if we have enough subnet peers, no need to dial more or we may have performance issues
536
+ // see https://github.com/ChainSafe/lodestar/issues/5741#issuecomment-1643113577
537
+ if (peer.subnets[type][subnet]) {
538
+ this.subnetRequests[type].set(subnet, {toUnixMs, peersToConnect: Math.max(peersToConnect - 1, 0)});
539
+ return true;
540
+ }
541
+ }
542
+ }
543
+ }
544
+
545
+ // ideally we may want to leave this cheap condition at the top of the function
546
+ // however we want to also update peersToConnect in this.subnetRequests
547
+ // the this.subnetRequests[type] gradually has 0 subnet so this function should be cheap enough
548
+ if (this.peersToConnect > 0) {
549
+ return true;
550
+ }
551
+
552
+ this.metrics?.discovery.notDialReason.inc({reason: NotDialReason.not_contain_requested_attnet_syncnet_subnets});
553
+ return false;
554
+ }
555
+
556
+ /**
557
+ * Handles DiscoveryEvent::QueryResult
558
+ * Peers that have been returned by discovery requests are dialed here if they are suitable.
559
+ */
560
+ private async dialPeer(cachedPeer: CachedENR): Promise<void> {
561
+ // we dial a peer when:
562
+ // - this.peersToConnect > 0
563
+ // - or the peer subscribes to a subnet that we want
564
+ // If this.peersToConnect is 3 while we need to dial 5 subnet peers, in that case we want this.peersToConnect
565
+ // to be 0 instead of a negative value. The next heartbeat may increase this.peersToConnect again if some dials
566
+ // are not successful.
567
+ this.peersToConnect = Math.max(this.peersToConnect - 1, 0);
568
+
569
+ const {peerId, multiaddrTCP} = cachedPeer;
570
+
571
+ // Must add the multiaddrs array to the address book before dialing
572
+ // https://github.com/libp2p/js-libp2p/blob/aec8e3d3bb1b245051b60c2a890550d262d5b062/src/index.js#L638
573
+ const peer = await this.libp2p.peerStore.merge(peerId, {multiaddrs: [multiaddrTCP]});
574
+ if (peer.addresses.length === 0) {
575
+ this.metrics?.discovery.notDialReason.inc({reason: NotDialReason.no_multiaddrs});
576
+ return;
577
+ }
578
+
579
+ // Note: PeerDiscovery adds the multiaddrTCP beforehand
580
+ const peerIdShort = prettyPrintPeerId(peerId);
581
+ this.logger.debug("Dialing discovered peer", {peer: peerIdShort});
582
+
583
+ this.metrics?.discovery.dialAttempts.inc();
584
+ const timer = this.metrics?.discovery.dialTime.startTimer();
585
+
586
+ // Note: `libp2p.dial()` is what libp2p.connectionManager autoDial calls
587
+ // Note: You must listen to the connected events to listen for a successful conn upgrade
588
+ try {
589
+ await this.libp2p.dial(peerId);
590
+ timer?.({status: "success"});
591
+ this.logger.debug("Dialed discovered peer", {peer: peerIdShort});
592
+ } catch (e) {
593
+ timer?.({status: "error"});
594
+ formatLibp2pDialError(e as Error);
595
+ this.metrics?.discovery.dialError.inc({reason: getLibp2pError(e as Error)});
596
+ this.logger.debug("Error dialing discovered peer", {peer: peerIdShort}, e as Error);
597
+ }
598
+ }
599
+
600
+ /** Check if there is 1+ open connection with this peer */
601
+ private isPeerConnected(peerIdStr: PeerIdStr): boolean {
602
+ const connections = getConnectionsMap(this.libp2p).get(peerIdStr);
603
+ return Boolean(connections?.value.some((connection) => connection.status === "open"));
604
+ }
605
+ }
606
+
607
+ /**
608
+ * libp2p errors with extremely noisy errors here, which are deeply nested taking 30-50 lines.
609
+ * Some known errors:
610
+ * ```
611
+ * Error: The operation was aborted
612
+ * Error: stream ended before 1 bytes became available
613
+ * Error: Error occurred during XX handshake: Error occurred while verifying signed payload: Peer ID doesn't match libp2p public key
614
+ * ```
615
+ *
616
+ * Also the error's message is not properly formatted, where the error message is indented and includes the full stack
617
+ * ```
618
+ * {
619
+ * emessage: '\n' +
620
+ * ' Error: stream ended before 1 bytes became available\n' +
621
+ * ' at /home/lion/Code/eth2.0/lodestar/node_modules/it-reader/index.js:37:9\n' +
622
+ * ' at runMicrotasks (<anonymous>)\n' +
623
+ * ' at decoder (/home/lion/Code/eth2.0/lodestar/node_modules/it-length-prefixed/src/decode.js:113:22)\n' +
624
+ * ' at first (/home/lion/Code/eth2.0/lodestar/node_modules/it-first/index.js:11:20)\n' +
625
+ * ' at Object.exports.read (/home/lion/Code/eth2.0/lodestar/node_modules/multistream-select/src/multistream.js:31:15)\n' +
626
+ * ' at module.exports (/home/lion/Code/eth2.0/lodestar/node_modules/multistream-select/src/select.js:21:19)\n' +
627
+ * ' at Upgrader._encryptOutbound (/home/lion/Code/eth2.0/lodestar/node_modules/libp2p/src/upgrader.js:397:36)\n' +
628
+ * ' at Upgrader.upgradeOutbound (/home/lion/Code/eth2.0/lodestar/node_modules/libp2p/src/upgrader.js:176:11)\n' +
629
+ * ' at ClassIsWrapper.dial (/home/lion/Code/eth2.0/lodestar/node_modules/libp2p-tcp/src/index.js:49:18)'
630
+ * }
631
+ * ```
632
+ *
633
+ * Tracking issue https://github.com/libp2p/js-libp2p/issues/996
634
+ */
635
+ function formatLibp2pDialError(e: Error): void {
636
+ const errorMessage = e.message.trim();
637
+ const newlineIndex = errorMessage.indexOf("\n");
638
+ e.message = newlineIndex !== -1 ? errorMessage.slice(0, newlineIndex) : errorMessage;
639
+
640
+ if (
641
+ e.message.includes("The operation was aborted") ||
642
+ e.message.includes("stream ended before 1 bytes became available") ||
643
+ e.message.includes("The operation was aborted")
644
+ ) {
645
+ e.stack = undefined;
646
+ }
647
+ }
@@ -0,0 +1,2 @@
1
+ export * from "./peerManager.js";
2
+ export * from "./score/index.js";