From 2f020a500d213724ddc066e8954fe7709f56651a Mon Sep 17 00:00:00 2001 From: Evgenii Stratonikov Date: Thu, 3 Jun 2021 18:24:09 +0300 Subject: [PATCH] [#562] config: parse key on config load Signed-off-by: Evgenii Stratonikov --- cmd/neofs-node/config/node/config.go | 19 +++++++++++++++---- cmd/neofs-node/config/node/config_test.go | 2 +- cmd/neofs-node/config/node/wallet.key | 1 + config/example/node.env | 2 +- config/example/node.json | 2 +- config/example/node.yaml | 2 +- 6 files changed, 20 insertions(+), 8 deletions(-) create mode 100644 cmd/neofs-node/config/node/wallet.key diff --git a/cmd/neofs-node/config/node/config.go b/cmd/neofs-node/config/node/config.go index 3c72509238..1883ce1c8f 100644 --- a/cmd/neofs-node/config/node/config.go +++ b/cmd/neofs-node/config/node/config.go @@ -3,6 +3,7 @@ package nodeconfig import ( "errors" "fmt" + "io/ioutil" "strconv" "github.com/nspcc-dev/neo-go/pkg/crypto/keys" @@ -26,16 +27,26 @@ var ( // from "node" section. // // Panics if value is not a non-empty string. -func Key(c *config.Config) string { +func Key(c *config.Config) *keys.PrivateKey { v := config.StringSafe(c.Sub(subsection), "key") if v == "" { panic(errKeyNotSet) } - // TODO: add string -> `ecdsa.PrivateKey` parsing logic - // after https://github.com/nspcc-dev/neofs-node/pull/569. + var ( + key *keys.PrivateKey + err error + data []byte + ) + if data, err = ioutil.ReadFile(v); err == nil { + key, err = keys.NewPrivateKeyFromBytes(data) + } - return v + if err != nil { + panic(fmt.Errorf("can't read key: %w", err)) + } + + return key } // Wallet returns value of node private key from "node" section. diff --git a/cmd/neofs-node/config/node/config_test.go b/cmd/neofs-node/config/node/config_test.go index 041c6ef4fe..d5335bbdec 100644 --- a/cmd/neofs-node/config/node/config_test.go +++ b/cmd/neofs-node/config/node/config_test.go @@ -49,7 +49,7 @@ func TestNodeSection(t *testing.T) { expectedAddr, err := network.AddressFromString("s01.neofs.devenv:8080") require.NoError(t, err) - require.Equal(t, "path/hex/WIF", key) + require.Equal(t, "NbUgTSFvPmsRxmGeWpuuGeJUoRoi6PErcM", key.Address()) require.Equal(t, true, addr.Equal(expectedAddr)) require.Equal(t, true, relay) diff --git a/cmd/neofs-node/config/node/wallet.key b/cmd/neofs-node/config/node/wallet.key new file mode 100644 index 0000000000..ba2021bd52 --- /dev/null +++ b/cmd/neofs-node/config/node/wallet.key @@ -0,0 +1 @@ +?ܳv/l \ No newline at end of file diff --git a/config/example/node.env b/config/example/node.env index 4243283761..9e492ffd82 100644 --- a/config/example/node.env +++ b/config/example/node.env @@ -7,7 +7,7 @@ NEOFS_METRICS_ADDRESS=127.0.0.1:9090 NEOFS_METRICS_SHUTDOWN_TIMEOUT=15s # Node section -NEOFS_NODE_KEY=path/hex/WIF +NEOFS_NODE_KEY=./wallet.key NEOFS_NODE_WALLET_PATH=./wallet.json NEOFS_NODE_WALLET_ADDRESS=NcpJzXcSDrh5CCizf4K9Ro6w4t59J5LKzz NEOFS_NODE_WALLET_PASSWORD=password diff --git a/config/example/node.json b/config/example/node.json index 646ccea5e3..c5fa0ee771 100644 --- a/config/example/node.json +++ b/config/example/node.json @@ -11,7 +11,7 @@ "shutdown_timeout": "15s" }, "node": { - "key": "path/hex/WIF", + "key": "./wallet.key", "wallet": { "path": "./wallet.json", "address": "NcpJzXcSDrh5CCizf4K9Ro6w4t59J5LKzz", diff --git a/config/example/node.yaml b/config/example/node.yaml index 59b01a9fd7..65e0a3d9f9 100644 --- a/config/example/node.yaml +++ b/config/example/node.yaml @@ -10,7 +10,7 @@ metrics: shutdown_timeout: 15s node: - key: path/hex/WIF + key: ./wallet.key wallet: path: "./wallet.json" address: "NcpJzXcSDrh5CCizf4K9Ro6w4t59J5LKzz"