From 050e3ac48b947fa4160306fd07f43cd54661f09d Mon Sep 17 00:00:00 2001 From: tersec Date: Wed, 14 Apr 2021 09:34:35 +0000 Subject: [PATCH] abstract over more BeaconState usage (#2496) --- beacon_chain/rpc/beacon_rest_api.nim | 37 +++++++++++--------- beacon_chain/rpc/nimbus_api.nim | 2 +- beacon_chain/rpc/nimbus_rest_api.nim | 3 +- beacon_chain/validators/validator_duties.nim | 14 ++++---- 4 files changed, 32 insertions(+), 24 deletions(-) diff --git a/beacon_chain/rpc/beacon_rest_api.nim b/beacon_chain/rpc/beacon_rest_api.nim index 8eb1b3b23..73e4441fb 100644 --- a/beacon_chain/rpc/beacon_rest_api.nim +++ b/beacon_chain/rpc/beacon_rest_api.nim @@ -167,9 +167,9 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = node.withStateForBlockSlot(bslot): return RestApiResponse.jsonResponse( ( - previous_version: state().fork.previous_version, - current_version: state().fork.current_version, - epoch: state().fork.epoch + previous_version: getStateField(stateData, fork).previous_version, + current_version: getStateField(stateData, fork).current_version, + epoch: getStateField(stateData, fork).epoch ) ) return RestApiResponse.jsonError(Http500, InternalServerError) @@ -191,9 +191,11 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = node.withStateForBlockSlot(bslot): return RestApiResponse.jsonResponse( ( - previous_justified: state().previous_justified_checkpoint, - current_justified: state().current_justified_checkpoint, - finalized: state().finalized_checkpoint + previous_justified: + getStateField(stateData, previous_justified_checkpoint), + current_justified: + getStateField(stateData, current_justified_checkpoint), + finalized: getStateField(stateData, finalized_checkpoint) ) ) return RestApiResponse.jsonError(Http500, InternalServerError) @@ -268,7 +270,7 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = node.withStateForBlockSlot(bslot): let current_epoch = get_current_epoch(node.chainDag.headState.data.data) var res: seq[RestValidatorTuple] - for index, validator in state().validators.pairs(): + for index, validator in getStateField(stateData, validators).pairs(): let includeFlag = (len(keySet) == 0) and (len(indexSet) == 0) or (len(indexSet) > 0 and (ValidatorIndex(index) in indexSet)) or @@ -280,7 +282,8 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = if includeFlag and statusFlag: res.add(( index: ValidatorIndex(index), - balance: Base10.toString(state().balances[index]), + balance: + Base10.toString(getStateField(stateData, balances)[index]), status: toString(vstatus), validator: validator )) @@ -310,14 +313,15 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = let vid = validator_id.get() case vid.kind of ValidatorQueryKind.Key: - for index, validator in state().validators.pairs(): + for index, validator in getStateField(stateData, validators).pairs(): if validator.pubkey == vid.key: let sres = validator.getStatus(current_epoch) if sres.isOk(): return RestApiResponse.jsonResponse( ( index: ValidatorIndex(index), - balance: Base10.toString(state().balances[index]), + balance: + Base10.toString(getStateField(stateData, balances)[index]), status: toString(sres.get()), validator: validator ) @@ -340,15 +344,15 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = UnsupportedValidatorIndexValueError) vres.get() - if uint64(vindex) >= uint64(len(state().validators)): + if uint64(vindex) >= uint64(len(getStateField(stateData, validators))): return RestApiResponse.jsonError(Http404, ValidatorNotFoundError) - let validator = state().validators[vindex] + let validator = getStateField(stateData, validators)[vindex] let sres = validator.getStatus(current_epoch) if sres.isOk(): return RestApiResponse.jsonResponse( ( index: vindex, - balance: Base10.toString(state().balances[vindex]), + balance: Base10.toString(getStateField(stateData, balances)[vindex]), status: toString(sres.get()), validator: validator ) @@ -414,7 +418,7 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = node.withStateForBlockSlot(bslot): let current_epoch = get_current_epoch(node.chainDag.headState.data.data) var res: seq[RestValidatorBalanceTuple] - for index, validator in state().validators.pairs(): + for index, validator in getStateField(stateData, validators).pairs(): let includeFlag = (len(keySet) == 0) and (len(indexSet) == 0) or (len(indexSet) > 0 and (ValidatorIndex(index) in indexSet)) or @@ -425,7 +429,8 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = if includeFlag: res.add(( index: ValidatorIndex(index), - balance: Base10.toString(state().balances[index]), + balance: + Base10.toString(getStateField(stateData, balances)[index]), )) return RestApiResponse.jsonResponse(res) @@ -500,7 +505,7 @@ proc installBeaconApiHandlers*(router: var RestRouter, node: BeaconNode) = var res: seq[RestBeaconStatesCommitteesTuple] let qepoch = if vepoch.isNone: - compute_epoch_at_slot(state().slot) + compute_epoch_at_slot(getStateField(stateData, slot)) else: vepoch.get() diff --git a/beacon_chain/rpc/nimbus_api.nim b/beacon_chain/rpc/nimbus_api.nim index 209069cc7..420331f12 100644 --- a/beacon_chain/rpc/nimbus_api.nim +++ b/beacon_chain/rpc/nimbus_api.nim @@ -105,7 +105,7 @@ proc installNimbusApiHandlers*(rpcServer: RpcServer, node: BeaconNode) {. let proposalState = assignClone(node.chainDag.headState) node.chainDag.withState(proposalState[], head.atSlot(wallSlot)): - return node.getBlockProposalEth1Data(state) + return node.getBlockProposalEth1Data(stateData) rpcServer.rpc("debug_getChronosFutures") do () -> seq[FutureInfo]: when defined(chronosFutureTracking): diff --git a/beacon_chain/rpc/nimbus_rest_api.nim b/beacon_chain/rpc/nimbus_rest_api.nim index d366624c2..a11fab6ab 100644 --- a/beacon_chain/rpc/nimbus_rest_api.nim +++ b/beacon_chain/rpc/nimbus_rest_api.nim @@ -185,7 +185,8 @@ proc installNimbusApiHandlers*(router: var RestRouter, node: BeaconNode) = res.get() let proposalState = assignClone(node.chainDag.headState) node.chainDag.withState(proposalState[], head.atSlot(wallSlot)): - return RestApiResponse.jsonResponse(node.getBlockProposalEth1Data(state)) + return RestApiResponse.jsonResponse( + node.getBlockProposalEth1Data(stateData)) router.api(MethodGet, "/api/nimbus/v1/debug/chronos/futures") do ( ) -> RestApiResponse: diff --git a/beacon_chain/validators/validator_duties.nim b/beacon_chain/validators/validator_duties.nim index a84c80b17..78b9d0629 100644 --- a/beacon_chain/validators/validator_duties.nim +++ b/beacon_chain/validators/validator_duties.nim @@ -231,18 +231,20 @@ proc createAndSendAttestation(node: BeaconNode, beacon_attestation_sent_delay.observe(delayMillis) proc getBlockProposalEth1Data*(node: BeaconNode, - state: BeaconState): BlockProposalEth1Data = + stateData: StateData): BlockProposalEth1Data = if node.eth1Monitor.isNil: - var pendingDepositsCount = state.eth1_data.deposit_count - - state.eth1_deposit_index + var pendingDepositsCount = + getStateField(stateData, eth1_data).deposit_count - + getStateField(stateData, eth1_deposit_index) if pendingDepositsCount > 0: result.hasMissingDeposits = true else: - result.vote = state.eth1_data + result.vote = getStateField(stateData, eth1_data) else: let finalizedEpochRef = node.chainDag.getFinalizedEpochRef() result = node.eth1Monitor.getBlockProposalData( - state, finalizedEpochRef.eth1_data, finalizedEpochRef.eth1_deposit_index) + stateData.data.data, finalizedEpochRef.eth1_data, + finalizedEpochRef.eth1_deposit_index) proc makeBeaconBlockForHeadAndSlot*(node: BeaconNode, randao_reveal: ValidatorSig, @@ -258,7 +260,7 @@ proc makeBeaconBlockForHeadAndSlot*(node: BeaconNode, node.chainDag.withState(proposalState[], head.atSlot(slot)): let - eth1Proposal = node.getBlockProposalEth1Data(state) + eth1Proposal = node.getBlockProposalEth1Data(stateData) poolPtr = unsafeAddr node.chainDag # safe because restore is short-lived if eth1Proposal.hasMissingDeposits: