From a71c2c4bfd131186ab64822d0bc152a8ec4b3a6b Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Thu, 20 Feb 2020 13:34:27 +0300 Subject: [PATCH] cli: move password getting to a separate function Also do not ignore errors from `terminal.ReadPassword`. --- cli/wallet/wallet.go | 42 ++++++++++++++++++++++-------------------- 1 file changed, 22 insertions(+), 20 deletions(-) diff --git a/cli/wallet/wallet.go b/cli/wallet/wallet.go index f94990d2f..b8f08c691 100644 --- a/cli/wallet/wallet.go +++ b/cli/wallet/wallet.go @@ -69,14 +69,13 @@ func dumpWallet(ctx *cli.Context) error { return cli.NewExitError(err, 1) } if ctx.Bool("decrypt") { - fmt.Print("Wallet password: ") - pass, err := terminal.ReadPassword(int(syscall.Stdin)) + pass, err := readPassword("Enter wallet password > ") if err != nil { return cli.NewExitError(err, 1) } for i := range wall.Accounts { // Just testing the decryption here. - err := wall.Accounts[i].Decrypt(string(pass)) + err := wall.Accounts[i].Decrypt(pass) if err != nil { return cli.NewExitError(err, 1) } @@ -111,33 +110,36 @@ func createWallet(ctx *cli.Context) error { } func createAccount(ctx *cli.Context, wall *wallet.Wallet) error { - var ( - rawName, - rawPhrase, - rawPhraseCheck []byte - ) buf := bufio.NewReader(os.Stdin) fmt.Print("Enter the name of the account > ") - rawName, _ = buf.ReadBytes('\n') - fmt.Print("Enter passphrase > ") - rawPhrase, _ = terminal.ReadPassword(int(syscall.Stdin)) - fmt.Print("\nConfirm passphrase > ") - rawPhraseCheck, _ = terminal.ReadPassword(int(syscall.Stdin)) - - // Clean data - var ( - name = strings.TrimRight(string(rawName), "\n") - phrase = strings.TrimRight(string(rawPhrase), "\n") - phraseCheck = strings.TrimRight(string(rawPhraseCheck), "\n") - ) + rawName, _ := buf.ReadBytes('\n') + phrase, err := readPassword("Enter passphrase > ") + if err != nil { + return cli.NewExitError(err, 1) + } + phraseCheck, err := readPassword("Confirm passphrase > ") + if err != nil { + return cli.NewExitError(err, 1) + } if phrase != phraseCheck { return errPhraseMismatch } + name := strings.TrimRight(string(rawName), "\n") return wall.CreateAccount(name, phrase) } +func readPassword(prompt string) (string, error) { + fmt.Print(prompt) + rawPass, err := terminal.ReadPassword(syscall.Stdin) + fmt.Println() + if err != nil { + return "", err + } + return strings.TrimRight(string(rawPass), "\n"), nil +} + func fmtPrintWallet(wall *wallet.Wallet) { b, _ := wall.JSON() fmt.Println("")