nimbus-eth2/beacon_chain/validator_pool.nim

69 lines
2.3 KiB
Nim
Raw Normal View History

import
tables,
chronos,
spec/[datatypes, crypto, helpers], ssz,
beacon_node_types
proc init*(T: type ValidatorPool): T =
2018-11-29 03:08:34 +02:00
result.validators = initTable[ValidatorPubKey, AttachedValidator]()
template count*(pool: ValidatorPool): int =
pool.validators.len
proc addLocalValidator*(pool: var ValidatorPool,
2018-11-29 03:08:34 +02:00
idx: int,
pubKey: ValidatorPubKey,
privKey: ValidatorPrivKey) =
2018-12-08 16:17:47 +02:00
let v = AttachedValidator(idx: idx,
kind: inProcess,
privKey: privKey)
2018-12-08 16:17:47 +02:00
pool.validators[pubKey] = v
2018-11-26 15:33:06 +02:00
proc getValidator*(pool: ValidatorPool,
2018-11-29 03:08:34 +02:00
validatorKey: ValidatorPubKey): AttachedValidator =
pool.validators.getOrDefault(validatorKey)
2019-02-07 21:36:03 +01:00
proc signBlockProposal*(v: AttachedValidator, fork: Fork,
proposal: Proposal): Future[ValidatorSig] {.async.} =
2018-11-29 03:08:34 +02:00
if v.kind == inProcess:
await sleepAsync(1)
let proposalRoot = hash_tree_root_final(proposal)
2018-12-12 15:57:23 +02:00
result = bls_sign(v.privKey, signed_root(proposal, "signature"),
get_domain(fork, slot_to_epoch(proposal.slot), DOMAIN_PROPOSAL))
else:
# TODO:
# send RPC
discard
proc signAttestation*(v: AttachedValidator,
attestation: AttestationData): Future[ValidatorSig] {.async.} =
# TODO: implement this
2018-11-29 03:08:34 +02:00
if v.kind == inProcess:
await sleepAsync(1)
2018-12-12 15:57:23 +02:00
let attestationRoot = hash_tree_root_final(attestation)
# TODO: Avoid the allocations belows
2019-01-09 03:01:07 +02:00
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
2019-03-14 00:04:43 +01:00
# 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(slot_to_epoch(slot).uint64),
get_domain(state.fork, slot_to_epoch(slot), DOMAIN_RANDAO))
func genRandaoReveal*(v: AttachedValidator, state: BeaconState, slot: Slot):
ValidatorSig =
genRandaoReveal(v.privKey, state, slot)