Enum lightning::events::PaymentPurpose

source ·
pub enum PaymentPurpose {
    Bolt11InvoicePayment {
        payment_preimage: Option<PaymentPreimage>,
        payment_secret: PaymentSecret,
    },
    Bolt12OfferPayment {
        payment_preimage: Option<PaymentPreimage>,
        payment_secret: PaymentSecret,
        payment_context: Bolt12OfferContext,
    },
    Bolt12RefundPayment {
        payment_preimage: Option<PaymentPreimage>,
        payment_secret: PaymentSecret,
        payment_context: Bolt12RefundContext,
    },
    SpontaneousPayment(PaymentPreimage),
}
Expand description

Some information provided on receipt of payment depends on whether the payment received is a spontaneous payment or a “conventional” lightning payment that’s paying an invoice.

Variants§

§

Bolt11InvoicePayment

A payment for a BOLT 11 invoice.

Fields

§payment_preimage: Option<PaymentPreimage>

The preimage to the payment_hash, if the payment hash (and secret) were fetched via ChannelManager::create_inbound_payment. When handling Event::PaymentClaimable, this can be passed directly to ChannelManager::claim_funds to claim the payment. No action is needed when seen in Event::PaymentClaimed.

§payment_secret: PaymentSecret

The “payment secret”. This authenticates the sender to the recipient, preventing a number of deanonymization attacks during the routing process. It is provided here for your reference, however its accuracy is enforced directly by ChannelManager using the values you previously provided to ChannelManager::create_inbound_payment or ChannelManager::create_inbound_payment_for_hash.

§

Bolt12OfferPayment

A payment for a BOLT 12 Offer.

Fields

§payment_preimage: Option<PaymentPreimage>

The preimage to the payment hash. When handling Event::PaymentClaimable, this can be passed directly to ChannelManager::claim_funds, if provided. No action is needed when seen in Event::PaymentClaimed.

§payment_secret: PaymentSecret

The secret used to authenticate the sender to the recipient, preventing a number of de-anonymization attacks while routing a payment.

See PaymentPurpose::Bolt11InvoicePayment::payment_secret for further details.

§payment_context: Bolt12OfferContext

The context of the payment such as information about the corresponding Offer and InvoiceRequest.

§

Bolt12RefundPayment

A payment for a BOLT 12 Refund.

Fields

§payment_preimage: Option<PaymentPreimage>

The preimage to the payment hash. When handling Event::PaymentClaimable, this can be passed directly to ChannelManager::claim_funds, if provided. No action is needed when seen in Event::PaymentClaimed.

§payment_secret: PaymentSecret

The secret used to authenticate the sender to the recipient, preventing a number of de-anonymization attacks while routing a payment.

See PaymentPurpose::Bolt11InvoicePayment::payment_secret for further details.

§payment_context: Bolt12RefundContext

The context of the payment such as information about the corresponding Refund.

§

SpontaneousPayment(PaymentPreimage)

Because this is a spontaneous payment, the payer generated their own preimage rather than us (the payee) providing a preimage.

Implementations§

source§

impl PaymentPurpose

source

pub fn preimage(&self) -> Option<PaymentPreimage>

Returns the preimage for this payment, if it is known.

Trait Implementations§

source§

impl Clone for PaymentPurpose

source§

fn clone(&self) -> PaymentPurpose

Returns a copy 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 PaymentPurpose

source§

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

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

impl PartialEq for PaymentPurpose

source§

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

This method tests for self and other values to be equal, and is used by ==.
1.0.0 · source§

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

This method tests for !=. The default implementation is almost always sufficient, and should not be overridden without very good reason.
source§

impl Readable for PaymentPurpose

source§

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

Reads a Self in from the given Read.
source§

impl Writeable for PaymentPurpose

source§

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

Writes self out to the given Writer.
source§

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

Writes self out to a Vec<u8>.
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§

impl Eq for PaymentPurpose

source§

impl StructuralPartialEq for PaymentPurpose

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> 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,

§

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>,

§

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>,

§

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.