Browse Source

importprivkey: do not import the same key twice

283
ThomasV 9 years ago
parent
commit
5733a5d125
  1. 3
      gui/qt/main_window.py
  2. 2
      lib/commands.py
  3. 4
      lib/keystore.py

3
gui/qt/main_window.py

@ -2208,10 +2208,9 @@ class ElectrumWindow(QMainWindow, MessageBoxMixin, PrintError):
badkeys = [] badkeys = []
addrlist = [] addrlist = []
for key in text: for key in text:
addr = self.wallet.import_key(key, password)
try: try:
addr = self.wallet.import_key(key, password) addr = self.wallet.import_key(key, password)
except Exception as e: except BaseException as e:
badkeys.append(key) badkeys.append(key)
continue continue
if not addr: if not addr:

2
lib/commands.py

@ -368,7 +368,7 @@ class Commands:
try: try:
addr = self.wallet.import_key(privkey, self._password) addr = self.wallet.import_key(privkey, self._password)
out = "Keypair imported: " + addr out = "Keypair imported: " + addr
except Exception as e: except BaseException as e:
out = "Error: " + str(e) out = "Error: " + str(e)
return out return out

4
lib/keystore.py

@ -115,7 +115,9 @@ class Imported_KeyStore(Software_KeyStore):
try: try:
pubkey = public_key_from_private_key(sec) pubkey = public_key_from_private_key(sec)
except Exception: except Exception:
raise Exception('Invalid private key') raise BaseException('Invalid private key')
if pubkey in self.keypairs:
raise BaseException('Private key already in keystore')
self.keypairs[pubkey] = sec self.keypairs[pubkey] = sec
return pubkey return pubkey

Loading…
Cancel
Save