mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-10 06:16:25 +00:00
6fe0a623f5
* use bearssl rng throughout * bump * bump * move keygen out of crypto
71 lines
2.6 KiB
Nim
71 lines
2.6 KiB
Nim
# beacon_chain
|
|
# Copyright (c) 2018-2020 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.
|
|
|
|
# Mocking validator public and private keys
|
|
# ---------------------------------------------------------------
|
|
|
|
import
|
|
bearssl, eth/keys,
|
|
# Specs
|
|
blscurve/bls_signature_scheme,
|
|
../../beacon_chain/spec/[datatypes, crypto]
|
|
|
|
proc newKeyPair(rng: var BrHmacDrbgContext): BlsResult[tuple[pub: ValidatorPubKey, priv: ValidatorPrivKey]] =
|
|
## Generates a new public-private keypair
|
|
## This requires entropy on the system
|
|
# The input-keying-material requires 32 bytes at least for security
|
|
# The generation is deterministic and the input-keying-material
|
|
# must be protected against side-channel attacks
|
|
|
|
var ikm: array[32, byte]
|
|
brHmacDrbgGenerate(rng, ikm)
|
|
|
|
var
|
|
sk: SecretKey
|
|
pk: bls_signature_scheme.PublicKey
|
|
if keyGen(ikm, pk, sk):
|
|
ok((ValidatorPubKey(kind: Real, blsValue: pk), ValidatorPrivKey(sk)))
|
|
else:
|
|
err "bls: cannot generate keypair"
|
|
|
|
# this is being indexed inside "mock_deposits.nim" by a value up to `validatorCount`
|
|
# which is `num_validators` which is `MIN_GENESIS_ACTIVE_VALIDATOR_COUNT`
|
|
proc genMockPrivKeys(privkeys: var array[MIN_GENESIS_ACTIVE_VALIDATOR_COUNT, ValidatorPrivKey]) =
|
|
let rng = newRng()
|
|
for i in 0 ..< privkeys.len:
|
|
let pair = newKeyPair(rng[])[]
|
|
privkeys[i] = pair.priv
|
|
|
|
func genMockPubKeys(
|
|
pubkeys: var array[MIN_GENESIS_ACTIVE_VALIDATOR_COUNT, ValidatorPubKey],
|
|
privkeys: array[MIN_GENESIS_ACTIVE_VALIDATOR_COUNT, ValidatorPrivKey]
|
|
) =
|
|
for i in 0 ..< privkeys.len:
|
|
pubkeys[i] = toPubKey(privkeys[i])
|
|
|
|
# Ref array necessary to limit stack usage / binary size
|
|
var MockPrivKeys*: ref array[MIN_GENESIS_ACTIVE_VALIDATOR_COUNT, ValidatorPrivKey]
|
|
new MockPrivKeys
|
|
genMockPrivKeys(MockPrivKeys[])
|
|
|
|
var MockPubKeys*: ref array[MIN_GENESIS_ACTIVE_VALIDATOR_COUNT, ValidatorPubKey]
|
|
new MockPubKeys
|
|
genMockPubKeys(MockPubKeys[], MockPrivKeys[])
|
|
|
|
type MockKey = ValidatorPrivKey or ValidatorPubKey
|
|
|
|
template `[]`*[N: static int](a: array[N, MockKey], idx: ValidatorIndex): MockKey =
|
|
a[idx.int]
|
|
|
|
when isMainModule:
|
|
echo "========================================"
|
|
echo "Mock keys"
|
|
for i in 0 ..< MIN_GENESIS_ACTIVE_VALIDATOR_COUNT:
|
|
echo " validator ", i
|
|
echo " seckey: ", MockPrivKeys[i].toHex()
|
|
echo " pubkey: ", MockPubKeys[i]
|