Commit graph

7087 commits

Author SHA1 Message Date
Valentine Wallace
caccb1cc21
Only write BlindedHopFeatures if any features are set.
Minor space-saving optimization.
2024-03-19 14:58:43 -04:00
Arik Sosman
5f2b04badf
Publicize all UnsignedNodeAnnouncement fields.
This is necessary for RGSS tests to create new announcements.
2024-03-19 08:34:05 -07:00
Elias Rohrer
2f581104b2
Track spent WatchedOutputs and re-add if unconfirmed
Previously, we would track a spending transaction but wouldn't account
for it being reorged out of the chain, in which case we wouldn't monitor
the `WatchedOutput`s until they'd be reloaded on restart.

Here, we keep any `WatchedOutput`s around until their spends are
sufficiently confirmed and only prune them after `ANTI_REORG_DELAY`.
2024-03-19 15:55:28 +01:00
Matt Corallo
b747b397ab
Merge pull request #2945 from valentinewallace/2024-03-optional-blindedhop-features
Make `BlindedHopFeatures` optional per spec
2024-03-19 13:41:43 +00:00
Elias Rohrer
ab4b872098
Remove redundant claiming_channel_id variable
.. as it's the same as `prev_channel_id` defined a few lines above.
2024-03-19 13:29:09 +01:00
Elias Rohrer
134d60a3e8
Expose {prev,next}_user_channel_id fields in PaymentForwarded
This is useful for users that track channels by `user_channel_id`.

For example, in `lightning-liquidity` we currently keep a full
`HashMap<ChanelId, u128>` around *just* to be able to associate
`PaymentForwarded` events with the channels otherwise tracked by
`user_channel_id`.
2024-03-19 13:29:09 +01:00
Valentine Wallace
18ebbf7244
Make blinded hop features optional per spec.
The spec states that if these features are missing, we MUST process the message
as if it were present and contained an empty array.
2024-03-18 17:07:27 -04:00
Matt Corallo
2c9dbb959d
Merge pull request #2936 from valentinewallace/2024-03-pay-relay-constraints-ser
Fix ser for `PaymentRelay` and `PaymentConstraints`
2024-03-18 13:37:23 +00:00
Elias Rohrer
282b52f7bd
Merge pull request #2942 from benthecarman/node-id-slice
Add NodeId::from_slice
2024-03-18 09:13:00 +00:00
benthecarman
227d73de2b
Add NodeId::from_slice 2024-03-17 15:26:27 +00:00
Matt Corallo
75822b8af3
Merge pull request #2937 from TheBlueMatt/2024-03-no-wake-on-shutdown
Avoid writing `ChannelManager` when hitting lnd bug 6039
2024-03-14 20:32:27 +00:00
Matt Corallo
03425e4e4c Avoid writing ChannelManager when hitting lnd bug 6039
When we hit lnd bug 6039, we end up sending error messages to peers
in a loop. This should be fine, but because we used the generic
`PersistenceNotifierGuard::notify_on_drop` lock above the specific
handling, we end up writing `ChannelManager` every time we manage a
round-trip to our peer.

This can add up quite quickly, and isn't actually changing, so we
really need to avoid writing the `ChannelManager` in this case.
2024-03-14 20:03:48 +00:00
Valentine Wallace
ef02b9e6f9
Fix ser for PaymentRelay and PaymentConstraints.
Two fields were serialized as u32/u64 when the spec said *tu32/tu64*.
/facepalm.
2024-03-14 15:26:11 -04:00
Duncan Dean
c56198ade5
Implement interactive tx construction protocol via InteractiveTxConstructor
This implements the interactive construction protocol described at
78e5a6b066/02-peer-protocol.md (L92).

Our implementation includes a state machine with typed states and transitions
to ensure consumers have compile-time assurances that the protocol is upheld.

States are tracked as in the `StateMachine` enum and can take on all
possible states during the negotiation.

The states are further divided into two categories, namely by the two traits
they implement, either `ReceivedMsgState` or `SentMsgState`.

The defined `StateTransitions` enforce the transitions that `ReceivedMsgState`,
`SentMsgState`, and the `_TxComplete`s can go through.

