lnd/lnwallet/btcwallet
Olaoluwa Osuntokun e1e9de24df
sweep: remove all unconfirmed descendant transactions when a sweep conflicts
Before this commit, we we were trying to sweep an anchor output, and
that output was spent by someone else (not the sweeper), then we would
report this back to the original resolver (allowing it to be cleaned
up), and also remove the set of inputs spent by that transaction from
the set we need to sweep.

However, it's possible that if a user is spending unconfirmed outputs,
then the wallet is holding onto an invalid transaction, as the outputs
that were used as inputs have been double spent elsewhere.

In this commit, we fix this issue by recursively removing all descendant
transactions of our past sweeps that have an intersecting input set as
the spending transaction. In cases where a user spent an unconfirmed
output to funding a channel, and that output was a descendant of the now
swept anchor output, the funds will now properly be marked as available.

Fixes #6241
2022-03-17 16:36:47 -07:00
..
blockchain.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
btcwallet_rpctest.go multi: add golang 1.17 compatible build tags 2021-09-29 17:31:37 -07:00
btcwallet.go sweep: remove all unconfirmed descendant transactions when a sweep conflicts 2022-03-17 16:36:47 -07:00
config.go multi: run gosimports 2022-02-10 11:02:01 +01:00
driver.go btcwallet: make blockcache available to BtcWallet 2021-04-28 09:46:11 +02:00
log.go lnd+lnwallet: add logger for btcwallet+rpcwallet 2022-01-06 13:24:32 +01:00
psbt_test.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
psbt.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
signer_test.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00
signer.go multi: use btcd's btcec/v2 and btcutil modules 2022-03-09 19:02:37 +01:00