breez_sdk_liquid::lightning_125::chain::chainmonitor

Trait Persist

pub trait Persist<ChannelSigner>
where ChannelSigner: EcdsaChannelSigner,
{ // Required methods fn persist_new_channel( &self, channel_funding_outpoint: OutPoint, monitor: &ChannelMonitor<ChannelSigner>, ) -> ChannelMonitorUpdateStatus; fn update_persisted_channel( &self, channel_funding_outpoint: OutPoint, monitor_update: Option<&ChannelMonitorUpdate>, monitor: &ChannelMonitor<ChannelSigner>, ) -> ChannelMonitorUpdateStatus; fn archive_persisted_channel(&self, channel_funding_outpoint: OutPoint); }
Expand description

Persist defines behavior for persisting channel monitors: this could mean writing once to disk, and/or uploading to one or more backup services.

Persistence can happen in one of two ways - synchronously completing before the trait method calls return or asynchronously in the background.

§For those implementing synchronous persistence

§For those implementing asynchronous persistence

All calls should generally spawn a background task and immediately return ChannelMonitorUpdateStatus::InProgress. Once the update completes, ChainMonitor::channel_monitor_updated should be called with the corresponding ChannelMonitor::get_latest_update_id or ChannelMonitorUpdate::update_id.

Note that unlike the direct chain::Watch interface, ChainMonitor::channel_monitor_updated must be called once for each update which occurs.

If at some point no further progress can be made towards persisting a pending update, the node should simply shut down. Until then, the background task should either loop indefinitely, or persistence should be regularly retried with ChainMonitor::list_pending_monitor_updates and ChainMonitor::get_monitor (note that if a full monitor is persisted all pending monitor updates may be marked completed).

§Using remote watchtowers

Watchtowers may be updated as a part of an implementation of this trait, utilizing the async update process described above while the watchtower is being updated. The following methods are provided for bulding transactions for a watchtower: ChannelMonitor::initial_counterparty_commitment_tx, ChannelMonitor::counterparty_commitment_txs_from_update, ChannelMonitor::sign_to_local_justice_tx, TrustedCommitmentTransaction::revokeable_output_index, TrustedCommitmentTransaction::build_to_local_justice_tx.

Required Methods§

fn persist_new_channel( &self, channel_funding_outpoint: OutPoint, monitor: &ChannelMonitor<ChannelSigner>, ) -> ChannelMonitorUpdateStatus

Persist a new channel’s data in response to a chain::Watch::watch_channel call. This is called by ChannelManager for new channels, or may be called directly, e.g. on startup.

The data can be stored any way you want, but the identifier provided by LDK is the channel’s outpoint (and it is up to you to maintain a correct mapping between the outpoint and the stored channel data). Note that you must persist every new monitor to disk.

The ChannelMonitor::get_latest_update_id uniquely links this call to ChainMonitor::channel_monitor_updated. For Persist::persist_new_channel, it is only necessary to call ChainMonitor::channel_monitor_updated when you return ChannelMonitorUpdateStatus::InProgress.

See Writeable::write on ChannelMonitor for writing out a ChannelMonitor and ChannelMonitorUpdateStatus for requirements when returning errors.

fn update_persisted_channel( &self, channel_funding_outpoint: OutPoint, monitor_update: Option<&ChannelMonitorUpdate>, monitor: &ChannelMonitor<ChannelSigner>, ) -> ChannelMonitorUpdateStatus

Update one channel’s data. The provided ChannelMonitor has already applied the given update.

Note that on every update, you must persist either the ChannelMonitorUpdate or the updated monitor itself to disk/backups. See the Persist trait documentation for more details.

During blockchain synchronization operations, and in some rare cases, this may be called with no ChannelMonitorUpdate, in which case the full ChannelMonitor needs to be persisted. Note that after the full ChannelMonitor is persisted any previous ChannelMonitorUpdates which were persisted should be discarded - they can no longer be applied to the persisted ChannelMonitor as they were already applied.

If an implementer chooses to persist the updates only, they need to make sure that all the updates are applied to the ChannelMonitors before the set of channel monitors is given to the ChannelManager deserialization routine. If there are any gaps in the persisted ChannelMonitorUpdates, implementer can safely ignore ChannelMonitorUpdates after the gap and load without them. See ChannelMonitor::update_monitor for applying a monitor update to a monitor. If full ChannelMonitors are persisted, then there is no need to persist individual updates.

Note that there could be a performance tradeoff between persisting complete channel monitors on every update vs. persisting only updates and applying them in batches. The size of each monitor grows O(number of state updates) whereas updates are small and O(1).

The ChannelMonitorUpdate::update_id or ChannelMonitor::get_latest_update_id uniquely links this call to ChainMonitor::channel_monitor_updated. For Persist::update_persisted_channel, it is only necessary to call ChainMonitor::channel_monitor_updated when a ChannelMonitorUpdate is provided and when you return ChannelMonitorUpdateStatus::InProgress.

See Writeable::write on ChannelMonitor for writing out a ChannelMonitor, Writeable::write on ChannelMonitorUpdate for writing out an update, and ChannelMonitorUpdateStatus for requirements when returning errors.

fn archive_persisted_channel(&self, channel_funding_outpoint: OutPoint)

Prevents the channel monitor from being loaded on startup.

Archiving the data in a backup location (rather than deleting it fully) is useful for hedging against data loss in case of unexpected failure.

Implementors§

§

impl<ChannelSigner, K> Persist<ChannelSigner> for K
where ChannelSigner: EcdsaChannelSigner, K: KVStore + ?Sized,

§

impl<ChannelSigner, K, L, ES, SP, BI, FE> Persist<ChannelSigner> for MonitorUpdatingPersister<K, L, ES, SP, BI, FE>
where ChannelSigner: EcdsaChannelSigner, K: Deref, L: Deref, ES: Deref, SP: Deref, BI: Deref, FE: Deref, <K as Deref>::Target: KVStore, <L as Deref>::Target: Logger, <ES as Deref>::Target: Sized + EntropySource, <SP as Deref>::Target: Sized + SignerProvider, <BI as Deref>::Target: BroadcasterInterface, <FE as Deref>::Target: FeeEstimator,