@lodestar/beacon-node 1.42.0-dev.eec18d0609 → 1.42.0-dev.f403d99def

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 (286) hide show
  1. package/lib/api/impl/beacon/blocks/index.d.ts.map +1 -1
  2. package/lib/api/impl/beacon/blocks/index.js +31 -11
  3. package/lib/api/impl/beacon/blocks/index.js.map +1 -1
  4. package/lib/api/impl/beacon/pool/index.d.ts.map +1 -1
  5. package/lib/api/impl/beacon/pool/index.js +4 -0
  6. package/lib/api/impl/beacon/pool/index.js.map +1 -1
  7. package/lib/api/impl/beacon/state/index.d.ts.map +1 -1
  8. package/lib/api/impl/beacon/state/index.js +13 -10
  9. package/lib/api/impl/beacon/state/index.js.map +1 -1
  10. package/lib/api/impl/debug/index.js.map +1 -1
  11. package/lib/api/impl/lodestar/index.d.ts.map +1 -1
  12. package/lib/api/impl/lodestar/index.js +4 -0
  13. package/lib/api/impl/lodestar/index.js.map +1 -1
  14. package/lib/api/impl/validator/index.d.ts.map +1 -1
  15. package/lib/api/impl/validator/index.js +9 -3
  16. package/lib/api/impl/validator/index.js.map +1 -1
  17. package/lib/chain/ColumnReconstructionTracker.d.ts +2 -1
  18. package/lib/chain/ColumnReconstructionTracker.d.ts.map +1 -1
  19. package/lib/chain/ColumnReconstructionTracker.js +5 -5
  20. package/lib/chain/ColumnReconstructionTracker.js.map +1 -1
  21. package/lib/chain/GetBlobsTracker.d.ts +2 -1
  22. package/lib/chain/GetBlobsTracker.d.ts.map +1 -1
  23. package/lib/chain/GetBlobsTracker.js +14 -12
  24. package/lib/chain/GetBlobsTracker.js.map +1 -1
  25. package/lib/chain/blocks/blockInput/blockInput.d.ts +5 -5
  26. package/lib/chain/blocks/blockInput/blockInput.d.ts.map +1 -1
  27. package/lib/chain/blocks/blockInput/blockInput.js.map +1 -1
  28. package/lib/chain/blocks/blockInput/types.d.ts +4 -4
  29. package/lib/chain/blocks/blockInput/types.d.ts.map +1 -1
  30. package/lib/chain/blocks/importBlock.d.ts.map +1 -1
  31. package/lib/chain/blocks/importBlock.js +19 -5
  32. package/lib/chain/blocks/importBlock.js.map +1 -1
  33. package/lib/chain/blocks/importExecutionPayload.d.ts.map +1 -1
  34. package/lib/chain/blocks/importExecutionPayload.js +14 -5
  35. package/lib/chain/blocks/importExecutionPayload.js.map +1 -1
  36. package/lib/chain/blocks/index.js +1 -1
  37. package/lib/chain/blocks/index.js.map +1 -1
  38. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts +14 -6
  39. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.d.ts.map +1 -1
  40. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js +33 -2
  41. package/lib/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.js.map +1 -1
  42. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts +2 -1
  43. package/lib/chain/blocks/payloadEnvelopeInput/types.d.ts.map +1 -1
  44. package/lib/chain/blocks/types.d.ts +3 -3
  45. package/lib/chain/blocks/types.d.ts.map +1 -1
  46. package/lib/chain/blocks/verifyBlocksExecutionPayloads.d.ts.map +1 -1
  47. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js +3 -2
  48. package/lib/chain/blocks/verifyBlocksExecutionPayloads.js.map +1 -1
  49. package/lib/chain/blocks/verifyBlocksSignatures.d.ts.map +1 -1
  50. package/lib/chain/blocks/verifyBlocksSignatures.js +4 -2
  51. package/lib/chain/blocks/verifyBlocksSignatures.js.map +1 -1
  52. package/lib/chain/chain.d.ts +4 -2
  53. package/lib/chain/chain.d.ts.map +1 -1
  54. package/lib/chain/chain.js +77 -28
  55. package/lib/chain/chain.js.map +1 -1
  56. package/lib/chain/emitter.d.ts +29 -7
  57. package/lib/chain/emitter.d.ts.map +1 -1
  58. package/lib/chain/emitter.js +12 -3
  59. package/lib/chain/emitter.js.map +1 -1
  60. package/lib/chain/errors/blockError.d.ts +11 -1
  61. package/lib/chain/errors/blockError.d.ts.map +1 -1
  62. package/lib/chain/errors/blockError.js +4 -0
  63. package/lib/chain/errors/blockError.js.map +1 -1
  64. package/lib/chain/errors/dataColumnSidecarError.d.ts +31 -1
  65. package/lib/chain/errors/dataColumnSidecarError.d.ts.map +1 -1
  66. package/lib/chain/errors/dataColumnSidecarError.js +7 -0
  67. package/lib/chain/errors/dataColumnSidecarError.js.map +1 -1
  68. package/lib/chain/forkChoice/index.d.ts.map +1 -1
  69. package/lib/chain/forkChoice/index.js +10 -8
  70. package/lib/chain/forkChoice/index.js.map +1 -1
  71. package/lib/chain/interface.d.ts +5 -2
  72. package/lib/chain/interface.d.ts.map +1 -1
  73. package/lib/chain/interface.js.map +1 -1
  74. package/lib/chain/lightClient/index.d.ts +2 -2
  75. package/lib/chain/lightClient/index.d.ts.map +1 -1
  76. package/lib/chain/lightClient/index.js +7 -0
  77. package/lib/chain/lightClient/index.js.map +1 -1
  78. package/lib/chain/opPools/aggregatedAttestationPool.d.ts.map +1 -1
  79. package/lib/chain/opPools/aggregatedAttestationPool.js +5 -2
  80. package/lib/chain/opPools/aggregatedAttestationPool.js.map +1 -1
  81. package/lib/chain/opPools/executionPayloadBidPool.d.ts +2 -2
  82. package/lib/chain/opPools/executionPayloadBidPool.d.ts.map +1 -1
  83. package/lib/chain/opPools/executionPayloadBidPool.js +2 -2
  84. package/lib/chain/opPools/executionPayloadBidPool.js.map +1 -1
  85. package/lib/chain/prepareNextSlot.d.ts.map +1 -1
  86. package/lib/chain/prepareNextSlot.js +7 -1
  87. package/lib/chain/prepareNextSlot.js.map +1 -1
  88. package/lib/chain/produceBlock/computeNewStateRoot.d.ts +3 -3
  89. package/lib/chain/produceBlock/computeNewStateRoot.d.ts.map +1 -1
  90. package/lib/chain/produceBlock/computeNewStateRoot.js +8 -8
  91. package/lib/chain/produceBlock/computeNewStateRoot.js.map +1 -1
  92. package/lib/chain/produceBlock/produceBlockBody.d.ts +5 -5
  93. package/lib/chain/produceBlock/produceBlockBody.d.ts.map +1 -1
  94. package/lib/chain/produceBlock/produceBlockBody.js +23 -4
  95. package/lib/chain/produceBlock/produceBlockBody.js.map +1 -1
  96. package/lib/chain/seenCache/seenGossipBlockInput.d.ts +1 -1
  97. package/lib/chain/seenCache/seenGossipBlockInput.d.ts.map +1 -1
  98. package/lib/chain/seenCache/seenGossipBlockInput.js +2 -2
  99. package/lib/chain/seenCache/seenGossipBlockInput.js.map +1 -1
  100. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts +1 -1
  101. package/lib/chain/seenCache/seenPayloadEnvelopeInput.d.ts.map +1 -1
  102. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js +2 -2
  103. package/lib/chain/seenCache/seenPayloadEnvelopeInput.js.map +1 -1
  104. package/lib/chain/validation/block.d.ts.map +1 -1
  105. package/lib/chain/validation/block.js +27 -5
  106. package/lib/chain/validation/block.js.map +1 -1
  107. package/lib/chain/validation/dataColumnSidecar.d.ts +11 -4
  108. package/lib/chain/validation/dataColumnSidecar.d.ts.map +1 -1
  109. package/lib/chain/validation/dataColumnSidecar.js +184 -5
  110. package/lib/chain/validation/dataColumnSidecar.js.map +1 -1
  111. package/lib/chain/validation/executionPayloadBid.d.ts.map +1 -1
  112. package/lib/chain/validation/executionPayloadBid.js +7 -4
  113. package/lib/chain/validation/executionPayloadBid.js.map +1 -1
  114. package/lib/chain/validation/executionPayloadEnvelope.d.ts.map +1 -1
  115. package/lib/chain/validation/executionPayloadEnvelope.js +6 -1
  116. package/lib/chain/validation/executionPayloadEnvelope.js.map +1 -1
  117. package/lib/chain/validation/payloadAttestationMessage.d.ts.map +1 -1
  118. package/lib/chain/validation/payloadAttestationMessage.js +4 -1
  119. package/lib/chain/validation/payloadAttestationMessage.js.map +1 -1
  120. package/lib/chain/validation/syncCommittee.d.ts.map +1 -1
  121. package/lib/chain/validation/syncCommittee.js +4 -0
  122. package/lib/chain/validation/syncCommittee.js.map +1 -1
  123. package/lib/chain/validation/syncCommitteeContributionAndProof.js +4 -1
  124. package/lib/chain/validation/syncCommitteeContributionAndProof.js.map +1 -1
  125. package/lib/chain/validatorMonitor.d.ts.map +1 -1
  126. package/lib/chain/validatorMonitor.js +3 -3
  127. package/lib/chain/validatorMonitor.js.map +1 -1
  128. package/lib/db/buckets.d.ts +2 -2
  129. package/lib/db/buckets.d.ts.map +1 -1
  130. package/lib/db/buckets.js +2 -2
  131. package/lib/db/buckets.js.map +1 -1
  132. package/lib/db/repositories/blockArchiveIndex.d.ts +2 -2
  133. package/lib/db/repositories/blockArchiveIndex.d.ts.map +1 -1
  134. package/lib/db/repositories/dataColumnSidecar.d.ts.map +1 -1
  135. package/lib/db/repositories/dataColumnSidecar.js +4 -2
  136. package/lib/db/repositories/dataColumnSidecar.js.map +1 -1
  137. package/lib/db/repositories/dataColumnSidecarArchive.d.ts.map +1 -1
  138. package/lib/db/repositories/dataColumnSidecarArchive.js +4 -2
  139. package/lib/db/repositories/dataColumnSidecarArchive.js.map +1 -1
  140. package/lib/metrics/metrics/lodestar.d.ts +20 -0
  141. package/lib/metrics/metrics/lodestar.d.ts.map +1 -1
  142. package/lib/metrics/metrics/lodestar.js +33 -0
  143. package/lib/metrics/metrics/lodestar.js.map +1 -1
  144. package/lib/network/interface.d.ts +3 -2
  145. package/lib/network/interface.d.ts.map +1 -1
  146. package/lib/network/network.d.ts +3 -2
  147. package/lib/network/network.d.ts.map +1 -1
  148. package/lib/network/network.js +3 -0
  149. package/lib/network/network.js.map +1 -1
  150. package/lib/network/processor/extractSlotRootFns.d.ts +1 -1
  151. package/lib/network/processor/extractSlotRootFns.d.ts.map +1 -1
  152. package/lib/network/processor/extractSlotRootFns.js +25 -5
  153. package/lib/network/processor/extractSlotRootFns.js.map +1 -1
  154. package/lib/network/processor/gossipHandlers.d.ts.map +1 -1
  155. package/lib/network/processor/gossipHandlers.js +246 -66
  156. package/lib/network/processor/gossipHandlers.js.map +1 -1
  157. package/lib/network/processor/index.d.ts +11 -1
  158. package/lib/network/processor/index.d.ts.map +1 -1
  159. package/lib/network/processor/index.js +234 -22
  160. package/lib/network/processor/index.js.map +1 -1
  161. package/lib/network/reqresp/handlers/beaconBlocksByRange.d.ts.map +1 -1
  162. package/lib/network/reqresp/handlers/beaconBlocksByRange.js +2 -1
  163. package/lib/network/reqresp/handlers/beaconBlocksByRange.js.map +1 -1
  164. package/lib/network/reqresp/handlers/beaconBlocksByRoot.d.ts.map +1 -1
  165. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js +2 -0
  166. package/lib/network/reqresp/handlers/beaconBlocksByRoot.js.map +1 -1
  167. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts +2 -2
  168. package/lib/network/reqresp/handlers/blobSidecarsByRange.d.ts.map +1 -1
  169. package/lib/network/reqresp/handlers/blobSidecarsByRange.js +7 -3
  170. package/lib/network/reqresp/handlers/blobSidecarsByRange.js.map +1 -1
  171. package/lib/network/reqresp/handlers/blobSidecarsByRoot.d.ts.map +1 -1
  172. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js +6 -0
  173. package/lib/network/reqresp/handlers/blobSidecarsByRoot.js.map +1 -1
  174. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts +2 -2
  175. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.d.ts.map +1 -1
  176. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js +7 -3
  177. package/lib/network/reqresp/handlers/dataColumnSidecarsByRange.js.map +1 -1
  178. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.d.ts.map +1 -1
  179. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js +2 -1
  180. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRange.js.map +1 -1
  181. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.d.ts.map +1 -1
  182. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js +3 -8
  183. package/lib/network/reqresp/handlers/executionPayloadEnvelopesByRoot.js.map +1 -1
  184. package/lib/network/reqresp/types.d.ts +3 -3
  185. package/lib/network/reqresp/types.d.ts.map +1 -1
  186. package/lib/network/reqresp/types.js +9 -3
  187. package/lib/network/reqresp/types.js.map +1 -1
  188. package/lib/node/nodejs.d.ts.map +1 -1
  189. package/lib/node/nodejs.js +4 -1
  190. package/lib/node/nodejs.js.map +1 -1
  191. package/lib/node/notifier.d.ts.map +1 -1
  192. package/lib/node/notifier.js +2 -2
  193. package/lib/node/notifier.js.map +1 -1
  194. package/lib/sync/unknownBlock.js +2 -2
  195. package/lib/sync/unknownBlock.js.map +1 -1
  196. package/lib/sync/utils/downloadByRange.d.ts +3 -3
  197. package/lib/sync/utils/downloadByRange.d.ts.map +1 -1
  198. package/lib/sync/utils/downloadByRange.js +4 -2
  199. package/lib/sync/utils/downloadByRange.js.map +1 -1
  200. package/lib/sync/utils/downloadByRoot.d.ts +3 -3
  201. package/lib/sync/utils/downloadByRoot.d.ts.map +1 -1
  202. package/lib/sync/utils/downloadByRoot.js +10 -5
  203. package/lib/sync/utils/downloadByRoot.js.map +1 -1
  204. package/lib/util/blobs.d.ts +3 -3
  205. package/lib/util/blobs.d.ts.map +1 -1
  206. package/lib/util/blobs.js +21 -10
  207. package/lib/util/blobs.js.map +1 -1
  208. package/lib/util/dataColumns.d.ts +18 -11
  209. package/lib/util/dataColumns.d.ts.map +1 -1
  210. package/lib/util/dataColumns.js +51 -17
  211. package/lib/util/dataColumns.js.map +1 -1
  212. package/lib/util/execution.d.ts +6 -2
  213. package/lib/util/execution.d.ts.map +1 -1
  214. package/lib/util/execution.js +49 -25
  215. package/lib/util/execution.js.map +1 -1
  216. package/lib/util/sszBytes.d.ts +25 -1
  217. package/lib/util/sszBytes.d.ts.map +1 -1
  218. package/lib/util/sszBytes.js +189 -2
  219. package/lib/util/sszBytes.js.map +1 -1
  220. package/package.json +15 -15
  221. package/src/api/impl/beacon/blocks/index.ts +46 -14
  222. package/src/api/impl/beacon/pool/index.ts +4 -0
  223. package/src/api/impl/beacon/state/index.ts +15 -15
  224. package/src/api/impl/debug/index.ts +2 -2
  225. package/src/api/impl/lodestar/index.ts +4 -0
  226. package/src/api/impl/validator/index.ts +9 -2
  227. package/src/chain/ColumnReconstructionTracker.ts +6 -5
  228. package/src/chain/GetBlobsTracker.ts +14 -12
  229. package/src/chain/blocks/blockInput/blockInput.ts +8 -8
  230. package/src/chain/blocks/blockInput/types.ts +4 -4
  231. package/src/chain/blocks/importBlock.ts +29 -8
  232. package/src/chain/blocks/importExecutionPayload.ts +15 -5
  233. package/src/chain/blocks/index.ts +1 -1
  234. package/src/chain/blocks/payloadEnvelopeInput/payloadEnvelopeInput.ts +53 -12
  235. package/src/chain/blocks/payloadEnvelopeInput/types.ts +2 -1
  236. package/src/chain/blocks/types.ts +3 -3
  237. package/src/chain/blocks/verifyBlocksExecutionPayloads.ts +2 -1
  238. package/src/chain/blocks/verifyBlocksSignatures.ts +9 -2
  239. package/src/chain/chain.ts +93 -32
  240. package/src/chain/emitter.ts +25 -7
  241. package/src/chain/errors/blockError.ts +7 -1
  242. package/src/chain/errors/dataColumnSidecarError.ts +32 -1
  243. package/src/chain/forkChoice/index.ts +11 -8
  244. package/src/chain/interface.ts +9 -2
  245. package/src/chain/lightClient/index.ts +15 -3
  246. package/src/chain/opPools/aggregatedAttestationPool.ts +6 -1
  247. package/src/chain/opPools/executionPayloadBidPool.ts +3 -3
  248. package/src/chain/prepareNextSlot.ts +8 -0
  249. package/src/chain/produceBlock/computeNewStateRoot.ts +11 -10
  250. package/src/chain/produceBlock/produceBlockBody.ts +40 -10
  251. package/src/chain/seenCache/seenGossipBlockInput.ts +2 -2
  252. package/src/chain/seenCache/seenPayloadEnvelopeInput.ts +2 -2
  253. package/src/chain/validation/block.ts +30 -7
  254. package/src/chain/validation/dataColumnSidecar.ts +230 -7
  255. package/src/chain/validation/executionPayloadBid.ts +7 -3
  256. package/src/chain/validation/executionPayloadEnvelope.ts +10 -1
  257. package/src/chain/validation/payloadAttestationMessage.ts +4 -0
  258. package/src/chain/validation/syncCommittee.ts +5 -1
  259. package/src/chain/validation/syncCommitteeContributionAndProof.ts +5 -1
  260. package/src/chain/validatorMonitor.ts +3 -2
  261. package/src/db/buckets.ts +2 -2
  262. package/src/db/repositories/dataColumnSidecar.ts +4 -2
  263. package/src/db/repositories/dataColumnSidecarArchive.ts +4 -2
  264. package/src/metrics/metrics/lodestar.ts +34 -0
  265. package/src/network/interface.ts +3 -2
  266. package/src/network/network.ts +7 -4
  267. package/src/network/processor/extractSlotRootFns.ts +32 -6
  268. package/src/network/processor/gossipHandlers.ts +310 -79
  269. package/src/network/processor/index.ts +304 -22
  270. package/src/network/reqresp/handlers/beaconBlocksByRange.ts +3 -1
  271. package/src/network/reqresp/handlers/beaconBlocksByRoot.ts +3 -0
  272. package/src/network/reqresp/handlers/blobSidecarsByRange.ts +15 -3
  273. package/src/network/reqresp/handlers/blobSidecarsByRoot.ts +11 -0
  274. package/src/network/reqresp/handlers/dataColumnSidecarsByRange.ts +19 -3
  275. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRange.ts +3 -1
  276. package/src/network/reqresp/handlers/executionPayloadEnvelopesByRoot.ts +3 -12
  277. package/src/network/reqresp/types.ts +13 -5
  278. package/src/node/nodejs.ts +5 -2
  279. package/src/node/notifier.ts +7 -2
  280. package/src/sync/unknownBlock.ts +3 -3
  281. package/src/sync/utils/downloadByRange.ts +9 -7
  282. package/src/sync/utils/downloadByRoot.ts +16 -12
  283. package/src/util/blobs.ts +35 -15
  284. package/src/util/dataColumns.ts +69 -25
  285. package/src/util/execution.ts +49 -30
  286. package/src/util/sszBytes.ts +245 -3
