Browse Source

add prioritize and freeze console commands. fix choose_inputs

283
ThomasV 13 years ago
parent
commit
e1b3b5892b
  1. 68
      electrum
  2. 4
      lib/gui_qt.py
  3. 2
      lib/wallet.py

68
electrum

@ -39,8 +39,35 @@ from optparse import OptionParser
from decimal import Decimal from decimal import Decimal
from electrum import Wallet, WalletSynchronizer, format_satoshis from electrum import Wallet, WalletSynchronizer, format_satoshis
known_commands = ['help', 'validateaddress', 'balance', 'contacts', 'create', 'restore', 'payto', 'sendtx', 'password', 'addresses', 'history', 'label', 'mktx','seed','import','signmessage','verifymessage','eval','deseed','reseed'] known_commands = [
offline_commands = ['password', 'mktx', 'label', 'contacts', 'help', 'validateaddress', 'signmessage', 'verifymessage', 'eval', 'create', 'addresses', 'import', 'seed','deseed','reseed'] 'help',
'validateaddress',
'balance',
'contacts',
'create',
'restore',
'payto',
'sendtx',
'password',
'addresses',
'history',
'label',
'mktx',
'seed',
'import',
'signmessage',
'verifymessage',
'eval',
'deseed',
'reseed',
'freeze',
'unfreeze',
'prioritize',
'unprioritize',
]
offline_commands = [ 'password', 'mktx', 'label', 'contacts', 'help', 'validateaddress', 'signmessage', 'verifymessage', 'eval', 'create', 'addresses', 'import', 'seed','deseed','reseed','freeze','unfreeze','prioritize','unprioritize']
protected_commands = ['payto', 'password', 'mktx', 'seed', 'import','signmessage' ] protected_commands = ['payto', 'password', 'mktx', 'seed', 'import','signmessage' ]
if __name__ == '__main__': if __name__ == '__main__':
@ -480,5 +507,40 @@ if __name__ == '__main__':
print True print True
except: except:
print False print False
elif cmd == 'freeze':
addr = args[1]
if addr in self.wallet.all_addresses() and addr not in self.wallet.frozen_addresses:
self.wallet.frozen_addresses.append(addr)
self.wallet.save()
print True
else:
print False
elif cmd == 'unfreeze':
addr = args[1]
if addr in self.wallet.all_addresses() and addr in self.wallet.frozen_addresses:
self.wallet.frozen_addresses.remove(addr)
self.wallet.save()
print True
else:
print False
elif cmd == 'prioritize':
addr = args[1]
if addr in self.wallet.all_addresses() and addr not in self.wallet.frozen_addresses:
self.wallet.prioritized_addresses.append(addr)
self.wallet.save()
print True
else:
print False
elif cmd == 'unprioritize':
addr = args[1]
if addr in self.wallet.all_addresses() and addr in self.wallet.frozen_addresses:
self.wallet.prioritized_addresses.remove(addr)
self.wallet.save()
print True
else:
print False

4
lib/gui_qt.py

@ -566,7 +566,7 @@ class ElectrumWindow(QMainWindow):
self.wallet.save() self.wallet.save()
self.update_receive_tab() self.update_receive_tab()
self.prioritizeButton = b = EnterButton(_("Set priority"), toggle_priority) self.prioritizeButton = b = EnterButton(_("Prioritize"), toggle_priority)
hbox.addWidget(b) hbox.addWidget(b)
hbox.addStretch(1) hbox.addStretch(1)
@ -592,7 +592,7 @@ class ElectrumWindow(QMainWindow):
t = _("Unfreeze") if addr in self.wallet.frozen_addresses else _("Freeze") t = _("Unfreeze") if addr in self.wallet.frozen_addresses else _("Freeze")
self.freezeButton.setText(t) self.freezeButton.setText(t)
t = _("Remove priority") if addr in self.wallet.prioritized_addresses else _("Set priority") t = _("Unprioritize") if addr in self.wallet.prioritized_addresses else _("Prioritize")
self.prioritizeButton.setText(t) self.prioritizeButton.setText(t)

2
lib/wallet.py

@ -669,7 +669,7 @@ class Wallet:
coins = sorted( coins, key = lambda x: x[1]['timestamp'] ) coins = sorted( coins, key = lambda x: x[1]['timestamp'] )
for addr in prioritized_addresses: for addr in self.prioritized_addresses:
h = self.history.get(addr) h = self.history.get(addr)
if h is None: continue if h is None: continue
for item in h: for item in h:

Loading…
Cancel
Save