breez_sdk_liquid::lightning_with_bolt12::util::persist

Struct UpdateName

pub struct UpdateName(pub u64, _);
Expand description

A struct representing a name for a channel monitor update.

UpdateName is primarily used within the MonitorUpdatingPersister in functions that store or retrieve partial updates to channel monitors. It provides a consistent way to generate and parse unique identifiers for monitor updates based on their sequence number.

The name is derived from the update’s sequence ID, which is a monotonically increasing u64 value. This format allows for easy ordering of updates and efficient storage and retrieval in key-value stores.

§Usage

While users of the Lightning Dev Kit library generally won’t need to interact with UpdateName directly, it still can be useful for custom persistence implementations. The u64 value is the update_id that can be compared with ChannelMonitor::get_latest_update_id to check if this update has been applied to the channel monitor or not, which is useful for pruning stale channel monitor updates off persistence.

§Examples

use lightning::util::persist::UpdateName;

let update_id: u64 = 42;
let update_name = UpdateName::from(update_id);
assert_eq!(update_name.as_str(), "42");

// Using UpdateName to generate a storage key
let monitor_name = "some_monitor_name";
let storage_key = format!("channel_monitor_updates/{}/{}", monitor_name, update_name.as_str());

Tuple Fields§

§0: u64

Implementations§

§

impl UpdateName

pub fn new(name: String) -> Result<UpdateName, Error>

Constructs an UpdateName, after verifying that an update sequence ID can be derived from the given name.

pub fn as_str(&self) -> &str

Convert this update name to a string slice.

This method is particularly useful when you need to use the update name as part of a key in a key-value store or when logging.

§Examples
use lightning::util::persist::UpdateName;

let update_name = UpdateName::from(42);
assert_eq!(update_name.as_str(), "42");

Trait Implementations§

§

impl Debug for UpdateName

§

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

Formats the value using the given formatter. Read more
§

impl From<u64> for UpdateName

§

fn from(value: u64) -> UpdateName

Creates an UpdateName from a u64.

This is typically used when you need to generate a storage key or identifier for a new channel monitor update.

§Examples
use lightning::util::persist::UpdateName;

let update_id: u64 = 42;
let update_name = UpdateName::from(update_id);
assert_eq!(update_name.as_str(), "42");

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 + Send + Sync>

§

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
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> IntoEither for T

Source§

fn into_either(self, into_left: bool) -> Either<Self, Self>

Converts self into a Left variant of Either<Self, Self> if into_left is true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
Source§

fn into_either_with<F>(self, into_left: F) -> Either<Self, Self>
where F: FnOnce(&Self) -> bool,

Converts self into a Left variant of Either<Self, Self> if into_left(&self) returns true. Converts self into a Right variant of Either<Self, Self> otherwise. Read more
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

§

impl<T> ErasedDestructor for T
where T: 'static,

§

impl<T> MaybeSendSync for T

§

impl<T> TaskRetFutTrait for T
where T: Send,