1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-13 17:00:59 +00:00

Fix PIN handling

This commit is contained in:
slush 2013-09-01 03:34:36 +02:00
parent cb594df790
commit 6fe26c26e4
2 changed files with 11 additions and 6 deletions

View File

@ -17,9 +17,6 @@ class CallException(Exception):
class PinException(CallException):
pass
class OtpException(CallException):
pass
class BitkeyClient(object):
def __init__(self, transport, debuglink=None,
@ -80,10 +77,10 @@ class BitkeyClient(object):
if isinstance(resp, proto.PinMatrixRequest):
if self.debuglink:
if self.debug_pin:
pin = self.debuglink.read_pin()
pin = self.debuglink.read_pin_encoded()
msg2 = proto.PinMatrixAck(pin=pin)
else:
msg2 = proto.PinMatrixAck(pin='__42__')
msg2 = proto.PinMatrixAck(pin='444444222222')
else:
pin = self.input_func("PIN required: ", resp.message)
msg2 = proto.PinMatrixAck(pin=pin)
@ -106,6 +103,9 @@ class BitkeyClient(object):
return resp
def ping(self, msg):
return self.call(proto.Ping(message=msg)).message
def get_uuid(self):
return self.call(proto.GetUUID()).UUID

View File

@ -20,11 +20,16 @@ class DebugLink(object):
print "Read PIN:", obj.pin
print "Read matrix:", obj.matrix
return (obj.pin, obj.matrix)
def read_pin_encoded(self):
pin, matrix = self.read_pin()
# Now we have real PIN and PIN matrix.
# We have to encode that into encoded pin,
# because application must send back positions
# on keypad, not a real PIN.
pin_encoded = ''.join([ str(obj.matrix.index(p) + 1) for p in obj.pin])
pin_encoded = ''.join([ str(matrix.index(p) + 1) for p in pin])
print "Encoded PIN:", pin_encoded
self.pin_func(pin_encoded)