From be5661eebc348604e14b56b1e04a3a558a6c501c Mon Sep 17 00:00:00 2001 From: cheatfate Date: Thu, 20 May 2021 21:43:42 +0300 Subject: [PATCH] Fix /api/eth/v1/validator/aggregate_and_proofs call --- beacon_chain/rpc/validator_rest_api.nim | 24 +++++++++++++----------- 1 file changed, 13 insertions(+), 11 deletions(-) diff --git a/beacon_chain/rpc/validator_rest_api.nim b/beacon_chain/rpc/validator_rest_api.nim index 6511e4d8a..e19a541f3 100644 --- a/beacon_chain/rpc/validator_rest_api.nim +++ b/beacon_chain/rpc/validator_rest_api.nim @@ -288,26 +288,28 @@ proc installValidatorApiHandlers*(router: var RestRouter, node: BeaconNode) = # https://ethereum.github.io/eth2.0-APIs/#/Validator/publishAggregateAndProofs router.api(MethodPost, "/api/eth/v1/validator/aggregate_and_proofs") do ( contentBody: Option[ContentBody]) -> RestApiResponse: - let payload = + let proofs = block: if contentBody.isNone(): return RestApiResponse.jsonError(Http400, EmptyRequestBodyError) - let dres = decodeBody(SignedAggregateAndProof, contentBody.get()) + let dres = decodeBody(seq[SignedAggregateAndProof], contentBody.get()) if dres.isErr(): return RestApiResponse.jsonError(Http400, InvalidAggregateAndProofObjectError, $dres.error()) dres.get() - let wallTime = node.processor.getWallTime() - let res = await node.attestationPool.validateAggregate( - node.processor.batchCrypto, payload, wallTime - ) - if res.isErr(): - return RestApiResponse.jsonError(Http400, - AggregateAndProofValidationError, - $res.error()) - node.network.broadcast(node.topicAggregateAndProofs, payload) + for item in proofs: + let wallTime = node.processor.getWallTime() + let res = await node.attestationPool.validateAggregate( + node.processor.batchCrypto, item, wallTime + ) + if res.isErr(): + return RestApiResponse.jsonError(Http400, + AggregateAndProofValidationError, + $res.error()) + node.network.broadcast(node.topicAggregateAndProofs, item) + return RestApiResponse.jsonError(Http200, AggregateAndProofValidationSuccess)