Struct OutboundHTLCDetails

Source
pub struct OutboundHTLCDetails {
    pub htlc_id: Option<u64>,
    pub amount_msat: u64,
    pub cltv_expiry: u32,
    pub payment_hash: PaymentHash,
    pub state: Option<OutboundHTLCStateDetails>,
    pub skimmed_fee_msat: Option<u64>,
    pub is_dust: bool,
}
Expand description

Exposes details around pending outbound HTLCs.

Fields§

§htlc_id: Option<u64>

The HTLC ID. The IDs are incremented by 1 starting from 0 for each offered HTLC. They are unique per channel and inbound/outbound direction, unless an HTLC was only announced and not part of any commitment transaction.

Not present when we are awaiting a remote revocation and the HTLC is not added yet.

§amount_msat: u64

The amount in msat.

§cltv_expiry: u32

The block height at which this HTLC expires.

§payment_hash: PaymentHash

The payment hash.

§state: Option<OutboundHTLCStateDetails>

The state of the HTLC in the state machine.

Determines on which commitment transactions the HTLC is included and what message the HTLC is waiting for to advance to the next state.

See OutboundHTLCStateDetails for information on the specific states.

LDK will always fill this field in, but when downgrading to prior versions of LDK, new states may result in None here.

§skimmed_fee_msat: Option<u64>

The extra fee being skimmed off the top of this HTLC.

§is_dust: bool

Whether the HTLC has an output below the local dust limit. If so, the output will be trimmed from the local commitment transaction and added to the commitment transaction fee. For non-anchor channels, this takes into account the cost of the second-stage HTLC transactions as well.

When the local commitment transaction is broadcasted as part of a unilateral closure, the value of this HTLC will therefore not be claimable but instead burned as a transaction fee.

Note that dust limits are specific to each party. An HTLC can be dust for the local commitment transaction but not for the counterparty’s commitment transaction and vice versa.

Trait Implementations§

Source§

impl Clone for OutboundHTLCDetails

Source§

fn clone(&self) -> OutboundHTLCDetails

Returns a duplicate of the value. Read more
1.0.0 · Source§

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

Performs copy-assignment from source. Read more
Source§

impl Debug for OutboundHTLCDetails

Source§

fn fmt(&self, f: &mut Formatter<'_>) -> Result

Formats the value using the given formatter. Read more
Source§

impl PartialEq for OutboundHTLCDetails

Source§

fn eq(&self, other: &OutboundHTLCDetails) -> bool

Tests for self and other values to be equal, and is used by ==.
1.0.0 · Source§

fn ne(&self, other: &Rhs) -> bool

Tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
Source§

impl Readable for OutboundHTLCDetails

Source§

fn read<R: Read>(reader: &mut R) -> Result<Self, DecodeError>

Reads a Self in from the given Read.
Source§

impl Writeable for OutboundHTLCDetails

Source§

fn write<W: Writer>(&self, writer: &mut W) -> Result<(), Error>

Writes self out to the given Writer.
Source§

fn serialized_length(&self) -> usize

Gets the length of this object after it has been serialized. This can be overridden to optimize cases where we prepend an object with its length.
Source§

fn encode(&self) -> Vec<u8>

Writes self out to a Vec<u8>.
Source§

impl StructuralPartialEq for OutboundHTLCDetails

Auto Trait Implementations§

Blanket Implementations§

Source§

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

Source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
Source§

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

Source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
Source§

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

Source§

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

Mutably borrows from an owned value. Read more
Source§

impl<T> CloneToUninit for T
where T: Clone,

Source§

unsafe fn clone_to_uninit(&self, dest: *mut u8)

🔬This is a nightly-only experimental API. (clone_to_uninit)
Performs copy-assignment from self to dest. Read more
Source§

impl<T> From<T> for T

Source§

fn from(t: T) -> T

Returns the argument unchanged.

Source§

impl<T, U> Into<U> for T
where 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> MaybeReadable for T
where T: Readable,

Source§

fn read<R>(reader: &mut R) -> Result<Option<T>, DecodeError>
where R: Read,

Reads a Self in from the given Read.
Source§

impl<T> ToOwned for T
where T: Clone,

Source§

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 T
where U: Into<T>,

Source§

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 T
where U: TryFrom<T>,

Source§

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.
Source§

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

Source§

fn vzip(self) -> V