Add new bls-aggregates crates

This commit is contained in:
Paul Hauner 2018-09-23 20:19:30 +10:00
parent 0b661c5b11
commit 67b11a394e
No known key found for this signature in database
GPG Key ID: 303E4494BB28068C
12 changed files with 34 additions and 47 deletions

View File

@ -7,7 +7,7 @@ authors = ["Paul Hauner <paul@paulhauner.com>"]
# TODO: remove "blake2" in favor of "blake2-rfc" # TODO: remove "blake2" in favor of "blake2-rfc"
blake2 = "^0.7.1" blake2 = "^0.7.1"
blake2-rfc = "0.2.18" blake2-rfc = "0.2.18"
bls = { git = "https://github.com/sigp/bls" } bls-aggregates = { git = "https://github.com/sigp/signature-schemes" }
boolean-bitfield = { path = "boolean-bitfield" } boolean-bitfield = { path = "boolean-bitfield" }
bytes = "" bytes = ""
crypto-mac = "^0.6.2" crypto-mac = "^0.6.2"

9
lighthouse/bls/mod.rs Normal file
View File

@ -0,0 +1,9 @@
extern crate bls_aggregates;
pub use self::bls_aggregates::AggregateSignature;
pub use self::bls_aggregates::AggregatePublicKey;
pub use self::bls_aggregates::Signature;
pub use self::bls_aggregates::Keypair;
pub use self::bls_aggregates::PublicKey;
pub const BLS_AGG_SIG_BYTE_SIZE: usize = 97;

View File

@ -2,6 +2,7 @@
extern crate slog; extern crate slog;
extern crate slog_term; extern crate slog_term;
extern crate slog_async; extern crate slog_async;
extern crate ssz;
extern crate clap; extern crate clap;
extern crate network_libp2p; extern crate network_libp2p;
extern crate futures; extern crate futures;

View File

@ -1,5 +1,8 @@
use super::utils::types::{ Hash256, Bitfield }; use super::utils::types::{ Hash256, Bitfield };
use super::utils::bls::{ AggregateSignature }; use super::bls::{
AggregateSignature,
BLS_AGG_SIG_BYTE_SIZE,
};
use super::ssz::{ use super::ssz::{
Encodable, Encodable,
Decodable, Decodable,
@ -16,7 +19,7 @@ pub const MIN_SSZ_ATTESTION_RECORD_LENGTH: usize = {
5 + // attester_bitfield (assuming 1 byte of bitfield) 5 + // attester_bitfield (assuming 1 byte of bitfield)
8 + // justified_slot 8 + // justified_slot
32 + // justified_block_hash 32 + // justified_block_hash
4 + (2 * 8) // aggregate sig (two 256 bit points) 4 + BLS_AGG_SIG_BYTE_SIZE // aggregate sig (two 256 bit points)
}; };
#[derive(Debug)] #[derive(Debug)]
@ -28,7 +31,7 @@ pub struct AttestationRecord {
pub attester_bitfield: Bitfield, pub attester_bitfield: Bitfield,
pub justified_slot: u64, pub justified_slot: u64,
pub justified_block_hash: Hash256, pub justified_block_hash: Hash256,
pub aggregate_sig: Option<AggregateSignature>, pub aggregate_sig: AggregateSignature,
} }
impl Encodable for AttestationRecord { impl Encodable for AttestationRecord {
@ -40,8 +43,7 @@ impl Encodable for AttestationRecord {
s.append_vec(&self.attester_bitfield.to_be_vec()); s.append_vec(&self.attester_bitfield.to_be_vec());
s.append(&self.justified_slot); s.append(&self.justified_slot);
s.append(&self.justified_block_hash); s.append(&self.justified_block_hash);
// TODO: encode the aggregate sig correctly s.append_vec(&self.aggregate_sig.as_bytes());
s.append_vec(&vec![0_u8; 16])
} }
} }
@ -57,7 +59,10 @@ impl Decodable for AttestationRecord {
let (justified_slot, i) = u64::ssz_decode(bytes, i)?; let (justified_slot, i) = u64::ssz_decode(bytes, i)?;
let (justified_block_hash, i) = Hash256::ssz_decode(bytes, i)?; let (justified_block_hash, i) = Hash256::ssz_decode(bytes, i)?;
// Do aggregate sig decoding properly. // Do aggregate sig decoding properly.
let aggregate_sig = None; let i = i + 20; let (agg_sig_bytes, i) = decode_ssz_list(bytes, i)?;
let aggregate_sig = AggregateSignature::from_bytes(&agg_sig_bytes)
.map_err(|_| DecodeError::OutOfBounds)?;
let attestation_record = Self { let attestation_record = Self {
slot, slot,
shard_id, shard_id,
@ -82,7 +87,7 @@ impl AttestationRecord {
attester_bitfield: Bitfield::new(), attester_bitfield: Bitfield::new(),
justified_slot: 0, justified_slot: 0,
justified_block_hash: Hash256::zero(), justified_block_hash: Hash256::zero(),
aggregate_sig: None, aggregate_sig: AggregateSignature::new(),
} }
} }
} }
@ -113,7 +118,7 @@ mod tests {
attester_bitfield: Bitfield::from(&vec![17; 42][..]), attester_bitfield: Bitfield::from(&vec![17; 42][..]),
justified_slot: 19, justified_slot: 19,
justified_block_hash: Hash256::from(&vec![15; 32][..]), justified_block_hash: Hash256::from(&vec![15; 32][..]),
aggregate_sig: None, aggregate_sig: AggregateSignature::new(),
}; };
let mut ssz_stream = SszStream::new(); let mut ssz_stream = SszStream::new();

