Crate lightning_invoice
Expand description
This crate provides data structures to represent lightning BOLT11 invoices and functions to create, encode and decode these. If you just want to use the standard en-/decoding functionality this should get you started:
- For parsing use str::parse::<Bolt11Invoice>(&self)(seeBolt11Invoice::from_str)
- For constructing invoices use the InvoiceBuilder
- For serializing invoices use the Display/ToStringtraits
Modules§
- constants
- Tag constants as specified in BOLT11
- payment
- Convenient utilities for paying Lightning invoices.
- utils
- Convenient utilities to create an invoice.
Structs§
- Bolt11Invoice 
- Represents a syntactically and semantically correct lightning BOLT11 invoice.
- Bolt11Invoice Signature 
- Recoverable signature
- Description
- Description string
- ExpiryTime 
- Positive duration that defines when (relatively to the timestamp) in the future the invoice expires
- InvoiceBuilder 
- Builder for Bolt11Invoices. It’s the most convenient and advised way to use this library. It ensures that only a semantically and syntactically correct invoice can be built using it.
- MinFinalCltv Expiry Delta 
- min_final_cltv_expiry_deltato use for the last HTLC in the route
- PayeePubKey 
- Payee public key
- PaymentSecret 
- The payment secret is used to authenticate the sender of an HTLC to the recipient and tie multi-part HTLCs together into a single payment.
- PositiveTimestamp 
- A timestamp that refers to a date after 1 January 1970.
- PrivateRoute 
- Private routing information
- RawBolt11Invoice 
- Represents an syntactically correct Bolt11Invoicefor a payment on the lightning network, but without the signature information. Decoding and encoding should not lead to information loss but may lead to different hashes.
- RawDataPart 
- Data of the RawBolt11Invoicethat is encoded in the data part
- RawHrp
- Data of the RawBolt11Invoicethat is encoded in the human readable part.
- RouteHint 
- A list of hops along a payment path terminating with a channel to the recipient.
- RouteHint Hop 
- A channel descriptor for a hop along a payment path.
- RoutingFees 
- Fees for routing via a given channel or a node
- Sha256
- SHA-256 hash
- SignedRawBolt11 Invoice 
- Represents a signed RawBolt11Invoicewith cached hash. The signature is not checked and may be invalid.
Enums§
- Bolt11Invoice Description 
- Represents the description of an invoice which has to be either a directly included string or a hash of a description provided out of band.
- Bolt11Parse Error 
- Errors that indicate what is wrong with the invoice. They have some granularity for debug reasons, but should generally result in an “invalid BOLT11 invoice” message for the user.
- Bolt11Semantic Error 
- Errors that may occur when converting a RawBolt11Invoiceto aBolt11Invoice. They relate to the requirements sections in BOLT #11
- CreationError 
- Errors that may occur when constructing a new RawBolt11InvoiceorBolt11Invoice
- Currency
- Enum representing the crypto currencies (or networks) supported by this library
- Fallback
- Fallback address in case no LN payment is possible
- ParseOrSemantic Error 
- Indicates that something went wrong while parsing or validating the invoice. Parsing errors should be mostly seen as opaque and are only there for debugging reasons. Semantic errors like wrong signatures, missing fields etc. could mean that someone tampered with the invoice.
- RawTaggedField 
- Tagged field which may have an unknown tag
- SiPrefix
- SI prefixes for the human readable part
- SignOrCreation Error 
- When signing using a fallible method either an user-supplied SignErroror aCreationErrormay occur.
- TaggedField 
- Tagged field with known tag
Constants§
- DEFAULT_EXPIRY_ TIME 
- Default expiry time as defined by BOLT 11.
- DEFAULT_MIN_ FINAL_ CLTV_ EXPIRY_ DELTA 
- Default minimum final CLTV expiry as defined by BOLT 11.
- MAX_TIMESTAMP 
- The maximum timestamp as Duration::as_secssince the Unix epoch allowed by [BOLT 11].