Eugene Kabanov 72c844534f
Add Keymanager API graffiti endpoints. (#6054)
* Initial commit.

* Add more tests.

* Fix API mistypes.

* Fix mistypes in tests.

* Fix one more mistype.

* Fix affected tests because of error code 401.

* Add GetGraffitiResponse object.

* Add more tests.

* Fix compilation errors.

* Recover old behavior.

* Recover old behavior.

* Fix mistype.

* Test could not know default graffiti value.

* Make VC use adopted graffiti settings.

* Make BN use adopted graffiti settings.

* Update Alltests.

* Fix test.

* Revert "Fix test."

This reverts commit c735f855d3cb9c4a1c8e8af29d3f4438d068e31f.

* Workaround {.push raises.} requirement.

* Fix comment.

* Update Alltests.
2024-03-14 03:44:00 +00:00

73 lines
2.6 KiB
Nim

# beacon_chain
# Copyright (c) 2024 Status Research & Development GmbH
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
{.push raises: [].}
import
std/typetraits,
results,
../spec/datatypes/base
from ../spec/eth2_apis/dynamic_fee_recipients import
DynamicFeeRecipientsStore, getDynamicFeeRecipient
from ../validators/keystore_management import
getPerValidatorDefaultFeeRecipient, getSuggestedGasLimit,
getSuggestedFeeRecipient, getSuggestedGraffiti
from ../spec/beaconstate import has_eth1_withdrawal_credential
from ../spec/presets import Eth1Address
export Eth1Address, DynamicFeeRecipientsStore
proc getFeeRecipient*(
dynamicFeeRecipientsStore: ref DynamicFeeRecipientsStore,
pubkey: ValidatorPubKey,
validatorIdx: Opt[ValidatorIndex],
stateValidator: Opt[Validator],
configFeeRecipient: Opt[Eth1Address],
configValidatorsDir: string,
epoch: Epoch
): Eth1Address =
let dynFeeRecipient =
if validatorIdx.isSome:
dynamicFeeRecipientsStore[].getDynamicFeeRecipient(
validatorIdx.get(), epoch)
else:
Opt.none(Eth1Address)
dynFeeRecipient.valueOr:
let
withdrawalAddress =
if stateValidator.isSome():
let validator = stateValidator.get()
if has_eth1_withdrawal_credential(validator):
var address: distinctBase(Eth1Address)
address[0 .. ^1] = validator.withdrawal_credentials.data[12 .. ^1]
Opt.some Eth1Address(address)
else:
Opt.none Eth1Address
else:
Opt.none Eth1Address
defaultFeeRecipient =
getPerValidatorDefaultFeeRecipient(configFeeRecipient,
withdrawalAddress)
getSuggestedFeeRecipient(
configValidatorsDir, pubkey, defaultFeeRecipient).valueOr:
defaultFeeRecipient
proc getGasLimit*(configValidatorsDir: string,
configGasLimit: uint64,
pubkey: ValidatorPubKey): uint64 =
getSuggestedGasLimit(configValidatorsDir, pubkey, configGasLimit).valueOr:
configGasLimit
proc getGraffiti*(configValidatorsDir: string,
configGraffiti: GraffitiBytes,
pubkey: ValidatorPubKey): GraffitiBytes =
getSuggestedGraffiti(configValidatorsDir, pubkey, configGraffiti).valueOr:
configGraffiti