forked from TrueCloudLab/frostfs-node
[#496] cmd/node: Add morph section to config
Signed-off-by: Alex Vanin <alexey@nspcc.ru>
This commit is contained in:
parent
44b19c145f
commit
cf5e371590
5 changed files with 126 additions and 0 deletions
54
cmd/neofs-node/config/morph/config.go
Normal file
54
cmd/neofs-node/config/morph/config.go
Normal file
|
@ -0,0 +1,54 @@
|
||||||
|
package morphconfig
|
||||||
|
|
||||||
|
import (
|
||||||
|
"fmt"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neofs-node/cmd/neofs-node/config"
|
||||||
|
)
|
||||||
|
|
||||||
|
const (
|
||||||
|
subsection = "morph"
|
||||||
|
|
||||||
|
// DialTimeoutDefault is a default dial timeout of morph chain client connection.
|
||||||
|
DialTimeoutDefault = 5 * time.Second
|
||||||
|
)
|
||||||
|
|
||||||
|
// RPCEndpoint returns list of values of "rpc_endpoint" config parameter
|
||||||
|
// from "morph" section.
|
||||||
|
//
|
||||||
|
// Throws panic if list is empty.
|
||||||
|
func RPCEndpoint(c *config.Config) []string {
|
||||||
|
v := config.StringSliceSafe(c.Sub(subsection), "rpc_endpoint")
|
||||||
|
if len(v) == 0 {
|
||||||
|
panic(fmt.Errorf("no morph chain RPC endpoints, see `morph.rpc_endpoint` section"))
|
||||||
|
}
|
||||||
|
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
// NotificationEndpoint returns list of values of "notification_endpoint" config
|
||||||
|
// parameter from "morph" section.
|
||||||
|
//
|
||||||
|
// Throws panic if list is empty.
|
||||||
|
func NotificationEndpoint(c *config.Config) []string {
|
||||||
|
v := config.StringSliceSafe(c.Sub(subsection), "notification_endpoint")
|
||||||
|
if len(v) == 0 {
|
||||||
|
panic(fmt.Errorf("no morph chain notification endpoints, see `morph.notification_endpoint` section"))
|
||||||
|
}
|
||||||
|
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
// DialTimeout returns value of "dial_timeout" config parameter
|
||||||
|
// from "morph" section.
|
||||||
|
//
|
||||||
|
// Returns DialTimeoutDefault if value is not positive duration.
|
||||||
|
func DialTimeout(c *config.Config) time.Duration {
|
||||||
|
v := config.DurationSafe(c.Sub(subsection), "dial_timeout")
|
||||||
|
if v != 0 {
|
||||||
|
return v
|
||||||
|
}
|
||||||
|
|
||||||
|
return DialTimeoutDefault
|
||||||
|
}
|
47
cmd/neofs-node/config/morph/config_test.go
Normal file
47
cmd/neofs-node/config/morph/config_test.go
Normal file
|
@ -0,0 +1,47 @@
|
||||||
|
package morphconfig_test
|
||||||
|
|
||||||
|
import (
|
||||||
|
"testing"
|
||||||
|
"time"
|
||||||
|
|
||||||
|
"github.com/nspcc-dev/neofs-node/cmd/neofs-node/config"
|
||||||
|
morphconfig "github.com/nspcc-dev/neofs-node/cmd/neofs-node/config/morph"
|
||||||
|
configtest "github.com/nspcc-dev/neofs-node/cmd/neofs-node/config/test"
|
||||||
|
"github.com/stretchr/testify/require"
|
||||||
|
)
|
||||||
|
|
||||||
|
func TestMorphSection(t *testing.T) {
|
||||||
|
t.Run("defaults", func(t *testing.T) {
|
||||||
|
empty := configtest.EmptyConfig()
|
||||||
|
|
||||||
|
require.Panics(t, func() { morphconfig.RPCEndpoint(empty) })
|
||||||
|
require.Panics(t, func() { morphconfig.NotificationEndpoint(empty) })
|
||||||
|
require.Equal(t, morphconfig.DialTimeoutDefault, morphconfig.DialTimeout(empty))
|
||||||
|
})
|
||||||
|
|
||||||
|
const path = "../../../../config/example/node"
|
||||||
|
|
||||||
|
var (
|
||||||
|
rpcs = []string{
|
||||||
|
"https://rpc1.morph.fs.neo.org:40341",
|
||||||
|
"https://rpc2.morph.fs.neo.org:40341",
|
||||||
|
}
|
||||||
|
|
||||||
|
wss = []string{
|
||||||
|
"wss://rpc1.morph.fs.neo.org:40341/ws",
|
||||||
|
"wss://rpc2.morph.fs.neo.org:40341/ws",
|
||||||
|
}
|
||||||
|
)
|
||||||
|
|
||||||
|
var fileConfigTest = func(c *config.Config) {
|
||||||
|
require.Equal(t, rpcs, morphconfig.RPCEndpoint(c))
|
||||||
|
require.Equal(t, wss, morphconfig.NotificationEndpoint(c))
|
||||||
|
require.Equal(t, 30*time.Second, morphconfig.DialTimeout(c))
|
||||||
|
}
|
||||||
|
|
||||||
|
configtest.ForEachFileType(path, fileConfigTest)
|
||||||
|
|
||||||
|
t.Run("ENV", func(t *testing.T) {
|
||||||
|
configtest.ForEnvFileType(path, fileConfigTest)
|
||||||
|
})
|
||||||
|
}
|
|
@ -29,6 +29,11 @@ NEOFS_CONTRACTS_CONTAINER=5d084790d7aa36cea7b53fe897380dab11d2cd3c
|
||||||
NEOFS_CONTRACTS_NETMAP=0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca
|
NEOFS_CONTRACTS_NETMAP=0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca
|
||||||
NEOFS_CONTRACTS_REPUTATION=441995f631c1da2b133462b71859494a5cd45e90
|
NEOFS_CONTRACTS_REPUTATION=441995f631c1da2b133462b71859494a5cd45e90
|
||||||
|
|
||||||
|
# Morph chain section
|
||||||
|
NEOFS_MORPH_DIAL_TIMEOUT=30s
|
||||||
|
NEOFS_MORPH_RPC_ENDPOINT=https://rpc1.morph.fs.neo.org:40341 https://rpc2.morph.fs.neo.org:40341
|
||||||
|
NEOFS_MORPH_NOTIFICATION_ENDPOINT=wss://rpc1.morph.fs.neo.org:40341/ws wss://rpc2.morph.fs.neo.org:40341/ws
|
||||||
|
|
||||||
# Storage engine section
|
# Storage engine section
|
||||||
NEOFS_STORAGE_SHARD_NUM=2
|
NEOFS_STORAGE_SHARD_NUM=2
|
||||||
## 0 shard
|
## 0 shard
|
||||||
|
|
|
@ -40,6 +40,17 @@
|
||||||
"netmap": "0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca",
|
"netmap": "0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca",
|
||||||
"reputation": "441995f631c1da2b133462b71859494a5cd45e90"
|
"reputation": "441995f631c1da2b133462b71859494a5cd45e90"
|
||||||
},
|
},
|
||||||
|
"morph": {
|
||||||
|
"dial_timeout": "30s",
|
||||||
|
"rpc_endpoint": [
|
||||||
|
"https://rpc1.morph.fs.neo.org:40341",
|
||||||
|
"https://rpc2.morph.fs.neo.org:40341"
|
||||||
|
],
|
||||||
|
"notification_endpoint": [
|
||||||
|
"wss://rpc1.morph.fs.neo.org:40341/ws",
|
||||||
|
"wss://rpc2.morph.fs.neo.org:40341/ws"
|
||||||
|
]
|
||||||
|
},
|
||||||
"storage": {
|
"storage": {
|
||||||
"shard_num": 2,
|
"shard_num": 2,
|
||||||
"shard": {
|
"shard": {
|
||||||
|
|
|
@ -36,6 +36,15 @@ contracts:
|
||||||
netmap: 0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca
|
netmap: 0cce9e948dca43a6b592efe59ddb4ecb89bdd9ca
|
||||||
reputation: 441995f631c1da2b133462b71859494a5cd45e90
|
reputation: 441995f631c1da2b133462b71859494a5cd45e90
|
||||||
|
|
||||||
|
morph:
|
||||||
|
dial_timeout: 30s
|
||||||
|
rpc_endpoint:
|
||||||
|
- https://rpc1.morph.fs.neo.org:40341
|
||||||
|
- https://rpc2.morph.fs.neo.org:40341
|
||||||
|
notification_endpoint:
|
||||||
|
- wss://rpc1.morph.fs.neo.org:40341/ws
|
||||||
|
- wss://rpc2.morph.fs.neo.org:40341/ws
|
||||||
|
|
||||||
storage:
|
storage:
|
||||||
shard_num: 2
|
shard_num: 2
|
||||||
shard:
|
shard:
|
||||||
|
|
Loading…
Reference in a new issue