deploy: 83f71ae9057df92dd3cb6a977b40f634dcb94a3e

This commit is contained in:
jm-clius 2021-10-12 12:09:51 +00:00
parent 685d4c0663
commit 51949c7175
8 changed files with 23 additions and 26 deletions

View File

@ -18,7 +18,9 @@ proc runBackground() {.async.} =
conf = WakuNodeConf.load() conf = WakuNodeConf.load()
(extIp, extTcpPort, extUdpPort) = setupNat(conf.nat, clientId, (extIp, extTcpPort, extUdpPort) = setupNat(conf.nat, clientId,
Port(uint16(conf.tcpPort) + conf.portsShift), Port(uint16(conf.tcpPort) + conf.portsShift),
Port(uint16(conf.udpPort) + conf.portsShift)) # This is actually a UDP port but we're only supplying this value
# To satisfy the API.
Port(uint16(conf.tcpPort) + conf.portsShift))
node = WakuNode.new(conf.nodeKey, conf.listenAddress, node = WakuNode.new(conf.nodeKey, conf.listenAddress,
Port(uint16(conf.tcpPort) + conf.portsShift), extIp, extTcpPort) Port(uint16(conf.tcpPort) + conf.portsShift), extIp, extTcpPort)

View File

@ -2,7 +2,7 @@
# libtool - Provide generalized library-building support services. # libtool - Provide generalized library-building support services.
# Generated automatically by config.status (libbacktrace) version-unused # Generated automatically by config.status (libbacktrace) version-unused
# Libtool was configured on host fv-az129-926: # Libtool was configured on host fv-az132-413:
# NOTE: Changes made to this file will be lost: look at ltmain.sh. # NOTE: Changes made to this file will be lost: look at ltmain.sh.
# #
# Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005, # Copyright (C) 1996, 1997, 1998, 1999, 2000, 2001, 2003, 2004, 2005,

View File

