2022-11-04 10:52:27 +01:00
|
|
|
|
when (NimMajor, NimMinor) < (1, 4):
|
|
|
|
|
{.push raises: [Defect].}
|
|
|
|
|
else:
|
|
|
|
|
{.push raises: [].}
|
2021-07-14 19:58:46 +02:00
|
|
|
|
|
2020-04-29 12:49:27 +08:00
|
|
|
|
import
|
2024-02-07 12:42:20 +01:00
|
|
|
|
std/[options, strutils, os, sequtils],
|
2021-06-09 16:37:08 +02:00
|
|
|
|
stew/shims/net as stewNet,
|
2022-11-23 10:08:00 +01:00
|
|
|
|
chronicles,
|
2022-10-18 12:35:26 -05:00
|
|
|
|
chronos,
|
|
|
|
|
metrics,
|
2022-11-30 19:41:19 +01:00
|
|
|
|
libbacktrace,
|
2022-10-18 12:35:26 -05:00
|
|
|
|
system/ansi_c,
|
2023-04-25 15:34:57 +02:00
|
|
|
|
libp2p/crypto/crypto
|
2022-07-25 13:01:37 +02:00
|
|
|
|
import
|
2023-11-09 15:18:39 +05:30
|
|
|
|
../../tools/rln_keystore_generator/rln_keystore_generator,
|
2024-03-06 19:38:43 +05:30
|
|
|
|
../../tools/rln_db_inspector/rln_db_inspector,
|
2022-12-07 12:30:32 +01:00
|
|
|
|
../../waku/common/logging,
|
2024-03-03 02:59:53 +02:00
|
|
|
|
../../waku/factory/external_config,
|
2024-04-19 20:03:36 +02:00
|
|
|
|
../../waku/factory/networks_config,
|
|
|
|
|
../../waku/factory/app
|
2022-10-18 12:35:26 -05:00
|
|
|
|
|
|
|
|
|
logScope:
|
2023-04-25 15:34:57 +02:00
|
|
|
|
topics = "wakunode main"
|
2021-07-22 11:46:54 +02:00
|
|
|
|
|
2024-02-07 12:42:20 +01:00
|
|
|
|
proc logConfig(conf: WakuNodeConf) =
|
|
|
|
|
info "Configuration: Enabled protocols",
|
|
|
|
|
relay = conf.relay,
|
|
|
|
|
rlnRelay = conf.rlnRelay,
|
|
|
|
|
store = conf.store,
|
|
|
|
|
filter = conf.filter,
|
|
|
|
|
lightpush = conf.lightpush,
|
|
|
|
|
peerExchange = conf.peerExchange
|
|
|
|
|
|
2024-03-16 00:08:47 +01:00
|
|
|
|
info "Configuration. Network", cluster = conf.clusterId, maxPeers = conf.maxRelayPeers
|
2024-02-07 12:42:20 +01:00
|
|
|
|
|
2024-02-28 17:19:20 +01:00
|
|
|
|
for shard in conf.pubsubTopics:
|
2024-03-16 00:08:47 +01:00
|
|
|
|
info "Configuration. Shards", shard = shard
|
2024-02-28 17:19:20 +01:00
|
|
|
|
|
2024-02-07 12:42:20 +01:00
|
|
|
|
for i in conf.discv5BootstrapNodes:
|
|
|
|
|
info "Configuration. Bootstrap nodes", node = i
|
|
|
|
|
|
|
|
|
|
if conf.rlnRelay and conf.rlnRelayDynamic:
|
|
|
|
|
info "Configuration. Validation",
|
|
|
|
|
mechanism = "onchain rln",
|
|
|
|
|
contract = conf.rlnRelayEthContractAddress,
|
2024-02-28 17:19:20 +01:00
|
|
|
|
maxMessageSize = conf.maxMessageSize,
|
|
|
|
|
rlnEpochSizeSec = conf.rlnEpochSizeSec,
|
|
|
|
|
rlnRelayUserMessageLimit = conf.rlnRelayUserMessageLimit,
|
|
|
|
|
rlnRelayEthClientAddress = string(conf.rlnRelayEthClientAddress)
|
2024-02-07 12:42:20 +01:00
|
|
|
|
|
|
|
|
|
{.pop.}
|
|
|
|
|
# @TODO confutils.nim(775, 17) Error: can raise an unlisted exception: ref IOError
|
2022-10-21 15:01:01 +02:00
|
|
|
|
when isMainModule:
|
|
|
|
|
## Node setup happens in 6 phases:
|
|
|
|
|
## 1. Set up storage
|
|
|
|
|
## 2. Initialize node
|
|
|
|
|
## 3. Mount and initialize configured protocols
|
|
|
|
|
## 4. Start node and mounted protocols
|
|
|
|
|
## 5. Start monitoring tools and external interfaces
|
|
|
|
|
## 6. Setup graceful shutdown hooks
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2023-04-25 15:34:57 +02:00
|
|
|
|
const versionString = "version / git commit hash: " & app.git_version
|
2022-11-03 10:45:06 +01:00
|
|
|
|
|
2024-02-07 12:42:20 +01:00
|
|
|
|
let confRes = WakuNodeConf.load(version = versionString)
|
2022-11-03 10:45:06 +01:00
|
|
|
|
if confRes.isErr():
|
2024-02-07 12:42:20 +01:00
|
|
|
|
error "failure while loading the configuration", error = confRes.error
|
2022-11-03 10:45:06 +01:00
|
|
|
|
quit(QuitFailure)
|
|
|
|
|
|
2024-02-07 12:42:20 +01:00
|
|
|
|
var conf = confRes.get()
|
|
|
|
|
|
2022-12-07 12:30:32 +01:00
|
|
|
|
## Logging setup
|
|
|
|
|
|
|
|
|
|
# Adhere to NO_COLOR initiative: https://no-color.org/
|
2024-02-07 12:42:20 +01:00
|
|
|
|
let color =
|
|
|
|
|
try:
|
|
|
|
|
not parseBool(os.getEnv("NO_COLOR", "false"))
|
|
|
|
|
except CatchableError:
|
|
|
|
|
true
|
2022-12-07 12:30:32 +01:00
|
|
|
|
|
|
|
|
|
logging.setupLogLevel(conf.logLevel)
|
|
|
|
|
logging.setupLogFormat(conf.logFormat, color)
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2024-02-07 12:42:20 +01:00
|
|
|
|
case conf.cmd
|
2023-11-09 15:18:39 +05:30
|
|
|
|
of generateRlnKeystore:
|
|
|
|
|
doRlnKeystoreGenerator(conf)
|
2024-03-06 19:38:43 +05:30
|
|
|
|
of inspectRlnDb:
|
|
|
|
|
doInspectRlnDb(conf)
|
2023-11-09 15:18:39 +05:30
|
|
|
|
of noCommand:
|
2024-04-04 08:19:31 +02:00
|
|
|
|
case conf.clusterId
|
|
|
|
|
# cluster-id=0
|
|
|
|
|
of 0:
|
|
|
|
|
let clusterZeroConf = ClusterConf.ClusterZeroConf()
|
|
|
|
|
conf.pubsubTopics = clusterZeroConf.pubsubTopics
|
|
|
|
|
# TODO: Write some template to "merge" the configs
|
|
|
|
|
# cluster-id=1 (aka The Waku Network)
|
|
|
|
|
of 1:
|
|
|
|
|
let twnClusterConf = ClusterConf.TheWakuNetworkConf()
|
|
|
|
|
if len(conf.shards) != 0:
|
|
|
|
|
conf.pubsubTopics = conf.shards.mapIt(twnClusterConf.pubsubTopics[it.uint16])
|
|
|
|
|
else:
|
|
|
|
|
conf.pubsubTopics = twnClusterConf.pubsubTopics
|
|
|
|
|
|
|
|
|
|
# Override configuration
|
|
|
|
|
conf.maxMessageSize = twnClusterConf.maxMessageSize
|
|
|
|
|
conf.clusterId = twnClusterConf.clusterId
|
|
|
|
|
conf.rlnRelay = twnClusterConf.rlnRelay
|
|
|
|
|
conf.rlnRelayEthContractAddress = twnClusterConf.rlnRelayEthContractAddress
|
|
|
|
|
conf.rlnRelayDynamic = twnClusterConf.rlnRelayDynamic
|
|
|
|
|
conf.rlnRelayBandwidthThreshold = twnClusterConf.rlnRelayBandwidthThreshold
|
|
|
|
|
conf.discv5Discovery = twnClusterConf.discv5Discovery
|
|
|
|
|
conf.discv5BootstrapNodes =
|
|
|
|
|
conf.discv5BootstrapNodes & twnClusterConf.discv5BootstrapNodes
|
|
|
|
|
conf.rlnEpochSizeSec = twnClusterConf.rlnEpochSizeSec
|
|
|
|
|
conf.rlnRelayUserMessageLimit = twnClusterConf.rlnRelayUserMessageLimit
|
2024-02-13 15:40:45 +05:30
|
|
|
|
else:
|
2024-04-04 08:19:31 +02:00
|
|
|
|
discard
|
2024-02-13 15:40:45 +05:30
|
|
|
|
|
|
|
|
|
info "Running nwaku node", version = app.git_version
|
|
|
|
|
logConfig(conf)
|
|
|
|
|
|
2024-03-08 16:46:42 -06:00
|
|
|
|
var wakunode2 = App.init(conf).valueOr:
|
|
|
|
|
error "App initialization failed", error = error
|
2023-11-09 15:18:39 +05:30
|
|
|
|
quit(QuitFailure)
|
2020-09-01 04:09:54 +02:00
|
|
|
|
|
2024-03-08 16:46:42 -06:00
|
|
|
|
wakunode2.startApp().isOkOr:
|
|
|
|
|
error "Starting app failed", error = error
|
2023-11-09 15:18:39 +05:30
|
|
|
|
quit(QuitFailure)
|
2022-10-28 00:05:02 +02:00
|
|
|
|
|
2024-03-08 16:46:42 -06:00
|
|
|
|
wakunode2.setupMonitoringAndExternalInterfaces().isOkOr:
|
|
|
|
|
error "Starting monitoring and external interfaces failed", error = error
|
2024-03-16 00:08:47 +01:00
|
|
|
|
quit(QuitFailure)
|
2022-10-28 00:05:02 +02:00
|
|
|
|
|
2024-03-08 16:46:42 -06:00
|
|
|
|
debug "Setting up shutdown hooks"
|
2023-11-09 15:18:39 +05:30
|
|
|
|
## Setup shutdown hooks for this process.
|
|
|
|
|
## Stop node gracefully on shutdown.
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2023-12-14 07:16:39 +01:00
|
|
|
|
proc asyncStopper(node: App) {.async: (raises: [Exception]).} =
|
2023-11-09 15:18:39 +05:30
|
|
|
|
await node.stop()
|
|
|
|
|
quit(QuitSuccess)
|
2022-12-06 11:51:33 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
# Handle Ctrl-C SIGINT
|
|
|
|
|
proc handleCtrlC() {.noconv.} =
|
|
|
|
|
when defined(windows):
|
|
|
|
|
# workaround for https://github.com/nim-lang/Nim/issues/4057
|
|
|
|
|
setupForeignThreadGc()
|
|
|
|
|
notice "Shutting down after receiving SIGINT"
|
|
|
|
|
asyncSpawn asyncStopper(wakunode2)
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
setControlCHook(handleCtrlC)
|
2021-04-15 10:18:14 +02:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
# Handle SIGTERM
|
|
|
|
|
when defined(posix):
|
|
|
|
|
proc handleSigterm(signal: cint) {.noconv.} =
|
|
|
|
|
notice "Shutting down after receiving SIGTERM"
|
|
|
|
|
asyncSpawn asyncStopper(wakunode2)
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
c_signal(ansi_c.SIGTERM, handleSigterm)
|
2022-11-23 10:08:00 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
# Handle SIGSEGV
|
|
|
|
|
when defined(posix):
|
|
|
|
|
proc handleSigsegv(signal: cint) {.noconv.} =
|
|
|
|
|
# Require --debugger:native
|
2024-02-07 12:42:20 +01:00
|
|
|
|
fatal "Shutting down after receiving SIGSEGV", stacktrace = getBacktrace()
|
2022-11-29 16:02:18 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
# Not available in -d:release mode
|
|
|
|
|
writeStackTrace()
|
2022-11-29 16:02:18 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
waitFor wakunode2.stop()
|
|
|
|
|
quit(QuitFailure)
|
2022-11-29 16:02:18 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
c_signal(ansi_c.SIGSEGV, handleSigsegv)
|
2022-11-29 16:02:18 +01:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
info "Node setup complete"
|
2020-09-01 04:09:54 +02:00
|
|
|
|
|
2023-11-09 15:18:39 +05:30
|
|
|
|
runForever()
|