Browse Source

add dumpprivkey command; finalize private_keys parameter for signrawtransaction

283
thomasv 12 years ago
parent
commit
0863f09a06
  1. 45
      electrum
  2. 22
      lib/bitcoin.py
  3. 13
      lib/wallet.py

45
electrum

@ -91,6 +91,7 @@ options:\n --fee, -f: set transaction fee\n --fromaddr, -s: send from address
'unfreeze':'', 'unfreeze':'',
'prioritize':'', 'prioritize':'',
'unprioritize':'', 'unprioritize':'',
'dumpprivkey':'',
'createmultisig':'similar to bitcoind\'s command', 'createmultisig':'similar to bitcoind\'s command',
'createrawtransaction':'similar to bitcoind\'s command', 'createrawtransaction':'similar to bitcoind\'s command',
'decoderawtransaction':'similar to bitcoind\'s command', 'decoderawtransaction':'similar to bitcoind\'s command',
@ -112,7 +113,7 @@ offline_commands = [ 'password', 'mktx', 'signtx',
] ]
protected_commands = ['payto', 'password', 'mktx', 'signtx', 'seed', 'importprivkey','signmessage', 'signrawtransaction' ] protected_commands = ['payto', 'password', 'mktx', 'signtx', 'seed', 'importprivkey','signmessage', 'signrawtransaction','dumpprivkey' ]
# get password routine # get password routine
def prompt_password(prompt, confirm=True): def prompt_password(prompt, confirm=True):
@ -696,6 +697,12 @@ if __name__ == '__main__':
print_msg(wallet.unprioritize(addr)) print_msg(wallet.unprioritize(addr))
elif cmd == 'dumpprivkey':
addr = args[1]
sec = wallet.get_private_key_base58(addr, password)
print_msg( sec )
elif cmd == 'createmultisig': elif cmd == 'createmultisig':
import ast import ast
from lib.bitcoin import * from lib.bitcoin import *
@ -726,23 +733,33 @@ if __name__ == '__main__':
elif cmd == 'signrawtransaction': elif cmd == 'signrawtransaction':
import ast
tx = Transaction(args[1]) tx = Transaction(args[1])
txouts = args[2] if len(args)>2 else [] txouts = ast.literal_eval(args[2]) if len(args)>2 else []
private_keys = args[3] if len(args)>3 else {} private_keys = ast.literal_eval(args[3]) if len(args)>3 else {}
# lookup addresses
for txin in tx.inputs:
txid = txin["prevout_hash"]
index = txin["prevout_n"]
utx = wallet.transactions.get(txid)
txout = utx['outputs'][index]
txin['address'] = txout['address']
txin['raw_output_script'] = txout['raw_output_script']
# convert to own format
txin['tx_hash'] = txin['prevout_hash']
txin['index'] = txin['prevout_n']
if not private_keys: if not private_keys:
for txin in tx.inputs: for txin in tx.inputs:
txid = txin["prevout_hash"] addr = txin['address']
index = txin["prevout_n"] private_keys[addr] = wallet.get_private_key_base58(addr, password)
utx = wallet.transactions.get(txid) else:
txout = utx['outputs'][index] pk = {}
txin['address'] = txout['address'] for sec in private_keys:
txin['raw_output_script'] = txout['raw_output_script'] address = bitcoin.address_from_private_key(sec)
# convert to own format pk[address] = sec
txin['tx_hash'] = txin['prevout_hash'] private_keys = pk
txin['index'] = txin['prevout_n']
secexp, compressed = wallet.get_private_key(txin['address'], password)
private_keys[addr] = (secexp,compressed)
tx.sign( private_keys ) tx.sign( private_keys )
print_msg(tx) print_msg(tx)

22
lib/bitcoin.py

@ -232,6 +232,22 @@ def is_compressed(sec):
b = ASecretToSecret(sec) b = ASecretToSecret(sec)
return len(b) == 33 return len(b) == 33
def address_from_private_key(sec):
# rebuild public key from private key, compressed or uncompressed
pkey = regenerate_key(sec)
assert pkey
# figure out if private key is compressed
compressed = is_compressed(sec)
# rebuild private and public key from regenerated secret
private_key = GetPrivKey(pkey, compressed)
public_key = GetPubKey(pkey.pubkey, compressed)
address = public_key_to_bc_address(public_key)
return address
########### end pywallet functions ####################### ########### end pywallet functions #######################
# secp256k1, http://www.oid-info.com/get/1.3.132.0.10 # secp256k1, http://www.oid-info.com/get/1.3.132.0.10
@ -447,7 +463,11 @@ class Transaction:
for i in range(len(self.inputs)): for i in range(len(self.inputs)):
txin = self.inputs[i] txin = self.inputs[i]
secexp, compressed = private_keys[txin['address']] sec = private_keys[txin['address']]
compressed = is_compressed(sec)
pkey = regenerate_key(sec)
secexp = pkey.secret
private_key = ecdsa.SigningKey.from_secret_exponent( secexp, curve = SECP256k1 ) private_key = ecdsa.SigningKey.from_secret_exponent( secexp, curve = SECP256k1 )
public_key = private_key.get_verifying_key() public_key = private_key.get_verifying_key()
pkey = EC_KEY(secexp) pkey = EC_KEY(secexp)

13
lib/wallet.py

@ -120,18 +120,7 @@ class Wallet:
except: except:
raise BaseException("Invalid password") raise BaseException("Invalid password")
# rebuild public key from private key, compressed or uncompressed address = address_from_private_key(sec)
pkey = regenerate_key(sec)
if not pkey:
return False
# figure out if private key is compressed
compressed = is_compressed(sec)
# rebuild private and public key from regenerated secret
private_key = GetPrivKey(pkey, compressed)
public_key = GetPubKey(pkey.pubkey, compressed)
address = public_key_to_bc_address(public_key)
if address in self.all_addresses(): if address in self.all_addresses():
raise BaseException('Address already in wallet') raise BaseException('Address already in wallet')

Loading…
Cancel
Save