From 33ff51d6b967298fe0120077937aa4ff4f12d0d1 Mon Sep 17 00:00:00 2001 From: Sean Young <sean.young@monax.io> Date: Wed, 20 Jun 2018 14:01:38 +0100 Subject: [PATCH] Allow keys directory to be specified for burrow configure Signed-off-by: Sean Young <sean.young@monax.io> --- cmd/burrow/commands/configure.go | 12 ++++++++++-- 1 file changed, 10 insertions(+), 2 deletions(-) diff --git a/cmd/burrow/commands/configure.go b/cmd/burrow/commands/configure.go index 937b7bc1..253abb58 100644 --- a/cmd/burrow/commands/configure.go +++ b/cmd/burrow/commands/configure.go @@ -47,6 +47,8 @@ func Configure(output Output) func(cmd *cli.Cmd) { keysUrlOpt := cmd.StringOpt("k keys-url", "", fmt.Sprintf("Provide keys GRPC address, default: %s", keys.DefaultKeysConfig().RemoteAddress)) + keysDir := cmd.StringOpt("keysdir", "", "Directory where keys are stored") + configOpt := cmd.StringOpt("c base-config", "", "Use the a specified burrow config file as a base") genesisDocOpt := cmd.StringOpt("g genesis-doc", "", "GenesisDoc in JSON or TOML to embed in config") @@ -83,10 +85,12 @@ func Configure(output Output) func(cmd *cli.Cmd) { chainNameOpt := cmd.StringOpt("n chain-name", "", "Default chain name") - cmd.Spec = "[--keys-url=<keys URL> | (--generate-keys=<secret keys files> [--keys-template=<text template for key>])] " + + cmd.Spec = "[--keys-url=<keys URL> | ([--keysdir=<keys directory>] " + + "[--generate-keys=<secret keys files> [--keys-template=<text template for key>]])] " + "[--config-template-in=<text template> --config-template-out=<output file>] " + "[--genesis-spec=<GenesisSpec file> | --genesis-doc=<GenesisDoc file>] " + "[--separate-genesis-doc=<genesis JSON file>] [--chain-name] [--json] " + + "[--keysdir=<keys directory>] " + "[--logging=<logging program>] [--describe-logging] [--debug]" cmd.Action = func() { @@ -126,7 +130,11 @@ func Configure(output Output) func(cmd *cli.Cmd) { if err != nil { output.Fatalf("Could not read GenesisSpec: %v", err) } - keyStore := keys.NewKeyStore(conf.Keys.KeysDirectory, conf.Keys.AllowBadFilePermissions, logging.NewNoopLogger()) + dir := conf.Keys.KeysDirectory + if *keysDir != "" { + dir = *keysDir + } + keyStore := keys.NewKeyStore(dir, conf.Keys.AllowBadFilePermissions, logging.NewNoopLogger()) if *generateKeysOpt != "" { keyClient := keys.NewLocalKeyClient(keyStore, logging.NewNoopLogger()) -- GitLab