2021-03-26 07:52:01 +01:00
# beacon_chain
2022-02-04 11:59:40 +00:00
# Copyright (c) 2018-2022 Status Research & Development GmbH
2021-03-26 07:52:01 +01:00
# Licensed and distributed under either of
# * MIT license (license terms in the root directory or at https://opensource.org/licenses/MIT).
# * Apache v2 license (license terms in the root directory or at https://www.apache.org/licenses/LICENSE-2.0).
# at your option. This file may not be copied, modified, or distributed except according to those terms.
2020-04-22 07:53:02 +02:00
{. push raises : [ Defect ] . }
2018-11-24 01:58:49 +02:00
import
2021-12-22 14:37:31 +02:00
std / [ strutils , os , options , unicode , uri ] ,
2022-02-11 21:40:49 +01:00
metrics ,
2021-05-19 09:38:13 +03:00
2020-07-02 18:14:11 +03:00
chronicles , chronicles / options as chroniclesOptions ,
2022-03-05 04:33:15 +02:00
confutils , confutils / defs , confutils / std / net ,
confutils / toml / defs as confTomlDefs ,
confutils / toml / std / net as confTomlNet ,
confutils / toml / std / uri as confTomlUri ,
serialization / errors , stew / shims / net as stewNet ,
2021-05-19 09:38:13 +03:00
stew / [ io2 , byteutils ] , unicodedb / properties , normalize ,
2021-02-16 21:35:10 +01:00
eth / common / eth_types as commonEthTypes , eth / net / nat ,
2020-11-25 00:23:28 +01:00
eth / p2p / discoveryv5 / enr ,
2020-07-17 23:59:50 +03:00
json_serialization , web3 / [ ethtypes , confutils_defs ] ,
2021-05-19 09:38:13 +03:00
2022-03-05 04:33:15 +02:00
. / spec / [ keystore , network , crypto ] ,
2021-06-21 08:35:24 +00:00
. / spec / datatypes / base ,
2021-03-05 14:12:00 +01:00
. / networking / network_metadata ,
2021-05-19 09:38:13 +03:00
. / validators / slashing_protection_common ,
. / filepath
2018-12-19 14:58:53 +02:00
2022-03-11 21:28:10 +01:00
from consensus_object_pools / block_pools_types_light_client
import ImportLightClientData
2018-12-19 14:58:53 +02:00
export
2022-02-11 21:40:49 +01:00
uri , nat , enr ,
2020-10-01 22:08:59 +03:00
defaultEth2TcpPort , enabledLogLevel , ValidIpAddress ,
2021-12-22 14:37:31 +02:00
defs , parseCmdArg , completeCmdArg , network_metadata ,
2022-03-05 04:33:15 +02:00
network , BlockHashOrNumber ,
confTomlDefs , confTomlNet , confTomlUri
2022-02-11 21:40:49 +01:00
declareGauge network_name , " network name " , [ " name " ]
2019-03-26 21:44:51 +02:00
2021-04-01 14:28:57 +02:00
const
# TODO: How should we select between IPv4 and IPv6
# Maybe there should be a config option for this.
defaultListenAddress * = ( static ValidIpAddress . init ( " 0.0.0.0 " ) )
defaultAdminListenAddress * = ( static ValidIpAddress . init ( " 127.0.0.1 " ) )
2021-11-30 03:20:21 +02:00
defaultSigningNodeRequestTimeout * = 60
2021-04-01 14:28:57 +02:00
2022-02-27 13:02:45 +02:00
when defined ( windows ) :
{. pragma : windowsOnly . }
2022-03-14 10:19:50 +01:00
{. pragma : posixOnly , hidden . }
2022-02-27 13:02:45 +02:00
else :
{. pragma : windowsOnly , hidden . }
2022-03-14 10:19:50 +01:00
{. pragma : posixOnly . }
2022-02-27 13:02:45 +02:00
2018-11-24 01:58:49 +02:00
type
2022-01-17 10:27:08 +01:00
BNStartUpCmd * {. pure . } = enum
2018-12-19 14:58:53 +02:00
noCommand
2019-03-26 12:01:13 +02:00
createTestnet
2020-06-16 01:20:31 +03:00
deposits
2020-06-23 22:11:07 +03:00
wallets
2020-11-25 00:23:28 +01:00
record
2020-12-04 18:28:42 +02:00
web3
2021-05-19 09:38:13 +03:00
slashingdb
2022-01-17 10:27:08 +01:00
trustedNodeSync
2020-06-16 01:20:31 +03:00
2020-06-23 22:11:07 +03:00
WalletsCmd * {. pure . } = enum
create = " Creates a new EIP-2386 wallet "
restore = " Restores a wallet from cold storage "
list = " Lists details about all wallets "
2020-06-16 01:20:31 +03:00
2020-06-23 22:11:07 +03:00
DepositsCmd * {. pure . } = enum
2021-04-08 14:35:58 +03:00
createTestnetDeposits = " Creates validator keystores and deposits for testnet usage "
2020-08-02 20:26:57 +03:00
` import ` = " Imports password-protected keystores interactively "
2020-11-27 21:48:33 +02:00
# status = "Displays status information about all deposits"
exit = " Submits a validator voluntary exit "
2019-11-01 11:53:06 +02:00
2021-11-30 03:20:21 +02:00
SNStartUpCmd * = enum
SNNoCommand
2020-11-25 00:23:28 +01:00
RecordCmd * {. pure . } = enum
create = " Create a new ENR "
print = " Print the content of a given ENR "
2020-12-04 18:28:42 +02:00
Web3Cmd * {. pure . } = enum
test = " Test a web3 provider "
2021-02-19 20:39:18 +02:00
SlashingDbKind * {. pure . } = enum
v1
v2
both
2021-11-02 18:06:36 +01:00
StdoutLogKind * {. pure . } = enum
Auto = " auto "
Colors = " colors "
NoColors = " nocolors "
Json = " json "
None = " none "
2021-05-19 09:38:13 +03:00
SlashProtCmd * = enum
` import ` = " Import a EIP-3076 slashing protection interchange file "
` export ` = " Export a EIP-3076 slashing protection interchange file "
# migrateAll = "Export and remove the whole validator slashing protection DB."
# migrate = "Export and remove specified validators from Nimbus."
2018-11-29 03:08:34 +02:00
BeaconNodeConf * = object
2022-03-05 04:33:15 +02:00
configFile * {.
desc : " Loads the configuration from a TOML file "
name : " config-file " } : Option [ InputFile ]
2019-01-17 01:01:15 +02:00
logLevel * {.
2021-05-19 09:38:13 +03:00
desc : " Sets the log level for process and topics (e.g. \" DEBUG; TRACE:discv5,libp2p; REQUIRED:none; DISABLED:none \" ) "
2020-11-09 10:12:48 +02:00
defaultValue : " INFO "
2020-04-28 01:39:04 +03:00
name : " log-level " } : string
2019-03-18 05:54:08 +02:00
2021-11-02 18:06:36 +01:00
logStdout * {.
2021-11-10 11:02:18 +02:00
hidden
2021-11-02 18:06:36 +01:00
desc : " Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json) "
defaultValueDesc : " auto "
defaultValue : StdoutLogKind . Auto
2021-11-10 11:02:18 +02:00
name : " log-format " } : StdoutLogKind
2021-11-02 18:06:36 +01:00
2020-07-15 16:15:55 +03:00
logFile * {.
2021-11-10 11:02:18 +02:00
desc : " Specifies a path for the written Json log file (deprecated) "
2020-07-15 16:15:55 +03:00
name : " log-file " } : Option [ OutFile ]
2020-07-02 18:14:11 +03:00
eth2Network * {.
2021-05-19 09:38:13 +03:00
desc : " The Eth2 network to join "
defaultValueDesc : " mainnet "
2020-07-02 18:14:11 +03:00
name : " network " } : Option [ string ]
2019-03-19 19:22:17 +02:00
dataDir * {.
2020-06-23 22:11:07 +03:00
desc : " The directory where nimbus will store all blockchain data "
2021-05-19 09:38:13 +03:00
defaultValue : config . defaultDataDir ( )
defaultValueDesc : " "
2019-11-11 14:43:12 +00:00
abbr : " d "
name : " data-dir " } : OutDir
2019-01-17 01:01:15 +02:00
2020-08-01 21:32:41 +03:00
validatorsDirFlag * {.
desc : " A directory containing validator keystores "
name : " validators-dir " } : Option [ InputDir ]
2020-08-02 20:26:57 +03:00
secretsDirFlag * {.
desc : " A directory containing validator keystore passwords "
name : " secrets-dir " } : Option [ InputDir ]
2020-07-17 23:59:50 +03:00
walletsDirFlag * {.
desc : " A directory containing wallet files "
name : " wallets-dir " } : Option [ InputDir ]
2021-04-07 00:42:59 +03:00
web3Urls * {.
2021-05-02 20:31:49 +05:30
desc : " One or more Web3 provider URLs used for obtaining deposit contract data "
2021-04-07 00:42:59 +03:00
name : " web3-url " } : seq [ string ]
2019-09-01 17:02:49 +02:00
2021-11-25 18:51:51 +02:00
web3ForcePolling * {.
hidden
defaultValue : false
desc : " Force the use of polling when determining the head block of Eth1 "
name : " web3-force-polling " } : bool
2020-06-01 22:48:20 +03:00
nonInteractive * {.
2020-06-23 22:11:07 +03:00
desc : " Do not display interative prompts. Quit on missing configuration "
2020-06-01 22:48:20 +03:00
name : " non-interactive " } : bool
2020-08-25 15:49:05 +03:00
netKeyFile * {.
desc : " Source of network (secp256k1) private key file " &
2021-05-19 09:38:13 +03:00
" (random|<path>) "
defaultValue : " random " ,
2020-08-25 15:49:05 +03:00
name : " netkey-file " } : string
netKeyInsecurePassword * {.
2021-05-19 09:38:13 +03:00
desc : " Use pre-generated INSECURE password for network private key file "
2020-08-25 15:49:05 +03:00
defaultValue : false ,
name : " insecure-netkey-password " } : bool
2020-11-28 09:00:36 +02:00
agentString * {.
defaultValue : " nimbus " ,
desc : " Node agent string which is used as identifier in network "
name : " agent-string " } : string
2022-01-24 20:40:59 +00:00
subscribeAllSubnets * {.
defaultValue : false ,
2022-02-04 12:34:03 +00:00
desc : " Subscribe to all subnet topics when gossiping "
2021-01-12 13:43:15 +01:00
name : " subscribe-all-subnets " } : bool
2021-02-19 20:39:18 +02:00
slashingDbKind * {.
2021-02-19 16:18:17 +01:00
hidden
2021-04-05 01:55:17 +03:00
defaultValue : SlashingDbKind . v2
2021-05-19 09:38:13 +03:00
desc : " The slashing DB flavour to use "
2021-02-19 20:39:18 +02:00
name : " slashing-db-kind " } : SlashingDbKind
2021-02-19 16:18:17 +01:00
2021-09-17 02:13:52 +02:00
numThreads * {.
2022-03-19 08:59:10 +01:00
defaultValue : 0 ,
desc : " Number of worker threads ( \" 0 \" = use as many threads as there are CPU cores available) "
2021-09-17 02:13:52 +02:00
name : " num-threads " } : int
2018-12-19 14:58:53 +02:00
case cmd * {.
command
2022-01-17 10:27:08 +01:00
defaultValue : BNStartUpCmd . noCommand } : BNStartUpCmd
2018-12-19 14:58:53 +02:00
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . noCommand :
2022-02-27 13:02:45 +02:00
runAsServiceFlag * {.
windowsOnly
defaultValue : false ,
desc : " Run as a Windows service "
name : " run-as-service " } : bool
2018-12-19 14:58:53 +02:00
bootstrapNodes * {.
2020-06-23 22:11:07 +03:00
desc : " Specifies one or more bootstrap nodes to use when connecting to the network "
2019-11-11 14:43:12 +00:00
abbr : " b "
name : " bootstrap-node " } : seq [ string ]
2018-11-24 01:58:49 +02:00
2018-12-19 14:58:53 +02:00
bootstrapNodesFile * {.
2020-06-23 22:11:07 +03:00
desc : " Specifies a line-delimited file of bootstrap Ethereum network addresses "
2021-05-19 09:38:13 +03:00
defaultValue : " "
2019-11-11 14:43:12 +00:00
name : " bootstrap-file " } : InputFile
2018-11-24 01:58:49 +02:00
2020-09-27 22:00:24 +02:00
listenAddress * {.
2021-05-19 09:38:13 +03:00
desc : " Listening address for the Ethereum LibP2P and Discovery v5 traffic "
2021-04-01 14:28:57 +02:00
defaultValue : defaultListenAddress
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 0.0.0.0 "
2020-06-05 18:08:50 +03:00
name : " listen-address " } : ValidIpAddress
2020-03-18 21:36:22 +02:00
2018-12-19 14:58:53 +02:00
tcpPort * {.
2021-05-19 09:38:13 +03:00
desc : " Listening TCP port for Ethereum LibP2P traffic "
2020-03-17 00:28:54 +02:00
defaultValue : defaultEth2TcpPort
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 9000 "
2020-03-17 00:28:54 +02:00
name : " tcp-port " } : Port
2018-11-24 01:58:49 +02:00
2018-12-19 14:58:53 +02:00
udpPort * {.
2021-05-19 09:38:13 +03:00
desc : " Listening UDP port for node discovery "
2020-03-17 00:28:54 +02:00
defaultValue : defaultEth2TcpPort
2021-06-10 11:42:40 +03:00
defaultValueDesc : " 9000 "
2020-03-17 00:28:54 +02:00
name : " udp-port " } : Port
2018-11-24 01:58:49 +02:00
2019-12-18 03:11:20 +02:00
maxPeers * {.
2022-03-11 11:51:53 +01:00
desc : " The target number of peers to connect to "
2020-11-29 14:43:41 +01:00
defaultValue : 160 # 5 (fanout) * 64 (subnets) / 2 (subs) for a heathy mesh
2019-12-18 03:11:20 +02:00
name : " max-peers " } : int
2022-03-11 11:51:53 +01:00
hardMaxPeers * {.
desc : " The maximum number of peers to connect to. Defaults to maxPeers * 1.5 "
name : " hard-max-peers " } : Option [ int ]
2019-03-18 21:57:19 -06:00
nat * {.
2019-10-29 01:04:52 +02:00
desc : " Specify method to use for determining public address. " &
2020-06-23 22:11:07 +03:00
" Must be one of: any, none, upnp, pmp, extip:<IP> "
2021-02-16 21:35:10 +01:00
defaultValue : NatConfig ( hasExtIp : false , nat : NatAny )
2021-05-19 09:38:13 +03:00
defaultValueDesc : " any "
2021-02-16 21:35:10 +01:00
name : " nat " . } : NatConfig
2019-03-18 21:57:19 -06:00
2021-02-02 09:07:21 +01:00
enrAutoUpdate * {.
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 "
2021-05-19 09:38:13 +03:00
defaultValue : false
2021-02-02 09:07:21 +01:00
name : " enr-auto-update " . } : bool
2020-09-22 23:42:42 +03:00
weakSubjectivityCheckpoint * {.
desc : " Weak subjectivity checkpoint in the format block_root:epoch_number "
2020-10-06 18:32:17 +03:00
name : " weak-subjectivity-checkpoint " } : Option [ Checkpoint ]
2018-12-19 14:58:53 +02:00
2020-09-22 23:42:42 +03:00
finalizedCheckpointState * {.
desc : " SSZ file specifying a recent finalized state "
name : " finalized-checkpoint-state " } : Option [ InputFile ]
finalizedCheckpointBlock * {.
desc : " SSZ file specifying a recent finalized block "
name : " finalized-checkpoint-block " } : Option [ InputFile ]
2020-07-02 18:52:48 +03:00
2019-10-29 01:04:52 +02:00
nodeName * {.
2019-03-22 16:35:20 +02:00
desc : " A name for this node that will appear in the logs. " &
2020-06-23 22:11:07 +03:00
" If you set this to ' auto ' , a persistent automatically generated ID will be selected for each --data-dir folder "
2021-05-19 09:38:13 +03:00
defaultValue : " "
2019-11-11 14:43:12 +00:00
name : " node-name " } : string
2019-03-22 16:35:20 +02:00
2020-06-29 20:30:19 +03:00
graffiti * {.
desc : " The graffiti value that will appear in proposed blocks. " &
2020-11-09 10:12:48 +02:00
" You can use a 0x-prefixed hex encoded string to specify raw bytes "
2020-06-29 20:30:19 +03:00
name : " graffiti " } : Option [ GraffitiBytes ]
2020-02-17 19:24:14 +01:00
verifyFinalization * {.
2022-02-04 12:34:03 +00:00
hidden
desc : " Specify whether to verify finalization occurs on schedule (debug only) "
2021-05-19 09:38:13 +03:00
defaultValue : false
2020-02-17 19:24:14 +01:00
name : " verify-finalization " } : bool
2020-02-17 22:22:50 +01:00
stopAtEpoch * {.
2022-03-04 18:38:01 +01:00
hidden
desc : " The wall-time epoch at which to exit the program. (for testing purposes) "
2021-05-19 09:38:13 +03:00
defaultValue : 0
2020-02-17 22:22:50 +01:00
name : " stop-at-epoch " } : uint64
2020-02-17 19:24:14 +01:00
2022-03-04 18:38:01 +01:00
stopAtSyncedEpoch * {.
hidden
desc : " The synced epoch at which to exit the program. (for testing purposes) "
defaultValue : 0
name : " stop-at-synced-epoch " } : uint64
2020-03-17 00:28:54 +02:00
metricsEnabled * {.
2021-05-19 09:38:13 +03:00
desc : " Enable the metrics server "
2019-10-29 01:04:52 +02:00
defaultValue : false
2020-03-17 00:28:54 +02:00
name : " metrics " } : bool
2019-09-07 13:48:05 -04:00
2020-03-17 00:28:54 +02:00
metricsAddress * {.
2021-05-19 09:38:13 +03:00
desc : " Listening address of the metrics server "
2021-04-01 14:28:57 +02:00
defaultValue : defaultAdminListenAddress
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 127.0.0.1 "
2020-06-05 18:08:50 +03:00
name : " metrics-address " } : ValidIpAddress
2019-09-07 13:48:05 -04:00
2020-03-17 00:28:54 +02:00
metricsPort * {.
2021-05-19 09:38:13 +03:00
desc : " Listening HTTP port of the metrics server "
2019-10-29 01:04:52 +02:00
defaultValue : 8008
2020-03-17 00:28:54 +02:00
name : " metrics-port " } : Port
2019-09-07 13:48:05 -04:00
2020-03-18 21:36:22 +02:00
statusBarEnabled * {.
2022-03-14 10:19:50 +01:00
posixOnly
2020-06-23 22:11:07 +03:00
desc : " Display a status bar at the bottom of the terminal screen "
2021-05-19 09:38:13 +03:00
defaultValue : true
2020-03-18 21:36:22 +02:00
name : " status-bar " } : bool
statusBarContents * {.
2022-03-14 10:19:50 +01:00
posixOnly
2021-05-19 09:38:13 +03:00
desc : " Textual template for the contents of the status bar "
2020-06-08 18:04:11 +02:00
defaultValue : " peers: $connected_peers ; " &
" finalized: $finalized_root : $finalized_epoch ; " &
" head: $head_root : $head_epoch : $head_epoch_slot ; " &
2020-09-11 15:46:01 +03:00
" time: $epoch : $epoch_slot ( $slot ); " &
2020-11-28 20:53:51 +02:00
" sync: $sync_status | " &
" ETH: $attached_validators_balance "
2021-05-19 09:38:13 +03:00
defaultValueDesc : " "
2020-03-18 21:36:22 +02:00
name : " status-bar-contents " } : string
rpcEnabled * {.
2022-03-07 15:42:20 +02:00
desc : " Enable the JSON-RPC server (deprecated) "
2020-03-18 21:36:22 +02:00
defaultValue : false
name : " rpc " } : bool
rpcPort * {.
2021-05-19 09:38:13 +03:00
desc : " HTTP port for the JSON-RPC service "
2020-03-18 21:36:22 +02:00
defaultValue : defaultEth2RpcPort
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 9190 "
2020-03-18 21:36:22 +02:00
name : " rpc-port " } : Port
rpcAddress * {.
2021-05-19 09:38:13 +03:00
desc : " Listening address of the RPC server "
2021-04-01 14:28:57 +02:00
defaultValue : defaultAdminListenAddress
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 127.0.0.1 "
2020-06-05 18:08:50 +03:00
name : " rpc-address " } : ValidIpAddress
2020-03-18 21:36:22 +02:00
2021-03-17 20:46:45 +02:00
restEnabled * {.
2021-10-21 11:24:22 +03:00
desc : " Enable the REST server "
2021-03-17 20:46:45 +02:00
defaultValue : false
name : " rest " } : bool
restPort * {.
2021-10-21 11:24:22 +03:00
desc : " Port for the REST server "
2021-03-29 13:59:39 +03:00
defaultValue : DefaultEth2RestPort
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 5052 "
2021-03-17 20:46:45 +02:00
name : " rest-port " } : Port
restAddress * {.
2021-10-21 11:24:22 +03:00
desc : " Listening address of the REST server "
2021-04-03 04:50:47 +03:00
defaultValue : defaultAdminListenAddress
2021-05-19 09:38:13 +03:00
defaultValueDesc : " 127.0.0.1 "
2021-03-17 20:46:45 +02:00
name : " rest-address " } : ValidIpAddress
2022-02-12 00:33:30 +02:00
restAllowedOrigin * {.
desc : " Limit the access to the REST API to a particular hostname " &
" (for CORS-enabled clients such as browsers) "
name : " rest-allow-origin " } : Option [ string ]
2022-01-05 16:49:10 +02:00
restCacheSize * {.
defaultValue : 3
desc : " The maximum number of recently accessed states that are kept in " &
" memory. Speeds up requests obtaining information for consecutive " &
" slots or epochs. "
name : " rest-statecache-size " } : Natural
restCacheTtl * {.
defaultValue : 60
desc : " The number of seconds to keep recently accessed states in memory "
name : " rest-statecache-ttl " } : Natural
2022-01-27 18:41:05 +02:00
restRequestTimeout * {.
defaultValue : 0
defaultValueDesc : " infinite "
desc : " The number of seconds to wait until complete REST request " &
" will be received "
name : " rest-request-timeout " } : Natural
restMaxRequestBodySize * {.
defaultValue : 16_384
desc : " Maximum size of REST request body (kilobytes) "
name : " rest-max-body-size " } : Natural
restMaxRequestHeadersSize * {.
defaultValue : 64
desc : " Maximum size of REST request headers (kilobytes) "
name : " rest-max-headers-size " } : Natural
2021-12-22 14:37:31 +02:00
keymanagerEnabled * {.
desc : " Enable the REST keymanager API (BETA version) "
defaultValue : false
name : " keymanager " } : bool
keymanagerPort * {.
desc : " Listening port for the REST keymanager API "
defaultValue : DefaultEth2RestPort
defaultValueDesc : " 5052 "
name : " keymanager-port " } : Port
keymanagerAddress * {.
desc : " Listening port for the REST keymanager API "
defaultValue : defaultAdminListenAddress
defaultValueDesc : " 127.0.0.1 "
name : " keymanager-address " } : ValidIpAddress
2022-02-12 00:33:30 +02:00
keymanagerAllowedOrigin * {.
desc : " Limit the access to the Keymanager API to a particular hostname " &
" (for CORS-enabled clients such as browsers) "
name : " keymanager-allow-origin " } : Option [ string ]
2021-12-22 14:37:31 +02:00
keymanagerTokenFile * {.
2022-02-27 16:55:02 +00:00
desc : " A file specifying the authorization token required for accessing the keymanager API "
2021-12-22 14:37:31 +02:00
name : " keymanager-token-file " } : Option [ InputFile ]
2021-10-04 22:08:31 +03:00
2022-03-11 21:28:10 +01:00
serveLightClientData * {.
hidden
desc : " BETA: Serve data for enabling light clients to stay in sync with the network "
2022-04-01 23:58:06 +02:00
name : " serve-light-client-data " } : Option [ bool ]
2022-03-11 21:28:10 +01:00
importLightClientData * {.
hidden
desc : " BETA: Which classes of light client data to import. " &
" Must be one of: none, only-new, full (slow startup), on-demand (may miss validator duties) "
2022-04-01 23:58:06 +02:00
name : " import-light-client-data " } : Option [ ImportLightClientData ]
2022-03-11 21:28:10 +01:00
2020-09-01 16:44:40 +03:00
inProcessValidators * {.
desc : " Disable the push model (the beacon node tells a signing process with the private keys of the validators what to sign and when) and load the validators in the beacon node itself "
2021-05-19 09:38:13 +03:00
defaultValue : true # the use of the nimbus_signing_process binary by default will be delayed until async I/O over stdin/stdout is developed for the child process.
2020-09-01 16:44:40 +03:00
name : " in-process-validators " } : bool
2020-08-24 13:52:06 +02:00
discv5Enabled * {.
2021-05-19 09:38:13 +03:00
desc : " Enable Discovery v5 "
2020-08-24 13:52:06 +02:00
defaultValue : true
name : " discv5 " } : bool
2020-03-18 21:36:22 +02:00
dumpEnabled * {.
2021-05-19 09:38:13 +03:00
desc : " Write SSZ dumps of blocks, attestations and states to data dir "
2019-12-03 12:32:27 +01:00
defaultValue : false
2020-03-18 21:36:22 +02:00
name : " dump " } : bool
2019-12-03 12:32:27 +01:00
2021-03-23 15:10:17 +09:00
directPeers * {.
desc : " The list of priviledged, secure and known peers to connect and maintain the connection to, this requires a not random netkey-file. In the complete multiaddress format like: /ip4/<address>/tcp/<port>/p2p/<peerId-public-key>. Peering agreements are established out of band and must be reciprocal. "
name : " direct-peer " . } : seq [ string ]
2021-02-01 12:18:16 +01:00
doppelgangerDetection * {.
2021-06-03 11:20:42 +02:00
desc : " If enabled, the beacon node prudently listens for 2 epochs for attestations from a validator with the same index (a doppelganger), before sending an attestation itself. This protects against slashing (due to double-voting) but means you will miss two attestations when restarting. "
2021-02-03 18:11:42 +01:00
defaultValue : true
2021-02-01 12:18:16 +01:00
name : " doppelganger-detection "
2021-02-03 18:11:42 +01:00
} : bool
2020-10-27 18:21:35 +01:00
2021-11-18 20:35:26 +01:00
syncHorizon * {.
hidden
desc : " Number of empty slots to process before considering the client out of sync "
defaultValue : MaxEmptySlotCount
defaultValueDesc : " 50 "
name : " sync-horizon " } : uint64
2021-12-13 15:45:48 +00:00
# https://github.com/ethereum/consensus-specs/blob/v1.1.6/specs/merge/client-settings.md#override-terminal-total-difficulty
2022-01-03 12:22:56 +00:00
# TODO nim-confutils on 32-bit platforms overflows decoding integers
# requiring 64-bit representations and doesn't build when specifying
# UInt256 directly, so pass this through for decoding elsewhere.
2021-11-25 10:53:31 +00:00
terminalTotalDifficultyOverride * {.
hidden
desc : " Override pre-configured TERMINAL_TOTAL_DIFFICULTY parameter "
name : " terminal-total-difficulty-override "
2022-01-03 12:22:56 +00:00
} : Option [ string ]
2021-11-25 10:53:31 +00:00
2021-12-20 20:20:31 +01:00
validatorMonitorAuto * {.
desc : " Automatically monitor locally active validators (BETA) "
defaultValue : false
name : " validator-monitor-auto " } : bool
validatorMonitorPubkeys * {.
desc : " One or more validators to monitor - works best when --subscribe-all-subnets is enabled (BETA) "
name : " validator-monitor-pubkey " } : seq [ ValidatorPubKey ]
validatorMonitorTotals * {.
desc : " Publish metrics to single ' totals ' label for better collection performance when monitoring many validators (BETA) "
defaultValue : false
name : " validator-monitor-totals " } : bool
2022-02-04 11:59:40 +00:00
proposerBoosting * {.
hidden
2022-03-31 16:43:05 +02:00
desc : " Enable proposer boosting; temporary option feature gate (debugging; option may be removed without warning) " ,
2022-02-04 11:59:40 +00:00
defaultValue : false
name : " proposer-boosting-debug " } : bool
2022-03-31 16:43:05 +02:00
useJwt * {.
hidden
desc : " Enable JWT authentication headers; temporary option feature gate (debugging; option may be remove without warning) " ,
defaultValue : false
name : " use-jwt-debug " } : bool
2022-03-18 11:46:39 +00:00
# https://github.com/ethereum/consensus-specs/blob/v1.1.10/sync/optimistic.md#fork-choice-poisoning
2022-02-15 13:54:37 +00:00
safeSlotsToImportOptimistically * {.
hidden
desc : " Modify SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY "
2022-03-18 11:46:39 +00:00
# https://github.com/ethereum/consensus-specs/blob/v1.1.10/sync/optimistic.md#constants
2022-02-15 13:54:37 +00:00
defaultValue : 128
name : " safe-slots-to-import-optimistically " } : uint64
2022-03-18 11:46:39 +00:00
# https://github.com/ethereum/execution-apis/blob/v1.0.0-alpha.8/src/engine/authentication.md#key-distribution
2022-02-27 16:55:02 +00:00
jwtSecret * {.
hidden
desc : " A file containing the hex-encoded 256 bit secret key to be used for verifying/generating jwt tokens "
name : " jwt-secret " . } : Option [ string ]
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . createTestnet :
2020-07-17 23:59:50 +03:00
testnetDepositsFile * {.
desc : " A LaunchPad deposits file for the genesis state validators "
name : " deposits-file " } : InputFile
2019-03-07 07:59:28 -06:00
2019-03-27 14:06:06 +02:00
totalValidators * {.
2020-06-23 22:11:07 +03:00
desc : " The number of validator deposits in the newly created chain "
2019-11-11 14:43:12 +00:00
name : " total-validators " } : uint64
2019-03-07 07:59:28 -06:00
2019-03-19 19:22:17 +02:00
bootstrapAddress * {.
2020-06-23 22:11:07 +03:00
desc : " The public IP address that will be advertised as a bootstrap node for the testnet "
2021-05-19 09:38:13 +03:00
defaultValue : init ( ValidIpAddress , " 127.0.0.1 " )
defaultValueDesc : " 127.0.0.1 "
2020-06-05 18:08:50 +03:00
name : " bootstrap-address " } : ValidIpAddress
2019-03-19 19:22:17 +02:00
bootstrapPort * {.
2020-06-23 22:11:07 +03:00
desc : " The TCP/UDP port that will be used by the bootstrap node "
2021-05-19 09:38:13 +03:00
defaultValue : defaultEth2TcpPort
defaultValueDesc : " 9000 "
2020-03-17 00:28:54 +02:00
name : " bootstrap-port " } : Port
2018-12-19 14:58:53 +02:00
2019-02-15 10:33:32 -06:00
genesisOffset * {.
2020-06-23 22:11:07 +03:00
desc : " Seconds from now to add to genesis time "
2021-05-19 09:38:13 +03:00
defaultValue : 5
2019-11-11 14:43:12 +00:00
name : " genesis-offset " } : int
2019-02-15 10:33:32 -06:00
2019-03-19 19:22:17 +02:00
outputGenesis * {.
2020-06-23 22:11:07 +03:00
desc : " Output file where to write the initial state snapshot "
2019-11-11 14:43:12 +00:00
name : " output-genesis " } : OutFile
2019-03-18 05:54:08 +02:00
2019-10-29 01:04:52 +02:00
outputBootstrapFile * {.
2020-06-23 22:11:07 +03:00
desc : " Output file with list of bootstrap nodes for the network "
2019-11-11 14:43:12 +00:00
name : " output-bootstrap-file " } : OutFile
2019-09-10 18:13:27 -04:00
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . wallets :
2020-06-23 22:11:07 +03:00
case walletsCmd * {. command . } : WalletsCmd
of WalletsCmd . create :
nextAccount * {.
desc : " Initial value for the ' nextaccount ' property of the wallet "
name : " next-account " } : Option [ Natural ]
2020-07-17 23:59:50 +03:00
createdWalletNameFlag * {.
desc : " An easy-to-remember name for the wallet of your choice "
name : " name " } : Option [ WalletName ]
2020-07-14 22:00:35 +03:00
2020-07-17 23:59:50 +03:00
createdWalletFileFlag * {.
2020-06-23 22:11:07 +03:00
desc : " Output wallet file "
name : " out " } : Option [ OutFile ]
of WalletsCmd . restore :
2020-07-17 23:59:50 +03:00
restoredWalletNameFlag * {.
2020-06-23 22:11:07 +03:00
desc : " An easy-to-remember name for the wallet of your choice "
name : " name " } : Option [ WalletName ]
2020-07-17 23:59:50 +03:00
restoredWalletFileFlag * {.
desc : " Output wallet file "
name : " out " } : Option [ OutFile ]
2020-06-23 22:11:07 +03:00
restoredDepositsCount * {.
desc : " Expected number of deposits to recover. If not specified, " &
" Nimbus will try to guess the number by inspecting the latest " &
" beacon state "
name : " deposits " . } : Option [ Natural ]
of WalletsCmd . list :
discard
2018-11-24 01:58:49 +02:00
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . deposits :
2020-06-16 21:38:51 +03:00
case depositsCmd * {. command . } : DepositsCmd
2021-04-08 14:35:58 +03:00
of DepositsCmd . createTestnetDeposits :
2020-06-16 01:20:31 +03:00
totalDeposits * {.
2020-06-23 22:11:07 +03:00
desc : " Number of deposits to generate "
2021-05-19 09:38:13 +03:00
defaultValue : 1
2020-06-16 01:20:31 +03:00
name : " count " } : int
2020-06-23 22:11:07 +03:00
existingWalletId * {.
desc : " An existing wallet ID. If not specified, a new wallet will be created "
name : " wallet " } : Option [ WalletName ]
2020-06-16 01:20:31 +03:00
outValidatorsDir * {.
2020-08-01 21:32:41 +03:00
desc : " Output folder for validator keystores "
2021-05-19 09:38:13 +03:00
defaultValue : " validators "
2020-08-01 21:32:41 +03:00
name : " out-validators-dir " } : string
2020-06-16 01:20:31 +03:00
outSecretsDir * {.
2020-06-23 22:11:07 +03:00
desc : " Output folder for randomly generated keystore passphrases "
2021-05-19 09:38:13 +03:00
defaultValue : " secrets "
2020-06-16 01:20:31 +03:00
name : " out-secrets-dir " } : string
2020-07-17 23:59:50 +03:00
outDepositsFile * {.
desc : " The name of generated deposits file "
name : " out-deposits-file " } : Option [ OutFile ]
newWalletNameFlag * {.
desc : " An easy-to-remember name for the wallet of your choice "
2020-08-02 20:26:57 +03:00
name : " new-wallet-name " } : Option [ WalletName ]
2020-07-17 23:59:50 +03:00
newWalletFileFlag * {.
desc : " Output wallet file "
name : " new-wallet-file " } : Option [ OutFile ]
2020-06-16 21:38:51 +03:00
2021-04-07 01:12:07 +03:00
#[
2020-11-27 21:48:33 +02:00
of DepositsCmd . status :
discard
2021-04-07 01:12:07 +03:00
] #
2020-11-27 21:48:33 +02:00
2020-08-02 20:26:57 +03:00
of DepositsCmd . ` import ` :
importedDepositsDir * {.
argument
2020-11-28 20:50:09 +02:00
desc : " A directory with keystores to import " } : Option [ InputDir ]
2020-08-02 20:26:57 +03:00
2020-11-27 21:48:33 +02:00
of DepositsCmd . exit :
exitedValidator * {.
name : " validator "
desc : " Validator index or a public key of the exited validator " } : string
exitAtEpoch * {.
name : " epoch "
desc : " The desired exit epoch " } : Option [ uint64 ]
2020-06-23 22:11:07 +03:00
2022-01-25 12:07:15 +02:00
restUrlForExit * {.
desc : " URL of the beacon node REST service "
2022-01-31 13:57:16 +02:00
name : " rest-url " } : Option [ Uri ]
rpcUrlForExit * {.
desc : " URL of the beacon node JSON-RPC service "
name : " rpc-url " } : Option [ Uri ]
2022-01-25 12:07:15 +02:00
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . record :
2020-11-25 00:23:28 +01:00
case recordCmd * {. command . } : RecordCmd
of RecordCmd . create :
ipExt * {.
desc : " External IP address "
name : " ip " . } : ValidIpAddress
tcpPortExt * {.
desc : " External TCP port "
name : " tcp-port " . } : Port
udpPortExt * {.
desc : " External UDP port "
name : " udp-port " . } : Port
seqNumber * {.
desc : " Record sequence number "
2021-05-19 09:38:13 +03:00
defaultValue : 1 ,
2020-11-25 00:23:28 +01:00
name : " seq-number " . } : uint
fields * {.
desc : " Additional record key pairs, provide as <string>:<bytes in hex> "
name : " field " . } : seq [ ( string ) ]
of RecordCmd . print :
recordPrint * {.
argument
desc : " ENR URI of the record to print "
name : " enr " . } : Record
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . web3 :
2020-12-04 18:28:42 +02:00
case web3Cmd * {. command . } : Web3Cmd
of Web3Cmd . test :
web3TestUrl * {.
argument
desc : " The web3 provider URL to test "
name : " url " } : Uri
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . slashingdb :
2021-05-19 09:38:13 +03:00
case slashingdbCmd * {. command . } : SlashProtCmd
of SlashProtCmd . ` import ` :
importedInterchangeFile * {.
desc : " EIP-3076 slashing protection interchange file to import "
argument . } : InputFile
of SlashProtCmd . ` export ` :
exportedValidators * {.
desc : " Limit the export to specific validators " &
" (specified as numeric indices or public keys) "
abbr : " v "
name : " validator " } : seq [ PubKey0x ]
exportedInterchangeFile * {.
desc : " EIP-3076 slashing protection interchange file to export "
argument } : OutFile
2022-01-17 10:27:08 +01:00
of BNStartUpCmd . trustedNodeSync :
trustedNodeUrl * {.
desc : " URL of the REST API to sync from "
defaultValue : " http://localhost:5052 "
name : " trusted-node-url "
. } : string
blockId * {.
desc : " Block id to sync to - this can be a block root, slot number, \" finalized \" or \" head \" "
defaultValue : " finalized "
. } : string
backfillBlocks * {.
desc : " Backfill blocks directly from REST server instead of fetching via API "
defaultValue : true
name : " backfill " } : bool
2022-03-11 13:49:47 +01:00
reindex * {.
desc : " Recreate historical state index at end of backfill, allowing full history access (requires full backfill) "
defaultValue : false } : bool
2020-05-22 20:04:52 +03:00
ValidatorClientConf * = object
2022-03-05 04:33:15 +02:00
configFile * {.
desc : " Loads the configuration from a TOML file "
name : " config-file " } : Option [ InputFile ]
2020-05-22 20:04:52 +03:00
logLevel * {.
2021-05-19 09:38:13 +03:00
desc : " Sets the log level "
2020-11-09 10:12:48 +02:00
defaultValue : " INFO "
2020-05-22 20:04:52 +03:00
name : " log-level " } : string
2021-11-02 18:06:36 +01:00
logStdout * {.
2021-11-10 11:02:18 +02:00
hidden
2021-11-02 18:06:36 +01:00
desc : " Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json) "
defaultValueDesc : " auto "
defaultValue : StdoutLogKind . Auto
2021-11-10 11:02:18 +02:00
name : " log-format " } : StdoutLogKind
2021-11-02 18:06:36 +01:00
2020-07-15 16:15:55 +03:00
logFile * {.
2021-11-10 11:02:18 +02:00
desc : " Specifies a path for the written Json log file (deprecated) "
2020-07-15 16:15:55 +03:00
name : " log-file " } : Option [ OutFile ]
2020-05-22 20:04:52 +03:00
dataDir * {.
2020-06-23 22:11:07 +03:00
desc : " The directory where nimbus will store all blockchain data "
2021-05-19 09:38:13 +03:00
defaultValue : config . defaultDataDir ( )
defaultValueDesc : " "
2020-05-22 20:04:52 +03:00
abbr : " d "
name : " data-dir " } : OutDir
2020-06-01 22:48:20 +03:00
nonInteractive * {.
2020-06-23 22:11:07 +03:00
desc : " Do not display interative prompts. Quit on missing configuration "
2020-06-01 22:48:20 +03:00
name : " non-interactive " } : bool
2020-09-01 16:44:40 +03:00
validatorsDirFlag * {.
desc : " A directory containing validator keystores "
name : " validators-dir " } : Option [ InputDir ]
secretsDirFlag * {.
desc : " A directory containing validator keystore passwords "
name : " secrets-dir " } : Option [ InputDir ]
2021-12-22 14:37:31 +02:00
keymanagerEnabled * {.
desc : " Enable the REST keymanager API (BETA version) "
defaultValue : false
name : " keymanager " } : bool
keymanagerPort * {.
desc : " Listening port for the REST keymanager API "
defaultValue : DefaultEth2RestPort
defaultValueDesc : " 5052 "
name : " keymanager-port " } : Port
keymanagerAddress * {.
desc : " Listening port for the REST keymanager API "
defaultValue : defaultAdminListenAddress
defaultValueDesc : " 127.0.0.1 "
name : " keymanager-address " } : ValidIpAddress
keymanagerTokenFile * {.
desc : " A file specifying the authorizition token required for accessing the keymanager API "
name : " keymanager-token-file " } : Option [ InputFile ]
2021-10-04 22:08:31 +03:00
2022-02-27 13:02:45 +02:00
graffiti * {.
desc : " The graffiti value that will appear in proposed blocks. " &
" You can use a 0x-prefixed hex encoded string to specify " &
" raw bytes "
name : " graffiti " } : Option [ GraffitiBytes ]
2020-10-27 13:04:17 +02:00
2022-02-27 13:02:45 +02:00
stopAtEpoch * {.
desc : " A positive epoch selects the epoch at which to stop "
defaultValue : 0
name : " stop-at-epoch " } : uint64
2020-09-01 16:38:34 +03:00
2022-02-27 13:02:45 +02:00
beaconNodes * {.
desc : " URL addresses to one or more beacon node HTTP REST APIs " ,
name : " beacon-node " } : seq [ string ]
2020-06-01 22:48:20 +03:00
2021-11-30 03:20:21 +02:00
SigningNodeConf * = object
2022-03-05 04:33:15 +02:00
configFile * {.
desc : " Loads the configuration from a TOML file "
name : " config-file " } : Option [ InputFile ]
2021-11-30 03:20:21 +02:00
logLevel * {.
desc : " Sets the log level "
defaultValue : " INFO "
name : " log-level " } : string
logStdout * {.
desc : " Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json) "
defaultValueDesc : " auto "
defaultValue : StdoutLogKind . Auto
name : " log-stdout " } : StdoutLogKind
logFile * {.
desc : " Specifies a path for the written Json log file "
name : " log-file " } : Option [ OutFile ]
nonInteractive * {.
desc : " Do not display interative prompts. Quit on missing configuration "
name : " non-interactive " } : bool
dataDir * {.
desc : " The directory where nimbus will store validator ' s keys "
defaultValue : config . defaultDataDir ( )
defaultValueDesc : " "
abbr : " d "
name : " data-dir " } : OutDir
validatorsDirFlag * {.
desc : " A directory containing validator keystores "
name : " validators-dir " } : Option [ InputDir ]
secretsDirFlag * {.
desc : " A directory containing validator keystore passwords "
name : " secrets-dir " } : Option [ InputDir ]
serverIdent * {.
desc : " Server identifier which will be used in HTTP Host header "
name : " server-ident " } : Option [ string ]
requestTimeout * {.
desc : " Request timeout, maximum time that node will wait for remote " &
" client request (in seconds) "
defaultValue : defaultSigningNodeRequestTimeout
name : " request-timeout " } : int
2022-02-27 13:02:45 +02:00
bindPort * {.
desc : " Port for the REST (BETA version) HTTP server "
defaultValue : DefaultEth2RestPort
defaultValueDesc : " 5052 "
name : " bind-port " } : Port
2021-11-30 03:20:21 +02:00
2022-02-27 13:02:45 +02:00
bindAddress * {.
desc : " Listening address of the REST (BETA version) HTTP server "
defaultValue : defaultAdminListenAddress
defaultValueDesc : " 127.0.0.1 "
name : " bind-address " } : ValidIpAddress
2021-11-30 03:20:21 +02:00
2022-02-27 13:02:45 +02:00
tlsEnabled * {.
desc : " Use secure TLS communication for REST (BETA version) server "
defaultValue : false
name : " tls " } : bool
2021-11-30 03:20:21 +02:00
2022-02-27 13:02:45 +02:00
tlsCertificate * {.
desc : " Path to SSL certificate file "
name : " tls-cert " } : Option [ InputFile ]
2021-11-30 03:20:21 +02:00
2022-02-27 13:02:45 +02:00
tlsPrivateKey * {.
desc : " Path to SSL ceritificate ' s private key "
name : " tls-key " } : Option [ InputFile ]
2021-11-30 03:20:21 +02:00
AnyConf * = BeaconNodeConf | ValidatorClientConf | SigningNodeConf
proc defaultDataDir * ( config : AnyConf ) : string =
2019-03-19 19:22:17 +02:00
let dataDir = when defined ( windows ) :
" AppData " / " Roaming " / " Nimbus "
elif defined ( macosx ) :
" Library " / " Application Support " / " Nimbus "
else :
" .cache " / " nimbus "
2018-12-09 10:25:02 +02:00
2019-10-29 01:04:52 +02:00
getHomeDir ( ) / dataDir / " BeaconNode "
2018-11-29 03:08:34 +02:00
2022-03-24 21:44:34 +00:00
func dumpDir ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
config . dataDir / " dump "
2019-12-10 15:20:40 +01:00
2021-11-30 03:20:21 +02:00
func dumpDirInvalid * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
config . dumpDir / " invalid " # things that failed validation
2020-06-16 10:49:32 +02:00
2021-11-30 03:20:21 +02:00
func dumpDirIncoming * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
config . dumpDir / " incoming " # things that couldn't be validated (missingparent etc)
2020-06-16 10:49:32 +02:00
2021-11-30 03:20:21 +02:00
func dumpDirOutgoing * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
config . dumpDir / " outgoing " # things we produced
2020-06-16 10:49:32 +02:00
2021-02-22 17:17:48 +01:00
proc createDumpDirs * ( config : BeaconNodeConf ) =
if config . dumpEnabled :
2022-03-22 18:06:21 +01:00
if ( let res = secureCreatePath ( config . dumpDirInvalid ) ; res . isErr ) :
warn " Could not create dump directory " ,
path = config . dumpDirInvalid , err = ioErrorMsg ( res . error )
if ( let res = secureCreatePath ( config . dumpDirIncoming ) ; res . isErr ) :
warn " Could not create dump directory " ,
path = config . dumpDirIncoming , err = ioErrorMsg ( res . error )
if ( let res = secureCreatePath ( config . dumpDirOutgoing ) ; res . isErr ) :
warn " Could not create dump directory " ,
path = config . dumpDirOutgoing , err = ioErrorMsg ( res . error )
2020-06-16 10:49:32 +02:00
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type GraffitiBytes , input : string ) : T
2020-06-29 20:30:19 +03:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
GraffitiBytes . init ( input )
2020-06-29 20:30:19 +03:00
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type GraffitiBytes , input : string ) : seq [ string ] =
2020-06-29 20:30:19 +03:00
return @ [ ]
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type BlockHashOrNumber , input : string ) : T
2020-11-12 21:01:26 +02:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
init ( BlockHashOrNumber , input )
2020-11-12 21:01:26 +02:00
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type BlockHashOrNumber , input : string ) : seq [ string ] =
2020-11-12 21:01:26 +02:00
return @ [ ]
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type Uri , input : string ) : T
2020-11-27 21:48:33 +02:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
parseUri ( input )
2020-11-27 21:48:33 +02:00
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type Uri , input : string ) : seq [ string ] =
2020-11-27 21:48:33 +02:00
return @ [ ]
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type PubKey0x , input : string ) : T
2021-05-19 09:38:13 +03:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
PubKey0x ( hexToPaddedByteArray [ RawPubKeySize ] ( input ) )
2021-05-19 09:38:13 +03:00
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type ValidatorPubKey , input : string ) : T
2021-12-20 20:20:31 +01:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
let res = ValidatorPubKey . fromHex ( input )
2021-12-20 20:20:31 +01:00
if res . isErr ( ) : raise ( ref ValueError ) ( msg : $ res . error ( ) )
res . get ( )
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type PubKey0x , input : string ) : seq [ string ] =
2021-05-19 09:38:13 +03:00
return @ [ ]
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type Checkpoint , input : string ) : T
2020-09-22 23:42:42 +03:00
{. raises : [ ValueError , Defect ] . } =
2022-03-24 21:44:34 +00:00
let sepIdx = find ( input , ' : ' )
2020-10-06 18:32:17 +03:00
if sepIdx = = - 1 :
raise newException ( ValueError ,
" The weak subjectivity checkpoint must be provided in the `block_root:epoch_number` format " )
T ( root : Eth2Digest . fromHex ( input [ 0 .. < sepIdx ] ) ,
epoch : parseBiggestUInt ( input [ sepIdx .. ^ 1 ] ) . Epoch )
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type Checkpoint , input : string ) : seq [ string ] =
2020-09-22 23:42:42 +03:00
return @ [ ]
2022-02-17 11:53:55 +00:00
func isPrintable ( rune : Rune ) : bool =
2020-10-02 17:48:27 +03:00
# This can be eventually replaced by the `unicodeplus` package, but a single
# proc does not justify the extra dependencies at the moment:
# https://github.com/nitely/nim-unicodeplus
# https://github.com/nitely/nim-segmentation
rune = = Rune ( 0x20 ) or unicodeCategory ( rune ) notin ctgC + ctgZ
2022-03-24 21:44:34 +00:00
func parseCmdArg * ( T : type WalletName , input : string ) : T
2020-06-23 22:11:07 +03:00
{. raises : [ ValueError , Defect ] . } =
if input . len = = 0 :
raise newException ( ValueError , " The wallet name should not be empty " )
if input [ 0 ] = = ' _ ' :
raise newException ( ValueError , " The wallet name should not start with an underscore " )
2022-03-24 21:44:34 +00:00
for rune in runes ( input ) :
2020-10-02 17:48:27 +03:00
if not rune . isPrintable :
raise newException ( ValueError , " The wallet name should consist only of printable characters " )
# From the Unicode Normalization FAQ (https://unicode.org/faq/normalization.html):
# NFKC is the preferred form for identifiers, especially where there are security concerns
# (see UTR #36 http://www.unicode.org/reports/tr36/)
return T ( toNFKC ( input ) )
2020-06-23 22:11:07 +03:00
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type WalletName , input : string ) : seq [ string ] =
2020-06-23 22:11:07 +03:00
return @ [ ]
2020-11-25 00:23:28 +01:00
2022-03-24 21:44:34 +00:00
proc parseCmdArg * ( T : type enr . Record , p : string ) : T
2020-11-25 00:23:28 +01:00
{. raises : [ ConfigurationError , Defect ] . } =
if not fromURI ( result , p ) :
raise newException ( ConfigurationError , " Invalid ENR " )
2022-03-24 21:44:34 +00:00
func completeCmdArg * ( T : type enr . Record , val : string ) : seq [ string ] =
2020-11-25 00:23:28 +01:00
return @ [ ]
2020-06-23 22:11:07 +03:00
2021-11-30 03:20:21 +02:00
func validatorsDir * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
string config . validatorsDirFlag . get ( InputDir ( config . dataDir / " validators " ) )
2020-06-03 14:52:36 +03:00
2021-11-30 03:20:21 +02:00
func secretsDir * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
string config . secretsDirFlag . get ( InputDir ( config . dataDir / " secrets " ) )
2019-12-10 15:20:40 +01:00
2021-02-22 17:17:48 +01:00
func walletsDir * ( config : BeaconNodeConf ) : string =
if config . walletsDirFlag . isSome :
config . walletsDirFlag . get . string
2020-07-17 23:59:50 +03:00
else :
2021-02-22 17:17:48 +01:00
config . dataDir / " wallets "
2020-07-17 23:59:50 +03:00
2021-02-22 17:17:48 +01:00
func outWalletName * ( config : BeaconNodeConf ) : Option [ WalletName ] =
2022-02-16 22:24:44 +00:00
proc fail {. noreturn . } =
2020-07-17 23:59:50 +03:00
raiseAssert " outWalletName should be used only in the right context "
2021-02-22 17:17:48 +01:00
case config . cmd
2020-07-14 22:00:35 +03:00
of wallets :
2021-02-22 17:17:48 +01:00
case config . walletsCmd
of WalletsCmd . create : config . createdWalletNameFlag
of WalletsCmd . restore : config . restoredWalletNameFlag
2020-07-17 23:59:50 +03:00
of WalletsCmd . list : fail ( )
of deposits :
2021-04-07 01:12:07 +03:00
case config . depositsCmd
2021-04-08 14:35:58 +03:00
of DepositsCmd . createTestnetDeposits : config . newWalletNameFlag
2021-04-07 01:12:07 +03:00
else : fail ( )
2020-07-14 22:00:35 +03:00
else :
2020-07-17 23:59:50 +03:00
fail ( )
2020-07-14 22:00:35 +03:00
2021-02-22 17:17:48 +01:00
func outWalletFile * ( config : BeaconNodeConf ) : Option [ OutFile ] =
2022-02-16 22:24:44 +00:00
proc fail {. noreturn . } =
2020-07-17 23:59:50 +03:00
raiseAssert " outWalletName should be used only in the right context "
2021-02-22 17:17:48 +01:00
case config . cmd
2020-07-17 23:59:50 +03:00
of wallets :
2021-02-22 17:17:48 +01:00
case config . walletsCmd
of WalletsCmd . create : config . createdWalletFileFlag
of WalletsCmd . restore : config . restoredWalletFileFlag
2020-07-17 23:59:50 +03:00
of WalletsCmd . list : fail ( )
of deposits :
2021-04-07 01:12:07 +03:00
case config . depositsCmd
2021-04-08 14:35:58 +03:00
of DepositsCmd . createTestnetDeposits : config . newWalletFileFlag
2021-04-07 01:12:07 +03:00
else : fail ( )
2020-07-17 23:59:50 +03:00
else :
fail ( )
2020-06-23 22:11:07 +03:00
2021-11-30 03:20:21 +02:00
func databaseDir * ( config : AnyConf ) : string =
2021-02-22 17:17:48 +01:00
config . dataDir / " db "
2019-12-10 15:20:40 +01:00
2022-02-27 13:02:45 +02:00
func runAsService * ( config : BeaconNodeConf ) : bool =
config . cmd = = noCommand and config . runAsServiceFlag
era: load blocks and states (#3394)
* era: load blocks and states
Era files contain finalized history and can be thought of as an
alternative source for block and state data that allows clients to avoid
syncing this information from the P2P network - the P2P network is then
used to "top up" the client with the most recent data. They can be
freely shared in the community via whatever means (http, torrent, etc)
and serve as a permanent cold store of consensus data (and, after the
merge, execution data) for history buffs and bean counters alike.
This PR gently introduces support for loading blocks and states in two
cases: block requests from rest/p2p and frontfilling when doing
checkpoint sync.
The era files are used as a secondary source if the information is not
found in the database - compared to the database, there are a few key
differences:
* the database stores the block indexed by block root while the era file
indexes by slot - the former is used only in rest, while the latter is
used both by p2p and rest.
* when loading blocks from era files, the root is no longer trivially
available - if it is needed, it must either be computed (slow) or cached
(messy) - the good news is that for p2p requests, it is not needed
* in era files, "framed" snappy encoding is used while in the database
we store unframed snappy - for p2p2 requests, the latter requires
recompression while the former could avoid it
* front-filling is the process of using era files to replace backfilling
- in theory this front-filling could happen from any block and
front-fills with gaps could also be entertained, but our backfilling
algorithm cannot take advantage of this because there's no (simple) way
to tell it to "skip" a range.
* front-filling, as implemented, is a bit slow (10s to load mainnet): we
load the full BeaconState for every era to grab the roots of the blocks
- it would be better to partially load the state - as such, it would
also be good to be able to partially decompress snappy blobs
* lookups from REST via root are served by first looking up a block
summary in the database, then using the slot to load the block data from
the era file - however, there needs to be an option to create the
summary table from era files to fully support historical queries
To test this, `ncli_db` has an era file exporter: the files it creates
should be placed in an `era` folder next to `db` in the data directory.
What's interesting in particular about this setup is that `db` remains
as the source of truth for security purposes - it stores the latest
synced head root which in turn determines where a node "starts" its
consensus participation - the era directory however can be freely shared
between nodes / people without any (significant) security implications,
assuming the era files are consistent / not broken.
There's lots of future improvements to be had:
* we can drop the in-memory `BlockRef` index almost entirely - at this
point, resident memory usage of Nimbus should drop to a cool 500-600 mb
* we could serve era files via REST trivially: this would drop backfill
times to whatever time it takes to download the files - unlike the
current implementation that downloads block by block, downloading an era
at a time almost entirely cuts out request overhead
* we can "reasonably" recreate detailed state history from almost any
point in time, turning an O(slot) process into O(1) effectively - we'll
still need caches and indices to do this with sufficient efficiency for
the rest api, but at least it cuts the whole process down to minutes
instead of hours, for arbitrary points in time
* CI: ignore failures with Nim-1.6 (temporary)
* test fixes
Co-authored-by: Ștefan Talpalaru <stefantalpalaru@yahoo.com>
2022-03-23 09:58:17 +01:00
func eraDir * ( config : AnyConf ) : string =
# TODO this should be shared between all instances of the same network
config . dataDir / " era "
2020-02-11 19:35:42 +02:00
template writeValue * ( writer : var JsonWriter ,
value : TypedInputFile | InputFile | InputDir | OutPath | OutDir | OutFile ) =
writer . writeValue ( string value )
2022-02-11 21:40:49 +01:00
2022-03-05 04:33:15 +02:00
template raiseUnexpectedValue ( r : var TomlReader , msg : string ) =
# TODO: We need to implement `raiseUnexpectedValue` for TOML,
# so the correct line and column information can be included
# in error messages:
raise newException ( SerializationError , msg )
proc readValue * ( r : var TomlReader , value : var Epoch )
{. raises : [ Defect , SerializationError , IOError ] . } =
value = Epoch r . parseInt ( uint64 )
proc readValue * ( r : var TomlReader , value : var GraffitiBytes )
{. raises : [ Defect , SerializationError , IOError ] . } =
try :
value = GraffitiBytes . init ( r . readValue ( string ) )
except ValueError as err :
r . raiseUnexpectedValue ( " A printable string or 0x-prefixed hex-encoded raw bytes expected " )
proc readValue * ( r : var TomlReader , val : var NatConfig )
{. raises : [ Defect , IOError , SerializationError ] . } =
2022-03-24 21:44:34 +00:00
val = try : parseCmdArg ( NatConfig , r . readValue ( string ) )
2022-03-05 04:33:15 +02:00
except CatchableError as err :
raise newException ( SerializationError , err . msg )
proc readValue * ( r : var TomlReader , a : var Eth2Digest )
{. raises : [ Defect , IOError , SerializationError ] . } =
try :
a = fromHex ( type ( a ) , r . readValue ( string ) )
except ValueError :
r . raiseUnexpectedValue ( " Hex string expected " )
proc readValue * ( reader : var TomlReader , value : var ValidatorPubKey )
{. raises : [ Defect , IOError , SerializationError ] . } =
let keyAsString = try :
reader . readValue ( string )
except CatchableError :
raiseUnexpectedValue ( reader , " A hex-encoded string expected " )
let key = ValidatorPubKey . fromHex ( keyAsString )
if key . isOk :
value = key . get
else :
# TODO: Can we provide better diagnostic?
raiseUnexpectedValue ( reader , " Valid hex-encoded public key expected " )
proc readValue * ( r : var TomlReader , a : var PubKey0x )
{. raises : [ Defect , IOError , SerializationError ] . } =
try :
2022-03-24 21:44:34 +00:00
a = parseCmdArg ( PubKey0x , r . readValue ( string ) )
2022-03-05 04:33:15 +02:00
except CatchableError :
r . raiseUnexpectedValue ( " a 0x-prefixed hex-encoded string expected " )
proc readValue * ( r : var TomlReader , a : var WalletName )
{. raises : [ Defect , IOError , SerializationError ] . } =
try :
2022-03-24 21:44:34 +00:00
a = parseCmdArg ( WalletName , r . readValue ( string ) )
2022-03-05 04:33:15 +02:00
except CatchableError :
r . raiseUnexpectedValue ( " string expected " )
2022-02-11 21:40:49 +01:00
proc loadEth2Network * ( config : BeaconNodeConf ) : Eth2NetworkMetadata {. raises : [ Defect , IOError ] . } =
network_name . set ( 2 , labelValues = [ config . eth2Network . get ( otherwise = " mainnet " ) ] )
2022-02-25 10:22:44 +02:00
when not defined ( gnosisChainBinary ) :
if config . eth2Network . isSome :
getMetadataForNetwork ( config . eth2Network . get )
2022-02-11 21:40:49 +01:00
else :
2022-02-25 10:22:44 +02:00
when const_preset = = " mainnet " :
mainnetMetadata
else :
# Presumably other configurations can have other defaults, but for now
# this simplifies the flow
echo " Must specify network on non-mainnet node "
quit 1
else :
checkNetworkParameterUse config . eth2Network
gnosisChainMetadata