Skip to content

Commit

Permalink
refactor attestation filtering
Browse files Browse the repository at this point in the history
  • Loading branch information
mehdi-aouadi committed Jul 25, 2024
1 parent 4883f6a commit 028fca4
Show file tree
Hide file tree
Showing 2 changed files with 26 additions and 18 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -276,7 +276,7 @@ public synchronized List<Attestation> getAttestations(
final UInt64 slot = maybeSlot.orElse(recentChainData.getCurrentSlot().orElse(UInt64.ZERO));
final SchemaDefinitions schemaDefinitions = spec.atSlot(slot).getSchemaDefinitions();

final boolean requestRequiresAttestationWithCommitteeBits =
final boolean requiresCommitteeBits =
schemaDefinitions.getAttestationSchema().requiresCommitteeBits();

return dataHashBySlot.descendingMap().entrySet().stream()
Expand All @@ -287,11 +287,8 @@ public synchronized List<Attestation> getAttestations(
.filter(Objects::nonNull)
.flatMap(
matchingDataAttestationGroup ->
matchingDataAttestationGroup.stream(maybeCommitteeIndex))
matchingDataAttestationGroup.stream(maybeCommitteeIndex, requiresCommitteeBits))
.map(ValidatableAttestation::getAttestation)
.filter(
attestation ->
attestation.requiresCommitteeBits() == requestRequiresAttestationWithCommitteeBits)
.toList();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -147,6 +147,22 @@ public Stream<ValidatableAttestation> stream(final Optional<UInt64> committeeInd
return StreamSupport.stream(spliterator(committeeIndex), false);
}

public Stream<ValidatableAttestation> stream(
final Optional<UInt64> committeeIndex, final boolean requiresCommitteeBits) {
// Group Attestation type mismatch
if (requiresCommitteeBits != includedValidators.requiresCommitteeBits()) {
return Stream.empty();
}
// Pre electra attestation and committee index not matching
if (committeeIndex.isPresent()
&& !includedValidators.requiresCommitteeBits()
&& !attestationData.getIndex().equals(committeeIndex.get())) {
return Stream.empty();
}
// Filter based on the committee index
return StreamSupport.stream(spliterator(committeeIndex), false);
}

public Spliterator<ValidatableAttestation> spliterator(final Optional<UInt64> committeeIndex) {
return Spliterators.spliteratorUnknownSize(iterator(committeeIndex), 0);
}
Expand Down Expand Up @@ -271,22 +287,17 @@ public Iterator<ValidatableAttestation> getRemainingAttestations() {
}

private boolean maybeFilterOnCommitteeIndex(final ValidatableAttestation candidate) {
final Attestation attestation = candidate.getAttestation();
final Optional<SszBitvector> maybeCommitteeBits = attestation.getCommitteeBits();
if (maybeCommitteeIndex.isEmpty()) {
final Optional<SszBitvector> maybeCommitteeBits =
candidate.getAttestation().getCommitteeBits();
if (maybeCommitteeBits.isEmpty() || maybeCommitteeIndex.isEmpty()) {
return true;
}
// Pre Electra attestation, filter based on the attestation data index
if (maybeCommitteeBits.isEmpty()) {
return attestation.getData().getIndex().equals(maybeCommitteeIndex.get());
} else {
// Post Electra attestation, filter on committee bits
final SszBitvector committeeBits = maybeCommitteeBits.get();
if (committeeBits.getBitCount() != 1) {
return false;
}
return committeeBits.isSet(maybeCommitteeIndex.get().intValue());

final SszBitvector committeeBits = maybeCommitteeBits.get();
if (committeeBits.getBitCount() != 1) {
return false;
}
return committeeBits.isSet(maybeCommitteeIndex.get().intValue());
}
}
}

0 comments on commit 028fca4

Please sign in to comment.