2018-11-28 13:49:03 -06:00
|
|
|
# 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
|
2018-11-29 03:08:34 +02:00
|
|
|
milagro_crypto, hashes
|
2018-12-13 10:00:55 -06:00
|
|
|
export milagro_crypto.`$`
|
2018-11-28 13:49:03 -06:00
|
|
|
|
|
|
|
type
|
2018-11-29 03:08:34 +02:00
|
|
|
ValidatorPubKey* = milagro_crypto.VerKey
|
|
|
|
ValidatorPrivKey* = milagro_crypto.SigKey
|
|
|
|
ValidatorSig* = milagro_crypto.Signature
|
|
|
|
|
|
|
|
template hash*(k: ValidatorPubKey|ValidatorPrivKey): Hash =
|
|
|
|
hash(k.getRaw)
|
|
|
|
|
2018-12-11 11:55:45 -06:00
|
|
|
func pubKey*(pk: ValidatorPrivKey): ValidatorPubKey = fromSigKey(pk)
|
2018-12-05 15:58:41 +02:00
|
|
|
|
2018-12-11 11:55:45 -06:00
|
|
|
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)
|