@lodestar/beacon-node 1.41.0-dev.702f7932c2 → 1.41.0-dev.95cf2edc4c

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 (254) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +121 -3
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/state/index.js +8 -8
  5. package/lib/api/impl/beacon/state/index.js.map +1 -1
  6. package/lib/api/impl/beacon/state/utils.d.ts +3 -4
  7. package/lib/api/impl/beacon/state/utils.d.ts.map +1 -1
  8. package/lib/api/impl/beacon/state/utils.js +5 -24
  9. package/lib/api/impl/beacon/state/utils.js.map +1 -1
  10. package/lib/api/impl/debug/index.d.ts.map +1 -1
  11. package/lib/api/impl/debug/index.js +5 -2
  12. package/lib/api/impl/debug/index.js.map +1 -1
  13. package/lib/api/impl/lightclient/index.d.ts.map +1 -1
  14. package/lib/api/impl/lightclient/index.js +19 -2
  15. package/lib/api/impl/lightclient/index.js.map +1 -1
  16. package/lib/api/impl/validator/index.d.ts.map +1 -1
  17. package/lib/api/impl/validator/index.js +104 -6
  18. package/lib/api/impl/validator/index.js.map +1 -1
  19. package/lib/chain/archiveStore/archiveStore.d.ts +1 -0
  20. package/lib/chain/archiveStore/archiveStore.d.ts.map +1 -1
  21. package/lib/chain/archiveStore/archiveStore.js +9 -0
  22. package/lib/chain/archiveStore/archiveStore.js.map +1 -1
  23. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts +5 -6
  24. package/lib/chain/archiveStore/historicalState/getHistoricalState.d.ts.map +1 -1
  25. package/lib/chain/archiveStore/historicalState/getHistoricalState.js +9 -10
  26. package/lib/chain/archiveStore/historicalState/getHistoricalState.js.map +1 -1
  27. package/lib/chain/archiveStore/historicalState/worker.js +3 -3
  28. package/lib/chain/archiveStore/historicalState/worker.js.map +1 -1
  29. package/lib/chain/archiveStore/utils/archivePayloads.d.ts +7 -0
  30. package/lib/chain/archiveStore/utils/archivePayloads.d.ts.map +1 -0
  31. package/lib/chain/archiveStore/utils/archivePayloads.js +10 -0
  32. package/lib/chain/archiveStore/utils/archivePayloads.js.map +1 -0
  33. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  34. package/lib/chain/blocks/importBlock.js +0 -2
  35. package/lib/chain/blocks/importBlock.js.map +1 -1
  36. package/lib/chain/blocks/index.d.ts.map +1 -1
  37. package/lib/chain/blocks/index.js +2 -1
  38. package/lib/chain/blocks/index.js.map +1 -1
  39. package/lib/chain/blocks/writeBlockInputToDb.d.ts.map +1 -1
  40. package/lib/chain/blocks/writeBlockInputToDb.js +3 -0
  41. package/lib/chain/blocks/writeBlockInputToDb.js.map +1 -1
  42. package/lib/chain/bls/multithread/index.d.ts +3 -3
  43. package/lib/chain/bls/multithread/index.d.ts.map +1 -1
  44. package/lib/chain/bls/multithread/index.js +5 -5
  45. package/lib/chain/bls/multithread/index.js.map +1 -1
  46. package/lib/chain/bls/multithread/jobItem.d.ts +2 -2
  47. package/lib/chain/bls/multithread/jobItem.d.ts.map +1 -1
  48. package/lib/chain/bls/multithread/jobItem.js +2 -2
  49. package/lib/chain/bls/multithread/jobItem.js.map +1 -1
  50. package/lib/chain/bls/singleThread.d.ts +4 -4
  51. package/lib/chain/bls/singleThread.d.ts.map +1 -1
  52. package/lib/chain/bls/singleThread.js +4 -4
  53. package/lib/chain/bls/singleThread.js.map +1 -1
  54. package/lib/chain/bls/utils.d.ts +2 -2
  55. package/lib/chain/bls/utils.d.ts.map +1 -1
  56. package/lib/chain/bls/utils.js +7 -4
  57. package/lib/chain/bls/utils.js.map +1 -1
  58. package/lib/chain/chain.d.ts +6 -9
  59. package/lib/chain/chain.d.ts.map +1 -1
  60. package/lib/chain/chain.js +32 -16
  61. package/lib/chain/chain.js.map +1 -1
  62. package/lib/chain/emitter.d.ts +2 -2
  63. package/lib/chain/emitter.d.ts.map +1 -1
  64. package/lib/chain/errors/blockError.d.ts +7 -1
  65. package/lib/chain/errors/blockError.d.ts.map +1 -1
  66. package/lib/chain/errors/blockError.js +2 -0
  67. package/lib/chain/errors/blockError.js.map +1 -1
  68. package/lib/chain/interface.d.ts +4 -6
  69. package/lib/chain/interface.d.ts.map +1 -1
  70. package/lib/chain/interface.js.map +1 -1
  71. package/lib/chain/lightClient/index.d.ts.map +1 -1
  72. package/lib/chain/lightClient/index.js +1 -1
  73. package/lib/chain/lightClient/index.js.map +1 -1
  74. package/lib/chain/options.d.ts.map +1 -1
  75. package/lib/chain/options.js.map +1 -1
  76. package/lib/chain/prepareNextSlot.js +3 -3
  77. package/lib/chain/prepareNextSlot.js.map +1 -1
  78. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +10 -2
  79. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  80. package/lib/chain/produceBlock/computeNewStateRoot.js +24 -2
  81. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  82. package/lib/chain/produceBlock/produceBlockBody.d.ts +22 -7
  83. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  84. package/lib/chain/produceBlock/produceBlockBody.js +110 -10
  85. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  86. package/lib/chain/validation/attestation.d.ts.map +1 -1
  87. package/lib/chain/validation/attestation.js +4 -1
  88. package/lib/chain/validation/attestation.js.map +1 -1
  89. package/lib/chain/validation/attesterSlashing.js +1 -1
  90. package/lib/chain/validation/attesterSlashing.js.map +1 -1
  91. package/lib/chain/validation/block.d.ts.map +1 -1
  92. package/lib/chain/validation/block.js +27 -3
  93. package/lib/chain/validation/block.js.map +1 -1
  94. package/lib/chain/validation/dataColumnSidecar.d.ts +2 -2
  95. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  96. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  97. package/lib/chain/validation/executionPayloadEnvelope.js +2 -1
  98. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  99. package/lib/chain/validation/payloadAttestationMessage.js +8 -1
  100. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  101. package/lib/chain/validation/proposerSlashing.js +1 -1
  102. package/lib/chain/validation/proposerSlashing.js.map +1 -1
  103. package/lib/chain/validation/syncCommitteeContributionAndProof.js +1 -1
  104. package/lib/db/beacon.d.ts +3 -1
  105. package/lib/db/beacon.d.ts.map +1 -1
  106. package/lib/db/beacon.js +5 -1
  107. package/lib/db/beacon.js.map +1 -1
  108. package/lib/db/buckets.d.ts +3 -1
  109. package/lib/db/buckets.d.ts.map +1 -1
  110. package/lib/db/buckets.js +2 -0
  111. package/lib/db/buckets.js.map +1 -1
  112. package/lib/db/interface.d.ts +3 -1
  113. package/lib/db/interface.d.ts.map +1 -1
  114. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  115. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  116. package/lib/db/repositories/dataColumnSidecar.d.ts +5 -3
  117. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  118. package/lib/db/repositories/dataColumnSidecar.js +14 -1
  119. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  120. package/lib/db/repositories/dataColumnSidecarArchive.d.ts +5 -3
  121. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  122. package/lib/db/repositories/dataColumnSidecarArchive.js +14 -1
  123. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  124. package/lib/db/repositories/executionPayloadEnvelope.d.ts +19 -0
  125. package/lib/db/repositories/executionPayloadEnvelope.d.ts.map +1 -0
  126. package/lib/db/repositories/executionPayloadEnvelope.js +22 -0
  127. package/lib/db/repositories/executionPayloadEnvelope.js.map +1 -0
  128. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts +18 -0
  129. package/lib/db/repositories/executionPayloadEnvelopeArchive.d.ts.map +1 -0
  130. package/lib/db/repositories/executionPayloadEnvelopeArchive.js +28 -0
  131. package/lib/db/repositories/executionPayloadEnvelopeArchive.js.map +1 -0
  132. package/lib/db/repositories/index.d.ts +2 -0
  133. package/lib/db/repositories/index.d.ts.map +1 -1
  134. package/lib/db/repositories/index.js +2 -0
  135. package/lib/db/repositories/index.js.map +1 -1
  136. package/lib/metrics/metrics/beacon.d.ts +1 -0
  137. package/lib/metrics/metrics/beacon.d.ts.map +1 -1
  138. package/lib/metrics/metrics/beacon.js +5 -0
  139. package/lib/metrics/metrics/beacon.js.map +1 -1
  140. package/lib/metrics/metrics/lodestar.d.ts +5 -0
  141. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  142. package/lib/metrics/metrics/lodestar.js +9 -0
  143. package/lib/metrics/metrics/lodestar.js.map +1 -1
  144. package/lib/metrics/metrics.d.ts.map +1 -1
  145. package/lib/metrics/metrics.js +8 -3
  146. package/lib/metrics/metrics.js.map +1 -1
  147. package/lib/monitoring/service.d.ts +2 -2
  148. package/lib/monitoring/service.d.ts.map +1 -1
  149. package/lib/monitoring/service.js +3 -2
  150. package/lib/monitoring/service.js.map +1 -1
  151. package/lib/network/gossip/interface.d.ts +3 -3
  152. package/lib/network/gossip/interface.d.ts.map +1 -1
  153. package/lib/network/gossip/topic.d.ts +114 -65
  154. package/lib/network/gossip/topic.d.ts.map +1 -1
  155. package/lib/network/gossip/topic.js +2 -2
  156. package/lib/network/gossip/topic.js.map +1 -1
  157. package/lib/network/interface.d.ts +3 -2
  158. package/lib/network/interface.d.ts.map +1 -1
  159. package/lib/network/network.d.ts +3 -2
  160. package/lib/network/network.d.ts.map +1 -1
  161. package/lib/network/network.js +10 -1
  162. package/lib/network/network.js.map +1 -1
  163. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  164. package/lib/network/processor/gossipHandlers.js +5 -1
  165. package/lib/network/processor/gossipHandlers.js.map +1 -1
  166. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.d.ts.map +1 -1
  167. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js +7 -1
  168. package/lib/network/reqresp/handlers/lightClientUpdatesByRange.js.map +1 -1
  169. package/lib/node/nodejs.d.ts +3 -5
  170. package/lib/node/nodejs.d.ts.map +1 -1
  171. package/lib/node/nodejs.js +6 -4
  172. package/lib/node/nodejs.js.map +1 -1
  173. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  174. package/lib/sync/utils/downloadByRange.js +3 -9
  175. package/lib/sync/utils/downloadByRange.js.map +1 -1
  176. package/lib/sync/utils/downloadByRoot.d.ts +1 -1
  177. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  178. package/lib/sync/utils/downloadByRoot.js +4 -4
  179. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  180. package/lib/util/blobs.d.ts +2 -2
  181. package/lib/util/blobs.d.ts.map +1 -1
  182. package/lib/util/blobs.js.map +1 -1
  183. package/lib/util/dataColumns.d.ts +15 -2
  184. package/lib/util/dataColumns.d.ts.map +1 -1
  185. package/lib/util/dataColumns.js +40 -5
  186. package/lib/util/dataColumns.js.map +1 -1
  187. package/lib/util/multifork.d.ts +8 -0
  188. package/lib/util/multifork.d.ts.map +1 -1
  189. package/lib/util/multifork.js +37 -0
  190. package/lib/util/multifork.js.map +1 -1
  191. package/lib/util/serializedCache.d.ts +5 -0
  192. package/lib/util/serializedCache.d.ts.map +1 -1
  193. package/lib/util/serializedCache.js +5 -0
  194. package/lib/util/serializedCache.js.map +1 -1
  195. package/package.json +15 -15
  196. package/src/api/impl/beacon/blocks/index.ts +145 -2
  197. package/src/api/impl/beacon/state/index.ts +8 -8
  198. package/src/api/impl/beacon/state/utils.ts +15 -29
  199. package/src/api/impl/debug/index.ts +8 -5
  200. package/src/api/impl/lightclient/index.ts +19 -2
  201. package/src/api/impl/validator/index.ts +127 -5
  202. package/src/chain/archiveStore/archiveStore.ts +10 -0
  203. package/src/chain/archiveStore/historicalState/getHistoricalState.ts +10 -11
  204. package/src/chain/archiveStore/historicalState/worker.ts +3 -3
  205. package/src/chain/archiveStore/utils/archivePayloads.ts +15 -0
  206. package/src/chain/blocks/importBlock.ts +0 -3
  207. package/src/chain/blocks/index.ts +2 -1
  208. package/src/chain/blocks/writeBlockInputToDb.ts +3 -0
  209. package/src/chain/bls/multithread/index.ts +7 -7
  210. package/src/chain/bls/multithread/jobItem.ts +3 -3
  211. package/src/chain/bls/singleThread.ts +5 -5
  212. package/src/chain/bls/utils.ts +8 -5
  213. package/src/chain/chain.ts +51 -26
  214. package/src/chain/emitter.ts +2 -2
  215. package/src/chain/errors/blockError.ts +4 -1
  216. package/src/chain/interface.ts +4 -11
  217. package/src/chain/lightClient/index.ts +4 -1
  218. package/src/chain/options.ts +1 -0
  219. package/src/chain/prepareNextSlot.ts +5 -5
  220. package/src/chain/produceBlock/computeNewStateRoot.ts +35 -3
  221. package/src/chain/produceBlock/produceBlockBody.ts +163 -13
  222. package/src/chain/validation/attestation.ts +4 -1
  223. package/src/chain/validation/attesterSlashing.ts +1 -1
  224. package/src/chain/validation/block.ts +32 -4
  225. package/src/chain/validation/dataColumnSidecar.ts +2 -5
  226. package/src/chain/validation/executionPayloadEnvelope.ts +2 -1
  227. package/src/chain/validation/payloadAttestationMessage.ts +10 -2
  228. package/src/chain/validation/proposerSlashing.ts +1 -1
  229. package/src/chain/validation/syncCommitteeContributionAndProof.ts +1 -1
  230. package/src/db/beacon.ts +8 -0
  231. package/src/db/buckets.ts +3 -0
  232. package/src/db/interface.ts +5 -0
  233. package/src/db/repositories/dataColumnSidecar.ts +18 -3
  234. package/src/db/repositories/dataColumnSidecarArchive.ts +18 -3
  235. package/src/db/repositories/executionPayloadEnvelope.ts +26 -0
  236. package/src/db/repositories/executionPayloadEnvelopeArchive.ts +32 -0
  237. package/src/db/repositories/index.ts +2 -0
  238. package/src/metrics/metrics/beacon.ts +5 -0
  239. package/src/metrics/metrics/lodestar.ts +9 -0
  240. package/src/metrics/metrics.ts +8 -3
  241. package/src/monitoring/service.ts +3 -2
  242. package/src/network/gossip/interface.ts +3 -3
  243. package/src/network/gossip/topic.ts +2 -1
  244. package/src/network/interface.ts +4 -1
  245. package/src/network/network.ts +21 -3
  246. package/src/network/processor/gossipHandlers.ts +7 -1
  247. package/src/network/reqresp/handlers/lightClientUpdatesByRange.ts +6 -1
  248. package/src/node/nodejs.ts +8 -9
  249. package/src/sync/utils/downloadByRange.ts +3 -15
  250. package/src/sync/utils/downloadByRoot.ts +5 -11
  251. package/src/util/blobs.ts +3 -3
  252. package/src/util/dataColumns.ts +54 -5
  253. package/src/util/multifork.ts +45 -0
  254. package/src/util/serializedCache.ts +5 -0
