Skip to content
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

Expose amount forwarded in PaymentForwarded event #2136

Conversation

marctyndel
Copy link
Contributor

This PR adds the amount forwarded to PaymentForwarded events.

We'd like this value for analytics. At the moment I've been computing it using fee_earned_msat and the outbound channel's forwarding policy, but this introduces rounding error (and I think could occasionally be incorrect if the policy was recently updated but not yet propagated).

@marctyndel marctyndel force-pushed the 2023-03-paymentforwarded-expose-amount-forwarded branch from 6823642 to 3ad0f09 Compare March 28, 2023 16:47
TheBlueMatt
TheBlueMatt previously approved these changes Mar 28, 2023
@@ -4151,6 +4151,7 @@ where
claim_from_onchain_tx: from_onchain,
prev_channel_id,
next_channel_id,
amount_forwarded_msat: forwarded_htlc_value_msat,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Ha, that was easy

@@ -603,6 +603,9 @@ pub enum Event {
/// If this is `true`, the forwarded HTLC was claimed by our counterparty via an on-chain
/// transaction.
claim_from_onchain_tx: bool,
/// The final amount forwarded, in milli-satoshis, after the fee is deducted.
/// The caveat described above the `fee_earned_msat` field applies here as well.
amount_forwarded_msat: Option<u64>,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Is there a name that more clearly indicates this is the outbound amount we forwarded downstream, rather than the amount we received? I think this is fine just want to make sure we don't see anything obviously better, I don't have any ideas, though.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Something like amount_outbound_forwarded_msat?

Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

maybe outgoing_amount_forwarded_msat? 🤷

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Up to you @marctyndel.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Going with a blend of the above: outbound_amount_forwarded_msat (because HTLCIntercepted, also uses the word "outbound"...I do see "outgoing" is used elsewhere but at a glance not in anything exposed)

lightning/src/events/mod.rs Outdated Show resolved Hide resolved
@@ -603,6 +603,9 @@ pub enum Event {
/// If this is `true`, the forwarded HTLC was claimed by our counterparty via an on-chain
/// transaction.
claim_from_onchain_tx: bool,
/// The final amount forwarded, in milli-satoshis, after the fee is deducted.
/// The caveat described above the `fee_earned_msat` field applies here as well.
amount_forwarded_msat: Option<u64>,
Copy link
Contributor

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

maybe outgoing_amount_forwarded_msat? 🤷

@TheBlueMatt
Copy link
Collaborator

Feel free to squash the fixup commit(s) down when you next push.

@marctyndel marctyndel force-pushed the 2023-03-paymentforwarded-expose-amount-forwarded branch from 6b3b0c9 to cf3c211 Compare March 29, 2023 16:58
@codecov-commenter
Copy link

codecov-commenter commented Mar 29, 2023

Codecov Report

Patch coverage: 80.00% and project coverage change: -0.04 ⚠️

Comparison is base (723c1a6) 91.40% compared to head (6b3b0c9) 91.37%.

❗ Current head 6b3b0c9 differs from pull request most recent head ee2cb8e. Consider uploading reports for the commit ee2cb8e to get more accurate results

📣 This organization is not using Codecov’s GitHub App Integration. We recommend you install it so Codecov can continue to function properly for your repositories. Learn more

Additional details and impacted files
@@            Coverage Diff             @@
##             main    #2136      +/-   ##
==========================================
- Coverage   91.40%   91.37%   -0.04%     
==========================================
  Files         102      102              
  Lines       49736    49568     -168     
  Branches    49736    49568     -168     
==========================================
- Hits        45461    45291     -170     
- Misses       4275     4277       +2     
Impacted Files Coverage Δ
lightning/src/ln/functional_test_utils.rs 92.59% <ø> (ø)
lightning/src/events/mod.rs 32.31% <33.33%> (+0.18%) ⬆️
lightning/src/ln/channelmanager.rs 89.15% <100.00%> (+0.02%) ⬆️
lightning/src/ln/functional_tests.rs 98.24% <100.00%> (+0.01%) ⬆️

... and 7 files with indirect coverage changes

Help us with your feedback. Take ten seconds to tell us how you rate us. Have a feature suggestion? Share it here.

☔ View full report in Codecov by Sentry.
📢 Do you have feedback about the report comment? Let us know in this issue.

@@ -1780,7 +1780,7 @@ macro_rules! expect_payment_forwarded {
let events = $node.node.get_and_clear_pending_events();
assert_eq!(events.len(), 1);
match events[0] {
Event::PaymentForwarded { fee_earned_msat, prev_channel_id, claim_from_onchain_tx, next_channel_id } => {
Event::PaymentForwarded { fee_earned_msat, prev_channel_id, claim_from_onchain_tx, next_channel_id, .. } => {
Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Question: for this test macro, if I add the new field, I get stuck trying to update the mid_update_fulfill_dance macro, because I can't see how to get the amount. I notice that fee is obtained there in a perhaps indirect way, by getting the forwarding_fee_base_msat from the channel config (meaning the test is run with 0 proportional fees), which suggests getting the amount from the HTLC might not straightforward here? Or I might be missing something.

Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Hmm, yea, you could do a few different things - you could add a new macro variant (ie the top level ($node,,, thing you can just add another one with a new parameter), you could indeed try to deduce the correct amount based on the fee fetched from the channel (though a few tests will fail that), or you could just not worry about it. The code here is simple enough and there are at least a few tests which exercise it, so I'm admittedly not super worried about ensuring we have Maximal Test Coverage of it.

Copy link
Contributor Author

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Then if everyone's okay with it I'll go with the "just not worry about it" option

TheBlueMatt
TheBlueMatt previously approved these changes Mar 29, 2023
Copy link
Contributor

@tnull tnull left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Generally looks good to me, just some minor remarks/suggestions.

lightning/src/events/mod.rs Show resolved Hide resolved
lightning/src/ln/functional_test_utils.rs Outdated Show resolved Hide resolved
lightning/src/events/mod.rs Outdated Show resolved Hide resolved
Copy link
Contributor

@tnull tnull left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

LGTM

Copy link
Contributor

@dunxen dunxen left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Nice one! :)

@TheBlueMatt TheBlueMatt merged commit 783e818 into lightningdevkit:main Mar 30, 2023
14 checks passed
@marctyndel marctyndel deleted the 2023-03-paymentforwarded-expose-amount-forwarded branch March 30, 2023 20:07
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

None yet

6 participants