mirror of
https://github.com/status-im/go-waku.git
synced 2025-01-12 23:04:45 +00:00
chore: return custom error code for non recoverable errors
This commit is contained in:
parent
ac9d826b03
commit
4af7e7a500
@ -8,6 +8,8 @@ import (
|
|||||||
"github.com/waku-org/go-waku/cmd/waku/keygen"
|
"github.com/waku-org/go-waku/cmd/waku/keygen"
|
||||||
"github.com/waku-org/go-waku/cmd/waku/rlngenerate"
|
"github.com/waku-org/go-waku/cmd/waku/rlngenerate"
|
||||||
"github.com/waku-org/go-waku/waku/v2/node"
|
"github.com/waku-org/go-waku/waku/v2/node"
|
||||||
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
||||||
|
"go.uber.org/zap"
|
||||||
)
|
)
|
||||||
|
|
||||||
var options NodeOptions
|
var options NodeOptions
|
||||||
@ -113,7 +115,16 @@ func main() {
|
|||||||
Before: altsrc.InitInputSourceWithContext(cliFlags, altsrc.NewTomlSourceFromFlagFunc("config-file")),
|
Before: altsrc.InitInputSourceWithContext(cliFlags, altsrc.NewTomlSourceFromFlagFunc("config-file")),
|
||||||
Flags: cliFlags,
|
Flags: cliFlags,
|
||||||
Action: func(c *cli.Context) error {
|
Action: func(c *cli.Context) error {
|
||||||
Execute(options)
|
err := Execute(options)
|
||||||
|
if err != nil {
|
||||||
|
utils.Logger().Error("failure while executing wakunode", zap.Error(err))
|
||||||
|
switch e := err.(type) {
|
||||||
|
case cli.ExitCoder:
|
||||||
|
return e
|
||||||
|
case error:
|
||||||
|
return cli.Exit(err.Error(), 1)
|
||||||
|
}
|
||||||
|
}
|
||||||
return nil
|
return nil
|
||||||
},
|
},
|
||||||
Commands: []*cli.Command{
|
Commands: []*cli.Command{
|
||||||
|
153
cmd/waku/node.go
153
cmd/waku/node.go
@ -5,7 +5,6 @@ import (
|
|||||||
"crypto/ecdsa"
|
"crypto/ecdsa"
|
||||||
"database/sql"
|
"database/sql"
|
||||||
"encoding/json"
|
"encoding/json"
|
||||||
"errors"
|
|
||||||
"fmt"
|
"fmt"
|
||||||
"net"
|
"net"
|
||||||
"os"
|
"os"
|
||||||
@ -17,6 +16,7 @@ import (
|
|||||||
rcmgr "github.com/libp2p/go-libp2p/p2p/host/resource-manager"
|
rcmgr "github.com/libp2p/go-libp2p/p2p/host/resource-manager"
|
||||||
"github.com/pbnjay/memory"
|
"github.com/pbnjay/memory"
|
||||||
"github.com/prometheus/client_golang/prometheus"
|
"github.com/prometheus/client_golang/prometheus"
|
||||||
|
"github.com/urfave/cli/v2"
|
||||||
|
|
||||||
dbutils "github.com/waku-org/go-waku/waku/persistence/utils"
|
dbutils "github.com/waku-org/go-waku/waku/persistence/utils"
|
||||||
wakupeerstore "github.com/waku-org/go-waku/waku/v2/peerstore"
|
wakupeerstore "github.com/waku-org/go-waku/waku/v2/peerstore"
|
||||||
@ -56,12 +56,6 @@ import (
|
|||||||
"github.com/waku-org/go-waku/waku/v2/utils"
|
"github.com/waku-org/go-waku/waku/v2/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
func failOnErr(err error, msg string) {
|
|
||||||
if err != nil {
|
|
||||||
utils.Logger().Fatal(msg, zap.Error(err))
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func requiresDB(options NodeOptions) bool {
|
func requiresDB(options NodeOptions) bool {
|
||||||
return options.Store.Enable || options.Rendezvous.Enable
|
return options.Store.Enable || options.Rendezvous.Enable
|
||||||
}
|
}
|
||||||
@ -80,21 +74,37 @@ func scalePerc(value float64) float64 {
|
|||||||
|
|
||||||
const dialTimeout = 7 * time.Second
|
const dialTimeout = 7 * time.Second
|
||||||
|
|
||||||
|
func nonRecoverErrorMsg(format string, a ...any) error {
|
||||||
|
err := fmt.Errorf(format, a...)
|
||||||
|
return nonRecoverError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
func nonRecoverError(err error) error {
|
||||||
|
return cli.Exit(err.Error(), 166)
|
||||||
|
}
|
||||||
|
|
||||||
// Execute starts a go-waku node with settings determined by the Options parameter
|
// Execute starts a go-waku node with settings determined by the Options parameter
|
||||||
func Execute(options NodeOptions) {
|
func Execute(options NodeOptions) error {
|
||||||
// Set encoding for logs (console, json, ...)
|
// Set encoding for logs (console, json, ...)
|
||||||
// Note that libp2p reads the encoding from GOLOG_LOG_FMT env var.
|
// Note that libp2p reads the encoding from GOLOG_LOG_FMT env var.
|
||||||
utils.InitLogger(options.LogEncoding, options.LogOutput)
|
utils.InitLogger(options.LogEncoding, options.LogOutput)
|
||||||
|
|
||||||
hostAddr, err := net.ResolveTCPAddr("tcp", fmt.Sprintf("%s:%d", options.Address, options.Port))
|
hostAddr, err := net.ResolveTCPAddr("tcp", fmt.Sprintf("%s:%d", options.Address, options.Port))
|
||||||
failOnErr(err, "invalid host address")
|
if err != nil {
|
||||||
|
return nonRecoverErrorMsg("invalid host address: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
prvKey, err := getPrivKey(options)
|
prvKey, err := getPrivKey(options)
|
||||||
failOnErr(err, "nodekey error")
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
p2pPrvKey := utils.EcdsaPrivKeyToSecp256k1PrivKey(prvKey)
|
p2pPrvKey := utils.EcdsaPrivKeyToSecp256k1PrivKey(prvKey)
|
||||||
id, err := peer.IDFromPublicKey(p2pPrvKey.GetPublic())
|
id, err := peer.IDFromPublicKey(p2pPrvKey.GetPublic())
|
||||||
failOnErr(err, "deriving peer ID from private key")
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
logger := utils.Logger().With(logging.HostID("node", id))
|
logger := utils.Logger().With(logging.HostID("node", id))
|
||||||
|
|
||||||
var db *sql.DB
|
var db *sql.DB
|
||||||
@ -104,7 +114,9 @@ func Execute(options NodeOptions) {
|
|||||||
Vacuum: options.Store.Vacuum,
|
Vacuum: options.Store.Vacuum,
|
||||||
}
|
}
|
||||||
db, migrationFn, err = dbutils.ExtractDBAndMigration(options.Store.DatabaseURL, dbSettings, logger)
|
db, migrationFn, err = dbutils.ExtractDBAndMigration(options.Store.DatabaseURL, dbSettings, logger)
|
||||||
failOnErr(err, "Could not connect to DB")
|
if err != nil {
|
||||||
|
return nonRecoverErrorMsg("could not connect to DB: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
ctx := context.Background()
|
ctx := context.Background()
|
||||||
@ -117,7 +129,7 @@ func Execute(options NodeOptions) {
|
|||||||
|
|
||||||
lvl, err := zapcore.ParseLevel(options.LogLevel)
|
lvl, err := zapcore.ParseLevel(options.LogLevel)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
failOnErr(err, "log level error")
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeOpts := []node.WakuNodeOption{
|
nodeOpts := []node.WakuNodeOption{
|
||||||
@ -137,8 +149,9 @@ func Execute(options NodeOptions) {
|
|||||||
if options.ExtIP != "" {
|
if options.ExtIP != "" {
|
||||||
ip := net.ParseIP(options.ExtIP)
|
ip := net.ParseIP(options.ExtIP)
|
||||||
if ip == nil {
|
if ip == nil {
|
||||||
failOnErr(errors.New("invalid IP address"), "could not set external IP address")
|
return nonRecoverErrorMsg("could not set external IP address: invalid IP")
|
||||||
}
|
}
|
||||||
|
|
||||||
nodeOpts = append(nodeOpts, node.WithExternalIP(ip))
|
nodeOpts = append(nodeOpts, node.WithExternalIP(ip))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -155,7 +168,9 @@ func Execute(options NodeOptions) {
|
|||||||
limits := rcmgr.DefaultLimits // Default memory limit: 1/8th of total memory, minimum 128MB, maximum 1GB
|
limits := rcmgr.DefaultLimits // Default memory limit: 1/8th of total memory, minimum 128MB, maximum 1GB
|
||||||
scaledLimits := limits.Scale(int64(float64(memory.TotalMemory())*memPerc/100), int(float64(getNumFDs())*fdPerc/100))
|
scaledLimits := limits.Scale(int64(float64(memory.TotalMemory())*memPerc/100), int(float64(getNumFDs())*fdPerc/100))
|
||||||
resourceManager, err := rcmgr.NewResourceManager(rcmgr.NewFixedLimiter(scaledLimits))
|
resourceManager, err := rcmgr.NewResourceManager(rcmgr.NewFixedLimiter(scaledLimits))
|
||||||
failOnErr(err, "setting resource limits")
|
if err != nil {
|
||||||
|
return fmt.Errorf("could not set resource limits: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
libp2pOpts = append(libp2pOpts, libp2p.ResourceManager(resourceManager))
|
libp2pOpts = append(libp2pOpts, libp2p.ResourceManager(resourceManager))
|
||||||
libp2p.SetDefaultServiceLimits(&limits)
|
libp2p.SetDefaultServiceLimits(&limits)
|
||||||
@ -179,7 +194,7 @@ func Execute(options NodeOptions) {
|
|||||||
logger.Warn("node forced to be publicly reachable!")
|
logger.Warn("node forced to be publicly reachable!")
|
||||||
libp2pOpts = append(libp2pOpts, libp2p.ForceReachabilityPublic())
|
libp2pOpts = append(libp2pOpts, libp2p.ForceReachabilityPublic())
|
||||||
} else {
|
} else {
|
||||||
failOnErr(errors.New("invalid reachability value"), "Reachability")
|
return nonRecoverErrorMsg("invalid reachability value")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -197,18 +212,23 @@ func Execute(options NodeOptions) {
|
|||||||
|
|
||||||
if options.ShowAddresses {
|
if options.ShowAddresses {
|
||||||
printListeningAddresses(ctx, nodeOpts, options)
|
printListeningAddresses(ctx, nodeOpts, options)
|
||||||
return
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.Store.Enable && options.PersistPeers {
|
if options.Store.Enable && options.PersistPeers {
|
||||||
// Create persistent peerstore
|
// Create persistent peerstore
|
||||||
queries, err := dbutils.NewQueries("peerstore", db)
|
queries, err := dbutils.NewQueries("peerstore", db)
|
||||||
failOnErr(err, "Peerstore")
|
if err != nil {
|
||||||
|
return nonRecoverErrorMsg("could not setup persistent peerstore database: %w", err)
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
datastore := dssql.NewDatastore(db, queries)
|
datastore := dssql.NewDatastore(db, queries)
|
||||||
opts := pstoreds.DefaultOpts()
|
opts := pstoreds.DefaultOpts()
|
||||||
peerStore, err := pstoreds.NewPeerstore(ctx, datastore, opts)
|
peerStore, err := pstoreds.NewPeerstore(ctx, datastore, opts)
|
||||||
failOnErr(err, "Peerstore")
|
if err != nil {
|
||||||
|
return nonRecoverErrorMsg("could not create persistent peerstore: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
nodeOpts = append(nodeOpts, node.WithPeerStore(peerStore))
|
nodeOpts = append(nodeOpts, node.WithPeerStore(peerStore))
|
||||||
}
|
}
|
||||||
@ -244,7 +264,10 @@ func Execute(options NodeOptions) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
dbStore, err = persistence.NewDBStore(prometheus.DefaultRegisterer, logger, dbOptions...)
|
dbStore, err = persistence.NewDBStore(prometheus.DefaultRegisterer, logger, dbOptions...)
|
||||||
failOnErr(err, "DBStore")
|
if err != nil {
|
||||||
|
return nonRecoverErrorMsg("error setting up db store: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
nodeOpts = append(nodeOpts, node.WithMessageProvider(dbStore))
|
nodeOpts = append(nodeOpts, node.WithMessageProvider(dbStore))
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -275,7 +298,7 @@ func Execute(options NodeOptions) {
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
logger.Fatal("DNS discovery URL is required")
|
return nonRecoverErrorMsg("DNS discovery URL is required")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -307,26 +330,36 @@ func Execute(options NodeOptions) {
|
|||||||
nodeOpts = append(nodeOpts, node.WithRendezvous(rdb))
|
nodeOpts = append(nodeOpts, node.WithRendezvous(rdb))
|
||||||
}
|
}
|
||||||
|
|
||||||
checkForRLN(logger, options, &nodeOpts)
|
|
||||||
|
|
||||||
wakuNode, err := node.New(nodeOpts...)
|
|
||||||
|
|
||||||
utils.Logger().Info("Version details ", zap.String("version", node.Version), zap.String("commit", node.GitCommit))
|
utils.Logger().Info("Version details ", zap.String("version", node.Version), zap.String("commit", node.GitCommit))
|
||||||
|
|
||||||
failOnErr(err, "Wakunode")
|
if err = checkForRLN(logger, options, &nodeOpts); err != nil {
|
||||||
|
return nonRecoverError(err)
|
||||||
|
}
|
||||||
|
|
||||||
|
wakuNode, err := node.New(nodeOpts...)
|
||||||
|
if err != nil {
|
||||||
|
return fmt.Errorf("could not instantiate waku: %w", err)
|
||||||
|
}
|
||||||
|
|
||||||
//Process pubSub and contentTopics specified and arrive at all corresponding pubSubTopics
|
//Process pubSub and contentTopics specified and arrive at all corresponding pubSubTopics
|
||||||
pubSubTopicMap := processTopics(options)
|
pubSubTopicMap, err := processTopics(options)
|
||||||
|
if err != nil {
|
||||||
|
return nonRecoverError(err)
|
||||||
|
}
|
||||||
|
|
||||||
pubSubTopicMapKeys := make([]string, 0, len(pubSubTopicMap))
|
pubSubTopicMapKeys := make([]string, 0, len(pubSubTopicMap))
|
||||||
for k := range pubSubTopicMap {
|
for k := range pubSubTopicMap {
|
||||||
pubSubTopicMapKeys = append(pubSubTopicMapKeys, k)
|
pubSubTopicMapKeys = append(pubSubTopicMapKeys, k)
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.Filter.UseV1 {
|
if options.Filter.UseV1 {
|
||||||
addStaticPeers(wakuNode, options.Filter.NodesV1, pubSubTopicMapKeys, legacy_filter.FilterID_v20beta1)
|
if err := addStaticPeers(wakuNode, options.Filter.NodesV1, pubSubTopicMapKeys, legacy_filter.FilterID_v20beta1); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if err = wakuNode.Start(ctx); err != nil {
|
if err = wakuNode.Start(ctx); err != nil {
|
||||||
logger.Fatal("starting waku node", zap.Error(err))
|
return nonRecoverError(err)
|
||||||
}
|
}
|
||||||
|
|
||||||
for _, d := range discoveredNodes {
|
for _, d := range discoveredNodes {
|
||||||
@ -334,10 +367,17 @@ func Execute(options NodeOptions) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
//For now assuming that static peers added support/listen on all topics specified via commandLine.
|
//For now assuming that static peers added support/listen on all topics specified via commandLine.
|
||||||
addStaticPeers(wakuNode, options.Store.Nodes, pubSubTopicMapKeys, store.StoreID_v20beta4)
|
staticPeers := map[protocol.ID][]multiaddr.Multiaddr{
|
||||||
addStaticPeers(wakuNode, options.LightPush.Nodes, pubSubTopicMapKeys, lightpush.LightPushID_v20beta1)
|
store.StoreID_v20beta4: options.Store.Nodes,
|
||||||
addStaticPeers(wakuNode, options.Rendezvous.Nodes, pubSubTopicMapKeys, rendezvous.RendezvousID)
|
lightpush.LightPushID_v20beta1: options.LightPush.Nodes,
|
||||||
addStaticPeers(wakuNode, options.Filter.Nodes, pubSubTopicMapKeys, filter.FilterSubscribeID_v20beta1)
|
rendezvous.RendezvousID: options.Rendezvous.Nodes,
|
||||||
|
filter.FilterSubscribeID_v20beta1: options.Filter.Nodes,
|
||||||
|
}
|
||||||
|
for protocolID, peers := range staticPeers {
|
||||||
|
if err = addStaticPeers(wakuNode, peers, pubSubTopicMapKeys, protocolID); err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
var wg sync.WaitGroup
|
var wg sync.WaitGroup
|
||||||
|
|
||||||
@ -345,7 +385,10 @@ func Execute(options NodeOptions) {
|
|||||||
for nodeTopic := range pubSubTopicMap {
|
for nodeTopic := range pubSubTopicMap {
|
||||||
nodeTopic := nodeTopic
|
nodeTopic := nodeTopic
|
||||||
sub, err := wakuNode.Relay().SubscribeToTopic(ctx, nodeTopic)
|
sub, err := wakuNode.Relay().SubscribeToTopic(ctx, nodeTopic)
|
||||||
failOnErr(err, "Error subscring to topic")
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
|
||||||
sub.Unsubscribe()
|
sub.Unsubscribe()
|
||||||
|
|
||||||
if len(options.Rendezvous.Nodes) != 0 {
|
if len(options.Rendezvous.Nodes) != 0 {
|
||||||
@ -401,8 +444,9 @@ func Execute(options NodeOptions) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for _, protectedTopic := range options.Relay.ProtectedTopics {
|
for _, protectedTopic := range options.Relay.ProtectedTopics {
|
||||||
err := wakuNode.Relay().AddSignedTopicValidator(protectedTopic.Topic, protectedTopic.PublicKey)
|
if err := wakuNode.Relay().AddSignedTopicValidator(protectedTopic.Topic, protectedTopic.PublicKey); err != nil {
|
||||||
failOnErr(err, "Error adding signed topic validator")
|
return nonRecoverErrorMsg("could not add signed topic validator: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -479,27 +523,33 @@ func Execute(options NodeOptions) {
|
|||||||
wakuNode.Stop()
|
wakuNode.Stop()
|
||||||
|
|
||||||
if options.RPCServer.Enable {
|
if options.RPCServer.Enable {
|
||||||
err := rpcServer.Stop(ctx)
|
if err := rpcServer.Stop(ctx); err != nil {
|
||||||
failOnErr(err, "RPCClose")
|
return err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.RESTServer.Enable {
|
if options.RESTServer.Enable {
|
||||||
err := restServer.Stop(ctx)
|
if err := restServer.Stop(ctx); err != nil {
|
||||||
failOnErr(err, "RESTClose")
|
return err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.Metrics.Enable {
|
if options.Metrics.Enable {
|
||||||
err = metricsServer.Stop(ctx)
|
if err = metricsServer.Stop(ctx); err != nil {
|
||||||
failOnErr(err, "MetricsClose")
|
return err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if options.Store.Enable {
|
if db != nil {
|
||||||
err = db.Close()
|
if err = db.Close(); err != nil {
|
||||||
failOnErr(err, "DBClose")
|
return err
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func processTopics(options NodeOptions) map[string]struct{} {
|
func processTopics(options NodeOptions) (map[string]struct{}, error) {
|
||||||
//Using a map to avoid duplicate pub-sub topics that can result from autosharding
|
//Using a map to avoid duplicate pub-sub topics that can result from autosharding
|
||||||
// or same-topic being passed twice.
|
// or same-topic being passed twice.
|
||||||
pubSubTopicMap := make(map[string]struct{})
|
pubSubTopicMap := make(map[string]struct{})
|
||||||
@ -516,7 +566,7 @@ func processTopics(options NodeOptions) map[string]struct{} {
|
|||||||
for _, cTopic := range options.Relay.ContentTopics.Value() {
|
for _, cTopic := range options.Relay.ContentTopics.Value() {
|
||||||
contentTopic, err := wprotocol.StringToContentTopic(cTopic)
|
contentTopic, err := wprotocol.StringToContentTopic(cTopic)
|
||||||
if err != nil {
|
if err != nil {
|
||||||
failOnErr(err, "failed to parse content topic")
|
return nil, err
|
||||||
}
|
}
|
||||||
pTopic := wprotocol.GetShardFromContentTopic(contentTopic, wprotocol.GenerationZeroShardsCount)
|
pTopic := wprotocol.GetShardFromContentTopic(contentTopic, wprotocol.GenerationZeroShardsCount)
|
||||||
pubSubTopicMap[pTopic.String()] = struct{}{}
|
pubSubTopicMap[pTopic.String()] = struct{}{}
|
||||||
@ -526,14 +576,17 @@ func processTopics(options NodeOptions) map[string]struct{} {
|
|||||||
pubSubTopicMap[relay.DefaultWakuTopic] = struct{}{}
|
pubSubTopicMap[relay.DefaultWakuTopic] = struct{}{}
|
||||||
}
|
}
|
||||||
|
|
||||||
return pubSubTopicMap
|
return pubSubTopicMap, nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func addStaticPeers(wakuNode *node.WakuNode, addresses []multiaddr.Multiaddr, pubSubTopics []string, protocols ...protocol.ID) {
|
func addStaticPeers(wakuNode *node.WakuNode, addresses []multiaddr.Multiaddr, pubSubTopics []string, protocols ...protocol.ID) error {
|
||||||
for _, addr := range addresses {
|
for _, addr := range addresses {
|
||||||
_, err := wakuNode.AddPeer(addr, wakupeerstore.Static, pubSubTopics, protocols...)
|
_, err := wakuNode.AddPeer(addr, wakupeerstore.Static, pubSubTopics, protocols...)
|
||||||
failOnErr(err, "error adding peer")
|
if err != nil {
|
||||||
|
return fmt.Errorf("could not add static peer: %w", err)
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
func loadPrivateKeyFromFile(path string, passwd string) (*ecdsa.PrivateKey, error) {
|
func loadPrivateKeyFromFile(path string, passwd string) (*ecdsa.PrivateKey, error) {
|
||||||
|
@ -8,6 +8,7 @@ import (
|
|||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
)
|
)
|
||||||
|
|
||||||
func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuNodeOption) {
|
func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuNodeOption) error {
|
||||||
// Do nothing
|
// Do nothing
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
@ -11,11 +11,12 @@ import (
|
|||||||
"go.uber.org/zap"
|
"go.uber.org/zap"
|
||||||
)
|
)
|
||||||
|
|
||||||
func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuNodeOption) {
|
func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuNodeOption) error {
|
||||||
if options.RLNRelay.Enable {
|
if options.RLNRelay.Enable {
|
||||||
if !options.Relay.Enable {
|
if !options.Relay.Enable {
|
||||||
failOnErr(errors.New("relay not available"), "Could not enable RLN Relay")
|
return errors.New("waku relay is required to enable RLN relay")
|
||||||
}
|
}
|
||||||
|
|
||||||
if !options.RLNRelay.Dynamic {
|
if !options.RLNRelay.Dynamic {
|
||||||
*nodeOpts = append(*nodeOpts, node.WithStaticRLNRelay((*rln.MembershipIndex)(options.RLNRelay.MembershipIndex), nil))
|
*nodeOpts = append(*nodeOpts, node.WithStaticRLNRelay((*rln.MembershipIndex)(options.RLNRelay.MembershipIndex), nil))
|
||||||
} else {
|
} else {
|
||||||
@ -32,4 +33,6 @@ func checkForRLN(logger *zap.Logger, options NodeOptions, nodeOpts *[]node.WakuN
|
|||||||
))
|
))
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return nil
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user