Struct LockedChannelMonitor
pub struct LockedChannelMonitor<'a, ChannelSigner>where
ChannelSigner: WriteableEcdsaChannelSigner,{ /* private fields */ }
Expand description
A read-only reference to a current ChannelMonitor.
Note that this holds a mutex in ChainMonitor
and may block other events until it is
released.
Methods from Deref<Target = ChannelMonitor<ChannelSigner>>§
pub fn update_monitor<B, F, L>(
&self,
updates: &ChannelMonitorUpdate,
broadcaster: &B,
fee_estimator: &F,
logger: &L,
) -> Result<(), ()>
pub fn update_monitor<B, F, L>( &self, updates: &ChannelMonitorUpdate, broadcaster: &B, fee_estimator: &F, logger: &L, ) -> Result<(), ()>
Updates a ChannelMonitor on the basis of some new information provided by the Channel itself.
panics if the given update is not the next update by update_id.
pub fn get_latest_update_id(&self) -> u64
pub fn get_latest_update_id(&self) -> u64
Gets the update_id from the latest ChannelMonitorUpdate which was applied to this ChannelMonitor.
pub fn get_funding_txo(&self) -> (OutPoint, Script)
pub fn get_funding_txo(&self) -> (OutPoint, Script)
Gets the funding transaction outpoint of the channel this ChannelMonitor is monitoring for.
pub fn get_outputs_to_watch(&self) -> Vec<(Txid, Vec<(u32, Script)>)>
pub fn get_outputs_to_watch(&self) -> Vec<(Txid, Vec<(u32, Script)>)>
Gets a list of txids, with their output scripts (in the order they appear in the transaction), which we must learn about spends of via block_connected().
pub fn load_outputs_to_watch<F>(&self, filter: &F)
pub fn load_outputs_to_watch<F>(&self, filter: &F)
Loads the funding txo and outputs to watch into the given chain::Filter
by repeatedly
calling chain::Filter::register_output
and chain::Filter::register_tx
until all outputs
have been registered.
pub fn get_and_clear_pending_monitor_events(&self) -> Vec<MonitorEvent>
pub fn get_and_clear_pending_monitor_events(&self) -> Vec<MonitorEvent>
Get the list of HTLCs who’s status has been updated on chain. This should be called by
ChannelManager via chain::Watch::release_pending_monitor_events
.
pub fn process_pending_events<H>(&self, handler: &H)
pub fn process_pending_events<H>(&self, handler: &H)
Processes SpendableOutputs
events produced from each ChannelMonitor
upon maturity.
For channels featuring anchor outputs, this method will also process BumpTransaction
events produced from each ChannelMonitor
while there is a balance to claim onchain
within each channel. As the confirmation of a commitment transaction may be critical to the
safety of funds, we recommend invoking this every 30 seconds, or lower if running in an
environment with spotty connections, like on mobile.
An EventHandler
may safely call back to the provider, though this shouldn’t be needed in
order to handle these events.
pub async fn process_pending_events_async<Future, H>(&self, handler: &H)
pub async fn process_pending_events_async<Future, H>(&self, handler: &H)
Processes any events asynchronously.
See Self::process_pending_events
for more information.
pub fn initial_counterparty_commitment_tx(
&self,
) -> Option<CommitmentTransaction>
pub fn initial_counterparty_commitment_tx( &self, ) -> Option<CommitmentTransaction>
Gets the counterparty’s initial commitment transaction. The returned commitment
transaction is unsigned. This is intended to be called during the initial persistence of
the monitor (inside an implementation of Persist::persist_new_channel
), to allow for
watchtowers in the persistence pipeline to have enough data to form justice transactions.
This is similar to Self::counterparty_commitment_txs_from_update
, except
that for the initial commitment transaction, we don’t have a corresponding update.
This will only return Some
for channel monitors that have been created after upgrading
to LDK 0.0.117+.
pub fn counterparty_commitment_txs_from_update(
&self,
update: &ChannelMonitorUpdate,
) -> Vec<CommitmentTransaction>
pub fn counterparty_commitment_txs_from_update( &self, update: &ChannelMonitorUpdate, ) -> Vec<CommitmentTransaction>
Gets all of the counterparty commitment transactions provided by the given update. This may be empty if the update doesn’t include any new counterparty commitments. Returned commitment transactions are unsigned.
This is provided so that watchtower clients in the persistence pipeline are able to build
justice transactions for each counterparty commitment upon each update. It’s intended to be
used within an implementation of Persist::update_persisted_channel
, which is provided
with a monitor and an update. Once revoked, signing a justice transaction can be done using
Self::sign_to_local_justice_tx
.
It is expected that a watchtower client may use this method to retrieve the latest counterparty commitment transaction(s), and then hold the necessary data until a later update in which the monitor has been updated with the corresponding revocation data, at which point the monitor can sign the justice transaction.
This will only return a non-empty list for monitor updates that have been created after upgrading to LDK 0.0.117+. Note that no restriction lies on the monitors themselves, which may have been created prior to upgrading.
pub fn sign_to_local_justice_tx(
&self,
justice_tx: Transaction,
input_idx: usize,
value: u64,
commitment_number: u64,
) -> Result<Transaction, ()>
pub fn sign_to_local_justice_tx( &self, justice_tx: Transaction, input_idx: usize, value: u64, commitment_number: u64, ) -> Result<Transaction, ()>
Wrapper around EcdsaChannelSigner::sign_justice_revoked_output
to make
signing the justice transaction easier for implementors of
chain::chainmonitor::Persist
. On success this method returns the provided transaction
signing the input at input_idx
. This method will only produce a valid signature for
a transaction spending the to_local
output of a commitment transaction, i.e. this cannot
be used for revoked HTLC outputs.
Value
is the value of the output being spent by the input at input_idx
, committed
in the BIP 143 signature.
This method will only succeed if this monitor has received the revocation secret for the
provided commitment_number
. If a commitment number is provided that does not correspond
to the commitment transaction being revoked, this will return a signed transaction, but
the signature will not be valid.
pub fn get_counterparty_node_id(&self) -> Option<PublicKey>
pub fn get_counterparty_node_id(&self) -> Option<PublicKey>
Gets the node_id
of the counterparty for this channel.
Will be None
for channels constructed on LDK versions prior to 0.0.110 and always Some
otherwise.
pub fn get_latest_holder_commitment_txn<L>(
&self,
logger: &L,
) -> Vec<Transaction>
pub fn get_latest_holder_commitment_txn<L>( &self, logger: &L, ) -> Vec<Transaction>
Used by ChannelManager
deserialization to broadcast the latest holder state if its copy
of the channel state was out-of-date.
You may also use this to broadcast the latest local commitment transaction, either because a monitor update failed or because we’ve fallen behind (i.e. we’ve received proof that our counterparty side knows a revocation secret we gave them that they shouldn’t know).
Broadcasting these transactions in the second case is UNSAFE, as they allow counterparty side to punish you. Nevertheless you may want to broadcast them if counterparty doesn’t close channel with their commitment transaction after a substantial amount of time. Best may be to contact the other node operator out-of-band to coordinate other options available to you.
pub fn unsafe_get_latest_holder_commitment_txn<L>(
&self,
logger: &L,
) -> Vec<Transaction>
pub fn unsafe_get_latest_holder_commitment_txn<L>( &self, logger: &L, ) -> Vec<Transaction>
Unsafe test-only version of get_latest_holder_commitment_txn used by our test framework to bypass HolderCommitmentTransaction state update lockdown after signature and generate revoked commitment transaction.
pub fn block_connected<B, F, L>(
&self,
header: &BlockHeader,
txdata: &[(usize, &Transaction)],
height: u32,
broadcaster: B,
fee_estimator: F,
logger: L,
) -> Vec<(Txid, Vec<(u32, TxOut)>)>
pub fn block_connected<B, F, L>( &self, header: &BlockHeader, txdata: &[(usize, &Transaction)], height: u32, broadcaster: B, fee_estimator: F, logger: L, ) -> Vec<(Txid, Vec<(u32, TxOut)>)>
Processes transactions in a newly connected block, which may result in any of the following:
- update the monitor’s state against resolved HTLCs
- punish the counterparty in the case of seeing a revoked commitment transaction
- force close the channel and claim/timeout incoming/outgoing HTLCs if near expiration
- detect settled outputs for later spending
- schedule and bump any in-flight claims
Returns any new outputs to watch from txdata
; after called, these are also included in
get_outputs_to_watch
.
pub fn block_disconnected<B, F, L>(
&self,
header: &BlockHeader,
height: u32,
broadcaster: B,
fee_estimator: F,
logger: L,
)
pub fn block_disconnected<B, F, L>( &self, header: &BlockHeader, height: u32, broadcaster: B, fee_estimator: F, logger: L, )
Determines if the disconnected block contained any transactions of interest and updates appropriately.
pub fn transactions_confirmed<B, F, L>(
&self,
header: &BlockHeader,
txdata: &[(usize, &Transaction)],
height: u32,
broadcaster: B,
fee_estimator: F,
logger: L,
) -> Vec<(Txid, Vec<(u32, TxOut)>)>
pub fn transactions_confirmed<B, F, L>( &self, header: &BlockHeader, txdata: &[(usize, &Transaction)], height: u32, broadcaster: B, fee_estimator: F, logger: L, ) -> Vec<(Txid, Vec<(u32, TxOut)>)>
Processes transactions confirmed in a block with the given header and height, returning new
outputs to watch. See block_connected
for details.
Used instead of block_connected
by clients that are notified of transactions rather than
blocks. See chain::Confirm
for calling expectations.
pub fn transaction_unconfirmed<B, F, L>(
&self,
txid: &Txid,
broadcaster: B,
fee_estimator: F,
logger: L,
)
pub fn transaction_unconfirmed<B, F, L>( &self, txid: &Txid, broadcaster: B, fee_estimator: F, logger: L, )
Processes a transaction that was reorganized out of the chain.
Used instead of block_disconnected
by clients that are notified of transactions rather
than blocks. See chain::Confirm
for calling expectations.
pub fn best_block_updated<B, F, L>(
&self,
header: &BlockHeader,
height: u32,
broadcaster: B,
fee_estimator: F,
logger: L,
) -> Vec<(Txid, Vec<(u32, TxOut)>)>
pub fn best_block_updated<B, F, L>( &self, header: &BlockHeader, height: u32, broadcaster: B, fee_estimator: F, logger: L, ) -> Vec<(Txid, Vec<(u32, TxOut)>)>
Updates the monitor with the current best chain tip, returning new outputs to watch. See
block_connected
for details.
Used instead of block_connected
by clients that are notified of transactions rather than
blocks. See chain::Confirm
for calling expectations.
pub fn get_relevant_txids(&self) -> Vec<(Txid, Option<BlockHash>)>
pub fn get_relevant_txids(&self) -> Vec<(Txid, Option<BlockHash>)>
Returns the set of txids that should be monitored for re-organization out of the chain.
pub fn current_best_block(&self) -> BestBlock
pub fn current_best_block(&self) -> BestBlock
Gets the latest best block which was connected either via the chain::Listen
or
chain::Confirm
interfaces.
pub fn rebroadcast_pending_claims<B, F, L>(
&self,
broadcaster: B,
fee_estimator: F,
logger: L,
)
pub fn rebroadcast_pending_claims<B, F, L>( &self, broadcaster: B, fee_estimator: F, logger: L, )
Triggers rebroadcasts/fee-bumps of pending claims from a force-closed channel. This is crucial in preventing certain classes of pinning attacks, detecting substantial mempool feerate changes between blocks, and ensuring reliability if broadcasting fails. We recommend invoking this every 30 seconds, or lower if running in an environment with spotty connections, like on mobile.
pub fn get_spendable_outputs(
&self,
tx: &Transaction,
confirmation_height: u32,
) -> Vec<SpendableOutputDescriptor>
pub fn get_spendable_outputs( &self, tx: &Transaction, confirmation_height: u32, ) -> Vec<SpendableOutputDescriptor>
Returns the descriptors for relevant outputs (i.e., those that we can spend) within the
transaction if they exist and the transaction has at least ANTI_REORG_DELAY
confirmations. For SpendableOutputDescriptor::DelayedPaymentOutput
descriptors to be
returned, the transaction must have at least max(ANTI_REORG_DELAY, to_self_delay)
confirmations.
Descriptors returned by this method are primarily exposed via Event::SpendableOutputs
once they are no longer under reorg risk. This method serves as a way to retrieve these
descriptors at a later time, either for historical purposes, or to replay any
missed/unhandled descriptors. For the purpose of gathering historical records, if the
channel close has fully resolved (i.e., ChannelMonitor::get_claimable_balances
returns
an empty set), you can retrieve all spendable outputs by providing all descendant spending
transactions starting from the channel’s funding transaction and going down three levels.
tx
is a transaction we’ll scan the outputs of. Any transaction can be provided. If any
outputs which can be spent by us are found, at least one descriptor is returned.
confirmation_height
must be the height of the block in which tx
was included in.
pub fn get_claimable_balances(&self) -> Vec<Balance>
pub fn get_claimable_balances(&self) -> Vec<Balance>
Gets the balances in this channel which are either claimable by us if we were to force-close the channel now or which are claimable on-chain (possibly awaiting confirmation).
Any balances in the channel which are available on-chain (excluding on-chain fees) are
included here until an Event::SpendableOutputs
event has been generated for the
balance, or until our counterparty has claimed the balance and accrued several
confirmations on the claim transaction.
Note that for ChannelMonitors
which track a channel which went on-chain with versions of
LDK prior to 0.0.111, not all or excess balances may be included.
See Balance
for additional details on the types of claimable balances which
may be returned here and their meanings.
Trait Implementations§
§impl<ChannelSigner> Deref for LockedChannelMonitor<'_, ChannelSigner>where
ChannelSigner: WriteableEcdsaChannelSigner,
impl<ChannelSigner> Deref for LockedChannelMonitor<'_, ChannelSigner>where
ChannelSigner: WriteableEcdsaChannelSigner,
§type Target = ChannelMonitor<ChannelSigner>
type Target = ChannelMonitor<ChannelSigner>
§fn deref(&self) -> &ChannelMonitor<ChannelSigner>
fn deref(&self) -> &ChannelMonitor<ChannelSigner>
Auto Trait Implementations§
impl<'a, ChannelSigner> Freeze for LockedChannelMonitor<'a, ChannelSigner>
impl<'a, ChannelSigner> RefUnwindSafe for LockedChannelMonitor<'a, ChannelSigner>
impl<'a, ChannelSigner> !Send for LockedChannelMonitor<'a, ChannelSigner>
impl<'a, ChannelSigner> Sync for LockedChannelMonitor<'a, ChannelSigner>where
ChannelSigner: Send,
impl<'a, ChannelSigner> Unpin for LockedChannelMonitor<'a, ChannelSigner>
impl<'a, ChannelSigner> UnwindSafe for LockedChannelMonitor<'a, ChannelSigner>
Blanket Implementations§
§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
§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
.§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