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

add wipe, wire.write is a generator, add trezor/workflows

This commit is contained in:
Jan Pochyla 2016-06-06 14:10:36 +02:00 committed by Pavol Rusnak
parent 9f40362482
commit 377fffa5a5
No known key found for this signature in database
GPG Key ID: 91F3B339B9A02A3D
11 changed files with 95 additions and 46 deletions

View File

@ -39,7 +39,7 @@ def layout_homescreen(initialize_msg=None):
features.passphrase_cached = False
features.passphrase_protection = False
features.vendor = 'bitcointrezor.com'
wire.write(features)
yield from wire.write(features)
yield loop.Wait([dispatcher.dispatch(),
swipe_to_rotate(),
animate_logo()])

View File

@ -12,6 +12,18 @@ def dispatch_LoadDevice(mtype, mbuf):
return layout_load_device(message)
@unimport_func
def dispatch_WipeDevice(mtype, mbuf):
from trezor.messages.WipeDevice import WipeDevice
message = WipeDevice.loads(mbuf)
from .layout_wipe_device import layout_wipe_device
return layout_wipe_device(message)
def boot():
LoadDevice = 13
register(LoadDevice, dispatch_LoadDevice)
WipeDevice = 5
register(WipeDevice, dispatch_WipeDevice)

View File

@ -1,22 +1,7 @@
from trezor import wire
from trezor import ui
from trezor.utils import unimport_gen
@unimport_gen
def confirm():
from trezor.ui.confirm import ConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest
from trezor.messages.ButtonRequestType import Other
from trezor.messages.ButtonAck import ButtonAck
dialog = ConfirmDialog()
dialog.render()
ack = yield from wire.call(ButtonRequest(code=Other), ButtonAck)
res = yield from dialog.wait()
return res == CONFIRMED
from trezor.workflows.confirm import confirm
@unimport_gen
@ -30,8 +15,8 @@ def layout_load_device(message):
if confirmed:
from trezor.messages.Success import Success
wire.write(Success(message='Loaded'))
yield from wire.write(Success(message='Loaded'))
else:
from trezor.messages.Failure import Failure
from trezor.messages.FailureType import ActionCancelled
wire.write(Failure(message='Cancelled', code=ActionCancelled))
yield from wire.write(Failure(message='Cancelled', code=ActionCancelled))

View File

@ -0,0 +1,22 @@
from trezor import wire
from trezor import ui
from trezor.utils import unimport_gen
from trezor.workflows.confirm import confirm
@unimport_gen
def layout_wipe_device(message):
ui.clear()
ui.display.text_center(120, 40, 'Really wipe device?', ui.BOLD, ui.WHITE, ui.BLACK)
ui.display.text_center(120, 100, 'You might regret it!', ui.NORMAL, ui.WHITE, ui.BLACK)
confirmed = yield from confirm()
if confirmed:
from trezor.messages.Success import Success
yield from wire.write(Success(message='Wiped'))
else:
from trezor.messages.Failure import Failure
from trezor.messages.FailureType import ActionCancelled
yield from wire.write(Failure(message='Cancelled', code=ActionCancelled))

View File

@ -1,23 +1,6 @@
from trezor import wire
from trezor.utils import unimport_gen
@unimport_gen
def request_pin():
from trezor.ui.pin import PinMatrix
from trezor.ui.confirm import ConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest
from trezor.messages.ButtonRequestType import ProtectCall
from trezor.messages.ButtonAck import ButtonAck
matrix = PinMatrix()
dialog = ConfirmDialog(matrix)
dialog.render()
ack = yield from wire.call(ButtonRequest(code=ProtectCall), ButtonAck)
res = yield from dialog.wait()
return matrix.pin if res == CONFIRMED else None
from trezor.workflows.request_pin import request_pin
@unimport_gen
@ -35,9 +18,9 @@ def layout_get_public_key(message):
pubkey.node.fingerprint = 0
pubkey.node.chain_code = 'deadbeef'
pubkey.node.public_key = 'deadbeef'
wire.write(pubkey)
yield from wire.write(pubkey)
else:
from trezor.messages.Failure import Failure
from trezor.messages.FailureType import ActionCancelled
wire.write(Failure(message='Cancelled', code=ActionCancelled))
yield from wire.write(Failure(message='Cancelled', code=ActionCancelled))

View File

@ -75,7 +75,15 @@ class TestWire(unittest.TestCase):
content = bytes([x for x in range(0, 256)])
message = b'##\xab\xcd\x00\x00\x01\00' + content
reports = [b'\x3f' + ch + '\x00' * (63 - len(ch)) for ch in chunks(message, 63)]
write_wire_msg(int('0xabcd'), content)
writer = write_wire_msg(int('0xabcd'), content)
res = 1 # Something not None
try:
while True:
writer.send(None)
except StopIteration as e:
res = e.value
self.assertEqual(res, None)
self.assertEqual(sent_reps, reports)

View File

@ -1,6 +1,3 @@
import ustruct
from trezor import loop
from TrezorMsg import Msg
_msg = Msg()

View File

@ -18,6 +18,7 @@ def read_report():
def write_report(rep):
size = msg.send(IFACE, rep)
assert size == REPORT_LEN, 'HID write failed'
yield # write_report is a generator for the sake of consistency
def read_wire_msg():
@ -64,7 +65,7 @@ def write_wire_msg(mtype, mbuf):
while i < len(data):
data[i] = 0
i += 1
write_report(rep)
yield from write_report(rep)
mbuf = mbuf[n:]
data = rep[1:]
@ -81,10 +82,10 @@ def read(*types):
def write(m):
mbuf = m.dumps()
mtype = m.message_type.wire_type
write_wire_msg(mtype, mbuf)
yield from write_wire_msg(mtype, mbuf)
def call(req, *types):
write(req)
yield from write(req)
res = yield from read(*types)
return res

View File

View File

@ -0,0 +1,21 @@
from trezor import wire
from trezor import ui
from trezor.utils import unimport_gen
@unimport_gen
def confirm(content=None, code=None):
from trezor.ui.confirm import ConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest
from trezor.messages.ButtonRequestType import Other
from trezor.messages.ButtonAck import ButtonAck
dialog = ConfirmDialog(content)
dialog.render()
if code is None:
code = Other
ack = yield from wire.call(ButtonRequest(code=code), ButtonAck)
res = yield from dialog.wait()
return res == CONFIRMED

View File

@ -0,0 +1,20 @@
from trezor import wire
from trezor.utils import unimport_gen
@unimport_gen
def request_pin():
from trezor.ui.pin import PinMatrix
from trezor.ui.confirm import ConfirmDialog, CONFIRMED
from trezor.messages.ButtonRequest import ButtonRequest
from trezor.messages.ButtonRequestType import ProtectCall
from trezor.messages.ButtonAck import ButtonAck
matrix = PinMatrix()
dialog = ConfirmDialog(matrix)
dialog.render()
ack = yield from wire.call(ButtonRequest(code=ProtectCall), ButtonAck)
res = yield from dialog.wait()
return matrix.pin if res == CONFIRMED else None