View File

@ -235,9 +235,9 @@ mod tests {
// will tell us if the hash changes, not that it matches some // will tell us if the hash changes, not that it matches some
// canonical reference. // canonical reference.
let expected_hash = [ let expected_hash = [
195, 180, 208, 144, 113, 20, 129, 108, 14, 128, 166, 170, 64, 176, 117, 210, 228, 229, 237, 100, 66, 66, 98,
137, 15, 191, 186, 34, 171, 79, 214, 74, 86, 89, 202, 255, 252, 31, 111, 218, 27, 160, 57, 164, 12, 15, 164,
9, 100, 170, 149, 160, 93, 59 66, 102, 142, 36, 2, 196, 121, 54, 242, 3
]; ];
assert_eq!(hash, expected_hash); assert_eq!(hash, expected_hash);

View File

@ -4,9 +4,10 @@ extern crate blake2_rfc as blake2;
extern crate bytes; extern crate bytes;
extern crate ssz; extern crate ssz;
use super::bls;
use super::db;
use super::Logger; use super::Logger;
use super::utils; use super::utils;
use super::db;
pub mod active_state; pub mod active_state;
pub mod attestation_record; pub mod attestation_record;

View File

@ -6,7 +6,7 @@ use super::attestation_parent_hashes::{
use super::db::ClientDB; use super::db::ClientDB;
use super::db::stores::BlockStore; use super::db::stores::BlockStore;
use super::ssz::SszStream; use super::ssz::SszStream;
use super::utils::bls::{ use super::bls::{
AggregateSignature, AggregateSignature,
PublicKey, PublicKey,
}; };

View File

@ -6,6 +6,7 @@ use super::block::Block;
use super::chain_config::ChainConfig; use super::chain_config::ChainConfig;
*/ */
use super::block; use super::block;
use super::bls;
use super::Logger; use super::Logger;
use super::db; use super::db;
use super::attestation_record::AttestationRecord; use super::attestation_record::AttestationRecord;

View File

@ -1,7 +1,7 @@
extern crate rand; extern crate rand;
use super::utils::types::{ Hash256, Address, U256 }; use super::utils::types::{ Hash256, Address, U256 };
use super::utils::bls::{ PublicKey, Keypair }; use super::bls::{ PublicKey, Keypair };
use self::rand::thread_rng; use self::rand::thread_rng;
@ -21,10 +21,9 @@ impl ValidatorRecord {
/// ///
/// Returns the new instance and new keypair. /// Returns the new instance and new keypair.
pub fn zero_with_thread_rand_keypair() -> (Self, Keypair) { pub fn zero_with_thread_rand_keypair() -> (Self, Keypair) {
let mut rng = thread_rng(); let keypair = Keypair::random();
let keypair = Keypair::generate(&mut rng);
let s = Self { let s = Self {
pubkey: keypair.public.clone(), pubkey: keypair.pk.clone(),
withdrawal_shard: 0, withdrawal_shard: 0,
withdrawal_address: Address::zero(), withdrawal_address: Address::zero(),
randao_commitment: Hash256::zero(), randao_commitment: Hash256::zero(),

View File

@ -1,13 +0,0 @@
extern crate bls;
extern crate pairing;
use self::bls::AggregateSignature as GenericAggregateSignature;
use self::bls::Signature as GenericSignature;
use self::bls::Keypair as GenericKeypair;
use self::bls::PublicKey as GenericPublicKey;
use self::pairing::bls12_381::Bls12;
pub type AggregateSignature = GenericAggregateSignature<Bls12>;
pub type Signature = GenericSignature<Bls12>;
pub type Keypair = GenericKeypair<Bls12>;
pub type PublicKey = GenericPublicKey<Bls12>;

View File

@ -7,9 +7,5 @@ extern crate boolean_bitfield;
pub mod macros; pub mod macros;
pub mod hash; pub mod hash;
pub mod types; pub mod types;
pub mod bls;
pub mod test_helpers;
pub mod logging; pub mod logging;
pub mod errors; pub mod errors;

View File

@ -1,12 +0,0 @@
extern crate rand;
use super::bls::Keypair;
use self::rand::thread_rng;
// Returns a keypair for use in testing purposes.
// It is dangerous because we provide no guarantees
// that the private key is unique or in-fact private.
pub fn get_dangerous_test_keypair() -> Keypair {
let mut rng = thread_rng();
Keypair::generate(&mut rng)
}