Enum Balance
pub enum Balance {
ClaimableOnChannelClose {
amount_satoshis: u64,
},
ClaimableAwaitingConfirmations {
amount_satoshis: u64,
confirmation_height: u32,
},
ContentiousClaimable {
amount_satoshis: u64,
timeout_height: u32,
payment_hash: PaymentHash,
payment_preimage: PaymentPreimage,
},
MaybeTimeoutClaimableHTLC {
amount_satoshis: u64,
claimable_height: u32,
payment_hash: PaymentHash,
},
MaybePreimageClaimableHTLC {
amount_satoshis: u64,
expiry_height: u32,
payment_hash: PaymentHash,
},
CounterpartyRevokedOutputClaimable {
amount_satoshis: u64,
},
}
Expand description
Details about the balance(s) available for spending once the channel appears on chain.
See ChannelMonitor::get_claimable_balances
for more details on when these will or will not
be provided.
Variants§
ClaimableOnChannelClose
The channel is not yet closed (or the commitment or closing transaction has not yet appeared in a block). The given balance is claimable (less on-chain fees) if the channel is force-closed now.
Fields
ClaimableAwaitingConfirmations
The channel has been closed, and the given balance is ours but awaiting confirmations until we consider it spendable.
Fields
amount_satoshis: u64
The amount available to claim, in satoshis, possibly excluding the on-chain fees which were spent in broadcasting the transaction.
confirmation_height: u32
The height at which an Event::SpendableOutputs
event will be generated for this
amount.
ContentiousClaimable
The channel has been closed, and the given balance should be ours but awaiting spending transaction confirmation. If the spending transaction does not confirm in time, it is possible our counterparty can take the funds by broadcasting an HTLC timeout on-chain.
Once the spending transaction confirms, before it has reached enough confirmations to be
considered safe from chain reorganizations, the balance will instead be provided via
Balance::ClaimableAwaitingConfirmations
.
Fields
amount_satoshis: u64
The amount available to claim, in satoshis, excluding the on-chain fees which will be required to do so.
timeout_height: u32
The height at which the counterparty may be able to claim the balance if we have not done so.
payment_hash: PaymentHash
The payment hash that locks this HTLC.
payment_preimage: PaymentPreimage
The preimage that can be used to claim this HTLC.
MaybeTimeoutClaimableHTLC
HTLCs which we sent to our counterparty which are claimable after a timeout (less on-chain fees) if the counterparty does not know the preimage for the HTLCs. These are somewhat likely to be claimed by our counterparty before we do.
Fields
amount_satoshis: u64
The amount potentially available to claim, in satoshis, excluding the on-chain fees which will be required to do so.
claimable_height: u32
The height at which we will be able to claim the balance if our counterparty has not done so.
payment_hash: PaymentHash
The payment hash whose preimage our counterparty needs to claim this HTLC.
MaybePreimageClaimableHTLC
HTLCs which we received from our counterparty which are claimable with a preimage which we do not currently have. This will only be claimable if we receive the preimage from the node to which we forwarded this HTLC before the timeout.
Fields
amount_satoshis: u64
The amount potentially available to claim, in satoshis, excluding the on-chain fees which will be required to do so.
expiry_height: u32
The height at which our counterparty will be able to claim the balance if we have not yet received the preimage and claimed it ourselves.
payment_hash: PaymentHash
The payment hash whose preimage we need to claim this HTLC.
CounterpartyRevokedOutputClaimable
The channel has been closed, and our counterparty broadcasted a revoked commitment transaction.
Thus, we’re able to claim all outputs in the commitment transaction, one of which has the following amount.
Implementations§
§impl Balance
impl Balance
pub fn claimable_amount_satoshis(&self) -> u64
pub fn claimable_amount_satoshis(&self) -> u64
The amount claimable, in satoshis. This excludes balances that we are unsure if we are able
to claim, this is because we are waiting for a preimage or for a timeout to expire. For more
information on these balances see Balance::MaybeTimeoutClaimableHTLC
and
Balance::MaybePreimageClaimableHTLC
.
On-chain fees required to claim the balance are not included in this amount.
Trait Implementations§
impl Eq for Balance
impl StructuralPartialEq for Balance
Auto Trait Implementations§
impl Freeze for Balance
impl RefUnwindSafe for Balance
impl Send for Balance
impl Sync for Balance
impl Unpin for Balance
impl UnwindSafe for Balance
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