mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-12 08:20:56 +00:00
Fixed load_device, including command line
This commit is contained in:
parent
56eb483f70
commit
e542c2dc29
19
cmd.py
19
cmd.py
@ -99,9 +99,6 @@ class Commands(object):
|
|||||||
def get_public_node(self, args):
|
def get_public_node(self, args):
|
||||||
return self.client.get_public_node(args.n)
|
return self.client.get_public_node(args.n)
|
||||||
|
|
||||||
def get_serial_number(self, args):
|
|
||||||
return binascii.hexlify(self.client.get_serial_number())
|
|
||||||
|
|
||||||
def set_label(self, args):
|
def set_label(self, args):
|
||||||
return self.client.apply_settings(label=args.label)
|
return self.client.apply_settings(label=args.label)
|
||||||
|
|
||||||
@ -109,9 +106,14 @@ class Commands(object):
|
|||||||
return self.client.apply_settings(coin_shortcut=args.coin_shortcut)
|
return self.client.apply_settings(coin_shortcut=args.coin_shortcut)
|
||||||
|
|
||||||
def load_device(self, args):
|
def load_device(self, args):
|
||||||
seed = ' '.join(args.seed)
|
if not args.mnemonic and not args.xprv:
|
||||||
|
raise Exception("Please provide mnemonic or xprv")
|
||||||
|
|
||||||
return self.client.load_device(seed, args.pin)
|
if args.mnemonic:
|
||||||
|
mnemonic = ' '.join(args.mnemonic)
|
||||||
|
return self.client.load_device_by_mnemonic(mnemonic, args.pin, args.passphrase_protection)
|
||||||
|
|
||||||
|
return self.client.load_device_by_xprv(args.xprv, args.pin, args.passphrase_protection)
|
||||||
|
|
||||||
def sign_message(self, args):
|
def sign_message(self, args):
|
||||||
return self.client.sign_message(args.n, args.message)
|
return self.client.sign_message(args.n, args.message)
|
||||||
@ -134,7 +136,6 @@ class Commands(object):
|
|||||||
get_address.help = 'Get bitcoin address in base58 encoding'
|
get_address.help = 'Get bitcoin address in base58 encoding'
|
||||||
get_entropy.help = 'Get example entropy'
|
get_entropy.help = 'Get example entropy'
|
||||||
get_features.help = 'Retrieve device features and settings'
|
get_features.help = 'Retrieve device features and settings'
|
||||||
get_serial_number.help = 'Get device\'s unique identifier'
|
|
||||||
get_public_node.help = 'Get public node of given path'
|
get_public_node.help = 'Get public node of given path'
|
||||||
set_label.help = 'Set new wallet label'
|
set_label.help = 'Set new wallet label'
|
||||||
set_coin.help = 'Switch device to another crypto currency'
|
set_coin.help = 'Switch device to another crypto currency'
|
||||||
@ -166,8 +167,10 @@ class Commands(object):
|
|||||||
)
|
)
|
||||||
|
|
||||||
load_device.arguments = (
|
load_device.arguments = (
|
||||||
(('-s', '--seed'), {'type': str, 'nargs': '+'}),
|
(('-m', '--mnemonic'), {'type': str, 'nargs': '+'}),
|
||||||
(('-n', '--pin'), {'type': str, 'default': ''}),
|
(('-x', '--xprv'), {'type': str}),
|
||||||
|
(('-p', '--pin'), {'type': str, 'default': ''}),
|
||||||
|
(('-r', '--passphrase-protection'), {'action': 'store_true', 'default': False}),
|
||||||
)
|
)
|
||||||
|
|
||||||
sign_message.arguments = (
|
sign_message.arguments = (
|
||||||
|
@ -3,7 +3,6 @@ import config
|
|||||||
|
|
||||||
from trezorlib.client import TrezorClient
|
from trezorlib.client import TrezorClient
|
||||||
from trezorlib.debuglink import DebugLink
|
from trezorlib.debuglink import DebugLink
|
||||||
from trezorlib import proto
|
|
||||||
|
|
||||||
class TrezorTest(unittest.TestCase):
|
class TrezorTest(unittest.TestCase):
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
@ -19,7 +18,7 @@ class TrezorTest(unittest.TestCase):
|
|||||||
self.client.setup_debuglink(button=True, pin_correct=True)
|
self.client.setup_debuglink(button=True, pin_correct=True)
|
||||||
|
|
||||||
self.client.load_device(
|
self.client.load_device(
|
||||||
seed=self.mnemonic1,
|
mnemonic=self.mnemonic1,
|
||||||
pin=self.pin1)
|
pin=self.pin1)
|
||||||
|
|
||||||
self.client.apply_settings(label='unit testing', coin_shortcut='BTC', language='english')
|
self.client.apply_settings(label='unit testing', coin_shortcut='BTC', language='english')
|
||||||
|
@ -1,7 +1,7 @@
|
|||||||
import unittest
|
import unittest
|
||||||
import common
|
import common
|
||||||
|
|
||||||
from trezorlib import proto
|
from trezorlib import messages_pb2 as messages
|
||||||
|
|
||||||
'''
|
'''
|
||||||
TODO:
|
TODO:
|
||||||
@ -14,16 +14,16 @@ from trezorlib import proto
|
|||||||
|
|
||||||
class TestBasic(common.TrezorTest):
|
class TestBasic(common.TrezorTest):
|
||||||
def test_features(self):
|
def test_features(self):
|
||||||
features = self.client.call(proto.Initialize())
|
features = self.client.call(messages.Initialize())
|
||||||
|
|
||||||
# Result is the same as reported by BitkeyClient class
|
# Result is the same as reported by BitkeyClient class
|
||||||
self.assertEqual(features, self.client.features)
|
self.assertEqual(features, self.client.features)
|
||||||
|
|
||||||
def test_ping(self):
|
def test_ping(self):
|
||||||
ping = self.client.call(proto.Ping(message='ahoj!'))
|
ping = self.client.call(messages.Ping(message='ahoj!'))
|
||||||
|
|
||||||
# Ping results in Success(message='Ahoj!')
|
# Ping results in Success(message='Ahoj!')
|
||||||
self.assertEqual(ping, proto.Success(message='ahoj!'))
|
self.assertEqual(ping, messages.Success(message='ahoj!'))
|
||||||
|
|
||||||
def test_uuid(self):
|
def test_uuid(self):
|
||||||
uuid1 = self.client.get_device_id()
|
uuid1 = self.client.get_device_id()
|
||||||
|
@ -2,6 +2,7 @@ import os
|
|||||||
import time
|
import time
|
||||||
|
|
||||||
import ckd_public
|
import ckd_public
|
||||||
|
import tools
|
||||||
import messages_pb2 as proto
|
import messages_pb2 as proto
|
||||||
import types_pb2 as types
|
import types_pb2 as types
|
||||||
|
|
||||||
@ -22,6 +23,8 @@ class CallException(Exception):
|
|||||||
class PinException(CallException):
|
class PinException(CallException):
|
||||||
pass
|
pass
|
||||||
|
|
||||||
|
PRIME_DERIVATION_FLAG = 0x80000000
|
||||||
|
|
||||||
class TrezorClient(object):
|
class TrezorClient(object):
|
||||||
|
|
||||||
def __init__(self, transport, debuglink=None,
|
def __init__(self, transport, debuglink=None,
|
||||||
@ -40,6 +43,10 @@ class TrezorClient(object):
|
|||||||
def _get_local_entropy(self):
|
def _get_local_entropy(self):
|
||||||
return os.urandom(32)
|
return os.urandom(32)
|
||||||
|
|
||||||
|
def _convert_prime(self, n):
|
||||||
|
# Convert minus signs to uint32 with flag
|
||||||
|
return [ int(abs(x) | PRIME_DERIVATION_FLAG) if x < 0 else x for x in n ]
|
||||||
|
|
||||||
def init_device(self):
|
def init_device(self):
|
||||||
self.features = self.call(proto.Initialize())
|
self.features = self.call(proto.Initialize())
|
||||||
|
|
||||||
@ -49,10 +56,11 @@ class TrezorClient(object):
|
|||||||
self.debuglink.transport.close()
|
self.debuglink.transport.close()
|
||||||
|
|
||||||
def get_public_node(self, n):
|
def get_public_node(self, n):
|
||||||
# print self.bip32_ckd(self.call(proto.GetPublicKey(address_n=n)).node, [2, ])
|
n = self._convert_prime(n)
|
||||||
return self.call(proto.GetPublicKey(address_n=n)).node
|
return self.call(proto.GetPublicKey(address_n=n)).node
|
||||||
|
|
||||||
def get_address(self, n):
|
def get_address(self, n):
|
||||||
|
n = self._convert_prime(n)
|
||||||
return self.call(proto.GetAddress(address_n=n)).address
|
return self.call(proto.GetAddress(address_n=n)).address
|
||||||
|
|
||||||
def get_entropy(self, size):
|
def get_entropy(self, size):
|
||||||
@ -139,6 +147,7 @@ class TrezorClient(object):
|
|||||||
return resp
|
return resp
|
||||||
|
|
||||||
def sign_message(self, n, message):
|
def sign_message(self, n, message):
|
||||||
|
n = self._convert_prime(n)
|
||||||
return self.call(proto.SignMessage(address_n=n, message=message))
|
return self.call(proto.SignMessage(address_n=n, message=message))
|
||||||
|
|
||||||
def verify_message(self, address, signature, message):
|
def verify_message(self, address, signature, message):
|
||||||
@ -266,8 +275,42 @@ class TrezorClient(object):
|
|||||||
self.init_device()
|
self.init_device()
|
||||||
return isinstance(resp, proto.Success)
|
return isinstance(resp, proto.Success)
|
||||||
|
|
||||||
def load_device(self, seed, pin):
|
def load_device_by_mnemonic(self, mnemonic, pin, passphrase_protection):
|
||||||
resp = self.call(proto.LoadDevice(seed=seed, pin=pin))
|
resp = self.call(proto.LoadDevice(mnemonic=mnemonic, pin=pin, passphrase_protection=passphrase_protection))
|
||||||
|
self.init_device()
|
||||||
|
return isinstance(resp, proto.Success)
|
||||||
|
|
||||||
|
def load_device_by_xprv(self, xprv, pin, passphrase_protection):
|
||||||
|
if xprv[0:4] not in ('xprv', 'tprv'):
|
||||||
|
raise Exception("Unknown type of xprv")
|
||||||
|
|
||||||
|
if len(xprv) < 100 and len(xprv) > 112:
|
||||||
|
raise Exception("Invalid length of xprv")
|
||||||
|
|
||||||
|
node = types.HDNodeType()
|
||||||
|
data = tools.b58decode(xprv, None).encode('hex')
|
||||||
|
|
||||||
|
if data[90:92] != '00':
|
||||||
|
raise Exception("Contain invalid private key")
|
||||||
|
|
||||||
|
# version 0488ade4
|
||||||
|
# depth 00
|
||||||
|
# fingerprint 00000000
|
||||||
|
# child_num 00000000
|
||||||
|
# chaincode 873dff81c02f525623fd1fe5167eac3a55a049de3d314bb42ee227ffed37d508
|
||||||
|
# privkey 00e8f32e723decf4051aefac8e2c93c9c5b214313817cdb01a1494b917c8436b35
|
||||||
|
# wtf is this? e77e9d71
|
||||||
|
|
||||||
|
node.version = int(data[0:8], 16)
|
||||||
|
node.depth = int(data[8:10], 16)
|
||||||
|
node.fingerprint = int(data[10:18], 16)
|
||||||
|
node.child_num = int(data[18:26], 16)
|
||||||
|
node.chain_code = data[26:90].decode('hex')
|
||||||
|
node.private_key = data[92:156].decode('hex') # skip 0x00 indicating privkey
|
||||||
|
print 'wtf is this?', len(data[156:])
|
||||||
|
# FIXME
|
||||||
|
|
||||||
|
resp = self.call(proto.LoadDevice(node=node, pin=pin, passphrase_protection=passphrase_protection))
|
||||||
self.init_device()
|
self.init_device()
|
||||||
return isinstance(resp, proto.Success)
|
return isinstance(resp, proto.Success)
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user