Commit graph

6763 commits

Author SHA1 Message Date
Matt Corallo
79affa0d51 Change v0.0.120 release name
"Un"blinded makes more sense, since the fuzzer was unblinded :)
2024-01-17 23:19:12 +00:00
Matt Corallo
5592378de2
Merge pull request #2834 from TheBlueMatt/2024-01-cut-120
Cut 0.0.120
2024-01-17 23:02:24 +00:00
Matt Corallo
37017ec39f Bump crate versions to 0.0.120/invoice 0.28 2024-01-17 21:34:29 +00:00
Matt Corallo
947850b1de Add CHANGELOG entry for 0.0.120 2024-01-17 21:34:29 +00:00
Matt Corallo
871db638f2
Merge pull request #2818 from valentinewallace/2024-01-blinded-path-retries
Avoid retrying over previously failed blinded paths
2024-01-17 21:21:36 +00:00
valentinewallace
a1759582ad
Merge pull request #2828 from TheBlueMatt/2024-01-crypto-module
Move cryptographic algorithms and utilities to a new `crypto` mod
2024-01-17 12:53:02 -05:00
Valentine Wallace
5c87f40f6b
Test that we won't retry over previously failed blinded paths. 2024-01-17 10:55:41 -05:00
Valentine Wallace
8fcfaeb8d5
Test util: separate out code to construct a blinded path. 2024-01-17 10:55:41 -05:00
Valentine Wallace
32ab7a9e4d
Avoid building routes over previously failed blinded payment paths. 2024-01-17 10:55:39 -05:00
Valentine Wallace
23ef2535d0
Store previously failed blinded paths on outbound payment failure.
Useful so we don't retry over these paths.
2024-01-17 10:44:38 -05:00
Valentine Wallace
5c5d691425
Persist previously failed blinded paths in RouteParameters.
Useful so we don't retry over these paths.
2024-01-17 10:44:33 -05:00
Valentine Wallace
75a1c47b19
Add failed_within_blinded_path to DecodedOnionFailure.
Will be used to ensure correctness when we store previously failed blinded
paths to avoid retrying over them.
2024-01-17 10:44:33 -05:00
Valentine Wallace
ae1288d8cc
Add failed_within_blinded_path to onion util internal struct.
Will be used to ensure correctness when we store previously failed blinded
paths to avoid retrying over them.
2024-01-17 10:44:33 -05:00
Matt Corallo
fbeb7ac9e1
Merge pull request #2831 from jkczyz/2024-01-fix-cltv-expiry-delta
Use consistent `cltv_expiry_delta` in `ForwardTlvs`
2024-01-17 00:47:48 +00:00
Matt Corallo
a97f945607
Merge pull request #2832 from p2pderivatives/fix-ln-net-tokio-dropping-messages
Fix lightning-net-tokio sometimes dropping messages
2024-01-17 00:37:09 +00:00
Matt Corallo
53f2e2e882
Merge pull request #2812 from valentinewallace/2023-12-blinded-forwarding
Complete route blinding support
2024-01-17 00:28:30 +00:00
Tibo-lg
4cd0e6a391 Fix lightning-net-tokio sometimes dropping messages 2024-01-17 09:24:49 +09:00
Jeffrey Czyz
8053aa3df4
Use consistent cltv_expiry_delta in ForwardTlvs
When converting from CounterpartyForwardingInfo to PaymentRelay, the
cltv_expiry_delta is copied. Then, when forming a blinded payment path,
the value is mutated so that esoteric values don't reveal information
about the path. However, the value was only used in computing
PaymentConstraints and wasn't actually updated in PaymentRelay. Move the
logic for modifying the cltv_expiry_delta to the conversion code to
avoid this inconsistency.
2024-01-16 16:59:27 -06:00
Valentine Wallace
aae39b4090
Advertise route blinding feature as supported.
Now that we fully support forwarding blinded payments, we should advertise
support so nodes on the network can include us in their blinded paths.
2024-01-16 17:46:41 -05:00
Valentine Wallace
027aef2b64
Fix sender double-including shadow offset in CLTV expiry height.
The excess delta is included in the final RouteHop::cltv_expiry_delta, so by
adding it explicitly to cur_cltv we were erroneously including it twice in the
total cltv expiry.

This could've add up to an extra MAX_SHADOW_CLTV_DELTA_OFFSET (432) blocks to
the total cltv expiry.
2024-01-16 17:46:41 -05:00
Valentine Wallace
6e6bd44138
Rename test var to be more descriptive. 2024-01-16 17:46:41 -05:00
Valentine Wallace
a76bb51a3a
Complete remaining TODOs for failing blinded non-intro forwards. 2024-01-16 17:46:41 -05:00
Valentine Wallace
c37d10944e
Add failure mode info to BlindedForward struct.
See added docs.
2024-01-16 17:46:39 -05:00
Matt Corallo
4a0abd52e7 Move cryptographic algorithms and utilities to a new crypto mod
As we'd generally like the `lightning` crate to, over time, have
more modules rather than being very monolithic, we should move the
cryptographic things into their own module, which we do here.

