fix Electra aggregated attestation gossip verification committee index (#6800)

This commit is contained in:
tersec 2024-12-29 15:12:43 +00:00 committed by GitHub
parent c0108c2f2a
commit 177897929b
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
8 changed files with 34 additions and 25 deletions

View File

@ -93,8 +93,7 @@ func peekColumnIndices*(quarantine: DataColumnQuarantine,
func gatherDataColumns*(quarantine: DataColumnQuarantine, func gatherDataColumns*(quarantine: DataColumnQuarantine,
digest: Eth2Digest): digest: Eth2Digest):
seq[ref DataColumnSidecar] = seq[ref DataColumnSidecar] =
# Returns the current data columns quried by a # Returns the current data columns queried by a block header
# block header
var columns: seq[ref DataColumnSidecar] var columns: seq[ref DataColumnSidecar]
for i in quarantine.custody_columns: for i in quarantine.custody_columns:
let dc_identifier = let dc_identifier =

View File

@ -592,7 +592,7 @@ func propagateInvalidity*(
if parentPhysicalIdx < 0 or parentPhysicalIdx >= self.nodes.len: if parentPhysicalIdx < 0 or parentPhysicalIdx >= self.nodes.len:
continue continue
# Invalidity transmits to all descendents # Invalidity transmits to all descendants
if self.nodes.buf[parentPhysicalIdx].invalid: if self.nodes.buf[parentPhysicalIdx].invalid:
self.nodes.buf[nodePhysicalIdx].invalid = true self.nodes.buf[nodePhysicalIdx].invalid = true

View File

@ -351,7 +351,7 @@ proc getExecutionValidity(
of PayloadExecutionStatus.invalid, of PayloadExecutionStatus.invalid,
PayloadExecutionStatus.invalid_block_hash: PayloadExecutionStatus.invalid_block_hash:
# Blocks come either from gossip or request manager requests. In the # Blocks come either from gossip or request manager requests. In the
# former case, they've passed libp2p gosisp validation which implies # former case, they've passed libp2p gossip validation which implies
# correct signature for correct proposer,which makes spam expensive, # correct signature for correct proposer,which makes spam expensive,
# while for the latter, spam is limited by the request manager. # while for the latter, spam is limited by the request manager.
info "execution payload invalid from EL client newPayload", info "execution payload invalid from EL client newPayload",

View File

@ -1113,7 +1113,7 @@ proc validateAttestation*(
# [REJECT] The committee index is within the expected range -- i.e. # [REJECT] The committee index is within the expected range -- i.e.
# data.index < get_committee_count_per_slot(state, data.target.epoch). # data.index < get_committee_count_per_slot(state, data.target.epoch).
let committee_index = block: let committee_index = block:
let idx = shufflingRef.get_committee_index(attestation.data.index) let idx = shufflingRef.get_committee_index(attestation.committee_index)
if idx.isErr(): if idx.isErr():
return pool.checkedReject( return pool.checkedReject(
"Attestation: committee index not within expected range") "Attestation: committee index not within expected range")
@ -1231,7 +1231,12 @@ proc validateAggregate*(
# [REJECT] The committee index is within the expected range -- i.e. # [REJECT] The committee index is within the expected range -- i.e.
# data.index < get_committee_count_per_slot(state, data.target.epoch). # data.index < get_committee_count_per_slot(state, data.target.epoch).
let committee_index = block: let committee_index = block:
when signedAggregateAndProof is electra.SignedAggregateAndProof:
let idx = get_committee_index_one(aggregate.committee_bits)
elif signedAggregateAndProof is phase0.SignedAggregateAndProof:
let idx = shufflingRef.get_committee_index(aggregate.data.index) let idx = shufflingRef.get_committee_index(aggregate.data.index)
else:
static: doAssert false
if idx.isErr(): if idx.isErr():
return pool.checkedReject( return pool.checkedReject(
"Attestation: committee index not within expected range") "Attestation: committee index not within expected range")

View File

@ -960,7 +960,7 @@ proc readResponse(conn: Connection, peer: Peer,
var results: MsgType var results: MsgType
while true: while true:
# Because we interleave networking with response processing, it may # Because we interleave networking with response processing, it may
# happen that reading all chunks takes longer than a strict dealine # happen that reading all chunks takes longer than a strict deadline
# timeout would allow, so we allow each chunk a new timeout instead. # timeout would allow, so we allow each chunk a new timeout instead.
# The problem is exacerbated by the large number of round-trips to the # The problem is exacerbated by the large number of round-trips to the
# poll loop that each future along the way causes. # poll loop that each future along the way causes.

View File

@ -15,7 +15,7 @@ See the [execution client comparison](https://ethereum.org/en/developers/docs/no
### 1. Install execution client ### 1. Install execution client
Select an execution client and install it, configuring it such that that the authenticated JSON-RPC interface is enabled and a JWT secret file is created. Select an execution client and install it, configuring it such that the authenticated JSON-RPC interface is enabled and a JWT secret file is created.
=== "Nimbus" === "Nimbus"

View File

@ -258,7 +258,7 @@ func `as`(blk: BlockObject, T: type bellatrix.ExecutionPayloadHeader): T =
state_root: blk.stateRoot as Eth2Digest, state_root: blk.stateRoot as Eth2Digest,
receipts_root: blk.receiptsRoot as Eth2Digest, receipts_root: blk.receiptsRoot as Eth2Digest,
logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)), logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)),
prev_randao: Eth2Digest(data: blk.difficulty.toByteArrayBE), # Is BE correct here? prev_randao: Eth2Digest(data: blk.difficulty.toBytesBE), # Is BE correct here?
block_number: uint64 blk.number, block_number: uint64 blk.number,
gas_limit: uint64 blk.gasLimit, gas_limit: uint64 blk.gasLimit,
gas_used: uint64 blk.gasUsed, gas_used: uint64 blk.gasUsed,
@ -274,7 +274,7 @@ func `as`(blk: BlockObject, T: type capella.ExecutionPayloadHeader): T =
state_root: blk.stateRoot as Eth2Digest, state_root: blk.stateRoot as Eth2Digest,
receipts_root: blk.receiptsRoot as Eth2Digest, receipts_root: blk.receiptsRoot as Eth2Digest,
logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)), logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)),
prev_randao: Eth2Digest(data: blk.difficulty.toByteArrayBE), prev_randao: Eth2Digest(data: blk.difficulty.toBytesBE),
block_number: uint64 blk.number, block_number: uint64 blk.number,
gas_limit: uint64 blk.gasLimit, gas_limit: uint64 blk.gasLimit,
gas_used: uint64 blk.gasUsed, gas_used: uint64 blk.gasUsed,
@ -291,7 +291,7 @@ func `as`(blk: BlockObject, T: type deneb.ExecutionPayloadHeader): T =
state_root: blk.stateRoot as Eth2Digest, state_root: blk.stateRoot as Eth2Digest,
receipts_root: blk.receiptsRoot as Eth2Digest, receipts_root: blk.receiptsRoot as Eth2Digest,
logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)), logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)),
prev_randao: Eth2Digest(data: blk.difficulty.toByteArrayBE), prev_randao: Eth2Digest(data: blk.difficulty.toBytesBE),
block_number: uint64 blk.number, block_number: uint64 blk.number,
gas_limit: uint64 blk.gasLimit, gas_limit: uint64 blk.gasLimit,
gas_used: uint64 blk.gasUsed, gas_used: uint64 blk.gasUsed,
@ -310,7 +310,7 @@ func `as`(blk: BlockObject, T: type electra.ExecutionPayloadHeader): T =
state_root: blk.stateRoot as Eth2Digest, state_root: blk.stateRoot as Eth2Digest,
receipts_root: blk.receiptsRoot as Eth2Digest, receipts_root: blk.receiptsRoot as Eth2Digest,
logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)), logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)),
prev_randao: Eth2Digest(data: blk.difficulty.toByteArrayBE), prev_randao: Eth2Digest(data: blk.difficulty.toBytesBE),
block_number: uint64 blk.number, block_number: uint64 blk.number,
gas_limit: uint64 blk.gasLimit, gas_limit: uint64 blk.gasLimit,
gas_used: uint64 blk.gasUsed, gas_used: uint64 blk.gasUsed,
@ -329,7 +329,7 @@ func `as`(blk: BlockObject, T: type fulu.ExecutionPayloadHeader): T =
state_root: blk.stateRoot as Eth2Digest, state_root: blk.stateRoot as Eth2Digest,
receipts_root: blk.receiptsRoot as Eth2Digest, receipts_root: blk.receiptsRoot as Eth2Digest,
logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)), logs_bloom: BloomLogs(data: distinctBase(blk.logsBloom)),
prev_randao: Eth2Digest(data: blk.difficulty.toByteArrayBE), prev_randao: Eth2Digest(data: blk.difficulty.toBytesBE),
block_number: uint64 blk.number, block_number: uint64 blk.number,
gas_limit: uint64 blk.gasLimit, gas_limit: uint64 blk.gasLimit,
gas_used: uint64 blk.gasUsed, gas_used: uint64 blk.gasUsed,

View File

@ -5,6 +5,8 @@
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0). # * 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. # at your option. This file may not be copied, modified, or distributed except according to those terms.
{.push raises: [].}
import import
std/[strutils, os, options, uri, json, tables], std/[strutils, os, options, uri, json, tables],
results, results,
@ -1031,7 +1033,7 @@ proc workerLoop(address: TransportAddress, uri: Uri, worker: int,
worker = worker worker = worker
return return
except CatchableError as exc: except CatchableError as exc:
warn "Unexpected exception while running test test run", host = hostname, warn "Unexpected exception while running test run", host = hostname,
error_name = exc.name, error_msg = exc.msg, index = index, error_name = exc.name, error_msg = exc.msg, index = index,
worker = worker worker = worker
return return
@ -1156,6 +1158,9 @@ proc run(conf: RestTesterConf): int =
waitFor(checkConnection(conf, uri)) waitFor(checkConnection(conf, uri))
except ConnectionError: except ConnectionError:
return 1 return 1
except CatchableError as exc:
fatal "Unexpected test failure", error_name = exc.name, error_msg = exc.msg
return 1
try: try:
return waitFor(startTests(conf, uri, jnodes)) return waitFor(startTests(conf, uri, jnodes))