diff --git a/core/src/ser.rs b/core/src/ser.rs index 1cc50a892..9b0a2fac3 100644 --- a/core/src/ser.rs +++ b/core/src/ser.rs @@ -23,10 +23,13 @@ use crate::core::hash::{DefaultHashable, Hash, Hashed}; use crate::keychain::{BlindingFactor, Identifier, IDENTIFIER_SIZE}; use crate::util::read_write::read_exact; use crate::util::secp::constants::{ - AGG_SIGNATURE_SIZE, MAX_PROOF_SIZE, PEDERSEN_COMMITMENT_SIZE, SECRET_KEY_SIZE, + AGG_SIGNATURE_SIZE, COMPRESSED_PUBLIC_KEY_SIZE, MAX_PROOF_SIZE, PEDERSEN_COMMITMENT_SIZE, + SECRET_KEY_SIZE, }; +use crate::util::secp::key::PublicKey; use crate::util::secp::pedersen::{Commitment, RangeProof}; use crate::util::secp::Signature; +use crate::util::secp::{ContextFlag, Secp256k1}; use byteorder::{BigEndian, ByteOrder, ReadBytesExt}; use std::fmt::Debug; use std::io::{self, Read, Write}; @@ -304,7 +307,7 @@ pub fn ser_vec(thing: &W) -> Result, Error> { } /// Utility to read from a binary source -struct BinReader<'a> { +pub struct BinReader<'a> { source: &'a mut dyn Read, } @@ -546,6 +549,29 @@ impl FixedLength for Signature { const LEN: usize = AGG_SIGNATURE_SIZE; } +impl FixedLength for PublicKey { + const LEN: usize = COMPRESSED_PUBLIC_KEY_SIZE; +} + +impl Writeable for PublicKey { + // Write the public key in compressed form + fn write(&self, writer: &mut W) -> Result<(), Error> { + let secp = Secp256k1::with_caps(ContextFlag::None); + writer.write_fixed_bytes(&self.serialize_vec(&secp, true).as_ref())?; + Ok(()) + } +} + +impl Readable for PublicKey { + // Read the public key in compressed form + fn read(reader: &mut dyn Reader) -> Result { + let buf = reader.read_fixed_bytes(PublicKey::LEN)?; + let secp = Secp256k1::with_caps(ContextFlag::None); + let pk = PublicKey::from_slice(&secp, &buf).map_err(|_| Error::CorruptedData)?; + Ok(pk) + } +} + /// Collections of items must be sorted lexicographically and all unique. pub trait VerifySortedAndUnique { /// Verify a collection of items is sorted and all unique.