Enum invoice::Beneficiary

source ·
#[non_exhaustive]
pub enum Beneficiary {
    Address(Address),
    BlindUtxo(ConcealedSeal),
    Descriptor(Descriptor<DescriptorPublicKey>),
    Psbt(Psbt),
    Bolt(LnAddress),
    Unknown(Blob),
}

Variants (Non-exhaustive)§

This enum is marked as non-exhaustive
Non-exhaustive enums could have additional variants added in future. Therefore, when matching against variants of non-exhaustive enums, an extra wildcard arm must be added to account for any future variants.
§

Address(Address)

Addresses are useful when you do not like to leak public key information

§

BlindUtxo(ConcealedSeal)

Used by protocols that work with existing UTXOs and can assign some client-validated data to them (like in RGB). We always hide the real UTXO behind the hashed version (using some salt)

§

Descriptor(Descriptor<DescriptorPublicKey>)

Miniscript-based descriptors allowing custom derivation & key generation

§

Psbt(Psbt)

Full transaction template in PSBT format

§

Bolt(LnAddress)

Lightning node receiving the payment. Not the same as lightning invoice since many of the invoice data now will be part of Invoice here.

§

Unknown(Blob)

Fallback option for all future variants

Trait Implementations§

source§

impl Clone for Beneficiary

source§

fn clone(&self) -> Beneficiary

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 Beneficiary

source§

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

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

impl Display for Beneficiary

source§

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

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

impl From<Address> for Beneficiary

source§

fn from(v: Address) -> Self

Converts to this type from the input type.
source§

impl From<ConcealedSeal> for Beneficiary

source§

fn from(v: ConcealedSeal) -> Self

Converts to this type from the input type.
source§

impl From<Descriptor<DescriptorPublicKey>> for Beneficiary

source§

fn from(v: Descriptor<DescriptorPublicKey>) -> Self

Converts to this type from the input type.
source§

impl From<LnAddress> for Beneficiary

source§

fn from(v: LnAddress) -> Self

Converts to this type from the input type.
source§

impl From<Psbt> for Beneficiary

source§

fn from(v: Psbt) -> Self

Converts to this type from the input type.
source§

impl FromStr for Beneficiary

§

type Err = BeneficiaryParseError

The associated error which can be returned from parsing.
source§

fn from_str(s: &str) -> Result<Self, Self::Err>

Parses a string s to return a value of this type. Read more
source§

impl PartialEq<Beneficiary> for Beneficiary

source§

fn eq(&self, other: &Beneficiary) -> 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 StrictDecode for Beneficiary

source§

fn strict_decode<D: Read>(d: D) -> Result<Self, Error>

Decode with the given std::io::Read instance; must either construct an instance or return implementation-specific error type.
source§

fn strict_deserialize(data: impl AsRef<[u8]>) -> Result<Self, Error>

Tries to deserialize byte array into the current type using StrictDecode::strict_decode. If there are some data remains in the buffer once deserialization is completed, fails with Error::DataNotEntirelyConsumed. Use io::Cursor over the buffer and StrictDecode::strict_decode to avoid such failures.
source§

fn strict_file_load(path: impl AsRef<Path>) -> Result<Self, Error>

Reads data from file at path and reconstructs object from it. Fails with Error::DataNotEntirelyConsumed if file contains remaining data after the object reconstruction.
source§

impl StrictEncode for Beneficiary

source§

fn strict_encode<E: Write>(&self, e: E) -> Result<usize, Error>

Encode with the given std::io::Write instance; must return result with either amount of bytes encoded – or implementation-specific error type.
source§

fn strict_serialize(&self) -> Result<Vec<u8, Global>, Error>

Serializes data as a byte array using StrictEncode::strict_encode function
source§

fn strict_file_save(&self, path: impl AsRef<Path>) -> Result<usize, Error>

Saves data to a file at a given path. If the file does not exists, attempts to create the file. If the file already exists, it gets truncated.
source§

impl Eq for Beneficiary

source§

impl StructuralEq for Beneficiary

source§

impl StructuralPartialEq for Beneficiary

Auto Trait Implementations§

Blanket Implementations§

source§

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

source§

fn type_id(&self) -> TypeId

Gets the TypeId of self. Read more
source§

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

const: unstable · source§

fn borrow(&self) -> &T

Immutably borrows from an owned value. Read more
source§

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

const: unstable · source§

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

Mutably borrows from an owned value. Read more
source§

impl<T> From<T> for T

const: unstable · source§

fn from(t: T) -> T

Returns the argument unchanged.

source§

impl<T, U> Into<U> for Twhere U: From<T>,

const: unstable · 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> Same<T> for T

§

type Output = T

Should always be Self
source§

impl<T> ToOwned for Twhere 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> ToString for Twhere T: Display + ?Sized,

source§

default fn to_string(&self) -> String

Converts the given value to a String. Read more
source§

impl<T, U> TryFrom<U> for Twhere U: Into<T>,

§

type Error = Infallible

The type returned in the event of a conversion error.
const: unstable · source§

fn try_from(value: U) -> Result<T, <T as TryFrom<U>>::Error>

Performs the conversion.
source§

impl<T, U> TryInto<U> for Twhere U: TryFrom<T>,

§

type Error = <U as TryFrom<T>>::Error

The type returned in the event of a conversion error.
const: unstable · source§

fn try_into(self) -> Result<U, <U as TryFrom<T>>::Error>

Performs the conversion.
§

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

§

fn vzip(self) -> V

source§

impl<T> VerifyEq for Twhere T: Eq,

source§

fn verify_eq(&self, other: &T) -> bool

Verifies commit-equivalence of two instances of the same type.