Browse Source

restore the option to display private keys for export

283
thomasv 13 years ago
parent
commit
ed1fe71238
  1. 22
      client/electrum.py

22
client/electrum.py

@ -19,7 +19,7 @@
import sys, base64, os, re, hashlib, socket, getpass, copy, operator, ast import sys, base64, os, re, hashlib, socket, getpass, copy, operator, ast
from decimal import Decimal from decimal import Decimal
from ecdsa.util import string_to_number from ecdsa.util import string_to_number, number_to_string
try: try:
import ecdsa import ecdsa
@ -319,11 +319,12 @@ class Wallet:
def get_private_key2(self, address, password): def get_private_key2(self, address, password):
""" Privatekey(type,n) = Master_private_key + H(n|S|type) """ """ Privatekey(type,n) = Master_private_key + H(n|S|type) """
order = generator_secp256k1.order()
if address in self.imported_keys.keys(): if address in self.imported_keys.keys():
b = self.pw_decode( self.imported_keys[address], password ) b = self.pw_decode( self.imported_keys[address], password )
b = ASecretToSecret( b ) b = ASecretToSecret( b )
secexp = int( b.encode('hex'), 16) secexp = int( b.encode('hex'), 16)
private_key = ecdsa.SigningKey.from_secret_exponent( secexp, curve=SECP256k1 )
else: else:
if address in self.addresses: if address in self.addresses:
n = self.addresses.index(address) n = self.addresses.index(address)
@ -335,14 +336,12 @@ class Wallet:
raise BaseException("unknown address") raise BaseException("unknown address")
seed = self.pw_decode( self.seed, password) seed = self.pw_decode( self.seed, password)
secexp = self.stretch_key(seed) secexp = self.stretch_key(seed)
order = generator_secp256k1.order() secexp = ( secexp + self.get_sequence(n,for_change) ) % order
privkey_number = ( secexp + self.get_sequence(n,for_change) ) % order
private_key = ecdsa.SigningKey.from_secret_exponent( privkey_number, curve = SECP256k1 )
# sanity check pk = number_to_string(secexp,order)
public_key = private_key.get_verifying_key() return pk
assert address == public_key_to_bc_address( '04'.decode('hex') + public_key.to_string() )
return private_key
def create_new_address2(self, for_change): def create_new_address2(self, for_change):
""" Publickey(type,n) = Master_public_key + H(n|S|type)*point """ """ Publickey(type,n) = Master_public_key + H(n|S|type)*point """
@ -612,7 +611,7 @@ class Wallet:
s_inputs = [] s_inputs = []
for i in range(len(inputs)): for i in range(len(inputs)):
addr, v, p_hash, p_pos, p_scriptPubKey, _, _ = inputs[i] addr, v, p_hash, p_pos, p_scriptPubKey, _, _ = inputs[i]
private_key = self.get_private_key2(addr, password) private_key = ecdsa.SigningKey.from_string( self.get_private_key2(addr, password), curve = SECP256k1 )
public_key = private_key.get_verifying_key() public_key = private_key.get_verifying_key()
pubkey = public_key.to_string() pubkey = public_key.to_string()
tx = filter( raw_tx( inputs, outputs, for_sig = i ) ) tx = filter( raw_tx( inputs, outputs, for_sig = i ) )
@ -897,6 +896,9 @@ if __name__ == '__main__':
else: no += 1 else: no += 1
b = "%d %d %f"%(no, ni, wallet.get_addr_balance(addr)[0]*1e-8) b = "%d %d %f"%(no, ni, wallet.get_addr_balance(addr)[0]*1e-8)
else: b='' else: b=''
if options.show_keys:
pk = wallet.get_private_key2(addr, password)
addr = addr + ':' + SecretToASecret(pk)
print addr, b, label print addr, b, label
if cmd == 'history': if cmd == 'history':

Loading…
Cancel
Save