mirror of
https://github.com/waku-org/nwaku.git
synced 2025-01-15 17:35:45 +00:00
55 lines
2.2 KiB
Nim
55 lines
2.2 KiB
Nim
{.push raises: [Defect].}
|
|
|
|
import
|
|
./servers/[httpserver],
|
|
./clients/[httpclient]
|
|
|
|
type RpcHttpProxy* = ref object of RootRef
|
|
rpcHttpClient*: RpcHttpClient
|
|
rpcHttpServer*: RpcHttpServer
|
|
|
|
proc proxyCall(client: RpcHttpClient, name: string): RpcProc =
|
|
return proc (params: JsonNode): Future[StringOfJson] {.async.} =
|
|
let res = await client.call(name, params)
|
|
return StringOfJson($res)
|
|
|
|
proc new*(T: type RpcHttpProxy, server: RpcHttpServer): T =
|
|
let client = newRpcHttpClient()
|
|
T(rpcHttpClient: client, rpcHttpServer: server)
|
|
|
|
proc new*(T: type RpcHttpProxy, listenAddresses: openArray[TransportAddress]): T {.raises: [Defect, CatchableError].} =
|
|
RpcHttpProxy.new(newRpcHttpServer(listenAddresses, RpcRouter.init()))
|
|
|
|
proc new*(T: type RpcHttpProxy, listenAddresses: openArray[string]): T {.raises: [Defect, CatchableError].} =
|
|
RpcHttpProxy.new(newRpcHttpServer(listenAddresses, RpcRouter.init()))
|
|
|
|
proc newRpcHttpProxy*(listenAddresses: openArray[string]): RpcHttpProxy {.raises: [Defect, CatchableError].} =
|
|
RpcHttpProxy.new(listenAddresses)
|
|
|
|
proc newRpcHttpProxy*(listenAddresses: openArray[TransportAddress]): RpcHttpProxy {.raises: [Defect, CatchableError].} =
|
|
RpcHttpProxy.new(listenAddresses)
|
|
|
|
proc start*(proxy:RpcHttpProxy, proxyServerUrl: string) {.async.} =
|
|
proxy.rpcHttpServer.start()
|
|
await proxy.rpcHttpClient.connect(proxyServerUrl)
|
|
|
|
proc start*(proxy:RpcHttpProxy, proxyServerAddress: string, proxyServerPort: Port) {.async.} =
|
|
proxy.rpcHttpServer.start()
|
|
await proxy.rpcHttpClient.connect(proxyServerAddress, proxyServerPort)
|
|
|
|
template rpc*(server: RpcHttpProxy, path: string, body: untyped): untyped =
|
|
server.rpcHttpServer.rpc(path, body)
|
|
|
|
proc registerProxyMethod*(proxy: var RpcHttpProxy, methodName: string) =
|
|
try:
|
|
proxy.rpcHttpServer.register(methodName, proxyCall(proxy.rpcHttpClient, methodName))
|
|
except CatchableError as err:
|
|
# Adding proc type to table gives invalid exception tracking, see Nim bug: https://github.com/nim-lang/Nim/issues/18376
|
|
raiseAssert err.msg
|
|
|
|
proc stop*(rpcHttpProxy: RpcHttpProxy) {.raises: [Defect, CatchableError].} =
|
|
rpcHttpProxy.rpcHttpServer.stop()
|
|
|
|
proc closeWait*(rpcHttpProxy: RpcHttpProxy) {.async.} =
|
|
await rpcHttpProxy.rpcHttpServer.closeWait()
|