2018-11-23 23:58:49 +00:00
|
|
|
import
|
2019-03-12 15:03:14 +00:00
|
|
|
tables,
|
2019-04-06 07:46:07 +00:00
|
|
|
chronos, chronicles,
|
|
|
|
spec/[datatypes, crypto, digest, helpers], ssz,
|
2019-03-12 15:03:14 +00:00
|
|
|
beacon_node_types
|
2018-11-23 23:58:49 +00:00
|
|
|
|
|
|
|
proc init*(T: type ValidatorPool): T =
|
2018-11-29 01:08:34 +00:00
|
|
|
result.validators = initTable[ValidatorPubKey, AttachedValidator]()
|
2018-11-23 23:58:49 +00:00
|
|
|
|
2018-12-19 12:58:53 +00:00
|
|
|
template count*(pool: ValidatorPool): int =
|
|
|
|
pool.validators.len
|
|
|
|
|
2018-11-23 23:58:49 +00:00
|
|
|
proc addLocalValidator*(pool: var ValidatorPool,
|
2019-10-03 01:51:44 +00:00
|
|
|
idx: ValidatorIndex,
|
2018-11-29 01:08:34 +00:00
|
|
|
pubKey: ValidatorPubKey,
|
2019-02-14 21:41:04 +00:00
|
|
|
privKey: ValidatorPrivKey) =
|
2019-10-03 01:51:44 +00:00
|
|
|
let v = AttachedValidator(idx: idx,
|
|
|
|
pubKey: pubKey,
|
2018-12-08 14:17:47 +00:00
|
|
|
kind: inProcess,
|
2019-02-14 21:41:04 +00:00
|
|
|
privKey: privKey)
|
2018-12-08 14:17:47 +00:00
|
|
|
pool.validators[pubKey] = v
|
2018-11-23 23:58:49 +00:00
|
|
|
|
2019-04-06 07:46:07 +00:00
|
|
|
info "Local validator attached", pubKey, validator = shortLog(v)
|
|
|
|
|
2018-11-26 13:33:06 +00:00
|
|
|
proc getValidator*(pool: ValidatorPool,
|
2018-11-29 01:08:34 +00:00
|
|
|
validatorKey: ValidatorPubKey): AttachedValidator =
|
|
|
|
pool.validators.getOrDefault(validatorKey)
|
2018-11-23 23:58:49 +00:00
|
|
|
|
2019-04-29 16:48:30 +00:00
|
|
|
proc signBlockProposal*(v: AttachedValidator, state: BeaconState, slot: Slot,
|
2019-04-06 07:46:07 +00:00
|
|
|
blockRoot: Eth2Digest): Future[ValidatorSig] {.async.} =
|
2018-11-29 01:08:34 +00:00
|
|
|
if v.kind == inProcess:
|
2019-09-08 22:35:13 +00:00
|
|
|
# TODO this is an ugly hack to fake a delay and subsequent async reordering
|
|
|
|
# for the purpose of testing the external validator delay - to be
|
|
|
|
# replaced by something more sensible
|
2019-03-29 14:45:38 +00:00
|
|
|
await sleepAsync(chronos.milliseconds(1))
|
2019-09-08 22:35:13 +00:00
|
|
|
|
|
|
|
let
|
|
|
|
domain =
|
|
|
|
get_domain(state, DOMAIN_BEACON_PROPOSER, compute_epoch_of_slot(slot))
|
|
|
|
result = bls_sign(v.privKey, blockRoot.data, domain)
|
2018-11-23 23:58:49 +00:00
|
|
|
else:
|
|
|
|
# TODO:
|
|
|
|
# send RPC
|
|
|
|
discard
|
|
|
|
|
|
|
|
proc signAttestation*(v: AttachedValidator,
|
2019-09-08 18:09:01 +00:00
|
|
|
attestation: AttestationData,
|
|
|
|
state: BeaconState): Future[ValidatorSig] {.async.} =
|
2018-11-29 01:08:34 +00:00
|
|
|
if v.kind == inProcess:
|
2019-09-08 22:35:13 +00:00
|
|
|
# TODO this is an ugly hack to fake a delay and subsequent async reordering
|
|
|
|
# for the purpose of testing the external validator delay - to be
|
|
|
|
# replaced by something more sensible
|
2019-03-29 14:45:38 +00:00
|
|
|
await sleepAsync(chronos.milliseconds(1))
|
2018-12-12 13:57:23 +00:00
|
|
|
|
2019-09-08 22:35:13 +00:00
|
|
|
let
|
|
|
|
attestationRoot = hash_tree_root(
|
|
|
|
AttestationDataAndCustodyBit(data: attestation, custody_bit: false))
|
|
|
|
domain = get_domain(state, DOMAIN_ATTESTATION, attestation.target.epoch)
|
|
|
|
|
|
|
|
result = bls_sign(v.privKey, attestationRoot.data, domain)
|
2018-11-23 23:58:49 +00:00
|
|
|
else:
|
|
|
|
# TODO:
|
|
|
|
# send RPC
|
|
|
|
discard
|
|
|
|
|
2019-02-20 01:33:58 +00:00
|
|
|
func genRandaoReveal*(k: ValidatorPrivKey, state: BeaconState, slot: Slot):
|
2019-02-07 20:13:10 +00:00
|
|
|
ValidatorSig =
|
2019-09-08 22:35:13 +00:00
|
|
|
let
|
|
|
|
domain = get_domain(state, DOMAIN_RANDAO, compute_epoch_of_slot(slot))
|
|
|
|
root = hash_tree_root(compute_epoch_of_slot(slot).uint64).data
|
|
|
|
|
|
|
|
bls_sign(k, root, domain)
|
2019-02-07 20:13:10 +00:00
|
|
|
|
2019-02-20 01:33:58 +00:00
|
|
|
func genRandaoReveal*(v: AttachedValidator, state: BeaconState, slot: Slot):
|
2019-02-07 20:13:10 +00:00
|
|
|
ValidatorSig =
|
2019-02-14 21:41:04 +00:00
|
|
|
genRandaoReveal(v.privKey, state, slot)
|