From 2b51be1eab42365de58084774922fca5dd88182e Mon Sep 17 00:00:00 2001 From: M1nd3r Date: Wed, 27 Nov 2024 12:21:35 +0100 Subject: [PATCH] fix(core): update structure of common seed so it works on BTC_ONLY [no changelog] --- core/src/apps/common/seed.py | 104 +++++++++++++++++++---------------- 1 file changed, 58 insertions(+), 46 deletions(-) diff --git a/core/src/apps/common/seed.py b/core/src/apps/common/seed.py index d52d30713b..4bb15184f8 100644 --- a/core/src/apps/common/seed.py +++ b/core/src/apps/common/seed.py @@ -68,66 +68,78 @@ if utils.USE_THP: assert common_seed is not None return common_seed -else: + if utils.BITCOIN_ONLY: + # === Bitcoin_only variant === + # We want to derive the normal seed ONLY - @cache.stored_async(APP_COMMON_SEED) - async def get_seed() -> bytes: - await derive_and_store_roots_legacy() - common_seed = context.cache_get(APP_COMMON_SEED) - assert common_seed is not None - return common_seed + async def derive_and_store_roots( + ctx: Context, msg: ThpCreateNewSession + ) -> None: + if msg.passphrase is not None and msg.on_device: + raise DataError("Passphrase provided when it shouldn't be!") -if utils.BITCOIN_ONLY: - # === Bitcoin_only variant === - # We want to derive the normal seed ONLY + if ctx.cache.is_set(APP_COMMON_SEED): + raise Exception("Seed is already set!") - async def derive_and_store_roots(ctx: Context, msg: ThpCreateNewSession) -> None: + from trezor import wire - if msg.passphrase is not None and msg.on_device: - raise DataError("Passphrase provided when it shouldn't be!") + if not storage_device.is_initialized(): + raise wire.NotInitialized("Device is not initialized") - if ctx.cache.is_set(APP_COMMON_SEED): - raise Exception("Seed is already set!") + passphrase = await get_passphrase(msg) + common_seed = mnemonic.get_seed(passphrase) + ctx.cache.set(APP_COMMON_SEED, common_seed) - from trezor import wire + else: + # === Cardano variant === + # We want to derive both the normal seed and the Cardano seed together + async def derive_and_store_roots( + ctx: Context, msg: ThpCreateNewSession + ) -> None: - if not storage_device.is_initialized(): - raise wire.NotInitialized("Device is not initialized") + if msg.passphrase is not None and msg.on_device: + raise DataError("Passphrase provided when it shouldn't be!") - passphrase = await get_passphrase(msg) - common_seed = mnemonic.get_seed(passphrase) - ctx.cache.set(APP_COMMON_SEED, common_seed) + from trezor import wire + + if not storage_device.is_initialized(): + raise wire.NotInitialized("Device is not initialized") + + if ctx.cache.is_set(APP_CARDANO_ICARUS_SECRET): + raise Exception("Cardano icarus secret is already set!") + + passphrase = await get_passphrase(msg) + common_seed = mnemonic.get_seed(passphrase) + ctx.cache.set(APP_COMMON_SEED, common_seed) + + if msg.derive_cardano: + from apps.cardano.seed import derive_and_store_secrets + + ctx.cache.set_bool(APP_COMMON_DERIVE_CARDANO, True) + derive_and_store_secrets(ctx, passphrase) else: - # === Cardano variant === - # We want to derive both the normal seed and the Cardano seed together, AND - # expose a method for Cardano to do the same + if utils.BITCOIN_ONLY: + # === Bitcoin-only variant === + # We use the simple version of `get_seed` that never needs to derive anything else. - async def derive_and_store_roots(ctx: Context, msg: ThpCreateNewSession) -> None: + @cache.stored_async(APP_COMMON_SEED) + async def get_seed() -> bytes: + passphrase = await get_passphrase_legacy() + return mnemonic.get_seed(passphrase=passphrase) - if msg.passphrase is not None and msg.on_device: - raise DataError("Passphrase provided when it shouldn't be!") + else: + # === Cardano variant === + # We want to derive both the normal seed and the Cardano seed together, AND + # expose a method for Cardano to do the same - from trezor import wire - - if not storage_device.is_initialized(): - raise wire.NotInitialized("Device is not initialized") - - if ctx.cache.is_set(APP_CARDANO_ICARUS_SECRET): - raise Exception("Cardano icarus secret is already set!") - - passphrase = await get_passphrase(msg) - common_seed = mnemonic.get_seed(passphrase) - ctx.cache.set(APP_COMMON_SEED, common_seed) - - if msg.derive_cardano: - from apps.cardano.seed import derive_and_store_secrets - - ctx.cache.set_bool(APP_COMMON_DERIVE_CARDANO, True) - derive_and_store_secrets(ctx, passphrase) - - if not utils.USE_THP: + @cache.stored_async(APP_COMMON_SEED) + async def get_seed() -> bytes: + await derive_and_store_roots_legacy() + common_seed = context.cache_get(APP_COMMON_SEED) + assert common_seed is not None + return common_seed async def derive_and_store_roots_legacy() -> None: from trezor import wire