mirror of
https://github.com/status-im/nimbus-eth2.git
synced 2025-01-09 22:06:21 +00:00
44bb13ae46
* use repeat_hash from spec in randao * add some logging to state processing * export crypto string converters in spec insulation layer * enable block signature verification * ssz: add support for arrays, remove custom data type code * correctly handle previous and new block * add trivial block processing tests * prefer iterative repeat_hash * state transition mostly done * handle most specials and slashings
43 lines
1.4 KiB
Nim
43 lines
1.4 KiB
Nim
# beacon_chain
|
|
# Copyright (c) 2018 Status Research & Development GmbH
|
|
# Licensed and distributed under either of
|
|
# * MIT license (license terms in the root directory or at http://opensource.org/licenses/MIT).
|
|
# * Apache v2 license (license terms in the root directory or at http://www.apache.org/licenses/LICENSE-2.0).
|
|
# at your option. This file may not be copied, modified, or distributed except according to those terms.
|
|
|
|
# At the time of writing, the exact definitions of what should be used for
|
|
# cryptography in the spec is in flux, with sizes and test vectors still being
|
|
# hashed out. This layer helps isolate those chagnes.
|
|
|
|
import
|
|
milagro_crypto, hashes
|
|
export milagro_crypto.`$`
|
|
|
|
type
|
|
ValidatorPubKey* = milagro_crypto.VerKey
|
|
ValidatorPrivKey* = milagro_crypto.SigKey
|
|
ValidatorSig* = milagro_crypto.Signature
|
|
|
|
template hash*(k: ValidatorPubKey|ValidatorPrivKey): Hash =
|
|
hash(k.getRaw)
|
|
|
|
func pubKey*(pk: ValidatorPrivKey): ValidatorPubKey = fromSigKey(pk)
|
|
|
|
func BLSAddPubkeys*(keys: openArray[ValidatorPubKey]): ValidatorPubKey =
|
|
# name from spec!
|
|
|
|
var empty = false
|
|
for key in keys:
|
|
if empty:
|
|
result = key
|
|
empty = false
|
|
else:
|
|
result.combine(key)
|
|
|
|
func BLSVerify*(
|
|
pubkey: ValidatorPubKey, msg: openArray[byte], sig: ValidatorSig,
|
|
domain: uint64): bool =
|
|
# name from spec!
|
|
# TODO domain!
|
|
sig.verifyMessage(msg, pubkey)
|