2020-04-29 12:49:27 +08:00
import
2022-11-02 15:55:09 +01:00
std / strutils ,
2022-10-26 17:10:30 +02:00
stew / results ,
chronos ,
2022-11-02 15:55:09 +01:00
regex ,
2022-11-03 10:45:06 +01:00
confutils ,
confutils / defs ,
2022-10-18 07:06:54 -05:00
confutils / std / net ,
2022-05-17 17:48:08 +02:00
confutils / toml / defs as confTomlDefs ,
confutils / toml / std / net as confTomlNet ,
2020-05-21 12:16:00 +08:00
libp2p / crypto / crypto ,
libp2p / crypto / secp ,
2023-01-26 15:48:30 +05:30
libp2p / multiaddress ,
2023-05-02 11:45:50 +02:00
nimcrypto / utils ,
secp256k1
2022-11-03 17:58:48 +01:00
import
2024-03-03 02:59:53 +02:00
.. / common / confutils / envvar / defs as confEnvvarDefs ,
.. / common / confutils / envvar / std / net as confEnvvarNet ,
.. / common / logging ,
.. / waku_enr ,
.. / node / peer_manager
2022-05-17 17:48:08 +02:00
2024-03-16 00:08:47 +01:00
include .. / waku_core / message / default_values
2024-01-03 13:11:50 +01:00
2024-03-16 00:08:47 +01:00
export confTomlDefs , confTomlNet , confEnvvarDefs , confEnvvarNet
2022-10-26 17:10:30 +02:00
type ConfResult * [ T ] = Result [ T , string ]
2023-05-02 11:45:50 +02:00
type ProtectedTopic * = object
topic * : string
key * : secp256k1 . SkPublicKey
2022-11-23 10:08:00 +01:00
2024-02-28 17:19:20 +01:00
type ShardIdx = distinct uint16
2024-02-07 12:42:20 +01:00
2024-03-27 10:08:53 -04:00
type EthRpcUrl * = distinct string
2024-02-16 18:36:31 +05:30
2023-11-09 15:18:39 +05:30
type StartUpCommand * = enum
2024-03-16 00:08:47 +01:00
noCommand # default, runs waku
generateRlnKeystore # generates a new RLN keystore
inspectRlnDb # Inspects a given RLN tree db, providing essential db stats
type WakuNodeConf * = object
configFile * {.
desc : " Loads configuration from a TOML file (cmd-line parameters take precedence) " ,
name : " config-file "
. } : Option [ InputFile ]
## Log configuration
logLevel * {.
desc :
" Sets the log level for process. Supported levels: TRACE, DEBUG, INFO, NOTICE, WARN, ERROR or FATAL " ,
defaultValue : logging . LogLevel . INFO ,
name : " log-level "
. } : logging . LogLevel
logFormat * {.
desc :
" Specifies what kind of logs should be written to stdout. Suported formats: TEXT, JSON " ,
defaultValue : logging . LogFormat . TEXT ,
name : " log-format "
. } : logging . LogFormat
rlnRelayCredPath * {.
desc : " The path for peristing rln-relay credential " ,
defaultValue : " " ,
name : " rln-relay-cred-path "
. } : string
rlnRelayEthClientAddress * {.
desc : " HTTP address of an Ethereum testnet client e.g., http://localhost:8540/ " ,
defaultValue : " http://localhost:8540/ " ,
name : " rln-relay-eth-client-address "
. } : EthRpcUrl
rlnRelayEthContractAddress * {.
desc : " Address of membership contract on an Ethereum testnet " ,
defaultValue : " " ,
name : " rln-relay-eth-contract-address "
. } : string
rlnRelayCredPassword * {.
desc : " Password for encrypting RLN credentials " ,
defaultValue : " " ,
name : " rln-relay-cred-password "
. } : string
rlnRelayEthPrivateKey * {.
desc : " Private key for broadcasting transactions " ,
defaultValue : " " ,
name : " rln-relay-eth-private-key "
. } : string
rlnRelayUserMessageLimit * {.
desc :
" Set a user message limit for the rln membership registration. Must be a positive integer. Default is 1. " ,
defaultValue : 1 ,
name : " rln-relay-user-message-limit "
. } : uint64
rlnEpochSizeSec * {.
desc :
" Epoch size in seconds used to rate limit RLN memberships. Default is 1 second. " ,
defaultValue : 1 ,
name : " rln-relay-epoch-sec "
. } : uint64
maxMessageSize * {.
desc :
" Maximum message size. Accepted units: KiB, KB, and B. e.g. 1024KiB; 1500 B; etc. " ,
defaultValue : DefaultMaxWakuMessageSizeStr ,
name : " max-msg-size "
. } : string
case cmd * {. command , defaultValue : noCommand . } : StartUpCommand
of inspectRlnDb :
# have to change the name here since it counts as a duplicate, within noCommand
treePath * {.
desc : " Path to the RLN merkle tree sled db (https://github.com/spacejam/sled) " ,
2023-11-09 15:18:39 +05:30
defaultValue : " " ,
2024-03-16 00:08:47 +01:00
name : " rln-relay-tree-path "
. } : string
of generateRlnKeystore :
execute * {.
desc : " Runs the registration function on-chain. By default, a dry-run will occur " ,
defaultValue : false ,
name : " execute "
. } : bool
of noCommand :
## Application-level configuration
protectedTopics * {.
desc :
" Topics and its public key to be used for message validation, topic:pubkey. Argument may be repeated. " ,
defaultValue : newSeq [ ProtectedTopic ] ( 0 ) ,
name : " protected-topic "
. } : seq [ ProtectedTopic ]
## General node config
clusterId * {.
desc :
" Cluster id that the node is running in. Node in a different cluster id is disconnected. " ,
defaultValue : 0 ,
name : " cluster-id "
. } : uint32
agentString * {.
defaultValue : " nwaku " ,
desc : " Node agent string which is used as identifier in network " ,
name : " agent-string "
. } : string
nodekey * {. desc : " P2P node private key as 64 char hex string. " , name : " nodekey " . } :
Option [ PrivateKey ]
listenAddress * {.
defaultValue : defaultListenAddress ( ) ,
desc : " Listening address for LibP2P (and Discovery v5, if enabled) traffic. " ,
name : " listen-address "
. } : IpAddress
tcpPort * {. desc : " TCP listening port. " , defaultValue : 60000 , name : " tcp-port " . } :
Port
portsShift * {.
desc : " Add a shift to all port numbers. " , defaultValue : 0 , name : " ports-shift "
. } : uint16
nat * {.
desc :
" Specify method to use for determining public address. " &
" Must be one of: any, none, upnp, pmp, extip:<IP>. " ,
defaultValue : " any "
. } : string
extMultiAddrs * {.
desc :
" External multiaddresses to advertise to the network. Argument may be repeated. " ,
name : " ext-multiaddr "
. } : seq [ string ]
extMultiAddrsOnly * {.
desc : " Only announce external multiaddresses " ,
defaultValue : false ,
name : " ext-multiaddr-only "
. } : bool
maxConnections * {.
desc : " Maximum allowed number of libp2p connections. " ,
defaultValue : 50 ,
name : " max-connections "
. } : uint16
colocationLimit * {.
desc :
" Max num allowed peers from the same IP. Set it to 0 to remove the limitation. " ,
defaultValue : defaultColocationLimit ( ) ,
name : " ip-colocation-limit "
. } : int
maxRelayPeers * {.
desc : " Maximum allowed number of relay peers. " , name : " max-relay-peers "
. } : Option [ int ]
peerStoreCapacity * {.
desc : " Maximum stored peers in the peerstore. " , name : " peer-store-capacity "
. } : Option [ int ]
peerPersistence * {.
desc : " Enable peer persistence. " , defaultValue : false , name : " peer-persistence "
. } : bool
## DNS addrs config
dnsAddrs * {.
desc : " Enable resolution of `dnsaddr`, `dns4` or `dns6` multiaddrs " ,
defaultValue : true ,
name : " dns-addrs "
. } : bool
dnsAddrsNameServers * {.
desc :
" DNS name server IPs to query for DNS multiaddrs resolution. Argument may be repeated. " ,
defaultValue : @ [ parseIpAddress ( " 1.1.1.1 " ) , parseIpAddress ( " 1.0.0.1 " ) ] ,
name : " dns-addrs-name-server "
. } : seq [ IpAddress ]
dns4DomainName * {.
desc : " The domain name resolving to the node ' s public IPv4 address " ,
2023-11-09 15:18:39 +05:30
defaultValue : " " ,
2024-03-16 00:08:47 +01:00
name : " dns4-domain-name "
. } : string
## Relay config
relay * {.
desc : " Enable relay protocol: true|false " , defaultValue : true , name : " relay "
. } : bool
relayPeerExchange * {.
desc : " Enable gossipsub peer exchange in relay protocol: true|false " ,
defaultValue : false ,
name : " relay-peer-exchange "
. } : bool
relayShardedPeerManagement * {.
desc :
" Enable experimental shard aware peer manager for relay protocol: true|false " ,
defaultValue : false ,
name : " relay-shard-manager "
. } : bool
rlnRelay * {.
desc : " Enable spam protection through rln-relay: true|false " ,
defaultValue : false ,
name : " rln-relay "
. } : bool
rlnRelayCredIndex * {.
desc : " the index of the onchain commitment to use " ,
name : " rln-relay-membership-index "
. } : Option [ uint ]
rlnRelayDynamic * {.
desc : " Enable waku-rln-relay with on-chain dynamic group management: true|false " ,
defaultValue : false ,
name : " rln-relay-dynamic "
. } : bool
rlnRelayIdKey * {.
desc : " Rln relay identity secret key as a Hex string " ,
2023-11-09 15:18:39 +05:30
defaultValue : " " ,
2024-03-16 00:08:47 +01:00
name : " rln-relay-id-key "
. } : string
2022-11-23 10:08:00 +01:00
2024-03-16 00:08:47 +01:00
rlnRelayIdCommitmentKey * {.
desc : " Rln relay identity commitment key as a Hex string " ,
2022-10-28 00:05:02 +02:00
defaultValue : " " ,
2024-03-16 00:08:47 +01:00
name : " rln-relay-id-commitment-key "
. } : string
2024-02-28 17:19:20 +01:00
2024-03-16 00:08:47 +01:00
rlnRelayTreePath * {.
desc : " Path to the RLN merkle tree sled db (https://github.com/spacejam/sled) " ,
defaultValue : " " ,
name : " rln-relay-tree-path "
. } : string
rlnRelayBandwidthThreshold * {.
desc : " Message rate in bytes/sec after which verification of proofs should happen " ,
defaultValue : 0 , # to maintain backwards compatibility
name : " rln-relay-bandwidth-threshold "
. } : int
staticnodes * {.
desc : " Peer multiaddr to directly connect with. Argument may be repeated. " ,
name : " staticnode "
. } : seq [ string ]
keepAlive * {.
desc : " Enable keep-alive for idle connections: true|false " ,
defaultValue : false ,
name : " keep-alive "
. } : bool
pubsubTopics * {.
desc : " Default pubsub topic to subscribe to. Argument may be repeated. " ,
name : " pubsub-topic "
. } : seq [ string ]
shards * {.
desc : " Shards index to subscribe to [0..MAX_SHARDS-1]. Argument may be repeated. " ,
defaultValue : @ [ ] ,
name : " shard "
. } : seq [ ShardIdx ]
contentTopics * {.
desc : " Default content topic to subscribe to. Argument may be repeated. " ,
name : " content-topic "
. } : seq [ string ]
## Store and message store config
store * {.
desc : " Enable/disable waku store protocol " , defaultValue : false , name : " store "
. } : bool
storenode * {.
desc : " Peer multiaddress to query for storage " ,
defaultValue : " " ,
name : " storenode "
. } : string
storeMessageRetentionPolicy * {.
desc :
" Message store retention policy. Time retention policy: ' time:<seconds> ' . Capacity retention policy: ' capacity:<count> ' . Size retention policy: ' size:<xMB/xGB> ' . Set to ' none ' to disable. " ,
defaultValue : " time: " & $ 2 . days . seconds ,
name : " store-message-retention-policy "
. } : string
storeMessageDbUrl * {.
desc : " The database connection URL for peristent storage. " ,
defaultValue : " sqlite://store.sqlite3 " ,
name : " store-message-db-url "
. } : string
storeMessageDbVacuum * {.
desc :
" Enable database vacuuming at start. Only supported by SQLite database engine. " ,
defaultValue : false ,
name : " store-message-db-vacuum "
. } : bool
storeMessageDbMigration * {.
desc : " Enable database migration at start. " ,
defaultValue : true ,
name : " store-message-db-migration "
. } : bool
storeMaxNumDbConnections * {.
desc : " Maximum number of simultaneous Postgres connections. " ,
defaultValue : 50 ,
name : " store-max-num-db-connections "
. } : int
## Filter config
filter * {.
desc : " Enable filter protocol: true|false " , defaultValue : false , name : " filter "
. } : bool
filternode * {.
desc : " Peer multiaddr to request content filtering of messages. " ,
defaultValue : " " ,
name : " filternode "
. } : string
filterTimeout * {.
desc :
" Filter clients will be wiped out if not able to receive push messages within this timeout. In seconds. " ,
defaultValue : 14400 , # 4 hours
name : " filter-timeout "
. } : int64
filterSubscriptionTimeout * {.
desc :
" Timeout for filter subscription without ping or refresh it, in seconds. Only for v2 filter protocol. " ,
defaultValue : 300 , # 5 minutes
name : " filter-subscription-timeout "
. } : int64
filterMaxPeersToServe * {.
desc : " Maximum number of peers to serve at a time. Only for v2 filter protocol. " ,
defaultValue : 1000 ,
name : " filter-max-peers-to-serve "
. } : uint32
filterMaxCriteria * {.
desc :
" Maximum number of pubsub- and content topic combination per peers at a time. Only for v2 filter protocol. " ,
defaultValue : 1000 ,
name : " filter-max-criteria "
. } : uint32
## Lightpush config
lightpush * {.
desc : " Enable lightpush protocol: true|false " ,
defaultValue : false ,
name : " lightpush "
. } : bool
lightpushnode * {.
desc : " Peer multiaddr to request lightpush of published messages. " ,
defaultValue : " " ,
name : " lightpushnode "
. } : string
## REST HTTP config
rest * {.
desc : " Enable Waku REST HTTP server: true|false " ,
defaultValue : false ,
name : " rest "
. } : bool
restAddress * {.
desc : " Listening address of the REST HTTP server. " ,
defaultValue : parseIpAddress ( " 127.0.0.1 " ) ,
name : " rest-address "
. } : IpAddress
restPort * {.
desc : " Listening port of the REST HTTP server. " ,
defaultValue : 8645 ,
name : " rest-port "
. } : uint16
restRelayCacheCapacity * {.
desc : " Capacity of the Relay REST API message cache. " ,
defaultValue : 30 ,
name : " rest-relay-cache-capacity "
. } : uint32
restAdmin * {.
desc : " Enable access to REST HTTP Admin API: true|false " ,
defaultValue : false ,
name : " rest-admin "
. } : bool
restPrivate * {.
desc : " Enable access to REST HTTP Private API: true|false " ,
defaultValue : false ,
name : " rest-private "
. } : bool
restAllowOrigin * {.
desc :
" Allow cross-origin requests from the specified origin. " &
" Argument may be repeated. " & " Wildcards: * or ? allowed. " &
" Ex.: \" localhost:* \" or \" 127.0.0.1:8080 \" " ,
defaultValue : newSeq [ string ] ( ) ,
name : " rest-allow-origin "
. } : seq [ string ]
## Metrics config
metricsServer * {.
desc : " Enable the metrics server: true|false " ,
defaultValue : false ,
name : " metrics-server "
. } : bool
metricsServerAddress * {.
desc : " Listening address of the metrics server. " ,
defaultValue : parseIpAddress ( " 127.0.0.1 " ) ,
name : " metrics-server-address "
. } : IpAddress
metricsServerPort * {.
desc : " Listening HTTP port of the metrics server. " ,
defaultValue : 8008 ,
name : " metrics-server-port "
. } : uint16
metricsLogging * {.
desc : " Enable metrics logging: true|false " ,
defaultValue : true ,
name : " metrics-logging "
. } : bool
## DNS discovery config
dnsDiscovery * {.
desc : " Enable discovering nodes via DNS " ,
defaultValue : false ,
name : " dns-discovery "
. } : bool
dnsDiscoveryUrl * {.
desc : " URL for DNS node list in format ' enrtree://<key>@<fqdn> ' " ,
defaultValue : " " ,
name : " dns-discovery-url "
. } : string
dnsDiscoveryNameServers * {.
desc : " DNS name server IPs to query. Argument may be repeated. " ,
defaultValue : @ [ parseIpAddress ( " 1.1.1.1 " ) , parseIpAddress ( " 1.0.0.1 " ) ] ,
name : " dns-discovery-name-server "
. } : seq [ IpAddress ]
## Discovery v5 config
discv5Discovery * {.
desc : " Enable discovering nodes via Node Discovery v5 " ,
defaultValue : false ,
name : " discv5-discovery "
. } : bool
discv5UdpPort * {.
desc : " Listening UDP port for Node Discovery v5. " ,
defaultValue : 9000 ,
name : " discv5-udp-port "
. } : Port
discv5BootstrapNodes * {.
desc :
" Text-encoded ENR for bootstrap node. Used when connecting to the network. Argument may be repeated. " ,
name : " discv5-bootstrap-node "
. } : seq [ string ]
discv5EnrAutoUpdate * {.
desc :
" Discovery can automatically update its ENR with the IP address " &
" and UDP port as seen by other nodes it communicates with. " &
" This option allows to enable/disable this functionality " ,
defaultValue : false ,
name : " discv5-enr-auto-update "
. } : bool
discv5TableIpLimit * {.
hidden ,
desc : " Maximum amount of nodes with the same IP in discv5 routing tables " ,
defaultValue : 10 ,
name : " discv5-table-ip-limit "
. } : uint
discv5BucketIpLimit * {.
hidden ,
desc : " Maximum amount of nodes with the same IP in discv5 routing table buckets " ,
defaultValue : 2 ,
name : " discv5-bucket-ip-limit "
. } : uint
discv5BitsPerHop * {.
hidden ,
desc : " Kademlia ' s b variable, increase for less hops per lookup " ,
2024-02-09 16:31:45 +05:30
defaultValue : 1 ,
2024-03-16 00:08:47 +01:00
name : " discv5-bits-per-hop "
. } : int
## waku peer exchange config
peerExchange * {.
desc : " Enable waku peer exchange protocol (responder side): true|false " ,
defaultValue : false ,
name : " peer-exchange "
. } : bool
peerExchangeNode * {.
desc :
" Peer multiaddr to send peer exchange requests to. (enables peer exchange protocol requester side) " ,
defaultValue : " " ,
name : " peer-exchange-node "
. } : string
## websocket config
websocketSupport * {.
desc : " Enable websocket: true|false " ,
defaultValue : false ,
name : " websocket-support "
. } : bool
websocketPort * {.
desc : " WebSocket listening port. " , defaultValue : 8000 , name : " websocket-port "
. } : Port
websocketSecureSupport * {.
desc : " Enable secure websocket: true|false " ,
defaultValue : false ,
name : " websocket-secure-support "
. } : bool
websocketSecureKeyPath * {.
desc : " Secure websocket key path: ' /path/to/key.txt ' " ,
defaultValue : " " ,
name : " websocket-secure-key-path "
. } : string
websocketSecureCertPath * {.
desc : " Secure websocket Certificate path: ' /path/to/cert.txt ' " ,
defaultValue : " " ,
name : " websocket-secure-cert-path "
. } : string
2021-11-02 10:29:11 +00:00
2024-04-15 15:28:35 +02:00
## Rate limitation config
## Currently default to switch of rate limit until become official
requestRateLimit * {.
desc :
" Number of requests to serve by each service in the specified period. Set it to 0 for unlimited " ,
defaultValue : 0 ,
name : " request-rate-limit "
. } : int
## Currently default to switch of rate limit until become official
requestRatePeriod * {.
desc : " Period of request rate limitation in seconds. Set it to 0 for unlimited " ,
defaultValue : 0 ,
name : " request-rate-period "
. } : int64
2022-12-07 12:30:32 +01:00
## Parsing
2020-05-21 12:16:00 +08:00
# NOTE: Keys are different in nim-libp2p
2022-11-02 14:55:48 +01:00
proc parseCmdArg * ( T : type crypto . PrivateKey , p : string ) : T =
2020-04-29 12:49:27 +08:00
try :
2020-05-26 11:55:53 +08:00
let key = SkPrivateKey . init ( utils . fromHex ( p ) ) . tryGet ( )
2022-11-03 10:45:06 +01:00
crypto . PrivateKey ( scheme : Secp256k1 , skkey : key )
2023-04-04 15:34:53 +02:00
except CatchableError :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid private key " )
2020-04-29 12:49:27 +08:00
2022-11-02 14:55:48 +01:00
proc completeCmdArg * ( T : type crypto . PrivateKey , val : string ) : seq [ string ] =
2020-04-29 12:49:27 +08:00
return @ [ ]
2023-05-02 11:45:50 +02:00
proc parseCmdArg * ( T : type ProtectedTopic , p : string ) : T =
let elements = p . split ( " : " )
if elements . len ! = 2 :
2024-03-16 00:08:47 +01:00
raise newException (
ValueError , " Invalid format for protected topic expected topic:publickey "
)
2023-05-02 11:45:50 +02:00
let publicKey = secp256k1 . SkPublicKey . fromHex ( elements [ 1 ] )
if publicKey . isErr :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid public key " )
2023-05-02 11:45:50 +02:00
return ProtectedTopic ( topic : elements [ 0 ] , key : publicKey . get ( ) )
proc completeCmdArg * ( T : type ProtectedTopic , val : string ) : seq [ string ] =
return @ [ ]
2022-12-07 12:30:32 +01:00
2023-12-14 07:16:39 +01:00
proc parseCmdArg * ( T : type IpAddress , p : string ) : T =
2020-04-29 12:49:27 +08:00
try :
2023-12-14 07:16:39 +01:00
parseIpAddress ( p )
2023-04-04 15:34:53 +02:00
except CatchableError :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid IP address " )
2020-04-29 12:49:27 +08:00
2023-12-14 07:16:39 +01:00
proc completeCmdArg * ( T : type IpAddress , val : string ) : seq [ string ] =
2020-04-29 12:49:27 +08:00
return @ [ ]
2020-07-24 09:39:58 +08:00
2023-12-14 07:16:39 +01:00
proc defaultListenAddress * ( ) : IpAddress =
2022-12-07 12:30:32 +01:00
# TODO: How should we select between IPv4 and IPv6
# Maybe there should be a config option for this.
2023-12-14 07:16:39 +01:00
( static parseIpAddress ( " 0.0.0.0 " ) )
2022-12-07 12:30:32 +01:00
2024-01-02 14:01:18 +01:00
proc defaultColocationLimit * ( ) : int =
return DefaultColocationLimit
2022-11-02 14:55:48 +01:00
proc parseCmdArg * ( T : type Port , p : string ) : T =
2020-07-24 09:39:58 +08:00
try :
2022-11-03 10:45:06 +01:00
Port ( parseInt ( p ) )
2023-04-04 15:34:53 +02:00
except CatchableError :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid Port number " )
2020-07-24 09:39:58 +08:00
2022-11-02 14:55:48 +01:00
proc completeCmdArg * ( T : type Port , val : string ) : seq [ string ] =
2020-07-24 09:39:58 +08:00
return @ [ ]
2023-01-31 17:26:22 +01:00
proc parseCmdArg * ( T : type Option [ int ] , p : string ) : T =
try :
some ( parseInt ( p ) )
2023-04-04 15:34:53 +02:00
except CatchableError :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid number " )
2022-10-26 17:10:30 +02:00
2024-02-07 12:42:20 +01:00
proc completeCmdArg * ( T : type ShardIdx , val : string ) : seq [ ShardIdx ] =
return @ [ ]
proc parseCmdArg * ( T : type ShardIdx , p : string ) : T =
try :
ShardIdx ( parseInt ( p ) )
except CatchableError :
raise newException ( ValueError , " Invalid shard index " )
2023-09-04 15:46:44 +05:30
proc parseCmdArg * ( T : type Option [ uint ] , p : string ) : T =
try :
some ( parseUint ( p ) )
except CatchableError :
2023-09-21 13:12:14 +02:00
raise newException ( ValueError , " Invalid unsigned integer " )
2023-09-04 15:46:44 +05:30
2024-02-16 18:36:31 +05:30
proc completeCmdArg * ( T : type EthRpcUrl , val : string ) : seq [ string ] =
return @ [ ]
proc parseCmdArg * ( T : type EthRpcUrl , s : string ) : T =
## allowed patterns:
## http://url:port
## https://url:port
## http://url:port/path
## https://url:port/path
## http://url/with/path
## http://url:port/path?query
## https://url:port/path?query
## disallowed patterns:
## any valid/invalid ws or wss url
2024-03-16 00:08:47 +01:00
var httpPattern =
2024-04-02 15:14:55 +02:00
re2" ^(https?): \ / \ /([ \ w-]+( \ .[ \ w-]+)*)(:[0-9]{1,5})?( \ /[ \ w.,@?^=%&: \ /~+#-]*)? $ "
2024-03-16 00:08:47 +01:00
var wsPattern =
2024-04-02 15:14:55 +02:00
re2" ^(wss?): \ / \ /([ \ w-]+( \ .[ \ w-]+)+)(:[0-9]{1,5})?( \ /[ \ w.,@?^=%&: \ /~+#-]*)? $ "
2024-02-16 18:36:31 +05:30
if regex . match ( s , wsPattern ) :
2024-03-16 00:08:47 +01:00
raise newException (
ValueError , " Websocket RPC URL is not supported, Please use an HTTP URL "
)
2024-02-16 18:36:31 +05:30
if not regex . match ( s , httpPattern ) :
raise newException ( ValueError , " Invalid HTTP RPC URL " )
return EthRpcUrl ( s )
2022-11-03 10:45:06 +01:00
## Load
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var TomlReader , value : var crypto . PrivateKey
) {. raises : [ SerializationError ] . } =
2022-11-23 10:08:00 +01:00
try :
2022-11-03 10:45:06 +01:00
value = parseCmdArg ( crypto . PrivateKey , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var EnvvarReader , value : var crypto . PrivateKey
) {. raises : [ SerializationError ] . } =
2022-11-23 10:08:00 +01:00
try :
2022-11-03 17:58:48 +01:00
value = parseCmdArg ( crypto . PrivateKey , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var TomlReader , value : var ProtectedTopic
) {. raises : [ SerializationError ] . } =
2023-05-02 11:45:50 +02:00
try :
value = parseCmdArg ( ProtectedTopic , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var EnvvarReader , value : var ProtectedTopic
) {. raises : [ SerializationError ] . } =
2023-05-02 11:45:50 +02:00
try :
value = parseCmdArg ( ProtectedTopic , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2022-11-03 10:45:06 +01:00
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var TomlReader , value : var ShardIdx
) {. raises : [ SerializationError ] . } =
2024-02-07 12:42:20 +01:00
try :
value = parseCmdArg ( ShardIdx , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var EnvvarReader , value : var ShardIdx
) {. raises : [ SerializationError ] . } =
2024-02-07 12:42:20 +01:00
try :
value = parseCmdArg ( ShardIdx , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var TomlReader , value : var EthRpcUrl
) {. raises : [ SerializationError ] . } =
2024-02-16 18:36:31 +05:30
try :
value = parseCmdArg ( EthRpcUrl , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2024-03-16 00:08:47 +01:00
proc readValue * (
r : var EnvvarReader , value : var EthRpcUrl
) {. raises : [ SerializationError ] . } =
2024-02-16 18:36:31 +05:30
try :
value = parseCmdArg ( EthRpcUrl , r . readValue ( string ) )
except CatchableError :
raise newException ( SerializationError , getCurrentExceptionMsg ( ) )
2022-11-03 10:45:06 +01:00
{. push warning [ ProveInit ] : off . }
2024-03-16 00:08:47 +01:00
proc load * ( T : type WakuNodeConf , version = " " ) : ConfResult [ T ] =
2022-11-03 10:45:06 +01:00
try :
let conf = WakuNodeConf . load (
2024-03-16 00:08:47 +01:00
version = version ,
secondarySources = proc (
conf : WakuNodeConf , sources : auto
) {. gcsafe , raises : [ ConfigurationError ] . } =
2022-11-03 17:58:48 +01:00
sources . addConfigFile ( Envvar , InputFile ( " wakunode2 " ) )
2022-11-03 10:45:06 +01:00
if conf . configFile . isSome ( ) :
sources . addConfigFile ( Toml , conf . configFile . get ( ) )
2024-03-16 00:08:47 +01:00
,
2022-11-03 10:45:06 +01:00
)
ok ( conf )
except CatchableError :
err ( getCurrentExceptionMsg ( ) )
2022-11-23 10:08:00 +01:00
{. pop . }