Co-authored-by: Wilmer Paulino <9447167+wpaulino@users.noreply.github.com>
Co-authored-by: Duncan Dean <git@dunxen.dev>
Co-authored-by: Jurvis Tan <5944973+jurvis@users.noreply.github.com>
2024-03-14 16:10:46 +02:00
Elias Rohrer
c14fbb49eb
Merge pull request #2932 from TheBlueMatt/2023-04-ci-fix
Avoid new "out of disk space" issues in CI
2024-03-14 09:57:23 +00:00
Valentine Wallace
664abf20d0
Support receiving keysend payments to blinded paths. 2024-03-13 15:48:04 -04:00
Valentine Wallace
154aa211e6
Parse keysend preimages in blinded onion payloads. 2024-03-13 15:47:58 -04:00
Valentine Wallace
658e2c0a48
Support sending keysend payments to blinded paths. 2024-03-13 15:47:52 -04:00
Matt Corallo
39c1d6b2af Replace the generic parse_int_be with a macro called twice
`parse_int_be` is generic across integer types and also input
types, but to do so it relies on the `num-traits` crate. There's
not a lot of reason for this now that std has `from_be_bytes`, so
we drop the generic now and replace it with a macro which is called
twice to create two functions, both only supporting conversion from
`u5` arrays.
2024-03-13 19:18:20 +00:00
Matt Corallo
c89b96a4b9 Use std's from_be_bytes rather than our to_int_be for int conv
`lightning-invoice` was mostly written before std's `from_be_bytes`
was stabilized, so used its own `to_int_be` utility to do int
conversions from `u8` arrays. Now that the std option has been
stable for quite some time, we should juse use it instead.
2024-03-13 19:16:20 +00:00
Matt Corallo
f5ee8c23a1
Merge pull request #2881 from TheBlueMatt/2024-02-offers-tweak
Small Offers Fixes
2024-03-13 16:34:40 +00:00
Matt Corallo
29984a78ac Use structured logging where appropriate in OnionMessenger 2024-03-13 14:18:44 +00:00
Matt Corallo
b29033659f Add PersistenceNotifierGuard take to offer/refund payments
This resolves an issue where offer and refund payments get delayed
while we wait for the `invoice_request`/`invoice` onion messages to
get sent. It further ensures we're likely to have the
`ChannelManager` persisted with the new payment info after
initiating the send/receive.
2024-03-13 14:18:44 +00:00
Matt Corallo
98340dc253 Use {}, not {:?} for PublicKey logging
The `Debug` serialization of `PublicKey`s includes both the X and Y
coordinate, which isn't something most of our users deal with.
Instead, logging using `Display` gives users the keys they're used
to.
2024-03-13 13:58:47 +00:00
Matt Corallo
9571988d21 Avoid new "out of disk space" issues in CI
Our 1.63 build on Ubuntu has been failing for quite some time
because it runs out of disk space trying to build tests in the last
cfg-flag steps. Thus, we add a few new `cargo clean`s here to fix
it.
2024-03-12 15:20:52 +00:00
Matt Corallo
aa334d5753
Merge pull request #2917 from jkczyz/2024-02-refund-unsupported-chain
Fail `request_refund_payment` for unsupported chain
2024-03-12 15:18:32 +00:00
Jeffrey Czyz
228e72ca34
Fail request_refund_payment for unsupported chain
If a Refund has an unsupported chain, ChannelManager should not send an
invoice as it can't be paid on that chain. Instead, return an error when
calling ChannelManager::request_refund_payment for such refunds.
2024-03-08 15:57:10 -06:00
Jeffrey Czyz
ad91fcd510
Update pay_for_offer docs about unsupported chains 2024-03-08 15:40:29 -06:00
Jeffrey Czyz
07d766a5e9
Test failing pay_for_offer on an unsupported chain 2024-03-08 15:40:16 -06:00
Matt Corallo
6d5c952556
Merge pull request #2823 from valentinewallace/2024-01-blinded-forwarding-tests
Test blinded forwarding
2024-03-08 21:32:40 +00:00
valentinewallace
670b41ae4e
Merge pull request #2903 from jkczyz/2024-02-bindings-builders
Offers builders for C-bindings
2024-03-08 16:07:10 -05:00
Matt Corallo
07059ec2c3
Merge pull request #2926 from tnull/2024-03-derive-eq-for-offer-refund
Impl `PartialEq`/`Eq` for `Offer`/`Refund`
2024-03-08 17:34:37 +00:00
Valentine Wallace
2027bf4e2a
Test that we'll round up blinded intermediate node fees if needed.
See comment in the new test.
2024-03-08 12:03:17 -05:00
Valentine Wallace
7777fc5285
Test utils: support intermediate nodes taking 1msat extra fee.
See docs on the new field.
2024-03-08 12:03:17 -05:00
Valentine Wallace
c30332ac86
Support fee overpayment by 1 msat in expect_payment_forwarded test util.
See ClaimAlongRouteArgs::allow_1_msat_fee_overpay.
2024-03-08 12:03:17 -05:00
Valentine Wallace
0b22ccd477
Functionally test min htlc BlindedPayInfo calculation. 2024-03-08 12:03:17 -05:00
Valentine Wallace
7b85d0145f
Account for prop fee in test util fee calculation. 2024-03-08 12:03:17 -05:00
Valentine Wallace
e8c85bd82b
Use correct min/max htlc in test util for constructing blinded pay params.
In testing, we use channel updates to construct blinded paths and the
{Forward,Receive}Tlvs encoded within. Given a blinded path from node A > B > C,
we currently use channel_update_A->B to construct the payment constraints for
A’s blinded payload.