@ -31,11 +31,6 @@ type
defaultValue: 30303 defaultValue: 30303
name: "devp2p-tcp-port" .}: uint16 name: "devp2p-tcp-port" .}: uint16
udpPort* {.
desc: "UDP listening port"
defaultValue: 9000
name: "udp-port" .}: uint16
portsShift* {. portsShift* {.
desc: "Add a shift to all default port numbers" desc: "Add a shift to all default port numbers"
defaultValue: 0 defaultValue: 0

View File

@ -265,24 +265,28 @@ when isMainModule:
if conf.logLevel != LogLevel.NONE: if conf.logLevel != LogLevel.NONE:
setLogLevel(conf.logLevel) setLogLevel(conf.logLevel)
## `udpPort` is only supplied to satisfy underlying APIs but is not
## actually a supported transport.
let udpPort = conf.devp2pTcpPort
# Load address configuration # Load address configuration
let let
(nodev1ExtIp, _, _) = setupNat(conf.nat, ClientIdV1, (nodev1ExtIp, _, _) = setupNat(conf.nat, ClientIdV1,
Port(conf.devp2pTcpPort + conf.portsShift), Port(conf.devp2pTcpPort + conf.portsShift),
Port(conf.udpPort + conf.portsShift)) Port(udpPort + conf.portsShift))
# TODO: EthereumNode should have a better split of binding address and # TODO: EthereumNode should have a better split of binding address and
# external address. Also, can't have different ports as it stands now. # external address. Also, can't have different ports as it stands now.
nodev1Address = if nodev1ExtIp.isNone(): nodev1Address = if nodev1ExtIp.isNone():
Address(ip: parseIpAddress("0.0.0.0"), Address(ip: parseIpAddress("0.0.0.0"),
tcpPort: Port(conf.devp2pTcpPort + conf.portsShift), tcpPort: Port(conf.devp2pTcpPort + conf.portsShift),
udpPort: Port(conf.udpPort + conf.portsShift)) udpPort: Port(udpPort + conf.portsShift))
else: else:
Address(ip: nodev1ExtIp.get(), Address(ip: nodev1ExtIp.get(),
tcpPort: Port(conf.devp2pTcpPort + conf.portsShift), tcpPort: Port(conf.devp2pTcpPort + conf.portsShift),
udpPort: Port(conf.udpPort + conf.portsShift)) udpPort: Port(udpPort + conf.portsShift))
(nodev2ExtIp, nodev2ExtPort, _) = setupNat(conf.nat, clientId, (nodev2ExtIp, nodev2ExtPort, _) = setupNat(conf.nat, clientId,
Port(uint16(conf.libp2pTcpPort) + conf.portsShift), Port(uint16(conf.libp2pTcpPort) + conf.portsShift),
Port(uint16(conf.udpPort) + conf.portsShift)) Port(uint16(udpPort) + conf.portsShift))
# Topic interest and bloom # Topic interest and bloom
var topicInterest: Option[seq[waku_protocol.Topic]] var topicInterest: Option[seq[waku_protocol.Topic]]

View File

@ -28,11 +28,6 @@ type
defaultValue: 30303 defaultValue: 30303
name: "tcp-port" .}: uint16 name: "tcp-port" .}: uint16
udpPort* {.
desc: "UDP listening port."
defaultValue: 30303
name: "udp-port" .}: uint16
portsShift* {. portsShift* {.
desc: "Add a shift to all port numbers." desc: "Add a shift to all port numbers."
defaultValue: 0 defaultValue: 0

View File

@ -15,20 +15,23 @@ const clientId = "Nimbus waku node"
proc run(config: WakuNodeConf, rng: ref BrHmacDrbgContext) proc run(config: WakuNodeConf, rng: ref BrHmacDrbgContext)
{.raises: [Defect, ValueError, RpcBindError, CatchableError, Exception]} = {.raises: [Defect, ValueError, RpcBindError, CatchableError, Exception]} =
## `udpPort` is only supplied to satisfy underlying APIs but is not
## actually a supported transport.
let udpPort = config.tcpPort
let let
(ipExt, tcpPortExt, udpPortExt) = setupNat(config.nat, clientId, (ipExt, tcpPortExt, _) = setupNat(config.nat, clientId,
Port(config.tcpPort + config.portsShift), Port(config.tcpPort + config.portsShift),
Port(config.udpPort + config.portsShift)) Port(udpPort + config.portsShift))
# TODO: EthereumNode should have a better split of binding address and # TODO: EthereumNode should have a better split of binding address and
# external address. Also, can't have different ports as it stands now. # external address. Also, can't have different ports as it stands now.
address = if ipExt.isNone(): address = if ipExt.isNone():
Address(ip: parseIpAddress("0.0.0.0"), Address(ip: parseIpAddress("0.0.0.0"),
tcpPort: Port(config.tcpPort + config.portsShift), tcpPort: Port(config.tcpPort + config.portsShift),
udpPort: Port(config.udpPort + config.portsShift)) udpPort: Port(udpPort + config.portsShift))
else: else:
Address(ip: ipExt.get(), Address(ip: ipExt.get(),
tcpPort: Port(config.tcpPort + config.portsShift), tcpPort: Port(config.tcpPort + config.portsShift),
udpPort: Port(config.udpPort + config.portsShift)) udpPort: Port(udpPort + config.portsShift))
# Set-up node # Set-up node
var node = newEthereumNode(config.nodekey, address, NetworkId(1), nil, clientId, var node = newEthereumNode(config.nodekey, address, NetworkId(1), nil, clientId,

View File

@ -32,11 +32,6 @@ type
defaultValue: 60000 defaultValue: 60000
name: "tcp-port" }: Port name: "tcp-port" }: Port
udpPort* {.
desc: "UDP listening port."
defaultValue: 60000
name: "udp-port" }: Port
portsShift* {. portsShift* {.
desc: "Add a shift to all port numbers." desc: "Add a shift to all port numbers."
defaultValue: 0 defaultValue: 0

View File

@ -823,11 +823,14 @@ when isMainModule:
## file. Optionally include persistent peer storage. ## file. Optionally include persistent peer storage.
## No protocols are mounted yet. ## No protocols are mounted yet.
## `udpPort` is only supplied to satisfy underlying APIs but is not
## actually a supported transport.
let udpPort = conf.tcpPort
let let
(extIp, extTcpPort, extUdpPort) = setupNat(conf.nat, (extIp, extTcpPort, extUdpPort) = setupNat(conf.nat,
clientId, clientId,
Port(uint16(conf.tcpPort) + conf.portsShift), Port(uint16(conf.tcpPort) + conf.portsShift),
Port(uint16(conf.udpPort) + conf.portsShift)) Port(uint16(udpPort) + conf.portsShift))
## @TODO: the NAT setup assumes a manual port mapping configuration if extIp config is set. This probably ## @TODO: the NAT setup assumes a manual port mapping configuration if extIp config is set. This probably
## implies adding manual config item for extPort as well. The following heuristic assumes that, in absence of manual ## implies adding manual config item for extPort as well. The following heuristic assumes that, in absence of manual
## config, the external port is the same as the bind port. ## config, the external port is the same as the bind port.