@@ -2,10 +2,11 @@ import {routes} from "@lodestar/api";
2
2
  import {ChainForkConfig} from "@lodestar/config";
3
3
  import {ForkPostFulu, ForkPreFulu} from "@lodestar/params";
4
4
  import {signedBlockToSignedHeader} from "@lodestar/state-transition";
5
- import {deneb, fulu} from "@lodestar/types";
6
- import {toHex} from "@lodestar/utils";
5
+ import {DataColumnSidecar, SignedBeaconBlock, deneb, isGloasDataColumnSidecar} from "@lodestar/types";
6
+ import {fromHex, toHex} from "@lodestar/utils";
7
7
  import {isBlockInputBlobs, isBlockInputColumns} from "../chain/blocks/blockInput/blockInput.js";
8
8
  import {BlockInputSource, IBlockInput} from "../chain/blocks/blockInput/types.js";
9
+ import {PayloadEnvelopeInput, PayloadEnvelopeInputSource} from "../chain/blocks/payloadEnvelopeInput/index.js";
9
10
  import {ChainEvent, ChainEventEmitter} from "../chain/emitter.js";
10
11
  import {IExecutionEngine} from "../execution/index.js";
11
12
  import {Metrics} from "../metrics/index.js";
@@ -14,6 +15,7 @@ import {
14
15
  getCellsAndProofs,
15
16
  getDataColumnSidecarsFromBlock,
16
17
  getDataColumnSidecarsFromColumnSidecar,
18
+ getGloasDataColumnSidecars,
17
19
  } from "./dataColumns.js";
