pub struct SecretKey {
    depth: Depth,
    data: Vec<u8>,
}
Expand description

Secret Key in the binary tree sum composition of the ed25519 scheme

Serialization:

  • period
  • keypair : ED25519 keypair
  • pks : depth size of left and right public keys
  • rs : Stack of right seed for updates

Fields§

§depth: Depth§data: Vec<u8>

Implementations§

source§

impl SecretKey

source

const T_OFFSET: usize = 0usize

source

const KEYPAIR_OFFSET: usize = 4usize

source

const MERKLE_PKS_OFFSET: usize = 68usize

source

const fn seed_offset(depth: Depth) -> usize

source

const fn seed_offset_index(depth: Depth, i: usize) -> usize

source

pub fn t(&self) -> usize

source

pub fn sk(&self) -> Keypair

source

fn set_t(&mut self, t: usize)

source

fn set_sk(&mut self, sk: &Keypair)

source

fn set_merkle_pks(&mut self, n: usize, pks: &(PublicKey, PublicKey))

source

fn get_merkle_pks(&self, n: usize) -> (PublicKey, PublicKey)

source

pub fn compute_public(&self) -> PublicKey

source

fn create( t: usize, keypair: Keypair, pks: &[(PublicKey, PublicKey)], rs: &[Seed] ) -> Self

source

pub fn rs_pop(&mut self) -> Option<Seed>

source

pub fn rs_extend(&mut self, seed_offset: usize, rs: Seeds<'_>)

source

pub fn depth(&self) -> Depth

source

pub fn is_updatable(&self) -> bool

source

pub fn from_bytes(depth: Depth, bytes: &[u8]) -> Result<Self, Error>

Trait Implementations§

source§

impl AsRef<[u8]> for SecretKey

source§

fn as_ref(&self) -> &[u8]

Converts this type into a shared reference of the (usually inferred) input type.
source§

impl Clone for SecretKey

source§

fn clone(&self) -> SecretKey

Returns a copy of the value. Read more
1.0.0 · source§

fn clone_from(&mut self, source: &Self)

Performs copy-assignment from source. Read more

Auto Trait Implementations§

Blanket Implementations§

source§

impl<T> Any for Twhere T: 'static + ?Sized,

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
§

impl<T> Base32Len for Twhere T: AsRef<[u8]>,

§

fn base32_len(&self) -> usize

Calculate the base32 serialized length
source§

impl<T> Borrow<T> for Twhere T: ?Sized,

source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

impl<T> BorrowMut<T> for Twhere T: ?Sized,

source§

fn borrow_mut(&mut self) -> &mut T

Mutably borrows from an owned value. Read more
§

impl<'f, T> CheckBase32<Vec<u5, Global>> for Twhere T: AsRef<[u8]>,

§

type Err = Error

Error type if conversion fails
§

fn check_base32( self ) -> Result<Vec<u5, Global>, <T as CheckBase32<Vec<u5, Global>>>::Err>

Check if all values are in range and return array-like struct of u5 values
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

source§

fn into(self) -> U

Calls U::from(self).

That is, this conversion is whatever the implementation of From<T> for U chooses to do.

source§

impl<T> Same<T> for T

§

type Output = T

Should always be Self
§

impl<T> ToBase32 for Twhere T: AsRef<[u8]>,

§

fn write_base32<W>(&self, writer: &mut W) -> Result<(), <W as WriteBase32>::Err>where W: WriteBase32,

Encode as base32 and write it to the supplied writer Implementations shouldn’t allocate.
§

fn to_base32(&self) -> Vec<u5, Global>

Convert Self to base32 vector
source§

impl<T> ToHex for Twhere T: AsRef<[u8]>,

source§

fn encode_hex<U>(&self) -> Uwhere U: FromIterator<char>,

Encode the hex strict representing self into the result. Lower case letters are used (e.g. f9b4ca)
source§

fn encode_hex_upper<U>(&self) -> Uwhere U: FromIterator<char>,

Encode the hex strict representing self into the result. Upper case letters are used (e.g. F9B4CA)
source§

impl<T> ToOwned for Twhere T: Clone,

§

type Owned = T

The resulting type after obtaining ownership.
source§

fn to_owned(&self) -> T

Creates owned data from borrowed data, usually by cloning. Read more
source§

fn clone_into(&self, target: &mut T)

Uses borrowed data to replace owned data, usually by cloning. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

impl<V, T> VZip<V> for Twhere V: MultiLane<T>,

§

fn vzip(self) -> V