Skip to content

Commit

Permalink
Electra attestation changes from Lions review (sigp#5971)
Browse files Browse the repository at this point in the history
* dedup/cleanup and remove unneeded hashset use

* remove irrelevant TODOs
  • Loading branch information
eserilev authored and realbigsean committed Jun 25, 2024
1 parent 6a47ab8 commit d8e2a85
Show file tree
Hide file tree
Showing 5 changed files with 11 additions and 27 deletions.
3 changes: 1 addition & 2 deletions beacon_node/beacon_chain/src/attestation_verification.rs
Original file line number Diff line number Diff line change
Expand Up @@ -1397,8 +1397,7 @@ pub fn obtain_indexed_attestation_and_committees_per_slot<T: BeaconChainTypes>(
attesting_indices_electra::get_indexed_attestation(&committees, att)
.map(|attestation| (attestation, committees_per_slot))
.map_err(|e| {
let index = att.committee_index().unwrap_or(0);
if e == BlockOperationError::BeaconStateError(NoCommitteeFound(index)) {
if let BlockOperationError::BeaconStateError(NoCommitteeFound(index)) = e {
Error::NoCommitteeForSlotAndIndex {
slot: att.data.slot,
index: att.committee_index(),
Expand Down
22 changes: 6 additions & 16 deletions beacon_node/beacon_chain/src/naive_aggregation_pool.rs
Original file line number Diff line number Diff line change
Expand Up @@ -134,22 +134,12 @@ impl<E: EthSpec> AggregateMap for AggregatedAttestationMap<E> {
fn insert(&mut self, a: AttestationRef<E>) -> Result<InsertOutcome, Error> {
let _timer = metrics::start_timer(&metrics::ATTESTATION_PROCESSING_AGG_POOL_CORE_INSERT);

let set_bits = match a {
AttestationRef::Base(att) => att
.aggregation_bits
.iter()
.enumerate()
.filter(|(_i, bit)| *bit)
.map(|(i, _bit)| i)
.collect::<Vec<_>>(),
AttestationRef::Electra(att) => att
.aggregation_bits
.iter()
.enumerate()
.filter(|(_i, bit)| *bit)
.map(|(i, _bit)| i)
.collect::<Vec<_>>(),
};
let aggregation_bit = *a
.set_aggregation_bits()
.iter()
.at_most_one()
.map_err(|iter| Error::MoreThanOneAggregationBitSet(iter.count()))?
.ok_or(Error::NoAggregationBitsSet)?;

let attestation_key = AttestationKey::from_attestation_ref(a)?;
let attestation_key_root = attestation_key.tree_hash_root();
Expand Down
1 change: 0 additions & 1 deletion beacon_node/beacon_chain/tests/attestation_verification.rs
Original file line number Diff line number Diff line change
Expand Up @@ -233,7 +233,6 @@ fn get_non_aggregator<T: BeaconChainTypes>(
let state = &head.beacon_state;
let current_slot = chain.slot().expect("should get slot");

// TODO(electra) make fork-agnostic
let committee = state
.get_beacon_committee(
current_slot,
Expand Down
11 changes: 4 additions & 7 deletions consensus/state_processing/src/common/get_attesting_indices.rs
Original file line number Diff line number Diff line change
Expand Up @@ -47,7 +47,6 @@ pub mod attesting_indices_electra {
use std::collections::HashSet;

use crate::per_block_processing::errors::{AttestationInvalid as Invalid, BlockOperationError};
use itertools::Itertools;
use safe_arith::SafeArith;
use types::*;

Expand Down Expand Up @@ -96,7 +95,7 @@ pub mod attesting_indices_electra {
aggregation_bits: &BitList<E::MaxValidatorsPerSlot>,
committee_bits: &BitVector<E::MaxCommitteesPerSlot>,
) -> Result<Vec<u64>, BeaconStateError> {
let mut output: HashSet<u64> = HashSet::new();
let mut attesting_indices = vec![];

let committee_indices = get_committee_indices::<E>(committee_bits);

Expand Down Expand Up @@ -128,18 +127,16 @@ pub mod attesting_indices_electra {
})
.collect::<HashSet<u64>>();

output.extend(committee_attesters);

attesting_indices.extend(committee_attesters);
committee_offset.safe_add_assign(beacon_committee.committee.len())?;
}

// TODO(electra) what should we do when theres no committee found for a given index?
}

let mut indices = output.into_iter().collect_vec();
indices.sort_unstable();
attesting_indices.sort_unstable();

Ok(indices)
Ok(attesting_indices)
}

pub fn get_committee_indices<E: EthSpec>(
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -326,7 +326,6 @@ where
genesis_validators_root,
);

// TODO(electra), signing root isnt unique in the case of electra
let message = indexed_attestation.data().signing_root(domain);

Ok(SignatureSet::multiple_pubkeys(signature, pubkeys, message))
Expand Down

0 comments on commit d8e2a85

Please sign in to comment.