mirror of
https://gitlab.com/pulsechaincom/staking-deposit-cli.git
synced 2025-01-12 05:50:06 +00:00
88 lines
3.2 KiB
Python
88 lines
3.2 KiB
Python
import click
|
|
from typing import (
|
|
Any,
|
|
Callable,
|
|
)
|
|
|
|
from staking_deposit.exceptions import ValidationError
|
|
from staking_deposit.key_handling.key_derivation.mnemonic import (
|
|
reconstruct_mnemonic,
|
|
)
|
|
from staking_deposit.utils.constants import (
|
|
WORD_LISTS_PATH,
|
|
)
|
|
from staking_deposit.utils.click import (
|
|
captive_prompt_callback,
|
|
jit_option,
|
|
)
|
|
from staking_deposit.utils.intl import load_text
|
|
from staking_deposit.utils.validation import validate_int_range
|
|
from .generate_keys import (
|
|
generate_keys,
|
|
generate_keys_arguments_decorator,
|
|
)
|
|
|
|
|
|
def load_mnemonic_arguments_decorator(function: Callable[..., Any]) -> Callable[..., Any]:
|
|
'''
|
|
This is a decorator that, when applied to a parent-command, implements the
|
|
to obtain the necessary arguments for the generate_keys() subcommand.
|
|
'''
|
|
decorators = [
|
|
jit_option(
|
|
callback=validate_mnemonic,
|
|
help=lambda: load_text(['arg_mnemonic', 'help'], func='existing_mnemonic'),
|
|
param_decls='--mnemonic',
|
|
prompt=lambda: load_text(['arg_mnemonic', 'prompt'], func='existing_mnemonic'),
|
|
type=str,
|
|
),
|
|
jit_option(
|
|
callback=captive_prompt_callback(
|
|
lambda x: x,
|
|
lambda: load_text(['arg_mnemonic_password', 'prompt'], func='existing_mnemonic'),
|
|
lambda: load_text(['arg_mnemonic_password', 'confirm'], func='existing_mnemonic'),
|
|
lambda: load_text(['arg_mnemonic_password', 'mismatch'], func='existing_mnemonic'),
|
|
True,
|
|
),
|
|
default='',
|
|
help=lambda: load_text(['arg_mnemonic_password', 'help'], func='existing_mnemonic'),
|
|
hidden=True,
|
|
param_decls='--mnemonic-password',
|
|
prompt=False,
|
|
),
|
|
]
|
|
for decorator in reversed(decorators):
|
|
function = decorator(function)
|
|
return function
|
|
|
|
|
|
def validate_mnemonic(ctx: click.Context, param: Any, mnemonic: str) -> str:
|
|
mnemonic = reconstruct_mnemonic(mnemonic, WORD_LISTS_PATH)
|
|
if mnemonic is not None:
|
|
return mnemonic
|
|
else:
|
|
raise ValidationError(load_text(['err_invalid_mnemonic']))
|
|
|
|
|
|
@click.command(
|
|
help=load_text(['arg_existing_mnemonic', 'help'], func='existing_mnemonic'),
|
|
)
|
|
@load_mnemonic_arguments_decorator
|
|
@jit_option(
|
|
callback=captive_prompt_callback(
|
|
lambda num: validate_int_range(num, 0, 2**32),
|
|
lambda: load_text(['arg_validator_start_index', 'prompt'], func='existing_mnemonic'),
|
|
lambda: load_text(['arg_validator_start_index', 'confirm'], func='existing_mnemonic'),
|
|
),
|
|
default=0,
|
|
help=lambda: load_text(['arg_validator_start_index', 'help'], func='existing_mnemonic'),
|
|
param_decls="--validator_start_index",
|
|
prompt=lambda: load_text(['arg_validator_start_index', 'prompt'], func='existing_mnemonic'),
|
|
)
|
|
@generate_keys_arguments_decorator
|
|
@click.pass_context
|
|
def existing_mnemonic(ctx: click.Context, mnemonic: str, mnemonic_password: str, **kwargs: Any) -> None:
|
|
ctx.obj = {} if ctx.obj is None else ctx.obj # Create a new ctx.obj if it doesn't exist
|
|
ctx.obj.update({'mnemonic': mnemonic, 'mnemonic_password': mnemonic_password})
|
|
ctx.forward(generate_keys)
|