mirror of
https://github.com/trezor/trezor-firmware.git
synced 2025-01-26 23:32:03 +00:00
feat(core/cardano): indicate whether Cardano seed should be derived
This commit is contained in:
parent
80e4b27f09
commit
8caac218ec
@ -33,7 +33,10 @@ enum SafetyCheckLevel {
|
||||
* @next Features
|
||||
*/
|
||||
message Initialize {
|
||||
optional bytes session_id = 1; // assumed device session id; Trezor clears caches if it is different or empty
|
||||
optional bytes session_id = 1; // assumed device session id; Trezor clears caches if it is different or empty
|
||||
// optional bool skip_passphrase = 2; // removed as part of passphrase redesign
|
||||
reserved 2;
|
||||
optional bool derive_cardano = 3; // whether to derive Cardano Icarus root keys in this session
|
||||
}
|
||||
|
||||
/**
|
||||
|
@ -98,10 +98,31 @@ def get_features() -> Features:
|
||||
|
||||
|
||||
async def handle_Initialize(ctx: wire.Context, msg: Initialize) -> Features:
|
||||
session_id = storage.cache.start_session(msg.session_id)
|
||||
|
||||
if not utils.BITCOIN_ONLY:
|
||||
derive_cardano = storage.cache.get(storage.cache.APP_COMMON_DERIVE_CARDANO)
|
||||
have_seed = storage.cache.is_set(storage.cache.APP_COMMON_SEED)
|
||||
|
||||
if (
|
||||
have_seed
|
||||
and msg.derive_cardano is not None
|
||||
and msg.derive_cardano != bool(derive_cardano)
|
||||
):
|
||||
# seed is already derived, and host wants to change derive_cardano setting
|
||||
# => create a new session
|
||||
storage.cache.end_current_session()
|
||||
session_id = storage.cache.start_session()
|
||||
have_seed = False
|
||||
|
||||
if not have_seed:
|
||||
storage.cache.set(
|
||||
storage.cache.APP_COMMON_DERIVE_CARDANO,
|
||||
b"\x01" if msg.derive_cardano else b"",
|
||||
)
|
||||
|
||||
features = get_features()
|
||||
if msg.session_id:
|
||||
msg.session_id = bytes(msg.session_id)
|
||||
features.session_id = storage.cache.start_session(msg.session_id)
|
||||
features.session_id = session_id
|
||||
return features
|
||||
|
||||
|
||||
|
@ -20,10 +20,11 @@ _SESSION_ID_LENGTH = 32
|
||||
|
||||
# Traditional cache keys
|
||||
APP_COMMON_SEED = 0
|
||||
APP_CARDANO_PASSPHRASE = 1
|
||||
APP_MONERO_LIVE_REFRESH = 2
|
||||
APP_COMMON_AUTHORIZATION_TYPE = 3
|
||||
APP_COMMON_AUTHORIZATION_DATA = 4
|
||||
APP_COMMON_DERIVE_CARDANO = 1
|
||||
APP_CARDANO_XPRV = 2
|
||||
APP_MONERO_LIVE_REFRESH = 3
|
||||
APP_COMMON_AUTHORIZATION_TYPE = 4
|
||||
APP_COMMON_AUTHORIZATION_DATA = 5
|
||||
|
||||
# Keys that are valid across sessions
|
||||
APP_COMMON_SEED_WITHOUT_PASSPHRASE = 0 | _SESSIONLESS_FLAG
|
||||
@ -87,7 +88,8 @@ class SessionCache(DataCache):
|
||||
self.session_id = bytearray(_SESSION_ID_LENGTH)
|
||||
self.fields = (
|
||||
64, # APP_COMMON_SEED
|
||||
50, # APP_CARDANO_PASSPHRASE
|
||||
1, # APP_COMMON_DERIVE_CARDANO
|
||||
96, # APP_CARDANO_XPRV
|
||||
1, # APP_MONERO_LIVE_REFRESH
|
||||
2, # APP_COMMON_AUTHORIZATION_TYPE
|
||||
128, # APP_COMMON_AUTHORIZATION_DATA
|
||||
|
@ -1784,11 +1784,13 @@ if TYPE_CHECKING:
|
||||
|
||||
class Initialize(protobuf.MessageType):
|
||||
session_id: "bytes | None"
|
||||
derive_cardano: "bool | None"
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
*,
|
||||
session_id: "bytes | None" = None,
|
||||
derive_cardano: "bool | None" = None,
|
||||
) -> None:
|
||||
pass
|
||||
|
||||
|
@ -2986,14 +2986,17 @@ class Initialize(protobuf.MessageType):
|
||||
MESSAGE_WIRE_TYPE = 0
|
||||
FIELDS = {
|
||||
1: protobuf.Field("session_id", "bytes", repeated=False, required=False),
|
||||
3: protobuf.Field("derive_cardano", "bool", repeated=False, required=False),
|
||||
}
|
||||
|
||||
def __init__(
|
||||
self,
|
||||
*,
|
||||
session_id: Optional["bytes"] = None,
|
||||
derive_cardano: Optional["bool"] = None,
|
||||
) -> None:
|
||||
self.session_id = session_id
|
||||
self.derive_cardano = derive_cardano
|
||||
|
||||
|
||||
class GetFeatures(protobuf.MessageType):
|
||||
|
Loading…
Reference in New Issue
Block a user