1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-05 04:50:57 +00:00

management: restore u2f_counter on device recovery

This commit is contained in:
Jan Pochyla 2019-01-15 16:53:44 +01:00
parent 2b24fe14bb
commit 2d70d5d447
2 changed files with 16 additions and 10 deletions

View File

@ -165,7 +165,7 @@ def set_autolock_delay_ms(delay_ms: int) -> None:
def next_u2f_counter() -> int: def next_u2f_counter() -> int:
b = config.get(_APP, _U2F_COUNTER) b = config.get(_APP, _U2F_COUNTER)
if b is None: if not b:
b = 0 b = 0
else: else:
b = int.from_bytes(b, "big") + 1 b = int.from_bytes(b, "big") + 1
@ -174,7 +174,10 @@ def next_u2f_counter() -> int:
def set_u2f_counter(cntr: int): def set_u2f_counter(cntr: int):
if cntr:
config.set(_APP, _U2F_COUNTER, cntr.to_bytes(4, "big")) config.set(_APP, _U2F_COUNTER, cntr.to_bytes(4, "big"))
else:
config.set(_APP, _U2F_COUNTER, b"")
def wipe(): def wipe():

View File

@ -52,14 +52,8 @@ async def recovery_device(ctx, msg):
if msg.pin_protection: if msg.pin_protection:
newpin = await request_pin_confirm(ctx, cancellable=False) newpin = await request_pin_confirm(ctx, cancellable=False)
# save into storage # dry run
if not msg.dry_run: if msg.dry_run:
if msg.pin_protection:
config.change_pin(pin_to_int(""), pin_to_int(newpin))
storage.load_settings(label=msg.label, use_passphrase=msg.passphrase_protection)
storage.load_mnemonic(mnemonic=mnemonic, needs_backup=False, no_backup=False)
return Success(message="Device recovered")
else:
if storage.get_mnemonic() == mnemonic: if storage.get_mnemonic() == mnemonic:
return Success( return Success(
message="The seed is valid and matches the one in the device" message="The seed is valid and matches the one in the device"
@ -69,6 +63,15 @@ async def recovery_device(ctx, msg):
"The seed is valid but does not match the one in the device" "The seed is valid but does not match the one in the device"
) )
# save into storage
if msg.pin_protection:
config.change_pin(pin_to_int(""), pin_to_int(newpin))
storage.set_u2f_counter(msg.u2f_counter)
storage.load_settings(label=msg.label, use_passphrase=msg.passphrase_protection)
storage.load_mnemonic(mnemonic=mnemonic, needs_backup=False, no_backup=False)
return Success(message="Device recovered")
@ui.layout @ui.layout
async def request_wordcount(ctx): async def request_wordcount(ctx):