Merge pull request #2455 from nspcc-dev/pass
cli: unify password-related prompts
This commit is contained in:
commit
19eb976166
2 changed files with 23 additions and 8 deletions
|
@ -204,7 +204,7 @@ func getDecryptedAccount(ctx *cli.Context, wall *wallet.Wallet, addr util.Uint16
|
||||||
return nil, fmt.Errorf("can't find account for the address: %s", address.Uint160ToString(addr))
|
return nil, fmt.Errorf("can't find account for the address: %s", address.Uint160ToString(addr))
|
||||||
}
|
}
|
||||||
|
|
||||||
if pass, err := input.ReadPassword("Password > "); err != nil {
|
if pass, err := input.ReadPassword(EnterPasswordPrompt); err != nil {
|
||||||
fmt.Println("Error reading password", err)
|
fmt.Println("Error reading password", err)
|
||||||
return nil, err
|
return nil, err
|
||||||
} else if err := acc.Decrypt(pass, wall.Scrypt); err != nil {
|
} else if err := acc.Decrypt(pass, wall.Scrypt); err != nil {
|
||||||
|
|
|
@ -22,6 +22,18 @@ import (
|
||||||
"github.com/urfave/cli"
|
"github.com/urfave/cli"
|
||||||
)
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
// EnterPasswordPrompt is a prompt used to ask the user for a password.
|
||||||
|
EnterPasswordPrompt = "Enter password > "
|
||||||
|
// EnterNewPasswordPrompt is a prompt used to ask the user for a password on
|
||||||
|
// account creation.
|
||||||
|
EnterNewPasswordPrompt = "Enter new password > "
|
||||||
|
// EnterOldPasswordPrompt is a prompt used to ask the user for an old password.
|
||||||
|
EnterOldPasswordPrompt = "Enter old password > "
|
||||||
|
// ConfirmPasswordPrompt is a prompt used to confirm the password.
|
||||||
|
ConfirmPasswordPrompt = "Confirm password > "
|
||||||
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
errNoPath = errors.New("wallet path is mandatory and should be passed using (--wallet, -w) flags")
|
errNoPath = errors.New("wallet path is mandatory and should be passed using (--wallet, -w) flags")
|
||||||
errPhraseMismatch = errors.New("the entered pass-phrases do not match. Maybe you have misspelled them")
|
errPhraseMismatch = errors.New("the entered pass-phrases do not match. Maybe you have misspelled them")
|
||||||
|
@ -306,6 +318,9 @@ func changePassword(ctx *cli.Context) error {
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(err, 1)
|
return cli.NewExitError(err, 1)
|
||||||
}
|
}
|
||||||
|
if len(wall.Accounts) == 0 {
|
||||||
|
return cli.NewExitError("wallet has no accounts", 1)
|
||||||
|
}
|
||||||
addrFlag := ctx.Generic("address").(*flags.Address)
|
addrFlag := ctx.Generic("address").(*flags.Address)
|
||||||
if addrFlag.IsSet {
|
if addrFlag.IsSet {
|
||||||
// Check for account presence first before asking for password.
|
// Check for account presence first before asking for password.
|
||||||
|
@ -315,7 +330,7 @@ func changePassword(ctx *cli.Context) error {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
oldPass, err := input.ReadPassword("Enter password > ")
|
oldPass, err := input.ReadPassword(EnterOldPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(fmt.Errorf("Error reading old password: %w", err), 1)
|
return cli.NewExitError(fmt.Errorf("Error reading old password: %w", err), 1)
|
||||||
}
|
}
|
||||||
|
@ -368,7 +383,7 @@ func convertWallet(ctx *cli.Context) error {
|
||||||
newWallet.Scrypt = wall.Scrypt
|
newWallet.Scrypt = wall.Scrypt
|
||||||
|
|
||||||
for _, acc := range wall.Accounts {
|
for _, acc := range wall.Accounts {
|
||||||
pass, err := input.ReadPassword(fmt.Sprintf("Enter passphrase for account %s (label '%s') > ", acc.Address, acc.Label))
|
pass, err := input.ReadPassword(fmt.Sprintf("Enter password for account %s (label '%s') > ", acc.Address, acc.Label))
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
||||||
}
|
}
|
||||||
|
@ -438,7 +453,7 @@ loop:
|
||||||
|
|
||||||
for _, wif := range wifs {
|
for _, wif := range wifs {
|
||||||
if decrypt {
|
if decrypt {
|
||||||
pass, err := input.ReadPassword("Enter password > ")
|
pass, err := input.ReadPassword(EnterPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
||||||
}
|
}
|
||||||
|
@ -634,7 +649,7 @@ func dumpWallet(ctx *cli.Context) error {
|
||||||
return cli.NewExitError(err, 1)
|
return cli.NewExitError(err, 1)
|
||||||
}
|
}
|
||||||
if ctx.Bool("decrypt") {
|
if ctx.Bool("decrypt") {
|
||||||
pass, err := input.ReadPassword("Enter wallet password > ")
|
pass, err := input.ReadPassword(EnterPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
return cli.NewExitError(fmt.Errorf("Error reading password: %w", err), 1)
|
||||||
}
|
}
|
||||||
|
@ -734,11 +749,11 @@ func readAccountInfo() (string, string, error) {
|
||||||
}
|
}
|
||||||
|
|
||||||
func readNewPassword() (string, error) {
|
func readNewPassword() (string, error) {
|
||||||
phrase, err := input.ReadPassword("Enter passphrase > ")
|
phrase, err := input.ReadPassword(EnterNewPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", fmt.Errorf("Error reading password: %w", err)
|
return "", fmt.Errorf("Error reading password: %w", err)
|
||||||
}
|
}
|
||||||
phraseCheck, err := input.ReadPassword("Confirm passphrase > ")
|
phraseCheck, err := input.ReadPassword(ConfirmPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return "", fmt.Errorf("Error reading password: %w", err)
|
return "", fmt.Errorf("Error reading password: %w", err)
|
||||||
}
|
}
|
||||||
|
@ -785,7 +800,7 @@ func newAccountFromWIF(w io.Writer, wif string, scrypt keys.ScryptParams) (*wall
|
||||||
// note: NEP2 strings always have length of 58 even though
|
// note: NEP2 strings always have length of 58 even though
|
||||||
// base58 strings can have different lengths even if slice lengths are equal
|
// base58 strings can have different lengths even if slice lengths are equal
|
||||||
if len(wif) == 58 {
|
if len(wif) == 58 {
|
||||||
pass, err := input.ReadPassword("Enter password > ")
|
pass, err := input.ReadPassword(EnterPasswordPrompt)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
return nil, fmt.Errorf("Error reading password: %w", err)
|
return nil, fmt.Errorf("Error reading password: %w", err)
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue