Commit graph

7078 commits

Author SHA1 Message Date
Wilmer Paulino
0b38b3981d
Track pending update_add_htlcs in ChannelManager for later processing
We plan to decode the onions of these `update_add_htlc`s as part of the
HTLC forwarding flow (i.e., `process_pending_htlc_forwards`), so we'll
need to track them per-channel at the `ChannelManager` level.
2024-03-27 14:28:01 -07:00
Wilmer Paulino
60ddd5d036
Remove unreachable handling of htlc_forwards upon channel_reestablish
`htlc_forwards` only returns a `Some` value from
`handle_channel_resumption` if we provide it a non-empty
`pending_forwards`. Since we don't, we'll never have a value to handle.
2024-03-27 14:28:00 -07:00
Wilmer Paulino
4ad00f4074
Track incoming UpdateAddHTLC until HTLC resolution
This commit serves as a stepping stone to moving towards resolving HTLCs
once the HTLC has been fully committed to by both sides.

Currently, we decode HTLC onions immediately upon receiving an
`update_add_htlc`. Doing so determines what we should do with the HTLC:
forward it, or immediately fail it back if it cannot be accepted. This
action is tracked until the HTLC is fully committed to by both sides,
and a new commitment in the latter case is proposed to fully remove the
HTLC. While this has worked so far, it has some minor privacy
implications, as forwarding/failing back do not go through the usual
`PendingHTLCsForwardable` flow. It also presents issues with the
quiescence handshake, as failures through this path do not go through
the holding cell abstraction, leading to a potential violation of the
handshake by sending an `update_fail_*` after already having sent
`stfu`.

Since `pending_inbound_htlcs` are written pre-TLVs, we introduce a new
serialization version in which we change the `PendingHTLCStatus`
serialization of
`InboundHTLC::AwaitingRemoteRevokeToRemove/AwaitingRemovedRemoteRevoke`
to be an option instead. We'll still write it as the current version
(`MIN_SERIALIZATION_VERSION`), but we'll support reading the new version
to allow users to downgrade back to this commit.
2024-03-27 14:27:59 -07:00
Wilmer Paulino
c096a24161
Support Vec serialization that include element length prefix
We add new macro alternatives to
impl_writeable_for_vec/impl_readable_for_vec that add a length prefix to
each element in the `Vec`. This is intended to be used over the existing
macros when attempting to serialize a `Vec` with elements of variable
lengths.
2024-03-27 14:27:59 -07:00
Wilmer Paulino
3c24a137b1
Don't consume readers with FixedLengthReader
We can't always assume that we're done reading after using a
FixedLengthReader. In some cases, we may need to read a set of
length-prefixed objects one at a time, and we'd like to do so without
incurring an additional allocation by reading a number of bytes first to
then deserialize them.
2024-03-27 14:27:55 -07:00
Valentine Wallace
143b8b3615
Support receiving custom TLVs to blinded paths. 2024-03-27 16:47:32 -04:00
Valentine Wallace
7d68b608c8
Support sending custom TLVs to blinded recipients. 2024-03-27 16:47:30 -04:00
valentinewallace
beef584cf3
Merge pull request #2906 from arik-so/arik/trampoline/2024-02-trampoline-onion-construction-vectors
Trampoline onion construction vectors
2024-03-27 15:46:53 -04:00
Arik Sosman
52039a2ffc
Test Trampoline payload serialization. 2024-03-27 00:42:31 -07:00
Arik Sosman
e7e1afac29
Trampoline onion construction. 2024-03-27 00:42:31 -07:00
Arik Sosman
4baa8a770c
Rename TrampolineOnionPacket enum comment. 2024-03-27 00:42:31 -07:00
Gursharan Singh
68d5e88e46
Merge pull request #2959 from tnull/2024-03-support-gossip-queries-in-ignoring-handler
Signal `GossipQuery` support when using `IgnoringMessagHandler`
2024-03-26 22:06:32 +01:00
Elias Rohrer
b8b1ef3149
Merge pull request #2963 from jkczyz/2024-03-a-channel-manager
Use `AChannelManager` in `BackgroundProcessor`
2024-03-25 14:27:08 +01:00
Jeffrey Czyz
d29e2ba949
Use AChannelManager in BackgroundProcessor
Replace instance of ChannelManager in BackgroundProcessor and in
Persister with AChannelManager. This reduces the number of type
parameters need in those types, which would need to be repeated in an
async version of Persister.
2024-03-23 17:02:28 -05:00
Jeffrey Czyz
82a13b52cc
Remove duplicate docs from trait implementations 2024-03-23 16:56:26 -05:00
Jeffrey Czyz
5e56c5ed45
Fix indentation in doc example 2024-03-23 16:18:58 -05:00
valentinewallace
6d1111111c
Merge pull request #2756 from arik-so/arik/trampoline/2023-11-outbound
Serialize Trampoline payloads in outbound onions.
2024-03-22 10:41:19 -04:00
Arik Sosman
f15c538e1f
Add Trampoline variant to OutboundOnionPayload. 2024-03-21 18:00:43 -07:00
Arik Sosman
c84d721c99
Introduce TrampolineOnionPacket. 2024-03-21 17:47:00 -07:00
Matt Corallo
650caa099d
Merge pull request #2946 from tnull/2024-03-txsync-readd-reorged-output-spends
Tx-Sync: Track spent `WatchedOutput`s and re-add if unconfirmed
2024-03-21 19:58:11 +00:00
Gursharan Singh
9ca22800b4
Merge pull request #2953 from dunxen/2024-03-fix2941
Fix `ChannelManager::accept_inbound_channel` error handling
2024-03-21 10:55:19 -07:00
Elias Rohrer
b71c6e2f67
Dedup confirmed_txs Vec
Previously, we would just push to the `confirmed_txs` `Vec`, leading to
redundant `Confirm::transactions_confirmed` calls, especially now that
we re-confirm previously disconnected spends.

