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

feat(core): Implement AuthenticateDevice message.

This commit is contained in:
Andrew Kozlik 2023-08-23 16:21:29 +02:00 committed by Andrew Kozlik
parent db6630a5a3
commit 6f139c9108
4 changed files with 56 additions and 0 deletions

View File

@ -0,0 +1 @@
Implement device authentication for Model R.

View File

@ -313,6 +313,8 @@ apps.management.apply_flags
import apps.management.apply_flags
apps.management.apply_settings
import apps.management.apply_settings
apps.management.authenticate_device
import apps.management.authenticate_device
apps.management.backup_device
import apps.management.backup_device
apps.management.backup_types

View File

@ -0,0 +1,50 @@
from typing import TYPE_CHECKING
if TYPE_CHECKING:
from trezor.messages import AuthenticateDevice, AuthenticityProof
async def authenticate_device(msg: AuthenticateDevice) -> AuthenticityProof:
from trezor import utils, wire
from trezor.crypto import optiga
from trezor.crypto.der import read_length
from trezor.crypto.hashlib import sha256
from trezor.messages import AuthenticityProof
from trezor.ui.layouts import confirm_action
from trezor.utils import BufferReader
from apps.common.writers import write_compact_size
await confirm_action(
"authenticate_device",
"Authenticate device",
description="Do you wish to verify the authenticity of your device?",
)
header = b"AuthenticateDevice:"
h = utils.HashWriter(sha256())
write_compact_size(h, len(header))
h.extend(header)
write_compact_size(h, len(msg.challenge))
h.extend(msg.challenge)
try:
signature = optiga.sign(optiga.DEVICE_ECC_KEY_INDEX, h.get_digest())
except optiga.SigningInaccessible:
raise wire.ProcessError("Signing inaccessible.")
certificates = []
r = BufferReader(optiga.get_certificate(optiga.DEVICE_CERT_INDEX))
while r.remaining_count() > 0:
cert_begin = r.offset
if r.get() != 0x30:
wire.FirmwareError("Device certificate is corrupted.")
n = read_length(r)
cert_len = r.offset - cert_begin + n
r.seek(cert_begin)
certificates.append(r.read_memoryview(cert_len))
return AuthenticityProof(
certificates=certificates,
signature=signature,
)

View File

@ -59,6 +59,9 @@ def _find_message_handler_module(msg_type: int) -> str:
if utils.USE_SD_CARD and msg_type == MessageType.SdProtect:
return "apps.management.sd_protect"
if utils.USE_OPTIGA and msg_type == MessageType.AuthenticateDevice:
return "apps.management.authenticate_device"
# bitcoin
if msg_type == MessageType.AuthorizeCoinJoin:
return "apps.bitcoin.authorize_coinjoin"