mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-09 22:06:21 +00:00
e4321dc4ed
* rename slot_to_epoch(...) to compute_epoch_of_slot(...) * rename aggregation_bitfield/custody_bitfield fields to aggregation_bits/custody_bits; rename convert_to_indexed(...) to get_indexed_attestation(...); mark BeaconBlockHeader as 0.8.0; update minimal preset MIN_ATTESTATION_INCLUSION_DELAY/time parameters in general to 0.8 * fix beacon node compilation; it used slightly different capitalizations of slot_to_epoch/slotToEpoch * mark integer_squareroot(...), Deposit, VoluntaryExit, and Transfer as 0.8.0; rename get_epoch_start_slot(...) to compute_start_slot_of_epoch(...) * add new Domain alias for uint64; rename bls_domain(...) to compute_domain(...), MAX_INDICES_PER_ATTESTATION to MAX_VALIDATORS_PER_COMMITTEE, and SignatureDomain to DomainType; update get_domain(...) to 0.8.0 * update/mark initiate_validator_exit(...) and Crosslink as 0.8.0; rename BeaconState.latest_block_roots -> BeaconState.block_roots; mark HistoricalBatch as 0.8.0
68 lines
2.4 KiB
Nim
68 lines
2.4 KiB
Nim
import
|
|
tables,
|
|
chronos, chronicles,
|
|
spec/[datatypes, crypto, digest, helpers], ssz,
|
|
beacon_node_types
|
|
|
|
|
|
proc init*(T: type ValidatorPool): T =
|
|
result.validators = initTable[ValidatorPubKey, AttachedValidator]()
|
|
|
|
template count*(pool: ValidatorPool): int =
|
|
pool.validators.len
|
|
|
|
proc addLocalValidator*(pool: var ValidatorPool,
|
|
pubKey: ValidatorPubKey,
|
|
privKey: ValidatorPrivKey) =
|
|
let v = AttachedValidator(pubKey: pubKey,
|
|
kind: inProcess,
|
|
privKey: privKey)
|
|
pool.validators[pubKey] = v
|
|
|
|
info "Local validator attached", pubKey, validator = shortLog(v)
|
|
|
|
proc getValidator*(pool: ValidatorPool,
|
|
validatorKey: ValidatorPubKey): AttachedValidator =
|
|
pool.validators.getOrDefault(validatorKey)
|
|
|
|
proc signBlockProposal*(v: AttachedValidator, state: BeaconState, slot: Slot,
|
|
blockRoot: Eth2Digest): Future[ValidatorSig] {.async.} =
|
|
if v.kind == inProcess:
|
|
await sleepAsync(chronos.milliseconds(1))
|
|
result = bls_sign(v.privKey, blockRoot.data,
|
|
get_domain(state, DOMAIN_BEACON_PROPOSER, compute_epoch_of_slot(slot)))
|
|
else:
|
|
# TODO:
|
|
# send RPC
|
|
discard
|
|
|
|
proc signAttestation*(v: AttachedValidator,
|
|
attestation: AttestationData): Future[ValidatorSig] {.async.} =
|
|
# TODO: implement this
|
|
if v.kind == inProcess:
|
|
await sleepAsync(chronos.milliseconds(1))
|
|
|
|
let attestationRoot = hash_tree_root(attestation)
|
|
# TODO: Avoid the allocations belows
|
|
var dataToSign = @(attestationRoot.data) & @[0'u8]
|
|
# TODO: Use `domain` here
|
|
let domain = 0'u64
|
|
result = bls_sign(v.privKey, dataToSign, domain)
|
|
else:
|
|
# TODO:
|
|
# send RPC
|
|
discard
|
|
|
|
func genRandaoReveal*(k: ValidatorPrivKey, state: BeaconState, slot: Slot):
|
|
ValidatorSig =
|
|
# https://github.com/ethereum/eth2.0-specs/blob/v0.2.0/specs/core/0_beacon-chain.md#randao
|
|
|
|
# Off-by-one? I often get slot == state.slot but the check was "doAssert slot > state.slot" (Mamy)
|
|
doAssert slot >= state.slot, "input slot: " & $humaneSlotNum(slot) & " - beacon state slot: " & $humaneSlotNum(state.slot)
|
|
bls_sign(k, hash_tree_root(compute_epoch_of_slot(slot).uint64).data,
|
|
get_domain(state, DOMAIN_RANDAO, compute_epoch_of_slot(slot)))
|
|
|
|
func genRandaoReveal*(v: AttachedValidator, state: BeaconState, slot: Slot):
|
|
ValidatorSig =
|
|
genRandaoReveal(v.privKey, state, slot)
|