diff --git a/beacon_chain/spec/eth2_apis/rest_types.nim b/beacon_chain/spec/eth2_apis/rest_types.nim index 2691b063b7..2a548266bb 100644 --- a/beacon_chain/spec/eth2_apis/rest_types.nim +++ b/beacon_chain/spec/eth2_apis/rest_types.nim @@ -45,6 +45,9 @@ const const preferSSZ* = "application/octet-stream,application/json;q=0.9" + LowestScoreAggregatedAttestation* = + phase0.Attestation( + aggregation_bits: CommitteeValidatorsBits(BitSeq.init(1))) static: doAssert(ClientMaximumValidatorIds <= ServerMaximumValidatorIds) @@ -615,6 +618,10 @@ type fork_choice_nodes*: seq[RestNode] extra_data*: RestExtraData +func isLowestScoreAggregatedAttestation*(a: phase0.Attestation): bool = + (a.data.slot == Slot(0)) and (a.data.index == 0'u64) and + (a.data.source.epoch == Epoch(0)) and (a.data.target.epoch == Epoch(0)) + func `==`*(a, b: RestValidatorIndex): bool = uint64(a) == uint64(b) diff --git a/beacon_chain/validator_client/api.nim b/beacon_chain/validator_client/api.nim index c27e492171..73bc18478f 100644 --- a/beacon_chain/validator_client/api.nim +++ b/beacon_chain/validator_client/api.nim @@ -1708,6 +1708,13 @@ proc getAggregatedAttestation*( handle400() ApiResponse[GetAggregatedAttestationResponse].err( ResponseInvalidError) + of 404: + # A 404 error must be returned if no attestation is available for the + # requested `attestation_data_root`. To address the issue #6184, we + # use empty GetAggregatedAttestationResponse. + ApiResponse[GetAggregatedAttestationResponse].ok( + GetAggregatedAttestationResponse( + data: LowestScoreAggregatedAttestation)) of 500: handle500() ApiResponse[GetAggregatedAttestationResponse].err( diff --git a/beacon_chain/validator_client/attestation_service.nim b/beacon_chain/validator_client/attestation_service.nim index 4181a8dd03..1cfd587c73 100644 --- a/beacon_chain/validator_client/attestation_service.nim +++ b/beacon_chain/validator_client/attestation_service.nim @@ -296,6 +296,12 @@ proc produceAndPublishAggregates(service: AttestationServiceRef, err_name = exc.name, err_msg = exc.msg return + if isLowestScoreAggregatedAttestation(aggAttestation): + warn "Aggregated attestation with the root was not seen by the " & + "beacon node", + attestation_root = shortLog(attestationRoot) + return + let pendingAggregates = block: var res: seq[Future[bool]] diff --git a/tests/test_validator_client.nim b/tests/test_validator_client.nim index fea8e5808d..bbc5553ab9 100644 --- a/tests/test_validator_client.nim +++ b/tests/test_validator_client.nim @@ -746,6 +746,15 @@ suite "Validator Client test suite": score = shortScore(getAggregatedAttestationDataScore(adata)) check score == vector[1] + test "getAggregatedAttestationDataScore() default test": + let + adata = GetAggregatedAttestationResponse( + data: LowestScoreAggregatedAttestation) + score = shortScore(getAggregatedAttestationDataScore(adata)) + check: + score == "0.0000" + isLowestScoreAggregatedAttestation(adata.data) == true + test "getSyncCommitteeContributionDataScore() test vectors": for vector in ContributionDataVectors: let @@ -905,4 +914,4 @@ suite "Validator Client test suite": res.isOk() len(res.get().data) == 1 res.get().data[0].index == 100000 - res.get().data[0].is_live == true \ No newline at end of file + res.get().data[0].is_live == true