mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-12 16:30:56 +00:00
core: add SafetyCheckLevel to Features
This commit is contained in:
parent
9f066e877d
commit
9d2ad96ad4
@ -7,6 +7,7 @@ from trezor import config, sdcard, utils, wire, workflow
|
|||||||
from trezor.messages import Capability, MessageType
|
from trezor.messages import Capability, MessageType
|
||||||
from trezor.messages.Features import Features
|
from trezor.messages.Features import Features
|
||||||
from trezor.messages.PreauthorizedRequest import PreauthorizedRequest
|
from trezor.messages.PreauthorizedRequest import PreauthorizedRequest
|
||||||
|
from trezor.messages.SafetyCheckLevel import Prompt, Strict
|
||||||
from trezor.messages.Success import Success
|
from trezor.messages.Success import Success
|
||||||
|
|
||||||
from apps.common import mnemonic
|
from apps.common import mnemonic
|
||||||
@ -92,6 +93,7 @@ def get_features() -> Features:
|
|||||||
f.sd_protection = storage.sd_salt.is_enabled()
|
f.sd_protection = storage.sd_salt.is_enabled()
|
||||||
f.wipe_code_protection = config.has_wipe_code()
|
f.wipe_code_protection = config.has_wipe_code()
|
||||||
f.passphrase_always_on_device = storage.device.get_passphrase_always_on_device()
|
f.passphrase_always_on_device = storage.device.get_passphrase_always_on_device()
|
||||||
|
f.safety_checks = Prompt if storage.device.unsafe_prompts_allowed() else Strict
|
||||||
|
|
||||||
return f
|
return f
|
||||||
|
|
||||||
|
@ -161,6 +161,8 @@ class TestMsgApplysettings:
|
|||||||
def test_safety_checks(self, client):
|
def test_safety_checks(self, client):
|
||||||
BAD_ADDRESS = parse_path("m/0")
|
BAD_ADDRESS = parse_path("m/0")
|
||||||
|
|
||||||
|
assert client.features.safety_checks == messages.SafetyCheckLevel.Strict
|
||||||
|
|
||||||
with pytest.raises(
|
with pytest.raises(
|
||||||
exceptions.TrezorFailure, match="Forbidden key path"
|
exceptions.TrezorFailure, match="Forbidden key path"
|
||||||
), client:
|
), client:
|
||||||
@ -173,6 +175,8 @@ class TestMsgApplysettings:
|
|||||||
client, safety_checks=messages.SafetyCheckLevel.Prompt
|
client, safety_checks=messages.SafetyCheckLevel.Prompt
|
||||||
)
|
)
|
||||||
|
|
||||||
|
assert client.features.safety_checks == messages.SafetyCheckLevel.Prompt
|
||||||
|
|
||||||
with client:
|
with client:
|
||||||
client.set_expected_responses(
|
client.set_expected_responses(
|
||||||
[messages.ButtonRequest(), messages.Address()]
|
[messages.ButtonRequest(), messages.Address()]
|
||||||
@ -185,6 +189,8 @@ class TestMsgApplysettings:
|
|||||||
client, safety_checks=messages.SafetyCheckLevel.Strict
|
client, safety_checks=messages.SafetyCheckLevel.Strict
|
||||||
)
|
)
|
||||||
|
|
||||||
|
assert client.features.safety_checks == messages.SafetyCheckLevel.Strict
|
||||||
|
|
||||||
with pytest.raises(
|
with pytest.raises(
|
||||||
exceptions.TrezorFailure, match="Forbidden key path"
|
exceptions.TrezorFailure, match="Forbidden key path"
|
||||||
), client:
|
), client:
|
||||||
|
Loading…
Reference in New Issue
Block a user