Enum ChannelMonitorUpdateStatus
pub enum ChannelMonitorUpdateStatus {
Completed,
InProgress,
UnrecoverableError,
}
Expand description
An enum representing the status of a channel monitor update persistence.
These are generally used as the return value for an implementation of Persist
which is used
as the storage layer for a ChainMonitor
. See the docs on Persist
for a high-level
explanation of how to handle different cases.
While UnrecoverableError
is provided as a failure variant, it is not truly “handled” on the
calling side, and generally results in an immediate panic. For those who prefer to avoid
panics, InProgress
can be used and you can retry the update operation in the background or
shut down cleanly.
Note that channels should generally not be force-closed after a persistence failure.
Force-closing with the latest ChannelMonitorUpdate
applied may result in a transaction
being broadcast which can only be spent by the latest ChannelMonitor
! Thus, if the
latest ChannelMonitor
is not durably persisted anywhere and exists only in memory, naively
calling ChannelManager::force_close_broadcasting_latest_txn
may result in loss of funds!
Variants§
Completed
The update has been durably persisted and all copies of the relevant ChannelMonitor
have been updated.
This includes performing any fsync()
calls required to ensure the update is guaranteed to
be available on restart even if the application crashes.
InProgress
Indicates that the update will happen asynchronously in the background or that a transient failure occurred which is being retried in the background and will eventually complete.
This will “freeze” a channel, preventing us from revoking old states or submitting a new
commitment transaction to the counterparty. Once the update(s) which are InProgress
have
been completed, a MonitorEvent::Completed
can be used to restore the channel to an
operational state.
Even when a channel has been “frozen”, updates to the ChannelMonitor
can continue to
occur (e.g. if an inbound HTLC which we forwarded was claimed upstream, resulting in us
attempting to claim it on this channel) and those updates must still be persisted.
No updates to the channel will be made which could invalidate other ChannelMonitor
s
until a MonitorEvent::Completed
is provided, even if you return no error on a later
monitor update for the same channel.
For deployments where a copy of ChannelMonitor
s and other local state are backed up in
a remote location (with local copies persisted immediately), it is anticipated that all
updates will return InProgress
until the remote copies could be updated.
Note that while fully asynchronous persistence of ChannelMonitor
data is generally
reliable, this feature is considered beta, and a handful of edge-cases remain. Until the
remaining cases are fixed, in rare cases, using this feature may lead to funds loss.
UnrecoverableError
Indicates that an update has failed and will not complete at any point in the future.
Currently returning this variant will cause LDK to immediately panic to encourage immediate shutdown. In the future this may be updated to disconnect peers and refuse to continue normal operation without a panic.
Applications which wish to perform an orderly shutdown after failure should consider
returning InProgress
instead and simply shut down without ever marking the update
complete.
Trait Implementations§
§impl Clone for ChannelMonitorUpdateStatus
impl Clone for ChannelMonitorUpdateStatus
§fn clone(&self) -> ChannelMonitorUpdateStatus
fn clone(&self) -> ChannelMonitorUpdateStatus
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl Debug for ChannelMonitorUpdateStatus
impl Debug for ChannelMonitorUpdateStatus
§impl PartialEq for ChannelMonitorUpdateStatus
impl PartialEq for ChannelMonitorUpdateStatus
impl Copy for ChannelMonitorUpdateStatus
impl Eq for ChannelMonitorUpdateStatus
impl StructuralPartialEq for ChannelMonitorUpdateStatus
Auto Trait Implementations§
impl Freeze for ChannelMonitorUpdateStatus
impl RefUnwindSafe for ChannelMonitorUpdateStatus
impl Send for ChannelMonitorUpdateStatus
impl Sync for ChannelMonitorUpdateStatus
impl Unpin for ChannelMonitorUpdateStatus
impl UnwindSafe for ChannelMonitorUpdateStatus
Blanket Implementations§
§impl<T> AnySync for T
impl<T> AnySync for T
§impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedExplicit<'a, E> for Twhere
T: 'a,
§impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
impl<'a, T, E> AsTaggedImplicit<'a, E> for Twhere
T: 'a,
Source§impl<T> BorrowMut<T> for Twhere
T: ?Sized,
impl<T> BorrowMut<T> for Twhere
T: ?Sized,
Source§fn borrow_mut(&mut self) -> &mut T
fn borrow_mut(&mut self) -> &mut T
Source§impl<T> CloneToUninit for Twhere
T: Clone,
impl<T> CloneToUninit for Twhere
T: Clone,
§impl<T> Downcast for Twhere
T: AsAny + ?Sized,
impl<T> Downcast for Twhere
T: AsAny + ?Sized,
§fn downcast_ref<T>(&self) -> Option<&T>where
T: AsAny,
fn downcast_ref<T>(&self) -> Option<&T>where
T: AsAny,
Any
.§fn downcast_mut<T>(&mut self) -> Option<&mut T>where
T: AsAny,
fn downcast_mut<T>(&mut self) -> Option<&mut T>where
T: AsAny,
Any
.Source§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
Source§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
key
and return true
if they are equal.§impl<Q, K> Equivalent<K> for Q
impl<Q, K> Equivalent<K> for Q
§fn equivalent(&self, key: &K) -> bool
fn equivalent(&self, key: &K) -> bool
§impl<T> Instrument for T
impl<T> Instrument for T
§fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
fn instrument(self, span: Span) -> Instrumented<Self> ⓘ
Source§impl<T> IntoEither for T
impl<T> IntoEither for T
Source§fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
fn into_either(self, into_left: bool) -> Either<Self, Self> ⓘ
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 moreSource§fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
fn into_either_with<F>(self, into_left: F) -> Either<Self, Self> ⓘ
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 moreSource§impl<T> IntoRequest<T> for T
impl<T> IntoRequest<T> for T
Source§fn into_request(self) -> Request<T>
fn into_request(self) -> Request<T>
T
in a tonic::Request