mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-09 06:50:58 +00:00
refactor(core): convert apps.common.sdcard to layouts
This commit is contained in:
parent
035f114125
commit
6ded531f8f
@ -1,9 +1,7 @@
|
|||||||
import storage.sd_salt
|
import storage.sd_salt
|
||||||
from storage.sd_salt import SD_CARD_HOT_SWAPPABLE
|
from storage.sd_salt import SD_CARD_HOT_SWAPPABLE
|
||||||
from trezor import fatfs, sdcard, ui, wire
|
from trezor import fatfs, sdcard, ui, wire
|
||||||
from trezor.ui.components.tt.text import Text
|
from trezor.ui.layouts import confirm_action, show_error
|
||||||
|
|
||||||
from apps.common.confirm import confirm, hold_to_confirm
|
|
||||||
|
|
||||||
if False:
|
if False:
|
||||||
from typing import Optional
|
from typing import Optional
|
||||||
@ -14,60 +12,95 @@ class SdCardUnavailable(wire.ProcessError):
|
|||||||
|
|
||||||
|
|
||||||
async def _wrong_card_dialog(ctx: wire.GenericContext) -> bool:
|
async def _wrong_card_dialog(ctx: wire.GenericContext) -> bool:
|
||||||
text = Text("SD card protection", ui.ICON_WRONG)
|
|
||||||
text.bold("Wrong SD card.")
|
|
||||||
text.br_half()
|
|
||||||
if SD_CARD_HOT_SWAPPABLE:
|
if SD_CARD_HOT_SWAPPABLE:
|
||||||
text.normal("Please insert the", "correct SD card for", "this device.")
|
return await confirm_action(
|
||||||
btn_confirm: Optional[str] = "Retry"
|
ctx,
|
||||||
btn_cancel = "Abort"
|
"warning_wrong_sd",
|
||||||
|
"SD card protection",
|
||||||
|
action="Wrong SD card.",
|
||||||
|
description="Please insert the correct SD card for this device.",
|
||||||
|
verb="Retry",
|
||||||
|
verb_cancel="Abort",
|
||||||
|
icon=ui.ICON_WRONG,
|
||||||
|
larger_vspace=True,
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
text.normal("Please unplug the", "device and insert the", "correct SD card.")
|
return await show_error(
|
||||||
btn_confirm = None
|
ctx,
|
||||||
btn_cancel = "Close"
|
"warning_wrong_sd",
|
||||||
|
header="SD card protection",
|
||||||
return await confirm(ctx, text, confirm=btn_confirm, cancel=btn_cancel)
|
subheader="Wrong SD card.",
|
||||||
|
content="Please unplug the\ndevice and insert the correct SD card.",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def insert_card_dialog(ctx: wire.GenericContext) -> bool:
|
async def insert_card_dialog(ctx: wire.GenericContext) -> bool:
|
||||||
text = Text("SD card protection", ui.ICON_WRONG)
|
|
||||||
text.bold("SD card required.")
|
|
||||||
text.br_half()
|
|
||||||
if SD_CARD_HOT_SWAPPABLE:
|
if SD_CARD_HOT_SWAPPABLE:
|
||||||
text.normal("Please insert your", "SD card.")
|
return await confirm_action(
|
||||||
btn_confirm: Optional[str] = "Retry"
|
ctx,
|
||||||
btn_cancel = "Abort"
|
"warning_no_sd",
|
||||||
|
"SD card protection",
|
||||||
|
action="SD card required.",
|
||||||
|
description="Please insert your SD card.",
|
||||||
|
verb="Retry",
|
||||||
|
verb_cancel="Abort",
|
||||||
|
icon=ui.ICON_WRONG,
|
||||||
|
larger_vspace=True,
|
||||||
|
)
|
||||||
else:
|
else:
|
||||||
text.normal("Please unplug the", "device and insert your", "SD card.")
|
return await show_error(
|
||||||
btn_confirm = None
|
ctx,
|
||||||
btn_cancel = "Close"
|
"warning_no_sd",
|
||||||
|
header="SD card protection",
|
||||||
return await confirm(ctx, text, confirm=btn_confirm, cancel=btn_cancel)
|
subheader="SD card required.",
|
||||||
|
content="Please unplug the\ndevice and insert your SD card.",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def format_card_dialog(ctx: wire.GenericContext) -> bool:
|
async def format_card_dialog(ctx: wire.GenericContext) -> bool:
|
||||||
# Format card? yes/no
|
# Format card? yes/no
|
||||||
text = Text("SD card error", ui.ICON_WRONG, ui.RED)
|
if not await confirm_action(
|
||||||
text.bold("Unknown filesystem.")
|
ctx,
|
||||||
text.br_half()
|
"warning_format_sd",
|
||||||
text.normal("Use a different card or")
|
"SD card error",
|
||||||
text.normal("format the SD card to")
|
action="Unknown filesystem.",
|
||||||
text.normal("the FAT32 filesystem.")
|
description="Use a different card or format the SD card to the FAT32 filesystem.",
|
||||||
if not await confirm(ctx, text, confirm="Format", cancel="Cancel"):
|
icon=ui.ICON_WRONG,
|
||||||
|
icon_color=ui.RED,
|
||||||
|
verb="Format",
|
||||||
|
verb_cancel="Cancel",
|
||||||
|
larger_vspace=True,
|
||||||
|
):
|
||||||
return False
|
return False
|
||||||
|
|
||||||
# Confirm formatting
|
# Confirm formatting
|
||||||
text = Text("Format SD card", ui.ICON_WIPE, ui.RED)
|
return await confirm_action(
|
||||||
text.normal("Do you really want to", "format the SD card?")
|
ctx,
|
||||||
text.br_half()
|
"confirm_format_sd",
|
||||||
text.bold("All data on the SD card", "will be lost.")
|
"Format SD card",
|
||||||
return await hold_to_confirm(ctx, text, confirm="Format SD card")
|
action="All data on the SD card will be lost.",
|
||||||
|
description="Do you really want to format the SD card?",
|
||||||
|
reverse=True,
|
||||||
|
verb="Format SD card",
|
||||||
|
icon=ui.ICON_WIPE,
|
||||||
|
icon_color=ui.RED,
|
||||||
|
hold=True,
|
||||||
|
larger_vspace=True,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def sd_problem_dialog(ctx: wire.GenericContext) -> bool:
|
async def sd_problem_dialog(ctx: wire.GenericContext) -> bool:
|
||||||
text = Text("SD card problem", ui.ICON_WRONG, ui.RED)
|
return await confirm_action(
|
||||||
text.normal("There was a problem", "accessing the SD card.")
|
ctx,
|
||||||
return await confirm(ctx, text, confirm="Retry", cancel="Abort")
|
"warning_sd_retry",
|
||||||
|
"SD card problem",
|
||||||
|
action=None,
|
||||||
|
description="There was a problem accessing the SD card.",
|
||||||
|
icon=ui.ICON_WRONG,
|
||||||
|
icon_color=ui.RED,
|
||||||
|
verb="Retry",
|
||||||
|
verb_cancel="Abort",
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
async def ensure_sdcard(
|
async def ensure_sdcard(
|
||||||
|
@ -1,13 +1,11 @@
|
|||||||
import storage.device
|
import storage.device
|
||||||
import storage.sd_salt
|
import storage.sd_salt
|
||||||
from trezor import config, ui, wire
|
from trezor import config, wire
|
||||||
from trezor.crypto import random
|
from trezor.crypto import random
|
||||||
from trezor.messages import SdProtectOperationType
|
from trezor.messages import SdProtectOperationType
|
||||||
from trezor.messages.Success import Success
|
from trezor.messages.Success import Success
|
||||||
from trezor.ui.components.tt.text import Text
|
from trezor.ui.layouts import confirm_action, require, show_success
|
||||||
from trezor.ui.layouts import require, show_success
|
|
||||||
|
|
||||||
from apps.common.confirm import require_confirm
|
|
||||||
from apps.common.request_pin import (
|
from apps.common.request_pin import (
|
||||||
error_pin_invalid,
|
error_pin_invalid,
|
||||||
request_pin,
|
request_pin,
|
||||||
@ -167,24 +165,14 @@ async def sd_protect_refresh(ctx: wire.Context, msg: SdProtect) -> Success:
|
|||||||
|
|
||||||
def require_confirm_sd_protect(ctx: wire.Context, msg: SdProtect) -> Awaitable[None]:
|
def require_confirm_sd_protect(ctx: wire.Context, msg: SdProtect) -> Awaitable[None]:
|
||||||
if msg.operation == SdProtectOperationType.ENABLE:
|
if msg.operation == SdProtectOperationType.ENABLE:
|
||||||
text = Text("SD card protection", ui.ICON_CONFIG)
|
text = "Do you really want to secure your device with SD card protection?"
|
||||||
text.normal(
|
|
||||||
"Do you really want to", "secure your device with", "SD card protection?"
|
|
||||||
)
|
|
||||||
elif msg.operation == SdProtectOperationType.DISABLE:
|
elif msg.operation == SdProtectOperationType.DISABLE:
|
||||||
text = Text("SD card protection", ui.ICON_CONFIG)
|
text = "Do you really want to remove SD card protection from your device?"
|
||||||
text.normal(
|
|
||||||
"Do you really want to", "remove SD card", "protection from your", "device?"
|
|
||||||
)
|
|
||||||
elif msg.operation == SdProtectOperationType.REFRESH:
|
elif msg.operation == SdProtectOperationType.REFRESH:
|
||||||
text = Text("SD card protection", ui.ICON_CONFIG)
|
text = "Do you really want to replace the current\nSD card secret with a newly generated one?"
|
||||||
text.normal(
|
|
||||||
"Do you really want to",
|
|
||||||
"replace the current",
|
|
||||||
"SD card secret with a",
|
|
||||||
"newly generated one?",
|
|
||||||
)
|
|
||||||
else:
|
else:
|
||||||
raise wire.ProcessError("Unknown operation")
|
raise wire.ProcessError("Unknown operation")
|
||||||
|
|
||||||
return require_confirm(ctx, text)
|
return require(
|
||||||
|
confirm_action(ctx, "set_sd", "SD card protection", description=text)
|
||||||
|
)
|
||||||
|
@ -24,7 +24,7 @@ from ..constants.tt import (
|
|||||||
from .common import interact
|
from .common import interact
|
||||||
|
|
||||||
if False:
|
if False:
|
||||||
from typing import Any, Iterator, List, Sequence, Union, Optional
|
from typing import Any, Iterator, List, Sequence, Union, Optional, Awaitable
|
||||||
|
|
||||||
from trezor import wire
|
from trezor import wire
|
||||||
from trezor.messages.ButtonRequest import EnumTypeButtonRequestType
|
from trezor.messages.ButtonRequest import EnumTypeButtonRequestType
|
||||||
@ -37,6 +37,7 @@ __all__ = (
|
|||||||
"confirm_backup",
|
"confirm_backup",
|
||||||
"confirm_path_warning",
|
"confirm_path_warning",
|
||||||
"show_address",
|
"show_address",
|
||||||
|
"show_error",
|
||||||
"show_pubkey",
|
"show_pubkey",
|
||||||
"show_success",
|
"show_success",
|
||||||
"show_xpub",
|
"show_xpub",
|
||||||
@ -57,24 +58,45 @@ async def confirm_action(
|
|||||||
ctx: wire.GenericContext,
|
ctx: wire.GenericContext,
|
||||||
br_type: str,
|
br_type: str,
|
||||||
title: str,
|
title: str,
|
||||||
action: str,
|
action: str = None,
|
||||||
description: str = None,
|
description: str = None,
|
||||||
verb: Union[str, bytes] = Confirm.DEFAULT_CONFIRM,
|
verb: Union[str, bytes, None] = Confirm.DEFAULT_CONFIRM,
|
||||||
verb_cancel: Union[str, bytes] = Confirm.DEFAULT_CANCEL,
|
verb_cancel: Union[str, bytes, None] = Confirm.DEFAULT_CANCEL,
|
||||||
icon: str = None,
|
hold: bool = False,
|
||||||
|
icon: str = None, # TODO cleanup @ redesign
|
||||||
|
icon_color: int = None, # TODO cleanup @ redesign
|
||||||
|
reverse: bool = False, # TODO cleanup @ redesign
|
||||||
|
larger_vspace: bool = False, # TODO cleanup @ redesign
|
||||||
br_code: EnumTypeButtonRequestType = ButtonRequestType.Other,
|
br_code: EnumTypeButtonRequestType = ButtonRequestType.Other,
|
||||||
**kwargs: Any,
|
**kwargs: Any,
|
||||||
) -> bool:
|
) -> bool:
|
||||||
text = Text(title, icon if icon is not None else ui.ICON_DEFAULT, new_lines=False)
|
text = Text(
|
||||||
text.bold(action)
|
title,
|
||||||
text.br()
|
icon if icon is not None else ui.ICON_DEFAULT,
|
||||||
if description:
|
icon_color if icon_color is not None else ui.ORANGE_ICON,
|
||||||
|
new_lines=False,
|
||||||
|
)
|
||||||
|
|
||||||
|
if reverse and description is not None:
|
||||||
|
text.normal(description)
|
||||||
|
elif action is not None:
|
||||||
|
text.bold(action)
|
||||||
|
|
||||||
|
if action is not None and description is not None:
|
||||||
|
text.br()
|
||||||
|
if larger_vspace:
|
||||||
|
text.br_half()
|
||||||
|
|
||||||
|
if reverse and action is not None:
|
||||||
|
text.bold(action)
|
||||||
|
elif description is not None:
|
||||||
text.normal(description)
|
text.normal(description)
|
||||||
|
|
||||||
|
cls = HoldToConfirm if hold else Confirm
|
||||||
return is_confirmed(
|
return is_confirmed(
|
||||||
await interact(
|
await interact(
|
||||||
ctx,
|
ctx,
|
||||||
Confirm(text, confirm=verb, cancel=verb_cancel),
|
cls(text, confirm=verb, cancel=verb_cancel),
|
||||||
br_type,
|
br_type,
|
||||||
br_code,
|
br_code,
|
||||||
)
|
)
|
||||||
@ -289,49 +311,95 @@ async def show_pubkey(
|
|||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
async def show_warning(
|
async def _show_modal(
|
||||||
|
ctx: wire.GenericContext,
|
||||||
|
br_type: str,
|
||||||
|
br_code: EnumTypeButtonRequestType,
|
||||||
|
header: str,
|
||||||
|
subheader: Optional[str],
|
||||||
|
content: str,
|
||||||
|
button_confirm: Optional[str],
|
||||||
|
button_cancel: Optional[str],
|
||||||
|
icon: str,
|
||||||
|
icon_color: int,
|
||||||
|
) -> bool:
|
||||||
|
text = Text(header, icon, icon_color, new_lines=False)
|
||||||
|
if subheader:
|
||||||
|
text.bold(subheader)
|
||||||
|
text.br()
|
||||||
|
text.br_half()
|
||||||
|
text.normal(content)
|
||||||
|
return is_confirmed(
|
||||||
|
await interact(
|
||||||
|
ctx,
|
||||||
|
Confirm(text, confirm=button_confirm, cancel=button_cancel),
|
||||||
|
br_type,
|
||||||
|
br_code,
|
||||||
|
)
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def show_error(
|
||||||
|
ctx: wire.GenericContext,
|
||||||
|
br_type: str,
|
||||||
|
content: str,
|
||||||
|
header: str = "Error",
|
||||||
|
subheader: Optional[str] = None,
|
||||||
|
button: str = "Close",
|
||||||
|
) -> Awaitable[bool]:
|
||||||
|
return _show_modal(
|
||||||
|
ctx,
|
||||||
|
br_type=br_type,
|
||||||
|
br_code=ButtonRequestType.Other,
|
||||||
|
header=header,
|
||||||
|
subheader=subheader,
|
||||||
|
content=content,
|
||||||
|
button_confirm=None,
|
||||||
|
button_cancel=button,
|
||||||
|
icon=ui.ICON_WRONG,
|
||||||
|
icon_color=ui.ORANGE_ICON,
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def show_warning(
|
||||||
ctx: wire.GenericContext,
|
ctx: wire.GenericContext,
|
||||||
br_type: str,
|
br_type: str,
|
||||||
content: str,
|
content: str,
|
||||||
subheader: Optional[str] = None,
|
subheader: Optional[str] = None,
|
||||||
button: str = "Try again",
|
button: str = "Try again",
|
||||||
) -> bool:
|
) -> Awaitable[bool]:
|
||||||
text = Text("Warning", ui.ICON_WRONG, ui.RED, new_lines=False)
|
return _show_modal(
|
||||||
if subheader:
|
ctx,
|
||||||
text.bold(subheader)
|
br_type=br_type,
|
||||||
text.br()
|
br_code=ButtonRequestType.Warning,
|
||||||
text.br_half()
|
header="Warning",
|
||||||
text.normal(content)
|
subheader=subheader,
|
||||||
return is_confirmed(
|
content=content,
|
||||||
await interact(
|
button_confirm=button,
|
||||||
ctx,
|
button_cancel=None,
|
||||||
Confirm(text, confirm=button, cancel=None),
|
icon=ui.ICON_WRONG,
|
||||||
br_type,
|
icon_color=ui.RED,
|
||||||
ButtonRequestType.Warning,
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
async def show_success(
|
def show_success(
|
||||||
ctx: wire.GenericContext,
|
ctx: wire.GenericContext,
|
||||||
br_type: str,
|
br_type: str,
|
||||||
content: str,
|
content: str,
|
||||||
subheader: Optional[str] = None,
|
subheader: Optional[str] = None,
|
||||||
button: str = "Continue",
|
button: str = "Continue",
|
||||||
) -> bool:
|
) -> Awaitable[bool]:
|
||||||
text = Text("Success", ui.ICON_CONFIRM, ui.GREEN, new_lines=False)
|
return _show_modal(
|
||||||
if subheader:
|
ctx,
|
||||||
text.bold(subheader)
|
br_type=br_type,
|
||||||
text.br()
|
br_code=ButtonRequestType.Success,
|
||||||
text.br_half()
|
header="Success",
|
||||||
text.normal(content)
|
subheader=subheader,
|
||||||
return is_confirmed(
|
content=content,
|
||||||
await interact(
|
button_confirm=button,
|
||||||
ctx,
|
button_cancel=None,
|
||||||
Confirm(text, confirm=button, cancel=None),
|
icon=ui.ICON_CONFIRM,
|
||||||
br_type,
|
icon_color=ui.GREEN,
|
||||||
ButtonRequestType.Success,
|
|
||||||
)
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user