1
0
mirror of https://github.com/trezor/trezor-firmware.git synced 2025-01-07 05:51:38 +00:00

core/recovery: remove group threshold from storage

This commit is contained in:
Tomas Susanka 2019-09-20 09:34:35 +02:00
parent 6731d1bbf2
commit 871e159bee
4 changed files with 13 additions and 19 deletions

View File

@ -16,7 +16,6 @@ _SLIP39_THRESHOLD = const(0x04) # int
_REMAINING = const(0x05) # int _REMAINING = const(0x05) # int
_SLIP39_ITERATION_EXPONENT = const(0x06) # int _SLIP39_ITERATION_EXPONENT = const(0x06) # int
_SLIP39_GROUP_COUNT = const(0x07) # int _SLIP39_GROUP_COUNT = const(0x07) # int
_SLIP39_GROUP_THRESHOLD = const(0x08) # int
# Deprecated Keys: # Deprecated Keys:
# _WORD_COUNT = const(0x02) # int # _WORD_COUNT = const(0x02) # int
@ -95,15 +94,6 @@ def get_slip39_group_count() -> Optional[int]:
) )
def set_slip39_group_threshold(group_threshold: int) -> None:
common.set_uint8(_NAMESPACE, _SLIP39_GROUP_THRESHOLD, group_threshold)
def get_slip39_group_threshold() -> Optional[int]:
_require_progress()
return common.get_uint8(_NAMESPACE, _SLIP39_GROUP_THRESHOLD)
def set_slip39_remaining_shares(shares_remaining: int, group_index: int) -> None: def set_slip39_remaining_shares(shares_remaining: int, group_index: int) -> None:
""" """
We store the remaining shares as a bytearray of length group_count. We store the remaining shares as a bytearray of length group_count.
@ -153,5 +143,4 @@ def end_progress() -> None:
common.delete(_NAMESPACE, _REMAINING) common.delete(_NAMESPACE, _REMAINING)
common.delete(_NAMESPACE, _SLIP39_ITERATION_EXPONENT) common.delete(_NAMESPACE, _SLIP39_ITERATION_EXPONENT)
common.delete(_NAMESPACE, _SLIP39_GROUP_COUNT) common.delete(_NAMESPACE, _SLIP39_GROUP_COUNT)
common.delete(_NAMESPACE, _SLIP39_GROUP_THRESHOLD)
recovery_shares.delete() recovery_shares.delete()

View File

@ -1,6 +1,6 @@
from trezor import loop, utils, wire from trezor import loop, utils, wire
from trezor.crypto import slip39
from trezor.crypto.hashlib import sha256 from trezor.crypto.hashlib import sha256
from trezor.crypto.slip39 import MAX_SHARE_COUNT
from trezor.errors import MnemonicError from trezor.errors import MnemonicError
from trezor.messages import BackupType from trezor.messages import BackupType
from trezor.messages.Success import Success from trezor.messages.Success import Success
@ -209,14 +209,18 @@ async def _show_remaining_groups_and_shares(ctx: wire.Context) -> None:
identifiers = [] identifiers = []
first_entered_index = -1 first_entered_index = -1
for i in range(len(shares_remaining)): for i in range(len(shares_remaining)):
if shares_remaining[i] < MAX_SHARE_COUNT: if shares_remaining[i] < slip39.MAX_SHARE_COUNT:
first_entered_index = i first_entered_index = i
share = None
for i, r in enumerate(shares_remaining): for i, r in enumerate(shares_remaining):
if 0 < r < MAX_SHARE_COUNT: if 0 < r < slip39.MAX_SHARE_COUNT:
identifier = storage.recovery_shares.fetch_group(i)[0].split(" ")[0:3] if not share:
m = storage.recovery_shares.fetch_group(i)[0]
share = slip39.decode_mnemonic(m)
identifier = mnemonic.split(" ")[0:3]
identifiers.append([r, identifier]) identifiers.append([r, identifier])
elif r == MAX_SHARE_COUNT: elif r == slip39.MAX_SHARE_COUNT:
identifier = storage.recovery_shares.fetch_group(first_entered_index)[ identifier = storage.recovery_shares.fetch_group(first_entered_index)[
0 0
].split(" ")[0:2] ].split(" ")[0:2]
@ -226,4 +230,6 @@ async def _show_remaining_groups_and_shares(ctx: wire.Context) -> None:
except ValueError: except ValueError:
identifiers.append([r, identifier]) identifiers.append([r, identifier])
return await layout.show_remaining_shares(ctx, identifiers, shares_remaining) return await layout.show_remaining_shares(
ctx, identifiers, shares_remaining, share.group_threshold
)

View File

@ -154,8 +154,8 @@ async def show_remaining_shares(
ctx: wire.Context, ctx: wire.Context,
groups: List[int, List[str]], # remaining + list 3 words groups: List[int, List[str]], # remaining + list 3 words
shares_remaining: List[int], shares_remaining: List[int],
group_threshold: int,
) -> None: ) -> None:
group_threshold = storage.recovery.get_slip39_group_threshold()
pages = [] pages = []
for remaining, group in groups: for remaining, group in groups:
if 0 < remaining < MAX_SHARE_COUNT: if 0 < remaining < MAX_SHARE_COUNT:

View File

@ -35,7 +35,6 @@ def process_slip39(words: str) -> Tuple[Optional[bytes], slip39.Share]:
# if this is the first share, parse and store metadata # if this is the first share, parse and store metadata
if not remaining: if not remaining:
storage.recovery.set_slip39_group_count(share.group_count) storage.recovery.set_slip39_group_count(share.group_count)
storage.recovery.set_slip39_group_threshold(share.group_threshold)
storage.recovery.set_slip39_iteration_exponent(share.iteration_exponent) storage.recovery.set_slip39_iteration_exponent(share.iteration_exponent)
storage.recovery.set_slip39_identifier(share.identifier) storage.recovery.set_slip39_identifier(share.identifier)
storage.recovery.set_slip39_threshold(share.threshold) storage.recovery.set_slip39_threshold(share.threshold)