Browse Source

wallet: minor clean-up of tx.set_rbf() calls

Better to always call it, to make sure inputs have identical sequence numbers.
patch-4
SomberNight 4 years ago
parent
commit
914eb9989d
No known key found for this signature in database GPG Key ID: B33B5F232C6271E9
  1. 3
      electrum/gui/kivy/uix/dialogs/tx_dialog.py
  2. 3
      electrum/gui/qt/confirm_tx_dialog.py
  3. 4
      electrum/gui/qt/main_window.py
  4. 3
      electrum/transaction.py
  5. 13
      electrum/wallet.py

3
electrum/gui/kivy/uix/dialogs/tx_dialog.py

@ -282,8 +282,7 @@ class TxDialog(Factory.Popup):
except CannotBumpFee as e: except CannotBumpFee as e:
self.app.show_error(str(e)) self.app.show_error(str(e))
return return
if is_final: new_tx.set_rbf(not is_final)
new_tx.set_rbf(False)
self.tx = new_tx self.tx = new_tx
self.update() self.update()
self.do_sign() self.do_sign()

3
electrum/gui/qt/confirm_tx_dialog.py

@ -111,8 +111,7 @@ class TxEditor:
self.main_window.show_error(str(e)) self.main_window.show_error(str(e))
raise raise
use_rbf = bool(self.config.get('use_rbf', True)) use_rbf = bool(self.config.get('use_rbf', True))
if use_rbf: self.tx.set_rbf(use_rbf)
self.tx.set_rbf(True)
def have_enough_funds_assuming_zero_fees(self) -> bool: def have_enough_funds_assuming_zero_fees(self) -> bool:
try: try:

4
electrum/gui/qt/main_window.py

@ -3242,7 +3242,6 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
except CannotCPFP as e: except CannotCPFP as e:
self.show_error(str(e)) self.show_error(str(e))
return return
new_tx.set_rbf(True)
self.show_transaction(new_tx) self.show_transaction(new_tx)
def _add_info_to_tx_from_wallet_and_network(self, tx: PartialTransaction) -> bool: def _add_info_to_tx_from_wallet_and_network(self, tx: PartialTransaction) -> bool:
@ -3329,8 +3328,7 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, Logger):
except Exception as e: except Exception as e:
self.show_error(str(e)) self.show_error(str(e))
return return
if is_final: new_tx.set_rbf(not is_final)
new_tx.set_rbf(False)
self.show_transaction(new_tx, tx_desc=tx_label) self.show_transaction(new_tx, tx_desc=tx_label)
def bump_fee_dialog(self, tx: Transaction): def bump_fee_dialog(self, tx: Transaction):

3
electrum/transaction.py

@ -864,7 +864,8 @@ class Transaction:
def add_info_from_wallet(self, wallet: 'Abstract_Wallet', **kwargs) -> None: def add_info_from_wallet(self, wallet: 'Abstract_Wallet', **kwargs) -> None:
return # no-op return # no-op
def is_final(self): def is_final(self) -> bool:
"""Whether RBF is disabled."""
return not any([txin.nsequence < 0xffffffff - 1 for txin in self.inputs()]) return not any([txin.nsequence < 0xffffffff - 1 for txin in self.inputs()])
def estimated_size(self): def estimated_size(self):

13
electrum/wallet.py

@ -195,9 +195,8 @@ async def sweep(
locktime = get_locktime_for_new_transaction(network) locktime = get_locktime_for_new_transaction(network)
tx = PartialTransaction.from_io(inputs, outputs, locktime=locktime, version=tx_version) tx = PartialTransaction.from_io(inputs, outputs, locktime=locktime, version=tx_version)
rbf = config.get('use_rbf', True) rbf = bool(config.get('use_rbf', True))
if rbf: tx.set_rbf(rbf)
tx.set_rbf(True)
tx.sign(keypairs) tx.sign(keypairs)
return tx return tx
@ -1303,6 +1302,7 @@ class Abstract_Wallet(AddressSynchronizer, ABC):
# Timelock tx to current height. # Timelock tx to current height.
tx.locktime = get_locktime_for_new_transaction(self.network) tx.locktime = get_locktime_for_new_transaction(self.network)
tx.set_rbf(False) # caller can set RBF manually later
tx.add_info_from_wallet(self) tx.add_info_from_wallet(self)
run_hook('make_unsigned_transaction', self, tx) run_hook('make_unsigned_transaction', self, tx)
return tx return tx
@ -1606,6 +1606,7 @@ class Abstract_Wallet(AddressSynchronizer, ABC):
outputs = [PartialTxOutput.from_address_and_value(out_address, output_value)] outputs = [PartialTxOutput.from_address_and_value(out_address, output_value)]
locktime = get_locktime_for_new_transaction(self.network) locktime = get_locktime_for_new_transaction(self.network)
tx_new = PartialTransaction.from_io(inputs, outputs, locktime=locktime) tx_new = PartialTransaction.from_io(inputs, outputs, locktime=locktime)
tx_new.set_rbf(True)
tx_new.add_info_from_wallet(self) tx_new.add_info_from_wallet(self)
return tx_new return tx_new
@ -1656,6 +1657,7 @@ class Abstract_Wallet(AddressSynchronizer, ABC):
raise CannotDoubleSpendTx(_("The output value remaining after fee is too low.")) raise CannotDoubleSpendTx(_("The output value remaining after fee is too low."))
outputs = [PartialTxOutput.from_address_and_value(out_address, value - new_fee)] outputs = [PartialTxOutput.from_address_and_value(out_address, value - new_fee)]
tx_new = PartialTransaction.from_io(inputs, outputs, locktime=locktime) tx_new = PartialTransaction.from_io(inputs, outputs, locktime=locktime)
tx_new.set_rbf(True)
tx_new.add_info_from_wallet(self) tx_new.add_info_from_wallet(self)
return tx_new return tx_new
@ -2301,9 +2303,8 @@ class Abstract_Wallet(AddressSynchronizer, ABC):
if locktime is not None: if locktime is not None:
tx.locktime = locktime tx.locktime = locktime
if rbf is None: if rbf is None:
rbf = self.config.get('use_rbf', True) rbf = bool(self.config.get('use_rbf', True))
if rbf: tx.set_rbf(rbf)
tx.set_rbf(True)
if not unsigned: if not unsigned:
self.sign_transaction(tx, password) self.sign_transaction(tx, password)
return tx return tx

Loading…
Cancel
Save