Enum ConfirmationTarget
pub enum ConfirmationTarget {
MaximumFeeEstimate,
UrgentOnChainSweep,
MinAllowedAnchorChannelRemoteFee,
MinAllowedNonAnchorChannelRemoteFee,
AnchorChannelFee,
NonAnchorChannelFee,
ChannelCloseMinimum,
OutputSpendingFee,
}
Expand description
An enum that represents the priority at which we want a transaction to confirm used for feerate estimation.
Variants§
MaximumFeeEstimate
The most aggressive (i.e. highest) feerate estimate available.
This is used to sanity-check our counterparty’s feerates and should be as conservative as possible to ensure that we don’t confuse a peer using a very conservative estimator for one trying to burn channel balance to dust.
UrgentOnChainSweep
We have some funds available on chain which we need to spend prior to some expiry time at which point our counterparty may be able to steal them.
Generally we have in the high tens to low hundreds of blocks to get our transaction on-chain (it doesn’t have to happen in the next few blocks!), but we shouldn’t risk too low a fee - this should be a relatively high priority feerate.
MinAllowedAnchorChannelRemoteFee
This is the lowest feerate we will allow our channel counterparty to have in an anchor channel in order to close the channel if a channel party goes away.
This needs to be sufficient to get into the mempool when the channel needs to be force-closed. Setting too high may result in force-closures if our counterparty attempts to use a lower feerate. Because this is for anchor channels, we can always bump the feerate later; the feerate here only needs to be sufficient to enter the mempool.
A good estimate is the expected mempool minimum at the time of force-closure. Obviously this is not an estimate which is very easy to calculate because we do not know the future. Using a simple long-term fee estimate or tracking of the mempool minimum is a good approach to ensure you can always close the channel. A future change to Bitcoin’s P2P network (package relay) may obviate the need for this entirely.
MinAllowedNonAnchorChannelRemoteFee
The lowest feerate we will allow our channel counterparty to have in a non-anchor channel.
This is the feerate on the transaction which we (or our counterparty) will broadcast in order to close the channel if a channel party goes away. Setting this value too high will cause immediate force-closures in order to avoid having an unbroadcastable state.
This feerate represents the fee we pick now, which must be sufficient to enter a block at an arbitrary time in the future. Obviously this is not an estimate which is very easy to calculate. This can leave channels subject to being unable to close if feerates rise, and in general you should prefer anchor channels to ensure you can increase the feerate when the transactions need broadcasting.
Do note some fee estimators round up to the next full sat/vbyte (ie 250 sats per kw), causing occasional issues with feerate disagreements between an initiator that wants a feerate of 1.1 sat/vbyte and a receiver that wants 1.1 rounded up to 2. If your fee estimator rounds subtracting 250 to your desired feerate here can help avoid this issue.
AnchorChannelFee
This is the feerate on the transaction which we (or our counterparty) will broadcast in order to close the channel if a channel party goes away.
This needs to be sufficient to get into the mempool when the channel needs to be force-closed. Setting too low may result in force-closures. Because this is for anchor channels, it can be a low value as we can always bump the feerate later.
A good estimate is the expected mempool minimum at the time of force-closure. Obviously this is not an estimate which is very easy to calculate because we do not know the future. Using a simple long-term fee estimate or tracking of the mempool minimum is a good approach to ensure you can always close the channel. A future change to Bitcoin’s P2P network (package relay) may obviate the need for this entirely.
NonAnchorChannelFee
Lightning is built around the ability to broadcast a transaction in the future to close our channel and claim all pending funds. In order to do so, non-anchor channels are built with transactions which we need to be able to broadcast at some point in the future.
This feerate represents the fee we pick now, which must be sufficient to enter a block at an arbitrary time in the future. Obviously this is not an estimate which is very easy to calculate, so most lightning nodes use some relatively high-priority feerate using the current mempool. This leaves channels subject to being unable to close if feerates rise, and in general you should prefer anchor channels to ensure you can increase the feerate when the transactions need broadcasting.
Since this should represent the feerate of a channel close that does not need fee bumping, this is also used as an upper bound for our attempted feerate when doing cooperative closure of any channel.
ChannelCloseMinimum
When cooperatively closing a channel, this is the minimum feerate we will accept. Recommended at least within a day or so worth of blocks.
This will also be used when initiating a cooperative close of a channel. When closing a
channel you can override this fee by using
ChannelManager::close_channel_with_feerate_and_script
.
OutputSpendingFee
The feerate used to claim on-chain funds when there is no particular urgency to do so.
It is used to get commitment transactions without any HTLCs confirmed in ChannelMonitor
and by OutputSweeper
on transactions spending SpendableOutputDescriptor
s after a
channel closure.
Generally spending these outputs is safe as long as they eventually confirm, so a value
(slightly above) the mempool minimum should suffice. However, as this value will influence
how long funds will be unavailable after channel closure, FeeEstimator
implementors
might want to choose a higher feerate to regain control over funds faster.
Trait Implementations§
§impl Clone for ConfirmationTarget
impl Clone for ConfirmationTarget
§fn clone(&self) -> ConfirmationTarget
fn clone(&self) -> ConfirmationTarget
1.0.0 · Source§fn clone_from(&mut self, source: &Self)
fn clone_from(&mut self, source: &Self)
source
. Read more§impl Debug for ConfirmationTarget
impl Debug for ConfirmationTarget
§impl Hash for ConfirmationTarget
impl Hash for ConfirmationTarget
§impl PartialEq for ConfirmationTarget
impl PartialEq for ConfirmationTarget
impl Copy for ConfirmationTarget
impl Eq for ConfirmationTarget
impl StructuralPartialEq for ConfirmationTarget
Auto Trait Implementations§
impl Freeze for ConfirmationTarget
impl RefUnwindSafe for ConfirmationTarget
impl Send for ConfirmationTarget
impl Sync for ConfirmationTarget
impl Unpin for ConfirmationTarget
impl UnwindSafe for ConfirmationTarget
Blanket Implementations§
§impl<T> AnyEq for T
impl<T> AnyEq 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,
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<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> 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
Source§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