Serialization and fingerprint for ExpandedSpendingKey and FullViewingKey

This commit is contained in:
Jack Grigg 2018-07-11 12:29:39 +01:00
parent 2fdfa4b671
commit 0e1d440287
No known key found for this signature in database
GPG Key ID: 1B8D649257DB0829
1 changed files with 40 additions and 1 deletions

View File

@ -5,7 +5,7 @@ extern crate pairing;
extern crate sapling_crypto; extern crate sapling_crypto;
use blake2_rfc::blake2b::{Blake2b, Blake2bResult}; use blake2_rfc::blake2b::{Blake2b, Blake2bResult};
use pairing::bls12_381::Bls12; use pairing::{bls12_381::Bls12, PrimeField, PrimeFieldRepr};
use sapling_crypto::{ use sapling_crypto::{
jubjub::{FixedGenerators, JubjubBls12, JubjubEngine, JubjubParams, ToUniform}, jubjub::{FixedGenerators, JubjubBls12, JubjubEngine, JubjubParams, ToUniform},
primitives::ViewingKey, primitives::ViewingKey,
@ -17,6 +17,7 @@ lazy_static! {
pub const PRF_EXPAND_PERSONALIZATION: &'static [u8; 16] = b"Zcash_ExpandSeed"; pub const PRF_EXPAND_PERSONALIZATION: &'static [u8; 16] = b"Zcash_ExpandSeed";
pub const ZIP32_SAPLING_MASTER_PERSONALIZATION: &'static [u8; 16] = b"ZcashIP32Sapling"; pub const ZIP32_SAPLING_MASTER_PERSONALIZATION: &'static [u8; 16] = b"ZcashIP32Sapling";
pub const ZIP32_SAPLING_FVFP_PERSONALIZATION: &'static [u8; 16] = b"ZcashSaplingFVFP";
// Sapling key components // Sapling key components
@ -54,6 +55,20 @@ impl<E: JubjubEngine> ExpandedSpendingKey<E> {
.copy_from_slice(&prf_expand(sk, &[0x02]).as_bytes()[..32]); .copy_from_slice(&prf_expand(sk, &[0x02]).as_bytes()[..32]);
ExpandedSpendingKey { ask, nsk, ovk } ExpandedSpendingKey { ask, nsk, ovk }
} }
fn to_bytes(&self) -> [u8; 96] {
let mut result = [0u8; 96];
self.ask
.into_repr()
.write_le(&mut result[..32])
.expect("length is 32 bytes");
self.nsk
.into_repr()
.write_le(&mut result[32..64])
.expect("length is 32 bytes");
(&mut result[64..]).copy_from_slice(&self.ovk.0);
result
}
} }
impl<E: JubjubEngine> FullViewingKey<E> { impl<E: JubjubEngine> FullViewingKey<E> {
@ -70,6 +85,20 @@ impl<E: JubjubEngine> FullViewingKey<E> {
ovk: xsk.ovk, ovk: xsk.ovk,
} }
} }
fn to_bytes(&self) -> [u8; 96] {
let mut result = [0u8; 96];
self.vk
.ak
.write(&mut result[..32])
.expect("length is 32 bytes");
self.vk
.nk
.write(&mut result[32..64])
.expect("length is 32 bytes");
(&mut result[64..]).copy_from_slice(&self.ovk.0);
result
}
} }
// ZIP 32 structures // ZIP 32 structures
@ -77,6 +106,16 @@ impl<E: JubjubEngine> FullViewingKey<E> {
/// A Sapling full viewing key fingerprint /// A Sapling full viewing key fingerprint
struct FVKFingerprint([u8; 32]); struct FVKFingerprint([u8; 32]);
impl<'a, E: JubjubEngine> From<&'a FullViewingKey<E>> for FVKFingerprint {
fn from(fvk: &FullViewingKey<E>) -> Self {
let mut h = Blake2b::with_params(32, &[], &[], ZIP32_SAPLING_FVFP_PERSONALIZATION);
h.update(&fvk.to_bytes());
let mut fvfp = [0u8; 32];
fvfp.copy_from_slice(h.finalize().as_bytes());
FVKFingerprint(fvfp)
}
}
/// A Sapling full viewing key tag /// A Sapling full viewing key tag
#[derive(Clone, Copy)] #[derive(Clone, Copy)]
struct FVKTag([u8; 4]); struct FVKTag([u8; 4]);