This is incorrect for setting A's PaymentConstraints::htlc_minimum_msat,
because channel_update_A->B contains the minimum value that *B* will accept,
and we want the constraints to contain the min value that *A* will accept.

This never caused test failures before because min/max htlc values were always
identical in both channel directions.

Therefore, set A’s htlc min/max values to the min/max that A will accept.
2024-03-08 12:03:17 -05:00
Valentine Wallace
bde5a652fa
Parameterize blinded test util with intro node min/max htlc.
We're currently not setting each node's min/max htlc correctly, see next
commit.
2024-03-08 12:03:17 -05:00
Valentine Wallace
203be7096e
Struct-ify test util pass_along_path args.
Lays groundwork to make pass_along_path easier to adapt without changing a
million callsites.
2024-03-08 12:03:11 -05:00
Valentine Wallace
2c22055589
Test 3-hop blinded path recipient failure.
This tests an intermediate forwarding node being failed back to with malformed
and then failing back themselves with malformed.
2024-03-08 11:56:26 -05:00
Jeffrey Czyz
9277166a8b
Drop error type parameter from SignError
SignError allows implementors of SignFunction to return a custom error
type. Drop this as an unconstrained type causes problems with bindings
and isn't useful unless the caller can take some sort of action based on
different errors.
2024-03-08 10:39:23 -06:00
Jeffrey Czyz
6b7050e8dc
Fix unused import warning 2024-03-08 10:39:23 -06:00
Jeffrey Czyz
407762446c
Support BOLT 12 signing in c_bindings
Replace the Fn trait bound on signing methods with a dedicated trait
since Fn is not supported in bindings. Implement the trait for Fn so
that closures can still be used in Rust.
2024-03-08 10:39:22 -06:00
Jeffrey Czyz
3bd00b943a
Add c_bindings version of InvoiceBuilder
Use the macros introduced in the previous commit to define two builders
for each type parameterization of InvoiceBuilder
- InvoiceWithExplicitSigningPubkeyBuilder
- InvoiceWithDerivedSigningPubkeyBuilder

The difference between these and InvoiceBuilder is that these have
methods that take `self` by mutable reference instead of by value and
don't return anything instead returning the modified builder. This is
required because bindings don't support move semantics nor impl blocks
specific to a certain type parameterization. Because of this, the
builder's contents must be cloned when building a Bolt12Invoice.

Keeps InvoiceBuilder defined so that it can be used internally in
ChannelManager's OffersMessageHandler even when compiled for c_bindings.
2024-03-08 10:39:22 -06:00
Elias Rohrer
47954e95df
Implement Hash for Offer and Refund 2024-03-08 17:35:20 +01:00
Elias Rohrer
3eeb8b82a5
Impl PartialEq/Eq for Offer/Refund
We add custom implementations based on comparing the `bytes` for
`Offer`/`Refund` themselves as this is sufficient and should be faster
than comapring all fields in the worst case.
2024-03-08 17:35:20 +01:00
Matt Corallo
aa3dbe8686
Merge pull request #2923 from tnull/2024-03-improve-best-block
Refactor `BestBlock` to expose inner fields
2024-03-07 17:55:59 +00:00
Elias Rohrer
edb22e1ab9
Implement Hash for BestBlock 2024-03-07 17:35:38 +01:00
Elias Rohrer
9bac73b4f3
Merge pull request #2912 from jkczyz/2024-02-prefer-more-connections
Order blinded paths by reliability criteria
2024-03-07 12:06:42 +01:00