@@ -7,7 +7,7 @@ import {Worker, spawn} from "@chainsafe/threads";
7
7
  self = undefined;
8
8
 
9
9
  import {PublicKey} from "@chainsafe/blst";
10
- import {ISignatureSet, Index2PubkeyCache} from "@lodestar/state-transition";
10
+ import {ISignatureSet, PubkeyCache} from "@lodestar/state-transition";
11
11
  import {Logger} from "@lodestar/utils";
12
12
  import {Metrics} from "../../../metrics/index.js";
13
13
  import {LinkedList} from "../../../util/array.js";
@@ -34,7 +34,7 @@ const workerDir = process.env.NODE_ENV === "test" ? "../../../../lib/chain/bls/m
34
34
  export type BlsMultiThreadWorkerPoolModules = {
35
35
  logger: Logger;
36
36
  metrics: Metrics | null;
37
- index2pubkey: Index2PubkeyCache;
37
+ pubkeyCache: PubkeyCache;
38
38
  };
39
39
 
40
40
  export type BlsMultiThreadWorkerPoolOptions = {
@@ -114,7 +114,7 @@ type WorkerDescriptor = {
114
114
  export class BlsMultiThreadWorkerPool implements IBlsVerifier {
115
115
  private readonly logger: Logger;
116
116
  private readonly metrics: Metrics | null;
117
- private readonly index2pubkey: Index2PubkeyCache;
117
+ private readonly pubkeyCache: PubkeyCache;
118
118
 
119
119
  private readonly workers: WorkerDescriptor[];
120
120
  private readonly jobs = new LinkedList<JobQueueItem>();
@@ -130,10 +130,10 @@ export class BlsMultiThreadWorkerPool implements IBlsVerifier {
130
130
  private workersBusy = 0;
131
131
 
132
132
  constructor(options: BlsMultiThreadWorkerPoolOptions, modules: BlsMultiThreadWorkerPoolModules) {
133
- const {logger, metrics, index2pubkey} = modules;
133
+ const {logger, metrics, pubkeyCache} = modules;
134
134
  this.logger = logger;
135
135
  this.metrics = metrics;
136
- this.index2pubkey = index2pubkey;
136
+ this.pubkeyCache = pubkeyCache;
137
137
  this.blsVerifyAllMultiThread = options.blsVerifyAllMultiThread ?? false;
138
138
 
139
139
  // Use compressed for herumi for now.
@@ -173,7 +173,7 @@ export class BlsMultiThreadWorkerPool implements IBlsVerifier {
173
173
  try {
174
174
  return verifySignatureSetsMaybeBatch(
175
175
  sets.map((set) => ({
176
- publicKey: getAggregatedPubkey(set, this.index2pubkey),
176
+ publicKey: getAggregatedPubkey(set, this.pubkeyCache),
177
177
  message: set.signingRoot.valueOf(),
178
178
  signature: set.signature,
179
179
  }))
@@ -398,7 +398,7 @@ export class BlsMultiThreadWorkerPool implements IBlsVerifier {
398
398
  try {
399
399
  // Note: This can throw, must be handled per-job.
400
400
  // Pubkey and signature aggregation is defered here
401
- workReq = await jobItemWorkReq(job, this.index2pubkey, this.metrics);
401
+ workReq = await jobItemWorkReq(job, this.pubkeyCache, this.metrics);
402
402
  } catch (e) {
403
403
  this.metrics?.blsThreadPool.errorAggregateSignatureSetsCount.inc({type: job.type});
404
404
 
@@ -1,5 +1,5 @@
1
1
  import {PublicKey, asyncAggregateWithRandomness} from "@chainsafe/blst";
2
- import {ISignatureSet, Index2PubkeyCache, SignatureSetType} from "@lodestar/state-transition";
2
+ import {ISignatureSet, PubkeyCache, SignatureSetType} from "@lodestar/state-transition";
3
3
  import {Metrics} from "../../../metrics/metrics.js";
4
4
  import {LinkedList} from "../../../util/array.js";
5
5
  import {VerifySignatureOpts} from "../interface.js";
@@ -50,7 +50,7 @@ export function jobItemSigSets(job: JobQueueItem): number {
50
50
  */
51
51
  export async function jobItemWorkReq(
52
52
  job: JobQueueItem,
53
- index2pubkey: Index2PubkeyCache,
53
+ pubkeyCache: PubkeyCache,
54
54
  metrics: Metrics | null
55
55
  ): Promise<BlsWorkReq> {
56
56
  switch (job.type) {
@@ -59,7 +59,7 @@ export async function jobItemWorkReq(
59
59
  opts: job.opts,
60
60
  sets: job.sets.map((set) => ({
61
61
  // this can throw, handled in the consumer code
62
- publicKey: getAggregatedPubkey(set, index2pubkey, metrics).toBytes(),
62
+ publicKey: getAggregatedPubkey(set, pubkeyCache, metrics).toBytes(),
63
63
  signature: set.signature,
64
64
  message: set.signingRoot,
65
65
  })),
@@ -1,5 +1,5 @@
1
1
  import {PublicKey, Signature, aggregatePublicKeys, aggregateSignatures, verify} from "@chainsafe/blst";
2
- import {ISignatureSet, Index2PubkeyCache} from "@lodestar/state-transition";
2
+ import {ISignatureSet, PubkeyCache} from "@lodestar/state-transition";
3
3
  import {Metrics} from "../../metrics/index.js";
4
4
  import {IBlsVerifier} from "./interface.js";
5
5
  import {verifySignatureSetsMaybeBatch} from "./maybeBatch.js";
@@ -7,18 +7,18 @@ import {getAggregatedPubkey, getAggregatedPubkeysCount} from "./utils.js";
7
7
 
8
8
  export class BlsSingleThreadVerifier implements IBlsVerifier {
9
9
  private readonly metrics: Metrics | null;
10
- private readonly index2pubkey: Index2PubkeyCache;
10
+ private readonly pubkeyCache: PubkeyCache;
11
11
 
12
- constructor({metrics = null, index2pubkey}: {metrics: Metrics | null; index2pubkey: Index2PubkeyCache}) {
12
+ constructor({metrics = null, pubkeyCache}: {metrics: Metrics | null; pubkeyCache: PubkeyCache}) {
13
13
  this.metrics = metrics;
14
- this.index2pubkey = index2pubkey;
14
+ this.pubkeyCache = pubkeyCache;
15
15
  }
16
16
 
17
17
  async verifySignatureSets(sets: ISignatureSet[]): Promise<boolean> {
18
18
  this.metrics?.bls.aggregatedPubkeys.inc(getAggregatedPubkeysCount(sets));
19
19
 
20
20
  const setsAggregated = sets.map((set) => ({
21
- publicKey: getAggregatedPubkey(set, this.index2pubkey, this.metrics),
21
+ publicKey: getAggregatedPubkey(set, this.pubkeyCache, this.metrics),
22
22
  message: set.signingRoot,
23
23
  signature: set.signature,
24
24
  }));
@@ -1,22 +1,25 @@
1
1
  import {PublicKey, aggregatePublicKeys} from "@chainsafe/blst";
2
- import {ISignatureSet, Index2PubkeyCache, SignatureSetType} from "@lodestar/state-transition";
2
+ import {ISignatureSet, PubkeyCache, SignatureSetType} from "@lodestar/state-transition";
3
3
  import {Metrics} from "../../metrics/metrics.js";
4
4
 
5
5
  export function getAggregatedPubkey(
6
6
  signatureSet: ISignatureSet,
7
- index2pubkey: Index2PubkeyCache,
7
+ pubkeyCache: PubkeyCache,
8
8
  metrics: Metrics | null = null
9
9
  ): PublicKey {
10
10
  switch (signatureSet.type) {
11
11
  case SignatureSetType.single:
12
12
  return signatureSet.pubkey;
13
13
 
14
- case SignatureSetType.indexed:
15
- return index2pubkey[signatureSet.index];
14
+ case SignatureSetType.indexed: {
15
+ return pubkeyCache.getOrThrow(signatureSet.index);
16
+ }
16
17
 
17
18
  case SignatureSetType.aggregate: {
18
19
  const timer = metrics?.blsThreadPool.pubkeysAggregationMainThreadDuration.startTimer();
19
- const pubkeys = signatureSet.indices.map((i) => index2pubkey[i]);
20
+ const pubkeys = signatureSet.indices.map((i) => {
21
+ return pubkeyCache.getOrThrow(i);
22
+ });
20
23
  const aggregated = aggregatePublicKeys(pubkeys);
21
24
  timer?.();
22
25
  return aggregated;
@@ -1,18 +1,26 @@
1
1
  import path from "node:path";
2
2
  import {PrivateKey} from "@libp2p/interface";
3
- import {PubkeyIndexMap} from "@chainsafe/pubkey-index-map";
4
3
  import {CompositeTypeAny, TreeView, Type} from "@chainsafe/ssz";
5
4
  import {BeaconConfig} from "@lodestar/config";
6
5
  import {CheckpointWithHex, IForkChoice, ProtoBlock, UpdateHeadOpt} from "@lodestar/fork-choice";
7
6
  import {LoggerNode} from "@lodestar/logger/node";
8
- import {EFFECTIVE_BALANCE_INCREMENT, GENESIS_SLOT, SLOTS_PER_EPOCH, isForkPostElectra} from "@lodestar/params";
7
+ import {
8
+ BUILDER_INDEX_SELF_BUILD,
9
+ EFFECTIVE_BALANCE_INCREMENT,
10
+ ForkPostFulu,
11
+ GENESIS_SLOT,
12
+ SLOTS_PER_EPOCH,
13
+ isForkPostElectra,
14
+ isForkPostGloas,
15
+ } from "@lodestar/params";
9
16
  import {
10
17
  BeaconStateAllForks,
11
18
  BeaconStateElectra,
12
19
  CachedBeaconStateAllForks,
20
+ CachedBeaconStateGloas,
13
21
  EffectiveBalanceIncrements,
14
22
  EpochShuffling,
15
- Index2PubkeyCache,
23
+ PubkeyCache,
16
24
  computeAnchorCheckpoint,
17
25
  computeAttestationsRewards,
18
26
  computeBlockRewards,
@@ -28,6 +36,7 @@ import {
28
36
  BeaconBlock,
29
37
  BlindedBeaconBlock,
30
38
  BlindedBeaconBlockBody,
39
+ DataColumnSidecars,
31
40
  Epoch,
32
41
  Root,
33
42
  RootHex,
@@ -38,7 +47,7 @@ import {
38
47
  ValidatorIndex,
39
48
  Wei,
40
49
  deneb,
41
- fulu,
50
+ gloas,
42
51
  isBlindedBeaconBlock,
43
52
  phase0,
44
53
  rewards,
@@ -87,8 +96,8 @@ import {
87
96
  } from "./opPools/index.js";
88
97
  import {IChainOptions} from "./options.js";
89
98
  import {PrepareNextSlotScheduler} from "./prepareNextSlot.js";
90
- import {computeNewStateRoot} from "./produceBlock/computeNewStateRoot.js";
91
- import {AssembledBlockType, BlockType, ProduceResult} from "./produceBlock/index.js";
99
+ import {computeEnvelopeStateRoot, computeNewStateRoot} from "./produceBlock/computeNewStateRoot.js";
100
+ import {AssembledBlockType, BlockType, ProduceFullGloas, ProduceResult} from "./produceBlock/index.js";
92
101
  import {BlockAttributes, produceBlockBody, produceCommonBlockBody} from "./produceBlock/produceBlockBody.js";
93
102
  import {QueuedStateRegenerator, RegenCaller} from "./regen/index.js";
94
103
  import {ReprocessController} from "./reprocess.js";
@@ -182,8 +191,7 @@ export class BeaconChain implements IBeaconChain {
182
191
  readonly seenBlockAttesters = new SeenBlockAttesters();
183
192
 
184
193
  // Global state caches
185
- readonly pubkey2index: PubkeyIndexMap;
186
- readonly index2pubkey: Index2PubkeyCache;
194
+ readonly pubkeyCache: PubkeyCache;
187
195
 
188
196
  readonly beaconProposerCache: BeaconProposerCache;
189
197
  readonly checkpointBalancesCache: CheckpointBalancesCache;
@@ -229,8 +237,7 @@ export class BeaconChain implements IBeaconChain {
229
237
  {
230
238
  privateKey,
231
239
  config,
232
- pubkey2index,
233
- index2pubkey,
240
+ pubkeyCache,
234
241
  db,
235
242
  dbName,
236
243
  dataDir,
@@ -246,8 +253,7 @@ export class BeaconChain implements IBeaconChain {
246
253
  }: {
247
254
  privateKey: PrivateKey;
248
255
  config: BeaconConfig;
249
- pubkey2index: PubkeyIndexMap;
250
- index2pubkey: Index2PubkeyCache;
256
+ pubkeyCache: PubkeyCache;
251
257
  db: IBeaconDb;
252
258
  dbName: string;
253
259
  dataDir: string;
@@ -279,8 +285,8 @@ export class BeaconChain implements IBeaconChain {
279
285
  const emitter = new ChainEventEmitter();
280
286
  // by default, verify signatures on both main threads and worker threads
281
287
  const bls = opts.blsVerifyAllMainThread
282
- ? new BlsSingleThreadVerifier({metrics, index2pubkey})
283
- : new BlsMultiThreadWorkerPool(opts, {logger, metrics, index2pubkey});
288
+ ? new BlsSingleThreadVerifier({metrics, pubkeyCache})
289
+ : new BlsMultiThreadWorkerPool(opts, {logger, metrics, pubkeyCache});
284
290
 
285
291
  if (!clock) clock = new Clock({config, genesisTime: this.genesisTime, signal});
286
292
 
@@ -336,8 +342,7 @@ export class BeaconChain implements IBeaconChain {
336
342
  ]);
337
343
 
338
344
  // Global cache of validators pubkey/index mapping
339
- this.pubkey2index = pubkey2index;
340
- this.index2pubkey = index2pubkey;
345
+ this.pubkeyCache = pubkeyCache;
341
346
 
342
347
  const fileDataStore = opts.nHistoricalStatesFileDataStore ?? true;
343
348
  const blockStateCache = new FIFOBlockStateCache(this.opts, {metrics});
@@ -808,7 +813,7 @@ export class BeaconChain implements IBeaconChain {
808
813
  return null;
809
814
  }
810
815
 
811
- async getDataColumnSidecars(blockSlot: Slot, blockRootHex: string): Promise<fulu.DataColumnSidecars> {
816
+ async getDataColumnSidecars(blockSlot: Slot, blockRootHex: string): Promise<DataColumnSidecars> {
812
817
  const blockInput = this.seenBlockInputCache.get(blockRootHex);
813
818
  if (blockInput) {
814
819
  if (!isBlockInputColumns(blockInput)) {
@@ -818,10 +823,10 @@ export class BeaconChain implements IBeaconChain {
818
823
  }
819
824
  const sidecarsUnfinalized = await this.db.dataColumnSidecar.values(fromHex(blockRootHex));
820
825
  if (sidecarsUnfinalized.length > 0) {
821
- return sidecarsUnfinalized;
826
+ return sidecarsUnfinalized as DataColumnSidecars;
822
827
  }
823
828
  const sidecarsFinalized = await this.db.dataColumnSidecarArchive.values(blockSlot);
824
- return sidecarsFinalized;
829
+ return sidecarsFinalized as DataColumnSidecars;
825
830
  }
826
831
 
827
832
  async getSerializedDataColumnSidecars(
@@ -843,7 +848,7 @@ export class BeaconChain implements IBeaconChain {
843
848
  if (serialized) {
844
849
  return serialized;
845
850
  }
846
- return ssz.fulu.DataColumnSidecar.serialize(sidecar);
851
+ return sszTypesFor(blockInput.forkName as ForkPostFulu).DataColumnSidecar.serialize(sidecar);
847
852
  });
848
853
  }
849
854
  const sidecarsUnfinalized = await this.db.dataColumnSidecar.getManyBinary(fromHex(blockRootHex), indices);
@@ -902,6 +907,7 @@ export class BeaconChain implements IBeaconChain {
902
907
  consensusBlockValue: Wei;
903
908
  shouldOverrideBuilder?: boolean;
904
909
  }> {
910
+ const fork = this.config.getForkName(slot);
905
911
  const state = await this.regen.getBlockSlotState(
906
912
  parentBlock,
907
913
  slot,
@@ -909,7 +915,7 @@ export class BeaconChain implements IBeaconChain {
909
915
  RegenCaller.produceBlock
910
916
  );
911
917
  const proposerIndex = state.epochCtx.getBeaconProposer(slot);
912
- const proposerPubKey = this.index2pubkey[proposerIndex].toBytes();
918
+ const proposerPubKey = this.pubkeyCache.getOrThrow(proposerIndex).toBytes();
913
919
 
914
920
  const {body, produceResult, executionPayloadValue, shouldOverrideBuilder} = await produceBlockBody.call(
915
921
  this,
@@ -930,7 +936,7 @@ export class BeaconChain implements IBeaconChain {
930
936
  // The hashtree root computed here for debug log will get cached and hence won't introduce additional delays
931
937
  const bodyRoot =
932
938
  produceResult.type === BlockType.Full
933
- ? this.config.getForkTypes(slot).BeaconBlockBody.hashTreeRoot(body)
939
+ ? sszTypesFor(fork).BeaconBlockBody.hashTreeRoot(body)
934
940
  : this.config
935
941
  .getPostBellatrixForkTypes(slot)
936
942
  .BlindedBeaconBlockBody.hashTreeRoot(body as BlindedBeaconBlockBody);
@@ -948,14 +954,33 @@ export class BeaconChain implements IBeaconChain {
948
954
  body,
949
955
  } as AssembledBlockType<T>;
950
956
 
951
- const {newStateRoot, proposerReward} = computeNewStateRoot(this.metrics, state, block);
957
+ const {newStateRoot, proposerReward, postState} = computeNewStateRoot(this.metrics, state, block);
952
958
  block.stateRoot = newStateRoot;
953
959
  const blockRoot =
954
960
  produceResult.type === BlockType.Full
955
- ? this.config.getForkTypes(slot).BeaconBlock.hashTreeRoot(block)
961
+ ? sszTypesFor(fork).BeaconBlock.hashTreeRoot(block)
956
962
  : this.config.getPostBellatrixForkTypes(slot).BlindedBeaconBlock.hashTreeRoot(block as BlindedBeaconBlock);
957
963
  const blockRootHex = toRootHex(blockRoot);
958
964
 
965
+ if (isForkPostGloas(fork)) {
966
+ // TODO GLOAS: we should retire BlockType post-gloas, may need a new enum for self vs non-self built
967
+ if (produceResult.type !== BlockType.Full) {
968
+ throw Error(`Unexpected block type=${produceResult.type} for post-gloas fork=${fork}`);
969
+ }
970
+
971
+ const gloasResult = produceResult as ProduceFullGloas;
972
+ const envelope: gloas.ExecutionPayloadEnvelope = {
973
+ payload: gloasResult.executionPayload,
974
+ executionRequests: gloasResult.executionRequests,
975
+ builderIndex: BUILDER_INDEX_SELF_BUILD,
976
+ beaconBlockRoot: blockRoot,
977
+ slot,
978
+ stateRoot: ZERO_HASH,
979
+ };
980
+ const envelopeStateRoot = computeEnvelopeStateRoot(this.metrics, postState as CachedBeaconStateGloas, envelope);
981
+ gloasResult.envelopeStateRoot = envelopeStateRoot;
982
+ }
983
+
959
984
  // Track the produced block for consensus broadcast validations, later validation, etc.
960
985
  this.blockProductionCache.set(blockRootHex, produceResult);
961
986
  this.metrics?.blockProductionCacheSize.set(this.blockProductionCache.size);
@@ -1506,7 +1531,7 @@ export class BeaconChain implements IBeaconChain {
1506
1531
  throw Error(`State is not in cache for slot ${slot}`);
1507
1532
  }
1508
1533
 
1509
- const rewards = await computeAttestationsRewards(this.config, this.pubkey2index, cachedState, validatorIds);
1534
+ const rewards = await computeAttestationsRewards(this.config, this.pubkeyCache, cachedState, validatorIds);
1510
1535
 
1511
1536
  return {rewards, executionOptimistic, finalized};
1512
1537
  }
@@ -1523,6 +1548,6 @@ export class BeaconChain implements IBeaconChain {
1523
1548
 
1524
1549
  preState = processSlots(preState, block.slot); // Dial preState's slot to block.slot
1525
1550
 
1526
- return computeSyncCommitteeRewards(this.config, this.index2pubkey, block, preState, validatorIds);
1551
+ return computeSyncCommitteeRewards(this.config, this.pubkeyCache, block, preState, validatorIds);
1527
1552
  }
1528
1553
  }
@@ -3,7 +3,7 @@ import {StrictEventEmitter} from "strict-event-emitter-types";
3
3
  import {routes} from "@lodestar/api";
4
4
  import {CheckpointWithHex} from "@lodestar/fork-choice";
5
5
  import {CachedBeaconStateAllForks} from "@lodestar/state-transition";
6
- import {RootHex, deneb, fulu, phase0} from "@lodestar/types";
6
+ import {DataColumnSidecars, RootHex, deneb, phase0} from "@lodestar/types";
7
7
  import {PeerIdStr} from "../util/peerId.js";
8
8
  import {BlockInputSource, IBlockInput} from "./blocks/blockInput/types.js";
9
9
 
@@ -88,7 +88,7 @@ export type IChainEvents = ApiEvents & {
88
88
 
89
89
  [ChainEvent.updateTargetCustodyGroupCount]: (targetGroupCount: number) => void;
90
90
 
91
- [ChainEvent.publishDataColumns]: (sidecars: fulu.DataColumnSidecar[]) => void;
91
+ [ChainEvent.publishDataColumns]: (sidecars: DataColumnSidecars) => void;
92
92
 
93
93
  [ChainEvent.publishBlobSidecars]: (sidecars: deneb.BlobSidecar[]) => void;
94
94
 
@@ -68,6 +68,8 @@ export enum BlockErrorCode {
68
68
  DATA_UNAVAILABLE = "BLOCK_ERROR_DATA_UNAVAILABLE",
69
69
  /** Block contains too many kzg commitments */
70
70
  TOO_MANY_KZG_COMMITMENTS = "BLOCK_ERROR_TOO_MANY_KZG_COMMITMENTS",
71
+ /** Bid parent block root does not match block parent root */
72
+ BID_PARENT_ROOT_MISMATCH = "BLOCK_ERROR_BID_PARENT_ROOT_MISMATCH",
71
73
  }
72
74
 
73
75
  type ExecutionErrorStatus = Exclude<
@@ -111,7 +113,8 @@ export type BlockErrorType =
111
113
  | {code: BlockErrorCode.TRANSACTIONS_TOO_BIG; size: number; max: number}
112
114
  | {code: BlockErrorCode.EXECUTION_ENGINE_ERROR; execStatus: ExecutionErrorStatus; errorMessage: string}
113
115
  | {code: BlockErrorCode.DATA_UNAVAILABLE}
114
- | {code: BlockErrorCode.TOO_MANY_KZG_COMMITMENTS; blobKzgCommitmentsLen: number; commitmentLimit: number};
116
+ | {code: BlockErrorCode.TOO_MANY_KZG_COMMITMENTS; blobKzgCommitmentsLen: number; commitmentLimit: number}
117
+ | {code: BlockErrorCode.BID_PARENT_ROOT_MISMATCH; bidParentRoot: RootHex; blockParentRoot: RootHex};
115
118
 
116
119
  export class BlockGossipError extends GossipActionError<BlockErrorType> {}
117
120
 
@@ -1,16 +1,11 @@
1
- import {PubkeyIndexMap} from "@chainsafe/pubkey-index-map";
2
1
  import {CompositeTypeAny, TreeView, Type} from "@chainsafe/ssz";
3
2
  import {BeaconConfig} from "@lodestar/config";
4
3
  import {CheckpointWithHex, IForkChoice, ProtoBlock} from "@lodestar/fork-choice";
5
- import {
6
- BeaconStateAllForks,
7
- CachedBeaconStateAllForks,
8
- EpochShuffling,
9
- Index2PubkeyCache,
10
- } from "@lodestar/state-transition";
4
+ import {BeaconStateAllForks, CachedBeaconStateAllForks, EpochShuffling, PubkeyCache} from "@lodestar/state-transition";
11
5
  import {
12
6
  BeaconBlock,
13
7
  BlindedBeaconBlock,
8
+ DataColumnSidecars,
14
9
  Epoch,
15
10
  Root,
16
11
  RootHex,
@@ -23,7 +18,6 @@ import {
23
18
  altair,
24
19
  capella,
25
20
  deneb,
26
- fulu,
27
21
  phase0,
28
22
  rewards,
29
23
  } from "@lodestar/types";
@@ -117,8 +111,7 @@ export interface IBeaconChain {
117
111
  readonly regen: IStateRegenerator;
118
112
  readonly lightClientServer?: LightClientServer;
119
113
  readonly reprocessController: ReprocessController;
120
- readonly pubkey2index: PubkeyIndexMap;
121
- readonly index2pubkey: Index2PubkeyCache;
114
+ readonly pubkeyCache: PubkeyCache;
122
115
  readonly archiveStore: IArchiveStore;
123
116
 
124
117
  // Ops pool
@@ -224,7 +217,7 @@ export interface IBeaconChain {
224
217
  ): Promise<{block: SignedBeaconBlock; executionOptimistic: boolean; finalized: boolean} | null>;
225
218
  getBlobSidecars(blockSlot: Slot, blockRootHex: string): Promise<deneb.BlobSidecars | null>;
226
219
  getSerializedBlobSidecars(blockSlot: Slot, blockRootHex: string): Promise<Uint8Array | null>;
227
- getDataColumnSidecars(blockSlot: Slot, blockRootHex: string): Promise<fulu.DataColumnSidecars>;
220
+ getDataColumnSidecars(blockSlot: Slot, blockRootHex: string): Promise<DataColumnSidecars>;
228
221
  getSerializedDataColumnSidecars(
229
222
  blockSlot: Slot,
230
223
  blockRootHex: string,
@@ -355,7 +355,10 @@ export class LightClientServer {
355
355
  // Signature data
356
356
  const update = await this.db.bestLightClientUpdate.get(period);
357
357
  if (!update) {
358
- throw Error(`No partialUpdate available for period ${period}`);
358
+ throw new LightClientServerError(
359
+ {code: LightClientServerErrorCode.RESOURCE_UNAVAILABLE},
360
+ `No partialUpdate available for period ${period}`
361
+ );
359
362
  }
360
363
  return update;
361
364
  }
@@ -27,6 +27,7 @@ export type IChainOptions = BlockProcessOpts &
27
27
  blsVerifyAllMainThread?: boolean;
28
28
  blsVerifyAllMultiThread?: boolean;
29
29
  blacklistedBlocks?: string[];
30
+ // TODO GLOAS: add similar option for execution payload envelopes?
30
31
  persistProducedBlocks?: boolean;
31
32
  persistInvalidSszObjects?: boolean;
32
33
  persistInvalidSszObjectsDir?: string;
@@ -1,14 +1,14 @@
1
1
  import {routes} from "@lodestar/api";
2
2
  import {ChainForkConfig} from "@lodestar/config";
3
3
  import {getSafeExecutionBlockHash} from "@lodestar/fork-choice";
4
- import {ForkPostBellatrix, ForkSeq, SLOTS_PER_EPOCH} from "@lodestar/params";
4
+ import {ForkPostBellatrix, ForkSeq, SLOTS_PER_EPOCH, isForkPostBellatrix} from "@lodestar/params";
5
5
  import {
6
6
  CachedBeaconStateAllForks,
7
7
  CachedBeaconStateExecutions,
8
+ CachedBeaconStateGloas,
8
9
  StateHashTreeRootSource,
9
10
  computeEpochAtSlot,
10
11
  computeTimeAtSlot,
11
- isExecutionStateType,
12
12
  } from "@lodestar/state-transition";
13
13
  import {Slot} from "@lodestar/types";
14
14
  import {Logger, fromHex, isErrorAborted, sleep} from "@lodestar/utils";
@@ -120,10 +120,10 @@ export class PrepareNextSlotScheduler {
120
120
  RegenCaller.precomputeEpoch
121
121
  );
122
122
 
123
- if (isExecutionStateType(prepareState)) {
123
+ if (isForkPostBellatrix(fork)) {
124
124
  const proposerIndex = prepareState.epochCtx.getBeaconProposer(prepareSlot);
125
125
  const feeRecipient = this.chain.beaconProposerCache.get(proposerIndex);
126
- let updatedPrepareState = prepareState;
126
+ let updatedPrepareState = prepareState as CachedBeaconStateExecutions | CachedBeaconStateGloas;
127
127
  let updatedHeadRoot = headRoot;
128
128
 
129
129
  if (feeRecipient) {
@@ -146,7 +146,7 @@ export class PrepareNextSlotScheduler {
146
146
  // only transfer cache if epoch transition because that's the state we will use to stateTransition() the 1st block of epoch
147
147
  {dontTransferCache: !isEpochTransition},
148
148
  RegenCaller.predictProposerHead
149
- )) as CachedBeaconStateExecutions;
149
+ )) as CachedBeaconStateExecutions | CachedBeaconStateGloas;
150
150
  updatedHeadRoot = proposerHeadRoot;
151
151
  }
152
152
 
@@ -1,11 +1,14 @@
1
1
  import {
2
2
  CachedBeaconStateAllForks,
3
+ CachedBeaconStateGloas,
3
4
  DataAvailabilityStatus,
4
5
  ExecutionPayloadStatus,
6
+ G2_POINT_AT_INFINITY,
5
7
  StateHashTreeRootSource,
6
8
  stateTransition,
7
9
  } from "@lodestar/state-transition";
8
- import {BeaconBlock, BlindedBeaconBlock, Gwei, Root} from "@lodestar/types";
10
+ import {processExecutionPayloadEnvelope} from "@lodestar/state-transition/block";
11
+ import {BeaconBlock, BlindedBeaconBlock, Gwei, Root, gloas} from "@lodestar/types";
9
12
  import {ZERO_HASH} from "../../constants/index.js";
10
13
  import {Metrics} from "../../metrics/index.js";
11
14
 
@@ -18,7 +21,7 @@ export function computeNewStateRoot(
18
21
  metrics: Metrics | null,
19
22
  state: CachedBeaconStateAllForks,
20
23
  block: BeaconBlock | BlindedBeaconBlock
21
- ): {newStateRoot: Root; proposerReward: Gwei} {
24
+ ): {newStateRoot: Root; proposerReward: Gwei; postState: CachedBeaconStateAllForks} {
22
25
  // Set signature to zero to re-use stateTransition() function which requires the SignedBeaconBlock type
23
26
  const blockEmptySig = {message: block, signature: ZERO_HASH};
24
27
 
@@ -51,5 +54,34 @@ export function computeNewStateRoot(
51
54
  const newStateRoot = postState.hashTreeRoot();
52
55
  hashTreeRootTimer?.();
53
56
 
54
- return {newStateRoot, proposerReward};
57
+ return {newStateRoot, proposerReward, postState};
58
+ }
59
+
60
+ /**
61
+ * Compute the state root after processing an execution payload envelope.
62
+ * Similar to `computeNewStateRoot` but for payload envelope processing.
63
+ *
64
+ * The `postBlockState` is mutated in place, callers must ensure it is not needed afterward.
65
+ */
66
+ export function computeEnvelopeStateRoot(
67
+ metrics: Metrics | null,
68
+ postBlockState: CachedBeaconStateGloas,
69
+ envelope: gloas.ExecutionPayloadEnvelope
70
+ ): Root {
71
+ const signedEnvelope: gloas.SignedExecutionPayloadEnvelope = {
72
+ message: envelope,
73
+ signature: G2_POINT_AT_INFINITY,
74
+ };
75
+
76
+ const processEnvelopeTimer = metrics?.blockPayload.executionPayloadEnvelopeProcessingTime.startTimer();
77
+ processExecutionPayloadEnvelope(postBlockState, signedEnvelope, false);
78
+ processEnvelopeTimer?.();
79
+
80
+ const hashTreeRootTimer = metrics?.stateHashTreeRootTime.startTimer({
81
+ source: StateHashTreeRootSource.computeEnvelopeStateRoot,
82
+ });
83
+ const stateRoot = postBlockState.hashTreeRoot();
84
+ hashTreeRootTimer?.();
85
+
86
+ return stateRoot;
55
87
  }