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§
Source§impl HtlcBasepoint
impl HtlcBasepoint
Sourcepub fn to_public_key(&self) -> PublicKey
pub fn to_public_key(&self) -> PublicKey
Get inner Public Key
Sourcepub fn derive_add_tweak(&self, per_commitment_point: &PublicKey) -> Sha256
pub fn derive_add_tweak(&self, per_commitment_point: &PublicKey) -> Sha256
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§
Source§impl Clone for HtlcBasepoint
impl Clone for HtlcBasepoint
Source§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 moreSource§impl Debug for HtlcBasepoint
impl Debug for HtlcBasepoint
Source§impl From<PublicKey> for HtlcBasepoint
impl From<PublicKey> for HtlcBasepoint
Source§impl Hash for HtlcBasepoint
impl Hash for HtlcBasepoint
Source§impl PartialEq for HtlcBasepoint
impl PartialEq for HtlcBasepoint
Source§impl Readable for HtlcBasepoint
impl Readable for HtlcBasepoint
Source§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§
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