From 5dba64fcc5fa2f016eac019b9b534b0ea5936635 Mon Sep 17 00:00:00 2001 From: Pavel Karpy Date: Tue, 15 Mar 2022 22:42:15 +0300 Subject: [PATCH] [#1243] node/cfg: Add notification config Signed-off-by: Pavel Karpy --- cmd/neofs-node/config.go | 8 ++++++++ cmd/neofs-node/main.go | 2 +- cmd/neofs-node/notificator.go | 14 ++++++++++---- 3 files changed, 19 insertions(+), 5 deletions(-) diff --git a/cmd/neofs-node/config.go b/cmd/neofs-node/config.go index 0f85c16fcb..2b2ee85cdc 100644 --- a/cmd/neofs-node/config.go +++ b/cmd/neofs-node/config.go @@ -97,6 +97,8 @@ type cfg struct { cfgObject cfgObject + cfgNotifications cfgNotifications + metricsCollector *metrics.StorageMetrics workers []worker @@ -183,6 +185,12 @@ type cfgObject struct { cfgLocalStorage cfgLocalStorage } +type cfgNotifications struct { + enabled bool + nw notificationWriter + defaultTopic string +} + type cfgLocalStorage struct { localStorage *engine.StorageEngine diff --git a/cmd/neofs-node/main.go b/cmd/neofs-node/main.go index 343ed2d64c..4647ed59ba 100644 --- a/cmd/neofs-node/main.go +++ b/cmd/neofs-node/main.go @@ -76,11 +76,11 @@ func initApp(c *cfg) { initContainerService(c) initSessionService(c) initReputationService(c) + initNotifications(c) initObjectService(c) initProfiler(c) initMetrics(c) initControlService(c) - initNotifications(c) fatalOnErr(c.cfgObject.cfgLocalStorage.localStorage.Open()) fatalOnErr(c.cfgObject.cfgLocalStorage.localStorage.Init()) diff --git a/cmd/neofs-node/notificator.go b/cmd/neofs-node/notificator.go index fef1f884de..7c02e8b985 100644 --- a/cmd/neofs-node/notificator.go +++ b/cmd/neofs-node/notificator.go @@ -131,6 +131,15 @@ func initNotifications(c *cfg) { panic("could not created object notificator: " + err.Error()) } + c.cfgNotifications = cfgNotifications{ + enabled: true, + nw: notificationWriter{ + l: c.log, + w: natsSvc, + }, + defaultTopic: topic, + } + n := notificator.New(new(notificator.Prm). SetLogger(c.log). SetNotificationSource( @@ -139,10 +148,7 @@ func initNotifications(c *cfg) { l: c.log, defaultTopic: topic, }). - SetWriter(notificationWriter{ - l: c.log, - w: natsSvc, - }), + SetWriter(c.cfgNotifications.nw), ) addNewEpochAsyncNotificationHandler(c, func(e event.Event) {