Here, we ensure that we don't push additional `ConfirmedTx` entries if
already one with matching `Txid` is present. This not only gets rid of
the spurious `transactions_confirmed` calls (which are harmless), but
more importantly saves us from issuing unnecessary network calls, which
improves latency.
2024-03-21 17:41:26 +01:00
valentinewallace
19bcb1c62f
Merge pull request #2934 from TheBlueMatt/2023-03-no-num-traits
Replace the generic `parse_int_be` with a macro called twice
2024-03-21 10:48:35 -04:00
Elias Rohrer
843079df72
Signal GossipQuery support when using IgnoringMessagHandler
With its v24.02 release CLN made `GossipQueries` a required feature,
leading to a incompatibility between LDK and CLN when using
`IgnoringMessagHandler` as a `RoutingMessageHandler`, which is usually
the case when a node uses RGS.

To fix this issue, we let `IgnoringMessagHandler` signal `GossipQuery`
support, just to go ahead and ignore every gossip message the peer will
send us. While this is nonsensical and still might result in some
unnecessary bandwidth wasted, we have to do something to fix the
incompatibility.
2024-03-21 09:05:05 +01:00
Duncan Dean
3206d1fa59
Test ChannelManager::accept_inbound_channel errors 2024-03-21 09:25:18 +02:00
Duncan Dean
1cb6d2faf5
Fix ChannelManager::accept_inbound_channel error handling 2024-03-21 09:25:16 +02:00
Matt Corallo
5e41425179
Merge pull request #2935 from valentinewallace/2024-03-keysend-to-blinded
Support keysend to blinded paths
2024-03-20 19:20:11 +00:00
Matt Corallo
8354e0c9ba
Merge pull request #2419 from jurvis/2023-03-interactivetxs
Interactive Transaction Construction
2024-03-20 19:06:22 +00:00
Matt Corallo
9b7bbe17da
Merge pull request #2887 from benthecarman/htlc-timeout
Add HTLCsTimedOut closing reason
2024-03-20 18:13:27 +00:00
Matt Corallo
0cc08589b7
Merge pull request #2951 from jkczyz/2024-03-fix-sender-is-intro-node
Fix sender is the introduction node onion messages
2024-03-20 14:35:35 +00:00
valentinewallace
a36b529752
Merge pull request #2924 from tnull/2024-03-add-user-channel-id-to-payment-forwarded
Expose `{prev,next}_user_channel_id` fields in `PaymentForwarded`
2024-03-20 10:27:16 -04:00
Matt Corallo
e4b6a5004e
Merge pull request #2948 from arik-so/2024-03-public-node-announcement-excess
Publicize all UnsignedNodeAnnouncement fields.
2024-03-20 00:53:38 +00:00
Matt Corallo
5c4935801c
Merge pull request #2949 from valentinewallace/2024-03-dont-write-empty-features
Only write `BlindedHopFeatures` if any features are set
2024-03-20 00:52:59 +00:00
benthecarman
9b5ebc4bec
Add HTLCsTimedOut closing reason
Before a force closure from timed out HTLCs was treated the same as when
the user manually force closed the channel. This leads to various UX
issues. This adds a new `ClosureReason` called `HTLCsTimedOut` that
signifies that the closure was caused because the HTLCs timed out. To go
along with this, previously we'd always send "Channel force-closed" when
force closing the channel in the error message which was ambigous, now
we send the force closure reason so the peer can know why the channel
was closed.
2024-03-19 18:57:15 -05:00
Jeffrey Czyz
806fef5848
Use OnionMessenger::send_onion_message in tests
Use OnionMessenger's public interface in tests whenever possible (i.e.,
when not using any intermediate_nodes in an OnionMessagePath. This
allows us to exercise DefaultMessageRouter, and, in particular that a
path can be found for an unannounced sender when its in the introduction
node.
2024-03-19 17:45:10 -05:00
Jeffrey Czyz
ad3de23666
Use DefaultMessageRouter in functional tests
This helps test cases in DefaultMessageRouter that may not be exercised
now or in the future.
2024-03-19 17:45:10 -05:00
Jeffrey Czyz
3d2a0c2832
pub(crate) visibility for routing/test_utils.rs
Give pub(crate) visibility to some routing test utilities to facilitate
testing DefaultMessageRouter in functional tests.
2024-03-19 17:45:10 -05:00
Jeffrey Czyz
f2b84e05e8
Fix sender is the introduction node onion messages
DefaultMessageRouter will form an OnionMessagePath from a BlindedPath
where the sender is the introduction node but only if the sender is
announced. If the sender is unannounced, then DefaultMessageRouter will
fail. While DefaultMessageRouter will only create a blinded path with an
announced introduction node, it may receive one where the introduction
node is unannounced. Don't return an error in this case, as the
OnionMessenger can advance the blinded path by one hop.

This may occur when two nodes have an unannounced channel and one (the
offer creator) wants to use it for payments without an intermediary node
and without putting its node id in the offer.
2024-03-19 17:40:25 -05:00
Jeffrey Czyz
dc627b371f
Include SocketAddress in test node_announcement 2024-03-19 17:08:09 -05:00
Jeffrey Czyz
22c9da3cfb
Re-order imports 2024-03-19 17:08:09 -05:00
Arik Sosman
c974225fa4
Add trampoline feature flag. 2024-03-19 13:37:31 -07:00
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