mirror of https://github.com/waku-org/nwaku.git
52 lines
1.4 KiB
Nim
52 lines
1.4 KiB
Nim
when (NimMajor, NimMinor) < (1, 4):
|
|
{.push raises: [Defect].}
|
|
else:
|
|
{.push raises: [].}
|
|
|
|
import
|
|
stew/shims/net,
|
|
chronicles,
|
|
json_rpc/rpcserver
|
|
import
|
|
../../waku/v2/node/message_cache,
|
|
../../waku/v2/waku_node,
|
|
../../waku/v2/node/jsonrpc/admin/handlers as admin_api,
|
|
../../waku/v2/node/jsonrpc/debug/handlers as debug_api,
|
|
../../waku/v2/node/jsonrpc/filter/handlers as filter_api,
|
|
../../waku/v2/node/jsonrpc/relay/handlers as relay_api,
|
|
../../waku/v2/node/jsonrpc/store/handlers as store_api,
|
|
./config
|
|
|
|
logScope:
|
|
topics = "wakunode jsonrpc"
|
|
|
|
|
|
proc startRpcServer*(node: WakuNode, address: ValidIpAddress, port: Port, conf: WakuNodeConf)
|
|
{.raises: [CatchableError].} =
|
|
|
|
let
|
|
ta = initTAddress(address, port)
|
|
server = newRpcHttpServer([ta])
|
|
|
|
installDebugApiHandlers(node, server)
|
|
|
|
# TODO: Move to setup protocols proc
|
|
if conf.relay:
|
|
let relayMessageCache = relay_api.MessageCache.init(capacity=30)
|
|
installRelayApiHandlers(node, server, relayMessageCache)
|
|
if conf.rpcPrivate:
|
|
installRelayPrivateApiHandlers(node, server, relayMessageCache)
|
|
|
|
# TODO: Move to setup protocols proc
|
|
if conf.filternode != "":
|
|
let filterMessageCache = filter_api.MessageCache.init(capacity=30)
|
|
installFilterApiHandlers(node, server, filterMessageCache)
|
|
|
|
installStoreApiHandlers(node, server)
|
|
|
|
if conf.rpcAdmin:
|
|
installAdminApiHandlers(node, server)
|
|
|
|
server.start()
|
|
info "RPC Server started", address=ta
|