-
Notifications
You must be signed in to change notification settings - Fork 407
Mind commit tx fee while assembling a route #2080
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2612,17 +2612,49 @@ impl<Signer: WriteableEcdsaChannelSigner> Channel<Signer> { | |
balance_msat -= outbound_stats.pending_htlcs_value_msat; | ||
|
||
let outbound_capacity_msat = cmp::max(self.value_to_self_msat as i64 | ||
- outbound_stats.pending_htlcs_value_msat as i64 | ||
- self.counterparty_selected_channel_reserve_satoshis.unwrap_or(0) as i64 * 1000, | ||
- outbound_stats.pending_htlcs_value_msat as i64 | ||
- self.counterparty_selected_channel_reserve_satoshis.unwrap_or(0) as i64 * 1000, | ||
0) as u64; | ||
|
||
let mut available_capacity_msat = outbound_capacity_msat; | ||
|
||
if self.is_outbound() { | ||
// We should mind channel commit tx fee when computing how much of the available capacity | ||
// can be used in the next htlc. Mirrors the logic in send_htlc. | ||
// | ||
// The fee depends on whether the amount we will be sending is above dust or not, | ||
// and the answer will in turn change the amount itself — making it a circular | ||
// dependency. | ||
// This complicates the computation around dust-values, up to the one-htlc-value. | ||
let mut real_dust_limit_success_msat = self.holder_dust_limit_satoshis * 1000; | ||
if !self.opt_anchors() { | ||
real_dust_limit_success_msat += self.feerate_per_kw as u64 * htlc_success_tx_weight(false); | ||
} | ||
|
||
let htlc_above_dust = HTLCCandidate::new(real_dust_limit_success_msat, HTLCInitiator::RemoteOffered); | ||
let max_reserved_commit_tx_fee_msat = FEE_SPIKE_BUFFER_FEE_INCREASE_MULTIPLE * self.next_local_commit_tx_fee_msat(htlc_above_dust, None); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We may also want to set |
||
let htlc_dust = HTLCCandidate::new(real_dust_limit_success_msat - 1000, HTLCInitiator::RemoteOffered); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Can be |
||
let min_reserved_commit_tx_fee_msat = FEE_SPIKE_BUFFER_FEE_INCREASE_MULTIPLE * self.next_local_commit_tx_fee_msat(htlc_dust, None); | ||
|
||
// We will first subtract the fee as if we were above-dust. Then, if the resulting | ||
// value ends up being below dust, we have this fee available again. In that case, | ||
// match the value to right-below-dust. | ||
available_capacity_msat -= max_reserved_commit_tx_fee_msat; | ||
if available_capacity_msat < real_dust_limit_success_msat { | ||
let one_htlc_difference_msat = max_reserved_commit_tx_fee_msat - min_reserved_commit_tx_fee_msat; | ||
assert!(one_htlc_difference_msat != 0); | ||
available_capacity_msat += one_htlc_difference_msat; | ||
available_capacity_msat = std::cmp::max(real_dust_limit_success_msat - 1, available_capacity_msat); | ||
} | ||
} | ||
AvailableBalances { | ||
inbound_capacity_msat: cmp::max(self.channel_value_satoshis as i64 * 1000 | ||
- self.value_to_self_msat as i64 | ||
- self.get_inbound_pending_htlc_stats(None).pending_htlcs_value_msat as i64 | ||
- self.holder_selected_channel_reserve_satoshis as i64 * 1000, | ||
0) as u64, | ||
outbound_capacity_msat, | ||
next_outbound_htlc_limit_msat: cmp::max(cmp::min(outbound_capacity_msat as i64, | ||
next_outbound_htlc_limit_msat: cmp::max(cmp::min(available_capacity_msat as i64, | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Pre-existing, but this doesn't take into account the max number of HTLCs we can actually send out. In that case this should be 0. |
||
self.counterparty_max_htlc_value_in_flight_msat as i64 | ||
- outbound_stats.pending_htlcs_value_msat as i64), | ||
0) as u64, | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -1609,6 +1609,19 @@ macro_rules! get_route_and_payment_hash { | |
}} | ||
} | ||
|
||
#[cfg(test)] | ||
#[macro_export] | ||
macro_rules! get_route_or_error { | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. nit: no reason this shouldn't be a function rather than a macro. |
||
($send_node: expr, $recv_node: expr, $recv_value: expr) => {{ | ||
let payment_params = $crate::routing::router::PaymentParameters::from_node_id($recv_node.node.get_our_node_id(), TEST_FINAL_CLTV) | ||
.with_features($recv_node.node.invoice_features()); | ||
let (payment_preimage, payment_hash, payment_secret) = $crate::get_payment_preimage_hash!($recv_node, Some($recv_value)); | ||
let route_or_error = $crate::get_route!($send_node, payment_params, $recv_value, TEST_FINAL_CLTV); | ||
(route_or_error, payment_hash, payment_preimage, payment_secret) | ||
}} | ||
} | ||
|
||
|
||
#[macro_export] | ||
#[cfg(any(test, feature = "_bench_unstable", feature = "_test_utils"))] | ||
macro_rules! expect_payment_claimable { | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
If it's an outbound HTLC, why are we relying on the success dust limit? The timeout dust limit should apply to us, and the success dust limit to the counterparty.