lnd/lnwallet
Olaoluwa Osuntokun 69a1cf4f23
lnwallet: ensure we re-sign retransmitted commits for taproot channels
In this commit, we fix an existing bug with the taproot channel type
that can cause force closes if a peer disconnects while attempting to
send the commitment signature.

Before this commit, since the `PartialSig` we send is never committed to
disk, the version read wouldn't contain the musig2 partial sig. We never
write these signatures to disk, as each time we make a new session, we
need to generate fresh nonces to avoid nonce-reuse.

Due to the above interaction, if we went to re-send a signature after a
disconnection, the `CommitSig` message we sent wouldn't actually contain
a `PartialSigWithNonce`, causing a protocol error.
2024-09-03 17:23:38 -07:00
..
btcwallet Merge pull request #8961 from yyforyongyu/fix-leaseoutput 2024-08-21 16:31:26 -07:00
chainfee multi: prevent nil panics in stop methods. 2024-07-31 14:43:34 +02:00
chancloser lnwallet+peer: add tapscript root awareness to musig2 sessions 2024-08-28 11:52:31 +02:00
chanfunding lnwallet/chanfunding: add optional tapscript root 2024-08-28 11:52:31 +02:00
chanvalidate
rpcwallet lnrpc+lnwallet: replace FetchInputInfo with new methods 2024-08-09 21:51:18 +08:00
test multi: expand SendOutputs and CreateSimpleTx to take utxos 2024-08-07 20:42:27 +08:00
aux_leaf_store.go lnwallet+channeldb: add new AuxLeafStore for dynamic aux leaves 2024-08-28 13:21:08 +02:00
channel_test.go lnwallet: pack commitment message indices into Dual 2024-08-28 14:02:59 -07:00
channel.go lnwallet: ensure we re-sign retransmitted commits for taproot channels 2024-09-03 17:23:38 -07:00
commit_sort_test.go
commit_sort.go
commitment_chain.go lnwallet: refactor channel to use new typed List 2024-07-31 13:03:34 -07:00
commitment.go lnwallet: thread thru input.AuxTapleaf to all relevant areas 2024-08-28 13:28:48 +02:00
config.go multi: thread thru the AuxLeafStore everywhere 2024-08-28 13:26:14 +02:00
errors.go
interface.go mulit: remove ListLeasedOutputs in LeaseOutput 2024-08-09 22:01:57 +08:00
log.go multi: add NewLogClosure in lnutils to avoid repetition 2024-07-25 21:25:23 +08:00
mock.go multi: thread thru the AuxLeafStore everywhere 2024-08-28 13:26:14 +02:00
musig_session_test.go multi: disable linter paralleltest 2023-10-13 13:50:09 +08:00
musig_session.go lnwallet+peer: add tapscript root awareness to musig2 sessions 2024-08-28 11:52:31 +02:00
parameters_test.go
parameters.go lnwallet+funding+lnd: trim unused parameters, from lnwallet.Config 2024-02-19 17:06:21 -08:00
payment_descriptor.go lnwallet: add TLV blob to PaymentDescriptor + htlc add 2024-08-28 13:21:12 +02:00
README.md
rebroadcaster_test.go multi: disable linter paralleltest 2023-10-13 13:50:09 +08:00
rebroadcaster.go
reservation.go lnwallet: update internal funding flow w/ tapscript root 2024-08-28 11:52:31 +02:00
revocation_producer_itest.go input: ensure sessionOpts is properly threaded through 2023-08-22 16:31:47 -07:00
revocation_producer.go input: ensure sessionOpts is properly threaded through 2023-08-22 16:31:47 -07:00
sigpool.go
test_utils.go lnwallet: add initial unit tests for musig2+tapscript root chans 2024-08-28 11:52:31 +02:00
test_vectors_anchors.json
test_vectors_legacy.json
test_vectors_zero_fee_htlc_tx.json
transactions_test.go lnwallet+channeldb: add new AuxLeafStore for dynamic aux leaves 2024-08-28 13:21:08 +02:00
transactions.go lnwallet: thread thru input.AuxTapleaf to all relevant areas 2024-08-28 13:28:48 +02:00
update_log.go lnwallet: update updateLog.modifiedHtlcs to use fn.Set 2024-08-06 10:05:20 -07:00
wallet_test.go funding: remove dead code and sanity check pending chan ID (#7887) 2023-10-09 10:58:18 +02:00
wallet.go multi: thread thru the AuxLeafStore everywhere 2024-08-28 13:26:14 +02:00

lnwallet

Build Status MIT licensed GoDoc

The lnwallet package implements an abstracted wallet controller that is able to drive channel funding workflows, a number of script utilities, witness generation functions for the various Lightning scripts, revocation key derivation, and the commitment update state machine.

The package is used within lnd as the core wallet of the daemon. The wallet itself is composed of several distinct interfaces that decouple the implementation of things like signing and blockchain access. This separation allows new WalletController implementations to be easily dropped into lnd without disrupting the code base. A series of integration tests at the interface level are also in place to ensure conformance of the implementation with the interface.

Installation and Updating

$  go get -u github.com/lightningnetwork/lnd/lnwallet