We also take this opportunity to move stream adapters into their
own module and make clear that the ChaChaPoly `decrypt` method is
variable time.
2024-01-16 20:07:08 +00:00
Jeffrey Czyz
4532fb52f0
Fix bench build warning 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
5aeb6c5167
Reorganize #[cfg(not(c_bindings))] imports 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
ffc24c3af9
Add ASCII art diagram explaining offers_tests 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
aef46d8c82
Functional test for failing duplicate payments 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
1c51aa17f3
Functional tests for failing without payment paths 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
e40387fc85
Add Features::clear_route_blinding for testing 2024-01-16 11:12:36 -06:00
Jeffrey Czyz
0a7a90a78f
Offers functional tests for duplicated payment ids 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
757315076a
Functional tests for failing without blinded paths 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
533c3cc868
Functional tests for offers with blinded paths 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
6c67e3e279
Functional tests for offers without blinded paths 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
1059ac3c28
Functional tests for BOLT 12 Offers payment flow
ChannelManager provides utilities to create offers and refunds along
with utilities to initiate and request payment for them, respectively.
It also manages the payment flow via implementing OffersMessageHandler.
Test that functionality, including the resulting event generation.
2024-01-16 11:12:35 -06:00
Jeffrey Czyz
aba77480ac
Consolidate conditional imports 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
a1c3004136
Remove redundant negations from feature check 2024-01-16 11:12:35 -06:00
Jeffrey Czyz
30c07021d9
Remove "no-std" feature checks
An upcoming rust-bitcoin release will remove the "no-std" feature.
Replace "no-std" in feature checks with "std", negating as needed. Using
a single feature flag makes the checks more consistent across modules.
2024-01-16 11:12:34 -06:00
Jeffrey Czyz
b578363248
Have TestRouter wrap DefaultRouter
TestRouter checks route and scoring expectations before delegating to
the standalone find_route function. Refactor it to wrap DefaultRouter
and delegate to it instead. This allows TestRouter to implement
create_blinded_payment_paths by delegating to DefaultRouter.
2024-01-16 11:12:34 -06:00
Jeffrey Czyz
3b6d039f89
Support OnionMessenger in functional_test_utils
OnionMessenger is needed to write functional tests for ChannelManager's
OffersMessageHandler implementation. Also adds a TestMessageRouter,
which simply wraps DefaultMessageRouter for now.
2024-01-16 11:12:20 -06:00
Jeffrey Czyz
8deac898ab
DRY up EntropySource implementation
The ChaCha20-based EntropySource implementation is duplicated within the
sign module. Refactor those into a RandomBytes implementation so that it
may be reused both there. Also useful as a standalone EntropySource
implementation for tests where an independent EntropySource is needed to
ensure that backwards-compatibility testing is not broken.
2024-01-15 20:12:37 -06:00
Jeffrey Czyz
911ed6dafc
Fix import order in functional_test_utils.rs 2024-01-15 20:12:36 -06:00
Jeffrey Czyz
ec8c6fb2a9
Add peel_onion_message method to OnionMessenger
When testing OnionMessenger in functional tests, it would be useful to
examine the contents of an OnionMessage response. Expose the standalone
peel_onion_message on OnionMessenger to facilitate this.
2024-01-15 20:12:36 -06:00
Elias Rohrer
ea5de93dd9
Merge pull request #2824 from shuoer86/main
Fix typos
2024-01-15 10:38:03 +01:00
shuoer86
fff6616b7c
Fix typo lightning/src/util/wakers.rs 2024-01-12 20:46:47 +08:00
shuoer86
9c22a48a49
Fix typo lightning/src/routing/router.rs 2024-01-12 20:46:40 +08:00
shuoer86
896477d33d
Fix typo lightning/src/ln/peer_handler.rs 2024-01-12 20:46:33 +08:00
shuoer86
8cd48060d7
Fix typo lightning-invoice/src/ser.rs 2024-01-12 20:46:26 +08:00
shuoer86
9c5edad51b
Fix typo CONTRIBUTING.md 2024-01-12 20:46:16 +08:00
Matt Corallo
4b70921c95
Merge pull request #2800 from optout21/channel-close-add-funding
Add channel funding txo to Channel Event::ChannelClosed
2024-01-11 19:35:26 +00:00