github.com/ethw3/go-ethereuma@v0.0.0-20221013053120-c14602a4c23c/cmd/utils/prompt.go (about)

     1  // Copyright 2020 The go-ethereum Authors
     2  // This file is part of go-ethereum.
     3  //
     4  // go-ethereum is free software: you can redistribute it and/or modify
     5  // it under the terms of the GNU General Public License as published by
     6  // the Free Software Foundation, either version 3 of the License, or
     7  // (at your option) any later version.
     8  //
     9  // go-ethereum is distributed in the hope that it will be useful,
    10  // but WITHOUT ANY WARRANTY; without even the implied warranty of
    11  // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
    12  // GNU General Public License for more details.
    13  //
    14  // You should have received a copy of the GNU General Public License
    15  // along with go-ethereum. If not, see <http://www.gnu.org/licenses/>.
    16  
    17  // Package utils contains internal helper functions for go-ethereum commands.
    18  package utils
    19  
    20  import (
    21  	"fmt"
    22  
    23  	"github.com/ethw3/go-ethereuma/console/prompt"
    24  )
    25  
    26  // GetPassPhrase displays the given text(prompt) to the user and requests some textual
    27  // data to be entered, but one which must not be echoed out into the terminal.
    28  // The method returns the input provided by the user.
    29  func GetPassPhrase(text string, confirmation bool) string {
    30  	if text != "" {
    31  		fmt.Println(text)
    32  	}
    33  	password, err := prompt.Stdin.PromptPassword("Password: ")
    34  	if err != nil {
    35  		Fatalf("Failed to read password: %v", err)
    36  	}
    37  	if confirmation {
    38  		confirm, err := prompt.Stdin.PromptPassword("Repeat password: ")
    39  		if err != nil {
    40  			Fatalf("Failed to read password confirmation: %v", err)
    41  		}
    42  		if password != confirm {
    43  			Fatalf("Passwords do not match")
    44  		}
    45  	}
    46  	return password
    47  }
    48  
    49  // GetPassPhraseWithList retrieves the password associated with an account, either fetched
    50  // from a list of preloaded passphrases, or requested interactively from the user.
    51  func GetPassPhraseWithList(text string, confirmation bool, index int, passwords []string) string {
    52  	// If a list of passwords was supplied, retrieve from them
    53  	if len(passwords) > 0 {
    54  		if index < len(passwords) {
    55  			return passwords[index]
    56  		}
    57  		return passwords[len(passwords)-1]
    58  	}
    59  	// Otherwise prompt the user for the password
    60  	password := GetPassPhrase(text, confirmation)
    61  	return password
    62  }