2024-08-22 08:04:03 +02:00
|
|
|
# beacon_chain
|
|
|
|
# Copyright (c) 2024 Status Research & Development GmbH
|
|
|
|
# Licensed and distributed under either of
|
|
|
|
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
|
|
|
|
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
|
|
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
|
|
|
|
{.push raises: [].}
|
|
|
|
|
|
|
|
import
|
|
|
|
std/typetraits,
|
|
|
|
eth/common/eth_types_rlp,
|
|
|
|
"."/[helpers, state_transition_block]
|
|
|
|
|
|
|
|
func readExecutionTransaction(
|
2024-10-14 16:55:56 +02:00
|
|
|
txBytes: bellatrix.Transaction): Result[EthTransaction, string] =
|
2024-08-22 08:04:03 +02:00
|
|
|
try:
|
2024-10-14 16:55:56 +02:00
|
|
|
ok rlp.decode(distinctBase(txBytes), EthTransaction)
|
2024-08-22 08:04:03 +02:00
|
|
|
except RlpError as exc:
|
|
|
|
err("Invalid transaction: " & exc.msg)
|
|
|
|
|
|
|
|
# https://github.com/ethereum/consensus-specs/blob/v1.5.0-alpha.4/specs/deneb/beacon-chain.md#is_valid_versioned_hashes
|
|
|
|
func is_valid_versioned_hashes*(blck: ForkyBeaconBlock): Result[void, string] =
|
|
|
|
static: doAssert typeof(blck).kind >= ConsensusFork.Deneb
|
|
|
|
template transactions: untyped = blck.body.execution_payload.transactions
|
|
|
|
template commitments: untyped = blck.body.blob_kzg_commitments
|
|
|
|
|
|
|
|
var i = 0
|
|
|
|
for txBytes in transactions:
|
2024-09-01 15:58:19 +02:00
|
|
|
when typeof(blck).kind >= ConsensusFork.Electra:
|
|
|
|
if txBytes.payload.blob_versioned_hashes.isNone:
|
|
|
|
continue
|
|
|
|
template hashes: untyped = txBytes.payload.blob_versioned_hashes.unsafeGet
|
|
|
|
else:
|
|
|
|
if txBytes.len == 0 or txBytes[0] != TxEip4844.byte:
|
|
|
|
continue # Only blob transactions may have blobs
|
|
|
|
let tx = ? txBytes.readExecutionTransaction()
|
|
|
|
template hashes: untyped = tx.versionedHashes
|
|
|
|
for vHash in hashes:
|
2024-08-22 08:04:03 +02:00
|
|
|
if commitments.len <= i:
|
|
|
|
return err("Extra blobs without matching `blob_kzg_commitments`")
|
2024-09-01 15:58:19 +02:00
|
|
|
when typeof(blck).kind >= ConsensusFork.Electra:
|
|
|
|
template hash: untyped = vHash
|
|
|
|
else:
|
|
|
|
template hash: untyped = vHash.data
|
|
|
|
if hash != kzg_commitment_to_versioned_hash(commitments[i]):
|
2024-08-22 08:04:03 +02:00
|
|
|
return err("Invalid `blob_versioned_hash` at index " & $i)
|
|
|
|
inc i
|
|
|
|
if i != commitments.len:
|
|
|
|
return err("Extra `blob_kzg_commitments` without matching blobs")
|
|
|
|
ok()
|