From 3b50a5ce16f31b4bf2eeca4c35d46269bc94cc33 Mon Sep 17 00:00:00 2001 From: Felix Passenberg Date: Fri, 26 Jan 2024 02:31:23 +0100 Subject: [PATCH 1/2] doublespendinputs: allow RBF per default --- cmd/chantools/doublespendinputs.go | 19 ++++++++++++++++++- doc/chantools_doublespendinputs.md | 2 ++ doc/chantools_fakechanbackup.md | 2 +- doc/chantools_recoverloopin.md | 1 + doc/chantools_zombierecovery_makeoffer.md | 1 + doc/chantools_zombierecovery_preparekeys.md | 1 + 6 files changed, 24 insertions(+), 2 deletions(-) diff --git a/cmd/chantools/doublespendinputs.go b/cmd/chantools/doublespendinputs.go index 440283c..d529a12 100644 --- a/cmd/chantools/doublespendinputs.go +++ b/cmd/chantools/doublespendinputs.go @@ -10,6 +10,7 @@ import ( "github.com/btcsuite/btcd/btcutil" "github.com/btcsuite/btcd/btcutil/hdkeychain" "github.com/btcsuite/btcd/chaincfg/chainhash" + "github.com/btcsuite/btcd/mempool" "github.com/btcsuite/btcd/txscript" "github.com/btcsuite/btcd/wire" "github.com/decred/dcrd/dcrec/secp256k1/v4" @@ -26,6 +27,7 @@ type doubleSpendInputs struct { SweepAddr string FeeRate uint32 RecoveryWindow uint32 + Rbf bool rootKey *rootKey cmd *cobra.Command @@ -43,6 +45,7 @@ only be used with inputs that belong to an lnd wallet.`, --inputoutpoints xxxxxxxxx:y,xxxxxxxxx:y \ --sweepaddr bc1q..... \ --feerate 10 \ + --rbf=true \ --publish`, RunE: cc.Execute, } @@ -68,6 +71,10 @@ only be used with inputs that belong to an lnd wallet.`, "number of keys to scan per internal/external branch; output "+ "will consist of double this amount of keys", ) + cc.cmd.Flags().BoolVar( + &cc.Rbf, "rbf", true, "choose RBF flag for this double spend "+ + "transaction. (Be sure to use '=' with this argument)", + ) cc.cmd.Flags().BoolVar( &cc.Publish, "publish", false, "publish replacement TX to "+ "the chain API instead of just printing the TX", @@ -230,9 +237,19 @@ func (c *doubleSpendInputs) Execute(_ *cobra.Command, _ []string) error { // Create the transaction. tx := wire.NewMsgTx(2) + // enable/disable RBF + var sequence uint32 = mempool.MaxRBFSequence + if !c.Rbf { + sequence = wire.MaxTxInSequenceNum + } + // Add the inputs. for _, outpoint := range outpoints { - tx.AddTxIn(wire.NewTxIn(outpoint, nil, nil)) + + tx.AddTxIn(&wire.TxIn{ + PreviousOutPoint: *outpoint, + Sequence: sequence, + }) } tx.AddTxOut(wire.NewTxOut(int64(totalInput-totalFee), sweepScript)) diff --git a/doc/chantools_doublespendinputs.md b/doc/chantools_doublespendinputs.md index fe6b5a6..e683594 100644 --- a/doc/chantools_doublespendinputs.md +++ b/doc/chantools_doublespendinputs.md @@ -19,6 +19,7 @@ chantools doublespendinputs \ --inputoutpoints xxxxxxxxx:y,xxxxxxxxx:y \ --sweepaddr bc1q..... \ --feerate 10 \ + --rbf=true \ --publish ``` @@ -31,6 +32,7 @@ chantools doublespendinputs \ -h, --help help for doublespendinputs --inputoutpoints strings list of outpoints to double spend in the format txid:vout --publish publish replacement TX to the chain API instead of just printing the TX + --rbf choose RBF flag for this double spend transaction. (Be sure to use '=' with this argument) (default true) --recoverywindow uint32 number of keys to scan per internal/external branch; output will consist of double this amount of keys (default 2500) --rootkey string BIP32 HD root key of the wallet to use for deriving the input keys; leave empty to prompt for lnd 24 word aezeed --sweepaddr string address to recover the funds to; specify 'fromseed' to derive a new address from the seed automatically diff --git a/doc/chantools_fakechanbackup.md b/doc/chantools_fakechanbackup.md index bf641d0..3cff89e 100644 --- a/doc/chantools_fakechanbackup.md +++ b/doc/chantools_fakechanbackup.md @@ -61,7 +61,7 @@ chantools fakechanbackup --from_channel_graph lncli_describegraph.json \ --channelpoint string funding transaction outpoint of the channel to rescue (:) as it is displayed on 1ml.com --from_channel_graph string the full LN channel graph in the JSON format that the 'lncli describegraph' returns -h, --help help for fakechanbackup - --multi_file string the fake channel backup file to create (default "results/fake-2023-04-11-16-33-35.backup") + --multi_file string the fake channel backup file to create (default "results/fake-2024-01-26-02-27-52.backup") --remote_node_addr string the remote node connection information in the format pubkey@host:port --rootkey string BIP32 HD root key of the wallet to use for encrypting the backup; leave empty to prompt for lnd 24 word aezeed --short_channel_id string the short channel ID in the format xx diff --git a/doc/chantools_recoverloopin.md b/doc/chantools_recoverloopin.md index b3d9cd2..5ae3d4a 100644 --- a/doc/chantools_recoverloopin.md +++ b/doc/chantools_recoverloopin.md @@ -27,6 +27,7 @@ chantools recoverloopin \ -h, --help help for recoverloopin --loop_db_dir string path to the loop database directory, where the loop.db file is located --num_tries int number of tries to try to find the correct key index (default 1000) + --output_amt uint amount of the output to sweep --publish publish sweep TX to the chain API instead of just printing the TX --rootkey string BIP32 HD root key of the wallet to use for deriving starting key; leave empty to prompt for lnd 24 word aezeed --start_key_index int start key index to try to find the correct key index diff --git a/doc/chantools_zombierecovery_makeoffer.md b/doc/chantools_zombierecovery_makeoffer.md index 3a2c99d..a8c2009 100644 --- a/doc/chantools_zombierecovery_makeoffer.md +++ b/doc/chantools_zombierecovery_makeoffer.md @@ -31,6 +31,7 @@ chantools zombierecovery makeoffer \ --bip39 read a classic BIP39 seed and passphrase from the terminal instead of asking for lnd seed format or providing the --rootkey flag --feerate uint32 fee rate to use for the sweep transaction in sat/vByte (default 30) -h, --help help for makeoffer + --matchonly only match the keys, don't create an offer --node1_keys string the JSON file generated in theprevious step ('preparekeys') command of node 1 --node2_keys string the JSON file generated in theprevious step ('preparekeys') command of node 2 --rootkey string BIP32 HD root key of the wallet to use for signing the offer; leave empty to prompt for lnd 24 word aezeed diff --git a/doc/chantools_zombierecovery_preparekeys.md b/doc/chantools_zombierecovery_preparekeys.md index 96ee567..085ac9c 100644 --- a/doc/chantools_zombierecovery_preparekeys.md +++ b/doc/chantools_zombierecovery_preparekeys.md @@ -28,6 +28,7 @@ chantools zombierecovery preparekeys \ --bip39 read a classic BIP39 seed and passphrase from the terminal instead of asking for lnd seed format or providing the --rootkey flag -h, --help help for preparekeys --match_file string the match JSON file that was sent to both nodes by the match maker + --num_keys uint32 the number of multisig keys to derive (default 2500) --payout_addr string the address where this node's rescued funds should be sent to, must be a P2WPKH (native SegWit) address --rootkey string BIP32 HD root key of the wallet to use for deriving the multisig keys; leave empty to prompt for lnd 24 word aezeed ``` From d9af0e36e5afcaa71fb9aa5eea1a2e094f50939e Mon Sep 17 00:00:00 2001 From: Felix Passenberg Date: Mon, 29 Jan 2024 16:11:01 +0100 Subject: [PATCH 2/2] doublespendinputs: remove RBF argument, RBF always on --- cmd/chantools/doublespendinputs.go | 15 +-------------- doc/chantools_doublespendinputs.md | 2 -- 2 files changed, 1 insertion(+), 16 deletions(-) diff --git a/cmd/chantools/doublespendinputs.go b/cmd/chantools/doublespendinputs.go index d529a12..532228b 100644 --- a/cmd/chantools/doublespendinputs.go +++ b/cmd/chantools/doublespendinputs.go @@ -27,7 +27,6 @@ type doubleSpendInputs struct { SweepAddr string FeeRate uint32 RecoveryWindow uint32 - Rbf bool rootKey *rootKey cmd *cobra.Command @@ -45,7 +44,6 @@ only be used with inputs that belong to an lnd wallet.`, --inputoutpoints xxxxxxxxx:y,xxxxxxxxx:y \ --sweepaddr bc1q..... \ --feerate 10 \ - --rbf=true \ --publish`, RunE: cc.Execute, } @@ -71,10 +69,6 @@ only be used with inputs that belong to an lnd wallet.`, "number of keys to scan per internal/external branch; output "+ "will consist of double this amount of keys", ) - cc.cmd.Flags().BoolVar( - &cc.Rbf, "rbf", true, "choose RBF flag for this double spend "+ - "transaction. (Be sure to use '=' with this argument)", - ) cc.cmd.Flags().BoolVar( &cc.Publish, "publish", false, "publish replacement TX to "+ "the chain API instead of just printing the TX", @@ -237,18 +231,11 @@ func (c *doubleSpendInputs) Execute(_ *cobra.Command, _ []string) error { // Create the transaction. tx := wire.NewMsgTx(2) - // enable/disable RBF - var sequence uint32 = mempool.MaxRBFSequence - if !c.Rbf { - sequence = wire.MaxTxInSequenceNum - } - // Add the inputs. for _, outpoint := range outpoints { - tx.AddTxIn(&wire.TxIn{ PreviousOutPoint: *outpoint, - Sequence: sequence, + Sequence: mempool.MaxRBFSequence, }) } diff --git a/doc/chantools_doublespendinputs.md b/doc/chantools_doublespendinputs.md index e683594..fe6b5a6 100644 --- a/doc/chantools_doublespendinputs.md +++ b/doc/chantools_doublespendinputs.md @@ -19,7 +19,6 @@ chantools doublespendinputs \ --inputoutpoints xxxxxxxxx:y,xxxxxxxxx:y \ --sweepaddr bc1q..... \ --feerate 10 \ - --rbf=true \ --publish ``` @@ -32,7 +31,6 @@ chantools doublespendinputs \ -h, --help help for doublespendinputs --inputoutpoints strings list of outpoints to double spend in the format txid:vout --publish publish replacement TX to the chain API instead of just printing the TX - --rbf choose RBF flag for this double spend transaction. (Be sure to use '=' with this argument) (default true) --recoverywindow uint32 number of keys to scan per internal/external branch; output will consist of double this amount of keys (default 2500) --rootkey string BIP32 HD root key of the wallet to use for deriving the input keys; leave empty to prompt for lnd 24 word aezeed --sweepaddr string address to recover the funds to; specify 'fromseed' to derive a new address from the seed automatically