[] cmd/neofs-node: Make cfg provide network address source interface

Signed-off-by: Leonard Lyubich <leonard@nspcc.ru>
This commit is contained in:
Leonard Lyubich 2020-09-23 16:31:51 +03:00 committed by Alex Vanin
parent caedef82af
commit 480362b02f

View file

@ -12,6 +12,7 @@ import (
crypto "github.com/nspcc-dev/neofs-crypto" crypto "github.com/nspcc-dev/neofs-crypto"
"github.com/nspcc-dev/neofs-node/misc" "github.com/nspcc-dev/neofs-node/misc"
"github.com/nspcc-dev/neofs-node/pkg/morph/client" "github.com/nspcc-dev/neofs-node/pkg/morph/client"
"github.com/nspcc-dev/neofs-node/pkg/network"
tokenStorage "github.com/nspcc-dev/neofs-node/pkg/services/session/storage" tokenStorage "github.com/nspcc-dev/neofs-node/pkg/services/session/storage"
"github.com/nspcc-dev/neofs-node/pkg/util/logger" "github.com/nspcc-dev/neofs-node/pkg/util/logger"
"github.com/spf13/viper" "github.com/spf13/viper"
@ -75,6 +76,8 @@ type cfg struct {
privateTokenStore *tokenStorage.TokenStore privateTokenStore *tokenStorage.TokenStore
cfgNodeInfo cfgNodeInfo cfgNodeInfo cfgNodeInfo
localAddr *network.Address
} }
type cfgGRPC struct { type cfgGRPC struct {
@ -139,6 +142,19 @@ func initCfg(path string) *cfg {
log, err := logger.NewLogger(viperCfg) log, err := logger.NewLogger(viperCfg)
fatalOnErr(err) fatalOnErr(err)
viperCfg.GetString(cfgListenAddress)
endpoint, port, err := net.SplitHostPort(viperCfg.GetString(cfgListenAddress))
fatalOnErr(err)
netAddr, err := network.AddressFromString(strings.Join([]string{
"/ip4",
endpoint,
"tcp",
port,
}, "/"))
fatalOnErr(err)
return &cfg{ return &cfg{
ctx: context.Background(), ctx: context.Background(),
viper: viperCfg, viper: viperCfg,
@ -161,6 +177,7 @@ func initCfg(path string) *cfg {
bootType: StorageNode, bootType: StorageNode,
attributes: parseAttributes(viperCfg), attributes: parseAttributes(viperCfg),
}, },
localAddr: netAddr,
} }
} }
@ -208,3 +225,7 @@ func defaultConfiguration(v *viper.Viper) {
v.SetDefault(cfgLogInitSampling, 1000) v.SetDefault(cfgLogInitSampling, 1000)
v.SetDefault(cfgLogThereafterSampling, 1000) v.SetDefault(cfgLogThereafterSampling, 1000)
} }
func (c *cfg) LocalAddress() *network.Address {
return c.localAddr
}