pub enum RecentPaymentDetails {
    AwaitingInvoice {
        payment_id: PaymentId,
    },
    Pending {
        payment_id: PaymentId,
        payment_hash: PaymentHash,
        total_msat: u64,
    },
    Fulfilled {
        payment_id: PaymentId,
        payment_hash: Option<PaymentHash>,
    },
    Abandoned {
        payment_id: PaymentId,
        payment_hash: PaymentHash,
    },
}
Expand description

Used by ChannelManager::list_recent_payments to express the status of recent payments. These include payments that have yet to find a successful path, or have unresolved HTLCs.

Variants§

§

AwaitingInvoice

When an invoice was requested and thus a payment has not yet been sent.

Fields

§payment_id: PaymentId

A user-provided identifier in ChannelManager::send_payment used to uniquely identify a payment and ensure idempotency in LDK.

§

Pending

When a payment is still being sent and awaiting successful delivery.

Fields

§payment_id: PaymentId

A user-provided identifier in ChannelManager::send_payment used to uniquely identify a payment and ensure idempotency in LDK.

§payment_hash: PaymentHash

Hash of the payment that is currently being sent but has yet to be fulfilled or abandoned.

§total_msat: u64

Total amount (in msat, excluding fees) across all paths for this payment, not just the amount currently inflight.

§

Fulfilled

When a pending payment is fulfilled, we continue tracking it until all pending HTLCs have been resolved. Upon receiving Event::PaymentSent, we delay for a few minutes before the payment is removed from tracking.

Fields

§payment_id: PaymentId

A user-provided identifier in ChannelManager::send_payment used to uniquely identify a payment and ensure idempotency in LDK.

§payment_hash: Option<PaymentHash>

Hash of the payment that was claimed. None for serializations of ChannelManager made before LDK version 0.0.104.

§

Abandoned

After a payment’s retries are exhausted per the provided Retry, or it is explicitly abandoned via ChannelManager::abandon_payment, it is marked as abandoned until all pending HTLCs for this payment resolve and an Event::PaymentFailed is generated.

Fields

§payment_id: PaymentId

A user-provided identifier in ChannelManager::send_payment used to uniquely identify a payment and ensure idempotency in LDK.

§payment_hash: PaymentHash

Hash of the payment that we have given up trying to send.

Trait Implementations§

§

impl Debug for RecentPaymentDetails

§

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

Formats the value using the given formatter. Read more
§

impl PartialEq for RecentPaymentDetails

§

fn eq(&self, other: &RecentPaymentDetails) -> 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.
§

impl StructuralPartialEq for RecentPaymentDetails

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
§

impl<T> Any for T
where T: Any,

§

fn into_any(self: Box<T>) -> Box<dyn Any>

§

fn into_any_rc(self: Rc<T>) -> Rc<dyn Any>

§

fn type_name(&self) -> &'static str

§

impl<T> AnySync for T
where T: Any + Send + Sync,

§

fn into_any_arc(self: Arc<T>) -> Arc<dyn Any + Sync + Send>

§

impl<T> AsAny for T
where T: Any,

§

fn as_any(&self) -> &(dyn Any + 'static)

§

fn as_any_mut(&mut self) -> &mut (dyn Any + 'static)

§

fn type_name(&self) -> &'static str

Gets the type name of self
§

impl<'a, T, E> AsTaggedExplicit<'a, E> for T
where T: 'a,

§

fn explicit(self, class: Class, tag: u32) -> TaggedParser<'a, Explicit, Self, E>

§

impl<'a, T, E> AsTaggedImplicit<'a, E> for T
where T: 'a,

§

fn implicit( self, class: Class, constructed: bool, tag: u32, ) -> TaggedParser<'a, Implicit, Self, E>

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
§

impl<T> Downcast for T
where T: AsAny + ?Sized,

§

fn is<T>(&self) -> bool
where T: AsAny,

Returns true if the boxed type is the same as T. Read more
§

fn downcast_ref<T>(&self) -> Option<&T>
where T: AsAny,

Forward to the method defined on the type Any.
§

fn downcast_mut<T>(&mut self) -> Option<&mut T>
where T: AsAny,

Forward to the method defined on the type Any.
source§

impl<T> From<T> for T

source§

fn from(t: T) -> T

Returns the argument unchanged.

§

impl<T> Instrument for T

§

fn instrument(self, span: Span) -> Instrumented<Self>

Instruments this type with the provided [Span], returning an Instrumented wrapper. Read more
§

fn in_current_span(self) -> Instrumented<Self>

Instruments this type with the current Span, returning an Instrumented wrapper. Read more
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> IntoRequest<T> for T

source§

fn into_request(self) -> Request<T>

Wrap the input message T in a tonic::Request
source§

impl<T> Same for T

source§

type Output = T

Should always be Self
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.
§

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

§

fn vzip(self) -> V

§

impl<T> WithSubscriber for T

§

fn with_subscriber<S>(self, subscriber: S) -> WithDispatch<Self>
where S: Into<Dispatch>,

Attaches the provided Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

fn with_current_subscriber(self) -> WithDispatch<Self>

Attaches the current default Subscriber to this type, returning a [WithDispatch] wrapper. Read more
§

impl<T> DartSafe for T