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: PublicKeyImplementations§
§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 duplicate 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<T> AnySync for T
impl<T> AnySync 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<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<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> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left is true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
Converts
self into a Left variant of Either<Self, Self>
if into_left(&self) returns true.
Converts self into a Right variant of Either<Self, Self>
otherwise. Read moreSource§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