cmd/ethereum: add a flag to switch to unencrytped keystore
This is mostly for automated tests. The tests can use the following commands to start the node: ethereum --unencrypted-keys account new ... ethereum --unencrypted-keys
This commit is contained in:
parent
58909117be
commit
99bc44cf52
|
@ -127,6 +127,7 @@ runtime will execute the file and exit.
|
||||||
utils.RPCEnabledFlag,
|
utils.RPCEnabledFlag,
|
||||||
utils.RPCListenAddrFlag,
|
utils.RPCListenAddrFlag,
|
||||||
utils.RPCPortFlag,
|
utils.RPCPortFlag,
|
||||||
|
utils.UnencryptedKeysFlag,
|
||||||
utils.VMDebugFlag,
|
utils.VMDebugFlag,
|
||||||
//utils.VMTypeFlag,
|
//utils.VMTypeFlag,
|
||||||
}
|
}
|
||||||
|
@ -213,6 +214,8 @@ func accountList(ctx *cli.Context) {
|
||||||
|
|
||||||
func accountCreate(ctx *cli.Context) {
|
func accountCreate(ctx *cli.Context) {
|
||||||
am := utils.GetAccountManager(ctx)
|
am := utils.GetAccountManager(ctx)
|
||||||
|
passphrase := ""
|
||||||
|
if !ctx.GlobalBool(utils.UnencryptedKeysFlag.Name) {
|
||||||
fmt.Println("The new account will be encrypted with a passphrase.")
|
fmt.Println("The new account will be encrypted with a passphrase.")
|
||||||
fmt.Println("Please enter a passphrase now.")
|
fmt.Println("Please enter a passphrase now.")
|
||||||
auth, err := readPassword("Passphrase: ", true)
|
auth, err := readPassword("Passphrase: ", true)
|
||||||
|
@ -226,7 +229,9 @@ func accountCreate(ctx *cli.Context) {
|
||||||
if auth != confirm {
|
if auth != confirm {
|
||||||
utils.Fatalf("Passphrases did not match.")
|
utils.Fatalf("Passphrases did not match.")
|
||||||
}
|
}
|
||||||
acct, err := am.NewAccount(auth)
|
passphrase = auth
|
||||||
|
}
|
||||||
|
acct, err := am.NewAccount(passphrase)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
utils.Fatalf("Could not create the account: %v", err)
|
utils.Fatalf("Could not create the account: %v", err)
|
||||||
}
|
}
|
||||||
|
|
|
@ -95,6 +95,10 @@ var (
|
||||||
Name: "mine",
|
Name: "mine",
|
||||||
Usage: "Enable mining",
|
Usage: "Enable mining",
|
||||||
}
|
}
|
||||||
|
UnencryptedKeysFlag = cli.BoolFlag{
|
||||||
|
Name: "unencrypted-keys",
|
||||||
|
Usage: "disable private key disk encryption (for testing)",
|
||||||
|
}
|
||||||
|
|
||||||
LogFileFlag = cli.StringFlag{
|
LogFileFlag = cli.StringFlag{
|
||||||
Name: "logfile",
|
Name: "logfile",
|
||||||
|
@ -220,7 +224,12 @@ func GetChain(ctx *cli.Context) (*core.ChainManager, ethutil.Database, ethutil.D
|
||||||
|
|
||||||
func GetAccountManager(ctx *cli.Context) *accounts.Manager {
|
func GetAccountManager(ctx *cli.Context) *accounts.Manager {
|
||||||
dataDir := ctx.GlobalString(DataDirFlag.Name)
|
dataDir := ctx.GlobalString(DataDirFlag.Name)
|
||||||
ks := crypto.NewKeyStorePassphrase(path.Join(dataDir, "keys"))
|
var ks crypto.KeyStore2
|
||||||
|
if ctx.GlobalBool(UnencryptedKeysFlag.Name) {
|
||||||
|
ks = crypto.NewKeyStorePlain(path.Join(dataDir, "plainkeys"))
|
||||||
|
} else {
|
||||||
|
ks = crypto.NewKeyStorePassphrase(path.Join(dataDir, "keys"))
|
||||||
|
}
|
||||||
return accounts.NewManager(ks)
|
return accounts.NewManager(ks)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue