From ca1f0c0a834883086adfba7b3b6e0c0fa567610d Mon Sep 17 00:00:00 2001 From: Povilas Liubauskas Date: Mon, 4 Nov 2024 12:36:09 +0200 Subject: [PATCH] Fix aggregate and proof aggregator not in committee validation bug for post-Electra aggregates --- fork_choice_store/src/store.rs | 22 +++++++++++++++++++--- 1 file changed, 19 insertions(+), 3 deletions(-) diff --git a/fork_choice_store/src/store.rs b/fork_choice_store/src/store.rs index 244e2f0d..7681ab81 100644 --- a/fork_choice_store/src/store.rs +++ b/fork_choice_store/src/store.rs @@ -1275,14 +1275,30 @@ impl Store

{ }, ); - let committee = accessors::beacon_committee(&target_state, slot, index)?; + let committee = if let Some(committee_bits) = aggregate.committee_bits() { + let committee_indices = misc::get_committee_indices::

(*committee_bits); + + let mut committees = vec![]; + + for committee_index in committee_indices { + let committee = accessors::beacon_committee(&target_state, slot, committee_index)?; + + committees.extend(committee); + } + + committees.into() + } else { + accessors::beacon_committee(&target_state, slot, index)? + .into_iter() + .collect::>() + }; // > The aggregator's validator index is within the committee ensure!( - committee.into_iter().contains(&aggregator_index), + committee.contains(&aggregator_index), Error::AggregatorNotInCommittee { aggregate_and_proof, - committee: committee.into_iter().collect(), + committee, }, );