2019-10-25 15:43:55 +00:00
|
|
|
import storage.device
|
2019-12-09 16:01:04 +00:00
|
|
|
from trezor import ui, utils, workflow
|
2019-07-11 14:52:25 +00:00
|
|
|
from trezor.crypto import bip39, slip39
|
2019-09-19 07:37:23 +00:00
|
|
|
from trezor.messages import BackupType
|
2020-01-24 14:11:23 +00:00
|
|
|
from trezor.ui.text import Text
|
2019-06-23 10:18:59 +00:00
|
|
|
|
2019-07-03 13:07:04 +00:00
|
|
|
if False:
|
2019-07-24 17:37:04 +00:00
|
|
|
from typing import Optional, Tuple
|
2019-09-19 07:37:23 +00:00
|
|
|
from trezor.messages.ResetDevice import EnumTypeBackupType
|
2019-06-23 10:18:59 +00:00
|
|
|
|
|
|
|
|
2019-07-24 17:37:04 +00:00
|
|
|
def get() -> Tuple[Optional[bytes], int]:
|
|
|
|
return get_secret(), get_type()
|
|
|
|
|
|
|
|
|
|
|
|
def get_secret() -> Optional[bytes]:
|
2019-10-25 15:43:55 +00:00
|
|
|
return storage.device.get_mnemonic_secret()
|
2019-07-24 17:37:04 +00:00
|
|
|
|
|
|
|
|
2019-09-19 07:37:23 +00:00
|
|
|
def get_type() -> EnumTypeBackupType:
|
2019-10-25 15:43:55 +00:00
|
|
|
return storage.device.get_backup_type()
|
2019-09-19 07:37:23 +00:00
|
|
|
|
|
|
|
|
|
|
|
def is_bip39() -> bool:
|
|
|
|
"""
|
|
|
|
If False then SLIP-39 (either Basic or Advanced).
|
|
|
|
Other invalid values are checked directly in storage.
|
|
|
|
"""
|
|
|
|
return get_type() == BackupType.Bip39
|
2019-06-23 10:18:59 +00:00
|
|
|
|
|
|
|
|
2019-07-03 13:07:04 +00:00
|
|
|
def get_seed(passphrase: str = "", progress_bar: bool = True) -> bytes:
|
2019-09-19 07:37:23 +00:00
|
|
|
mnemonic_secret = get_secret()
|
2019-07-24 17:37:04 +00:00
|
|
|
if mnemonic_secret is None:
|
|
|
|
raise ValueError("Mnemonic not set")
|
2019-07-11 14:52:25 +00:00
|
|
|
|
|
|
|
render_func = None
|
2019-12-09 16:01:04 +00:00
|
|
|
if progress_bar and not utils.DISABLE_ANIMATION:
|
2019-07-11 14:52:25 +00:00
|
|
|
_start_progress()
|
|
|
|
render_func = _render_progress
|
|
|
|
|
2019-09-19 07:37:23 +00:00
|
|
|
if is_bip39():
|
2019-07-11 14:52:25 +00:00
|
|
|
seed = bip39.seed(mnemonic_secret.decode(), passphrase, render_func)
|
|
|
|
|
2019-09-19 07:37:23 +00:00
|
|
|
else: # SLIP-39
|
2019-10-25 15:43:55 +00:00
|
|
|
identifier = storage.device.get_slip39_identifier()
|
|
|
|
iteration_exponent = storage.device.get_slip39_iteration_exponent()
|
2019-07-30 08:25:26 +00:00
|
|
|
if identifier is None or iteration_exponent is None:
|
|
|
|
# Identifier or exponent expected but not found
|
|
|
|
raise RuntimeError
|
2019-07-11 14:52:25 +00:00
|
|
|
seed = slip39.decrypt(
|
2019-12-12 13:43:17 +00:00
|
|
|
mnemonic_secret, passphrase.encode(), iteration_exponent, identifier
|
2019-06-23 10:18:59 +00:00
|
|
|
)
|
|
|
|
|
2019-07-11 14:52:25 +00:00
|
|
|
return seed
|
|
|
|
|
2019-06-23 10:18:59 +00:00
|
|
|
|
2019-07-03 13:07:04 +00:00
|
|
|
def _start_progress() -> None:
|
2019-08-20 14:20:02 +00:00
|
|
|
# Because we are drawing to the screen manually, without a layout, we
|
|
|
|
# should make sure that no other layout is running. At this point, only
|
|
|
|
# the homescreen should be on, so shut it down.
|
2019-11-04 14:32:50 +00:00
|
|
|
workflow.kill_default()
|
2020-01-24 14:11:23 +00:00
|
|
|
t = Text("Please wait", ui.ICON_CONFIG)
|
|
|
|
ui.draw_simple(t)
|
2019-06-23 10:18:59 +00:00
|
|
|
|
|
|
|
|
2019-07-03 13:07:04 +00:00
|
|
|
def _render_progress(progress: int, total: int) -> None:
|
2019-06-23 10:18:59 +00:00
|
|
|
p = 1000 * progress // total
|
|
|
|
ui.display.loader(p, False, 18, ui.WHITE, ui.BG)
|
2019-12-09 16:01:04 +00:00
|
|
|
ui.refresh()
|