Struct HtlcBasepoint
pub struct HtlcBasepoint(pub PublicKey);
Expand description
Base key used in conjunction with a per_commitment_point
to generate an HtlcKey
.
HTLC keys are used to ensure only the recipient of an HTLC can claim it on-chain with the HTLC preimage and that only the sender of an HTLC can claim it on-chain after it has timed out. Thus, both channel counterparties’ HTLC keys will appears in each HTLC output’s script.
Tuple Fields§
§0: PublicKey
Implementations§
§impl HtlcBasepoint
impl HtlcBasepoint
pub fn to_public_key(&self) -> PublicKey
pub fn to_public_key(&self) -> PublicKey
Get inner Public Key
pub fn derive_add_tweak(&self, per_commitment_point: &PublicKey) -> Hash
pub fn derive_add_tweak(&self, per_commitment_point: &PublicKey) -> Hash
Derives the “tweak” used in calculate HtlcKey::from_basepoint
.
HtlcKey::from_basepoint
calculates a private key as:
privkey = basepoint_secret + SHA256(per_commitment_point || basepoint)
This calculates the hash part in the tweak derivation process, which is used to ensure that each key is unique and cannot be guessed by an external party.
Trait Implementations§
§impl Clone for HtlcBasepoint
impl Clone for HtlcBasepoint
§fn clone(&self) -> HtlcBasepoint
fn clone(&self) -> HtlcBasepoint
Returns a copy of the value. Read more
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
Performs copy-assignment from
source
. Read more§impl Debug for HtlcBasepoint
impl Debug for HtlcBasepoint
§impl From<PublicKey> for HtlcBasepoint
impl From<PublicKey> for HtlcBasepoint
§fn from(value: PublicKey) -> HtlcBasepoint
fn from(value: PublicKey) -> HtlcBasepoint
Converts to this type from the input type.
§impl Hash for HtlcBasepoint
impl Hash for HtlcBasepoint
§impl PartialEq for HtlcBasepoint
impl PartialEq for HtlcBasepoint
§impl Readable for HtlcBasepoint
impl Readable for HtlcBasepoint
§fn read<R>(r: &mut R) -> Result<HtlcBasepoint, DecodeError>where
R: Read,
fn read<R>(r: &mut R) -> Result<HtlcBasepoint, DecodeError>where
R: Read,
Reads a
Self
in from the given Read
.§impl Writeable for HtlcBasepoint
impl Writeable for HtlcBasepoint
impl Copy for HtlcBasepoint
impl Eq for HtlcBasepoint
impl StructuralPartialEq for HtlcBasepoint
Auto Trait Implementations§
impl Freeze for HtlcBasepoint
impl RefUnwindSafe for HtlcBasepoint
impl Send for HtlcBasepoint
impl Sync for HtlcBasepoint
impl Unpin for HtlcBasepoint
impl UnwindSafe for HtlcBasepoint
Blanket Implementations§
§impl<T> AnyEq for T
impl<T> AnyEq for T
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Mutably borrows from an owned value. Read more
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Checks if this value is equivalent to the given key. Read more
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
Compare self to
key
and return true
if they are equal.§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request
Source§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
Wrap the input message
T
in a tonic::Request