electrum

Electrum Bitcoin wallet
git clone https://git.parazyd.org/electrum
Log | Files | Refs | Submodules

commit efa1efedca6e6916db44e26101c70434b771e5e6
parent b752e91dae3a1ea4519e2299bd595cdf85d179aa
Author: Neil Booth <kyuupichan@gmail.com>
Date:   Sat, 23 Jan 2016 22:05:08 +0900

Hardware wallets: limit change outputs to 1

Diffstat:
Mlib/wallet.py | 5++++-
Mplugins/ledger/ledger.py | 1+
Mplugins/trezor/plugin.py | 1+
3 files changed, 6 insertions(+), 1 deletion(-)

diff --git a/lib/wallet.py b/lib/wallet.py @@ -151,6 +151,9 @@ class Abstract_Wallet(PrintError): Wallet classes are created to handle various address generation methods. Completion states (watching-only, single account, no seed, etc) are handled inside classes. """ + + max_change_outputs = 3 + def __init__(self, storage): self.storage = storage self.network = None @@ -966,7 +969,7 @@ class Abstract_Wallet(PrintError): dust_threshold = 182 * 3 * self.relayfee() / 1000 # Let the coin chooser select the coins to spend - max_change = 3 if self.multiple_change else 1 + max_change = self.max_change_outputs if self.multiple_change else 1 coin_chooser = self.coin_chooser(config) tx = coin_chooser.make_tx(coins, outputs, change_addrs[:max_change], fee_estimator, dust_threshold) diff --git a/plugins/ledger/ledger.py b/plugins/ledger/ledger.py @@ -33,6 +33,7 @@ class BTChipWallet(BIP44_Wallet): wallet_type = 'btchip' device = 'Ledger' restore_wallet_class = BIP44_Wallet + max_change_outputs = 1 def __init__(self, storage): BIP44_Wallet.__init__(self, storage) diff --git a/plugins/trezor/plugin.py b/plugins/trezor/plugin.py @@ -36,6 +36,7 @@ class TrezorCompatibleWallet(BIP44_Wallet): # - wallet_type restore_wallet_class = BIP44_Wallet + max_change_outputs = 1 def __init__(self, storage): BIP44_Wallet.__init__(self, storage)