18
20
 
19
21
  export enum DataColumnEngineResult {
@@ -124,27 +126,32 @@ export async function getBlobSidecarsFromExecution(
124
126
  }
125
127
 
126
128
  /**
127
- * Post fulu, call getBlobsV2 from execution engine once per slot whenever we see either beacon_block or data_column_sidecar gossip message
129
+ * Call getBlobsV2 from execution engine once per slot to fetch blobs and compute data columns.
130
+ *
131
+ * Post fulu, whenever we see either beacon_block or data_column_sidecar gossip message and data isn't complete.
132
+ * Post gloas, immediately when beacon block is successfully imported and PayloadEnvelopeInput is created.
128
133
  */
129
134
  export async function getDataColumnSidecarsFromExecution(
130
135
  config: ChainForkConfig,
131
136
  executionEngine: IExecutionEngine,
132
137
  emitter: ChainEventEmitter,
133
- blockInput: IBlockInput,
138
+ input: IBlockInput | PayloadEnvelopeInput,
134
139
  metrics: Metrics | null,
135
140
  blobAndProofBuffers?: Uint8Array[]
136
141
  ): Promise<DataColumnEngineResult> {
137
- // If its not a column block input, exit
138
- if (!isBlockInputColumns(blockInput)) {
142
+ const isPayloadInput = input instanceof PayloadEnvelopeInput;
143
+
144
+ // Pre gloas, ensure it's a column block input
145
+ if (!isPayloadInput && !isBlockInputColumns(input)) {
139
146
  return DataColumnEngineResult.PreFulu;
140
147
  }
141
148
 
142
149
  // If already have all columns, exit
143
- if (blockInput.hasAllData()) {
150
+ if (input.hasAllData()) {
144
151
  return DataColumnEngineResult.NotAttemptedFull;
145
152
  }
146
153
 
147
- const versionedHashes = blockInput.getVersionedHashes();
154
+ const versionedHashes = input.getVersionedHashes();
148
155
 
149
156
  // If there are no blobs in this block, exit
150
157
  if (versionedHashes.length === 0) {
@@ -154,11 +161,7 @@ export async function getDataColumnSidecarsFromExecution(
154
161
  // Get blobs from execution engine
155
162
  metrics?.peerDas.getBlobsV2Requests.inc();
156
163
  const timer = metrics?.peerDas.getBlobsV2RequestDuration.startTimer();
157
- const blobs = await executionEngine.getBlobs(
158
- blockInput.forkName as ForkPostFulu,
159
- versionedHashes,
160
- blobAndProofBuffers
161
- );
164
+ const blobs = await executionEngine.getBlobs(input.forkName as ForkPostFulu, versionedHashes, blobAndProofBuffers);
162
165
  timer?.();
163
166
 
164
167
  // Execution engine was unable to find one or more blobs
@@ -168,22 +171,24 @@ export async function getDataColumnSidecarsFromExecution(
168
171
  metrics?.peerDas.getBlobsV2Responses.inc();
169
172
 
170
173
  // Return if we received all data columns while waiting for getBlobs
171
- if (blockInput.hasAllData()) {
174
+ if (input.hasAllData()) {
172
175
  return DataColumnEngineResult.SuccessLate;
173
176
  }
174
177
 
175
- let dataColumnSidecars: fulu.DataColumnSidecars;
178
+ let dataColumnSidecars: DataColumnSidecar[];
176
179
  const compTimer = metrics?.peerDas.dataColumnSidecarComputationTime.startTimer();
177
180
  try {
178
181
  const cellsAndProofs = await getCellsAndProofs(blobs);
179
- if (blockInput.hasBlock()) {
182
+ if (isPayloadInput) {
183
+ dataColumnSidecars = getGloasDataColumnSidecars(input.slot, fromHex(input.blockRootHex), cellsAndProofs);
184
+ } else if (input.hasBlock()) {
180
185
  dataColumnSidecars = getDataColumnSidecarsFromBlock(
181
186
  config,
182
- blockInput.getBlock() as fulu.SignedBeaconBlock,
187
+ input.getBlock() as SignedBeaconBlock<ForkPostFulu>,
183
188
  cellsAndProofs
184
189
  );
185
190
  } else {
186
- const firstSidecar = blockInput.getAllColumns()[0];
191
+ const firstSidecar = input.getAllColumns()[0];
187
192
  dataColumnSidecars = getDataColumnSidecarsFromColumnSidecar(firstSidecar, cellsAndProofs);
188
193
  }
189
194
  } finally {
@@ -191,36 +196,50 @@ export async function getDataColumnSidecarsFromExecution(
191
196
  }
192
197
 
193
198
  // Publish columns if and only if subscribed to them
194
- const previouslyMissingColumns = blockInput.getMissingSampledColumnMeta().missing;
199
+ const previouslyMissingColumns = input.getMissingSampledColumnMeta().missing;
195
200
  const sampledColumns = previouslyMissingColumns.map((columnIndex) => dataColumnSidecars[columnIndex]);
196
201
 
197
202
  // for columns that we already seen, it will be ignored through `ignoreDuplicatePublishError` gossip option
198
203
  emitter.emit(ChainEvent.publishDataColumns, sampledColumns);
199
204
  // TODO: Can we record dataColumns.sentPeersPerSubnet metric here somehow
200
205
 
201
- // add all sampled columns to the block input, even if we didn't sample them
206
+ // add all sampled columns to the input, even if we didn't sample them
202
207
  const seenTimestampSec = Date.now() / 1000;
203
208
  let alreadyAddedColumnsCount = 0;
204
209
  for (const columnSidecar of sampledColumns) {
205
- if (blockInput.hasColumn(columnSidecar.index)) {
210
+ if (input.hasColumn(columnSidecar.index)) {
206
211
  // columns may have been added while waiting
207
212
  alreadyAddedColumnsCount++;
208
213
  continue;
209
214
  }
210
215
 
211
- blockInput.addColumn({
212
- columnSidecar,
213
- blockRootHex: blockInput.blockRootHex,
214
- source: BlockInputSource.engine,
215
- seenTimestampSec,
216
- });
216
+ if (isPayloadInput) {
217
+ if (!isGloasDataColumnSidecar(columnSidecar)) {
218
+ throw new Error(`Expected gloas DataColumnSidecar for block ${input.blockRootHex}`);
219
+ }
220
+ input.addColumn({
221
+ columnSidecar,
222
+ source: PayloadEnvelopeInputSource.engine,
223
+ seenTimestampSec,
224
+ });
225
+ } else {
226
+ if (isGloasDataColumnSidecar(columnSidecar)) {
227
+ throw new Error(`Expected fulu DataColumnSidecar for block ${input.blockRootHex}`);
228
+ }
229
+ input.addColumn({
230
+ columnSidecar,
231
+ blockRootHex: input.blockRootHex,
232
+ source: BlockInputSource.engine,
233
+ seenTimestampSec,
234
+ });
235
+ }
217
236
 
218
237
  if (emitter.listenerCount(routes.events.EventType.dataColumnSidecar)) {
219
238
  emitter.emit(routes.events.EventType.dataColumnSidecar, {
220
- blockRoot: blockInput.blockRootHex,
221
- slot: blockInput.slot,
239
+ blockRoot: input.blockRootHex,
240
+ slot: input.slot,
222
241
  index: columnSidecar.index,
223
- kzgCommitments: columnSidecar.kzgCommitments.map(toHex),
242
+ kzgCommitments: !isGloasDataColumnSidecar(columnSidecar) ? columnSidecar.kzgCommitments.map(toHex) : undefined,
224
243
  });
225
244
  }
226
245
  }
@@ -17,6 +17,8 @@ export type BlockRootHex = RootHex;
17
17
  export type AttDataBase64 = string;
18
18
  // electra, CommitteeBits
19
19
  export type CommitteeBitsBase64 = string;
20
+ /** `attestation.data.index` from gossip-serialized attestations / aggregates */
21
+ export type AttDataIndex = number;
20
22
 
21
23
  // pre-electra
22
24
  // class Attestation(Container):
@@ -57,6 +59,7 @@ const SIGNATURE_SIZE = 96;
57
59
  const SINGLE_ATTESTATION_ATTDATA_OFFSET = 8 + 8;
58
60
  const SINGLE_ATTESTATION_SLOT_OFFSET = SINGLE_ATTESTATION_ATTDATA_OFFSET;
59
61
  const SINGLE_ATTESTATION_COMMITTEE_INDEX_OFFSET = 0;
62
+ const SINGLE_ATTESTATION_DATA_INDEX_OFFSET = SINGLE_ATTESTATION_ATTDATA_OFFSET + 8;
60
63
  const SINGLE_ATTESTATION_ATTESTER_INDEX_OFFSET = 8;
61
64
  const SINGLE_ATTESTATION_BEACON_BLOCK_ROOT_OFFSET = SINGLE_ATTESTATION_ATTDATA_OFFSET + 8 + 8;
62
65
  const SINGLE_ATTESTATION_SIGNATURE_OFFSET = SINGLE_ATTESTATION_ATTDATA_OFFSET + ATTESTATION_DATA_SIZE;
@@ -180,7 +183,7 @@ export function getSlotFromSingleAttestationSerialized(data: Uint8Array): Slot |
180
183
 
181
184
  /**
182
185
  * Extract committee index from SingleAttestation serialized bytes.
183
- * Return null if data is not long enough to extract slot.
186
+ * Return null if data is not long enough to extract the committee index.
184
187
  */
185
188
  export function getCommitteeIndexFromSingleAttestationSerialized(
186
189
  fork: ForkName,
@@ -201,6 +204,29 @@ export function getCommitteeIndexFromSingleAttestationSerialized(
201
204
  return getIndexFromOffset(data, VARIABLE_FIELD_OFFSET + SLOT_SIZE);
202
205
  }
203
206
 
207
+ /**
208
+ * Extract data index from SingleAttestation serialized bytes.
209
+ * Post-gloas, `data.index` field is repurposed:
210
+ * - 0 - payload was not available (or attestation is same-slot, where availability is not yet known)
211
+ * - 1 - payload was available
212
+ * Return null if data is not long enough to extract the index.
213
+ */
214
+ export function getDataIndexFromSingleAttestationSerialized(fork: ForkName, data: Uint8Array): AttDataIndex | null {
215
+ if (isForkPostElectra(fork)) {
216
+ if (data.length !== SINGLE_ATTESTATION_SIZE) {
217
+ return null;
218
+ }
219
+
220
+ return getIndexFromOffset(data, SINGLE_ATTESTATION_DATA_INDEX_OFFSET);
221
+ }
222
+
223
+ if (data.length < VARIABLE_FIELD_OFFSET + SLOT_SIZE + COMMITTEE_INDEX_SIZE) {
224
+ return null;
225
+ }
226
+
227
+ return getIndexFromOffset(data, VARIABLE_FIELD_OFFSET + SLOT_SIZE);
228
+ }
229
+
204
230
  /**
205
231
  * Extract attester index from SingleAttestation serialized bytes.
206
232
  * Return null if data is not long enough to extract index.
@@ -269,6 +295,7 @@ export function getSignatureFromSingleAttestationSerialized(data: Uint8Array): B
269
295
  const AGGREGATE_AND_PROOF_OFFSET = 4 + 96;
270
296
  const AGGREGATE_OFFSET = AGGREGATE_AND_PROOF_OFFSET + 8 + 4 + 96;
271
297
  const SIGNED_AGGREGATE_AND_PROOF_SLOT_OFFSET = AGGREGATE_OFFSET + VARIABLE_FIELD_OFFSET;
298
+ const SIGNED_AGGREGATE_AND_PROOF_ATTESTATION_DATA_INDEX_OFFSET = SIGNED_AGGREGATE_AND_PROOF_SLOT_OFFSET + SLOT_SIZE;
272
299
  const SIGNED_AGGREGATE_AND_PROOF_BLOCK_ROOT_OFFSET = SIGNED_AGGREGATE_AND_PROOF_SLOT_OFFSET + 8 + 8;
273
300
 
274
301
  /**
@@ -303,6 +330,19 @@ export function getBlockRootFromSignedAggregateAndProofSerialized(data: Uint8Arr
303
330
  return "0x" + blockRootBuf.toString("hex");
304
331
  }
305
332
 
333
+ /**
334
+ * Extract data index from signed aggregate and proof serialized bytes.
335
+ * Return null if data is not long enough to extract the index.
336
+ * This works for both phase0 + electra (index is in attestation data at the same offset).
337
+ */
338
+ export function getDataIndexFromSignedAggregateAndProofSerialized(data: Uint8Array): AttDataIndex | null {
339
+ if (data.length < SIGNED_AGGREGATE_AND_PROOF_ATTESTATION_DATA_INDEX_OFFSET + COMMITTEE_INDEX_SIZE) {
340
+ return null;
341
+ }
342
+
343
+ return getIndexFromOffset(data, SIGNED_AGGREGATE_AND_PROOF_ATTESTATION_DATA_INDEX_OFFSET);
344
+ }
345
+
306
346
  /**
307
347
  * Extract AttestationData base64 from SignedAggregateAndProof for electra
308
348
  * Return null if data is not long enough
@@ -369,6 +409,8 @@ export function getAttDataFromSignedAggregateAndProofPhase0(data: Uint8Array): A
369
409
  * ```
370
410
  */
371
411
  const SLOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK = VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE;
412
+ // proposer_index is ValidatorIndex = uint64 = 8 bytes
413
+ const PARENT_ROOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK = VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE + SLOT_SIZE + 8;
372
414
 
373
415
  export function getSlotFromSignedBeaconBlockSerialized(data: Uint8Array): Slot | null {
374
416
  if (data.length < SLOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK + SLOT_SIZE) {
@@ -378,6 +420,68 @@ export function getSlotFromSignedBeaconBlockSerialized(data: Uint8Array): Slot |
378
420
  return getSlotFromOffset(data, SLOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK);
379
421
  }
380
422
 
423
+ export function getParentRootFromSignedBeaconBlockSerialized(data: Uint8Array): RootHex | null {
424
+ if (data.length < PARENT_ROOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK + ROOT_SIZE) {
425
+ return null;
426
+ }
427
+ blockRootBuf.set(
428
+ data.subarray(
429
+ PARENT_ROOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK,
430
+ PARENT_ROOT_BYTES_POSITION_IN_SIGNED_BEACON_BLOCK + ROOT_SIZE
431
+ )
432
+ );
433
+ return `0x${blockRootBuf.toString("hex")}`;
434
+ }
435
+
436
+ /**
437
+ * Extract parentBlockHash from a GLOAS SignedBeaconBlock by navigating the SSZ offset pointer
438
+ * to the embedded SignedExecutionPayloadBid.
439
+ *
440
+ * Layout (bytes from start of SignedBeaconBlock):
441
+ * [0..4) message offset
442
+ * [4..100) signature (96 B)
443
+ * [100..184) BeaconBlock fixed section: slot(8)+proposer_index(8)+parent_root(32)+state_root(32)+body_offset(4)
444
+ * [184..) BeaconBlockBody
445
+ *
446
+ * BeaconBlockBody (GLOAS) fixed section before signedExecutionPayloadBid offset pointer:
447
+ * randaoReveal(96) + eth1Data(72) + graffiti(32)
448
+ * + proposerSlashings(4) + attesterSlashings(4) + attestations(4) + deposits(4) + voluntaryExits(4)
449
+ * + syncAggregate(160) + blsToExecutionChanges(4) = 384 bytes
450
+ *
451
+ * The 4-byte pointer at byte 568 (= 184+384) gives the offset of SignedExecutionPayloadBid
452
+ * within BeaconBlockBody. parentBlockHash is at that bid's byte 100 (after offset+sig).
453
+ */
454
+ // BeaconBlock body starts after: msg_offset(4) + sig(96) + slot(8) + proposer_index(8) + parent_root(32) + state_root(32) + body_offset_ptr(4)
455
+ const GLOAS_BODY_START_IN_SIGNED_BEACON_BLOCK =
456
+ VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE + SLOT_SIZE + 8 + ROOT_SIZE + ROOT_SIZE + VARIABLE_FIELD_OFFSET; // = 184
457
+ const GLOAS_SIGNED_BID_OFFSET_POINTER_IN_BODY = 96 + 72 + 32 + 4 + 4 + 4 + 4 + 4 + 160 + 4; // = 384
458
+ const GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK =
459
+ GLOAS_BODY_START_IN_SIGNED_BEACON_BLOCK + GLOAS_SIGNED_BID_OFFSET_POINTER_IN_BODY; // = 568
460
+ // Within SignedExecutionPayloadBid, parentBlockHash is at byte 100 (msg_offset:4 + sig:96)
461
+ const PARENT_BLOCK_HASH_OFFSET_IN_SIGNED_BID = VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE; // = 100
462
+
463
+ // CAUTION: update offsets if BeaconBlockBody fixed fields change after Gloas
464
+ export function getParentBlockHashFromGloasSignedBeaconBlockSerialized(data: Uint8Array): RootHex | null {
465
+ if (data.length < GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK + VARIABLE_FIELD_OFFSET) {
466
+ return null;
467
+ }
468
+ const bidOffset =
469
+ data[GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK] |
470
+ (data[GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK + 1] << 8) |
471
+ (data[GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK + 2] << 16) |
472
+ (data[GLOAS_SIGNED_BID_OFFSET_POINTER_IN_SIGNED_BEACON_BLOCK + 3] << 24);
473
+
474
+ const parentBlockHashStart =
475
+ GLOAS_BODY_START_IN_SIGNED_BEACON_BLOCK + bidOffset + PARENT_BLOCK_HASH_OFFSET_IN_SIGNED_BID;
476
+
477
+ if (data.length < parentBlockHashStart + ROOT_SIZE) {
478
+ return null;
479
+ }
480
+
481
+ blockRootBuf.set(data.subarray(parentBlockHashStart, parentBlockHashStart + ROOT_SIZE));
482
+ return `0x${blockRootBuf.toString("hex")}`;
483
+ }
484
+
381
485
  /**
382
486
  * class BlobSidecar(Container):
383
487
  * index: BlobIndex [fixed - 8 bytes ],
@@ -527,6 +631,104 @@ export function getSlotFromBeaconStateSerialized(data: Uint8Array): Slot | null
527
631
  return getSlotFromOffset(data, SLOT_BYTES_POSITION_IN_BEACON_STATE);
528
632
  }
529
633
 
634
+ /**
635
+ * PayloadAttestationMessage: {
636
+ * validatorIndex: ValidatorIndex (8 bytes)
637
+ * data: PayloadAttestationData {
638
+ * beaconBlockRoot: Root (32 bytes) ← offset 8
639
+ * slot: Slot (8 bytes) ← offset 40
640
+ * payloadPresent: Boolean (1 byte)
641
+ * blobDataAvailable: Boolean (1 byte)
642
+ * }
643
+ * signature: BLSSignature (96 bytes)
644
+ * }
645
+ * Fully fixed-size container, no offset table.
646
+ */
647
+ const PAYLOAD_ATTESTATION_MESSAGE_BEACON_BLOCK_ROOT_OFFSET = 8;
648
+ const PAYLOAD_ATTESTATION_MESSAGE_SLOT_OFFSET = 8 + ROOT_SIZE; // 40
649
+ const PAYLOAD_ATTESTATION_MESSAGE_PAYLOAD_PRESENT_OFFSET = PAYLOAD_ATTESTATION_MESSAGE_SLOT_OFFSET + SLOT_SIZE; // 48
650
+
651
+ export function getSlotFromPayloadAttestationMessageSerialized(data: Uint8Array): Slot | null {
652
+ if (data.length < PAYLOAD_ATTESTATION_MESSAGE_SLOT_OFFSET + SLOT_SIZE) {
653
+ return null;
654
+ }
655
+ return getSlotFromOffset(data, PAYLOAD_ATTESTATION_MESSAGE_SLOT_OFFSET);
656
+ }
657
+
658
+ export function getPayloadPresentFromPayloadAttestationMessageSerialized(data: Uint8Array): boolean | null {
659
+ if (data.length < PAYLOAD_ATTESTATION_MESSAGE_PAYLOAD_PRESENT_OFFSET + 1) {
660
+ return null;
661
+ }
662
+ return data[PAYLOAD_ATTESTATION_MESSAGE_PAYLOAD_PRESENT_OFFSET] !== 0;
663
+ }
664
+
665
+ export function getBlockRootFromPayloadAttestationMessageSerialized(data: Uint8Array): RootHex | null {
666
+ if (data.length < PAYLOAD_ATTESTATION_MESSAGE_BEACON_BLOCK_ROOT_OFFSET + ROOT_SIZE) {
667
+ return null;
668
+ }
669
+ blockRootBuf.set(
670
+ data.subarray(
671
+ PAYLOAD_ATTESTATION_MESSAGE_BEACON_BLOCK_ROOT_OFFSET,
672
+ PAYLOAD_ATTESTATION_MESSAGE_BEACON_BLOCK_ROOT_OFFSET + ROOT_SIZE
673
+ )
674
+ );
675
+ return `0x${blockRootBuf.toString("hex")}`;
676
+ }
677
+
678
+ /**
679
+ * SignedExecutionPayloadBid: {message: ExecutionPayloadBid (variable), signature: BLSSignature (96 bytes)}
680
+ * Fixed part: 4-byte offset + 96-byte signature = 100 bytes
681
+ * message data starts at byte 100
682
+ *
683
+ * ExecutionPayloadBid fixed fields (in order):
684
+ * parentBlockHash: Bytes32 (32 bytes)
685
+ * parentBlockRoot: Root (32 bytes)
686
+ * blockHash: Bytes32 (32 bytes)
687
+ * prevRandao: Bytes32 (32 bytes)
688
+ * feeRecipient: ExecutionAddress(20 bytes)
689
+ * gasLimit: UintBn64 (8 bytes)
690
+ * builderIndex: BuilderIndex (8 bytes)
691
+ * slot: Slot (8 bytes) ← absolute offset 264
692
+ */
693
+ const SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_HASH_OFFSET = VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE; // 100
694
+ const SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_ROOT_OFFSET =
695
+ SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_HASH_OFFSET + ROOT_SIZE; // 132
696
+ const SIGNED_EXECUTION_PAYLOAD_BID_SLOT_OFFSET =
697
+ VARIABLE_FIELD_OFFSET + SIGNATURE_SIZE + 32 + 32 + 32 + 32 + 20 + 8 + 8; // 264
698
+
699
+ export function getSlotFromSignedExecutionPayloadBidSerialized(data: Uint8Array): Slot | null {
700
+ if (data.length < SIGNED_EXECUTION_PAYLOAD_BID_SLOT_OFFSET + SLOT_SIZE) {
701
+ return null;
702
+ }
703
+ return getSlotFromOffset(data, SIGNED_EXECUTION_PAYLOAD_BID_SLOT_OFFSET);
704
+ }
705
+
706
+ export function getParentBlockHashFromSignedExecutionPayloadBidSerialized(data: Uint8Array): RootHex | null {
707
+ if (data.length < SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_HASH_OFFSET + ROOT_SIZE) {
708
+ return null;
709
+ }
710
+ blockRootBuf.set(
711
+ data.subarray(
712
+ SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_HASH_OFFSET,
713
+ SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_HASH_OFFSET + ROOT_SIZE
714
+ )
715
+ );
716
+ return `0x${blockRootBuf.toString("hex")}`;
717
+ }
718
+
719
+ export function getParentBlockRootFromSignedExecutionPayloadBidSerialized(data: Uint8Array): RootHex | null {
720
+ if (data.length < SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_ROOT_OFFSET + ROOT_SIZE) {
721
+ return null;
722
+ }
723
+ blockRootBuf.set(
724
+ data.subarray(
725
+ SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_ROOT_OFFSET,
726
+ SIGNED_EXECUTION_PAYLOAD_BID_PARENT_BLOCK_ROOT_OFFSET + ROOT_SIZE
727
+ )
728
+ );
729
+ return `0x${blockRootBuf.toString("hex")}`;
730
+ }
731
+
530
732
  /**
531
733
  * Read only the first 4 bytes of Slot, max value is 4,294,967,295 will be reached 1634 years after genesis
532
734
  *
@@ -562,9 +764,49 @@ export function getBlobKzgCommitmentsCountFromSignedBeaconBlockSerialized(
562
764
  if (slot === null) throw new Error("Can not parse the slot from block bytes");
563
765
 
564
766
  if (config.getForkSeq(slot) < ForkSeq.deneb) return 0;
767
+ const forkName = config.getForkName(slot);
768
+
769
+ if (isForkPostGloas(forkName)) {
770
+ // Gloas stores commitments under signedExecutionPayloadBid.message.blobKzgCommitments.
771
+ // Navigate the offset chain: SignedBeaconBlock → message → body → signedExecutionPayloadBid → message → blobKzgCommitments
772
+ const {SignedBeaconBlock: GloasSignedBlock, BeaconBlock: GloasBlock, BeaconBlockBody: GloasBody} = ssz[forkName];
773
+ const {SignedExecutionPayloadBid, ExecutionPayloadBid} = ssz[forkName];
774
+ const commitmentSize = ssz.deneb.KZGCommitment.fixedSize;
775
+
776
+ const view = new DataView(blockBytes.buffer, blockBytes.byteOffset, blockBytes.byteLength);
777
+
778
+ const signedBlockRanges = GloasSignedBlock.getFieldRanges(view, 0, blockBytes.length);
779
+ const messageIdx = Object.keys(GloasSignedBlock.fields).indexOf("message");
780
+ const messageRange = signedBlockRanges[messageIdx];
781
+
782
+ const blockRanges = GloasBlock.getFieldRanges(view, messageRange.start, messageRange.end);
783
+ const bodyIdx = Object.keys(GloasBlock.fields).indexOf("body");
784
+ const bodyRange = blockRanges[bodyIdx];
785
+ const bodyStart = messageRange.start + bodyRange.start;
786
+ const bodyEnd = messageRange.start + bodyRange.end;
787
+
788
+ const bodyRanges = GloasBody.getFieldRanges(view, bodyStart, bodyEnd);
789
+ const bidIdx = Object.keys(GloasBody.fields).indexOf("signedExecutionPayloadBid");
790
+ const bidRange = bodyRanges[bidIdx];
791
+ const bidStart = bodyStart + bidRange.start;
792
+ const bidEnd = bodyStart + bidRange.end;
793
+
794
+ const bidRanges = SignedExecutionPayloadBid.getFieldRanges(view, bidStart, bidEnd);
795
+ const bidMsgIdx = Object.keys(SignedExecutionPayloadBid.fields).indexOf("message");
796
+ const bidMsgRange = bidRanges[bidMsgIdx];
797
+ const bidMsgStart = bidStart + bidMsgRange.start;
798
+ const bidMsgEnd = bidStart + bidMsgRange.end;
799
+
800
+ const execBidRanges = ExecutionPayloadBid.getFieldRanges(view, bidMsgStart, bidMsgEnd);
801
+ const commitmentsIdx = Object.keys(ExecutionPayloadBid.fields).indexOf("blobKzgCommitments");
802
+ const commitmentsRange = execBidRanges[commitmentsIdx];
803
+
804
+ const start = bidMsgStart + commitmentsRange.start;
805
+ const end = bidMsgStart + commitmentsRange.end;
806
+ return Math.round(((end > blockBytes.byteLength ? blockBytes.byteLength : end) - start) / commitmentSize);
807
+ }
565
808
 
566
- const {SignedBeaconBlock, BeaconBlock, BeaconBlockBody, KZGCommitment} =
567
- ssz[config.getForkName(slot) as ForkPostDeneb];
809
+ const {SignedBeaconBlock, BeaconBlock, BeaconBlockBody, KZGCommitment} = ssz[forkName as ForkPostDeneb];
568
810
 
569
811
  const view = new DataView(blockBytes.buffer, blockBytes.byteOffset, blockBytes.byteLength);
570
812
  const singedBlockFieldRanges = SignedBeaconBlock.getFieldRanges(view, 0, blockBytes.length);