format pragmas consistently in `conf.nim` (#3750)

Aligns code style in `conf.nim`. Some pragmas lacked trailing `.`
This commit is contained in:
Etan Kissling 2022-06-15 20:04:07 +02:00 committed by GitHub
parent 27e1625d34
commit 6144ecd95c
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 144 additions and 146 deletions

View File

@ -108,93 +108,93 @@ type
BeaconNodeConf* = object BeaconNodeConf* = object
configFile* {. configFile* {.
desc: "Loads the configuration from a TOML file" desc: "Loads the configuration from a TOML file"
name: "config-file" }: Option[InputFile] name: "config-file" .}: Option[InputFile]
logLevel* {. logLevel* {.
desc: "Sets the log level for process and topics (e.g. \"DEBUG; TRACE:discv5,libp2p; REQUIRED:none; DISABLED:none\")" desc: "Sets the log level for process and topics (e.g. \"DEBUG; TRACE:discv5,libp2p; REQUIRED:none; DISABLED:none\")"
defaultValue: "INFO" defaultValue: "INFO"
name: "log-level" }: string name: "log-level" .}: string
logStdout* {. logStdout* {.
hidden hidden
desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)" desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)"
defaultValueDesc: "auto" defaultValueDesc: "auto"
defaultValue: StdoutLogKind.Auto defaultValue: StdoutLogKind.Auto
name: "log-format" }: StdoutLogKind name: "log-format" .}: StdoutLogKind
logFile* {. logFile* {.
desc: "Specifies a path for the written Json log file (deprecated)" desc: "Specifies a path for the written Json log file (deprecated)"
name: "log-file" }: Option[OutFile] name: "log-file" .}: Option[OutFile]
eth2Network* {. eth2Network* {.
desc: "The Eth2 network to join" desc: "The Eth2 network to join"
defaultValueDesc: "mainnet" defaultValueDesc: "mainnet"
name: "network" }: Option[string] name: "network" .}: Option[string]
dataDir* {. dataDir* {.
desc: "The directory where nimbus will store all blockchain data" desc: "The directory where nimbus will store all blockchain data"
defaultValue: config.defaultDataDir() defaultValue: config.defaultDataDir()
defaultValueDesc: "" defaultValueDesc: ""
abbr: "d" abbr: "d"
name: "data-dir" }: OutDir name: "data-dir" .}: OutDir
validatorsDirFlag* {. validatorsDirFlag* {.
desc: "A directory containing validator keystores" desc: "A directory containing validator keystores"
name: "validators-dir" }: Option[InputDir] name: "validators-dir" .}: Option[InputDir]
secretsDirFlag* {. secretsDirFlag* {.
desc: "A directory containing validator keystore passwords" desc: "A directory containing validator keystore passwords"
name: "secrets-dir" }: Option[InputDir] name: "secrets-dir" .}: Option[InputDir]
walletsDirFlag* {. walletsDirFlag* {.
desc: "A directory containing wallet files" desc: "A directory containing wallet files"
name: "wallets-dir" }: Option[InputDir] name: "wallets-dir" .}: Option[InputDir]
web3Urls* {. web3Urls* {.
desc: "One or more Web3 provider URLs used for obtaining deposit contract data" desc: "One or more Web3 provider URLs used for obtaining deposit contract data"
name: "web3-url" }: seq[string] name: "web3-url" .}: seq[string]
web3ForcePolling* {. web3ForcePolling* {.
hidden hidden
defaultValue: false defaultValue: false
desc: "Force the use of polling when determining the head block of Eth1" desc: "Force the use of polling when determining the head block of Eth1"
name: "web3-force-polling" }: bool name: "web3-force-polling" .}: bool
nonInteractive* {. nonInteractive* {.
desc: "Do not display interative prompts. Quit on missing configuration" desc: "Do not display interative prompts. Quit on missing configuration"
name: "non-interactive" }: bool name: "non-interactive" .}: bool
netKeyFile* {. netKeyFile* {.
desc: "Source of network (secp256k1) private key file " & desc: "Source of network (secp256k1) private key file " &
"(random|<path>)" "(random|<path>)"
defaultValue: "random", defaultValue: "random",
name: "netkey-file" }: string name: "netkey-file" .}: string
netKeyInsecurePassword* {. netKeyInsecurePassword* {.
desc: "Use pre-generated INSECURE password for network private key file" desc: "Use pre-generated INSECURE password for network private key file"
defaultValue: false, defaultValue: false,
name: "insecure-netkey-password" }: bool name: "insecure-netkey-password" .}: bool
agentString* {. agentString* {.
defaultValue: "nimbus", defaultValue: "nimbus",
desc: "Node agent string which is used as identifier in network" desc: "Node agent string which is used as identifier in network"
name: "agent-string" }: string name: "agent-string" .}: string
subscribeAllSubnets* {. subscribeAllSubnets* {.
defaultValue: false, defaultValue: false,
desc: "Subscribe to all subnet topics when gossiping" desc: "Subscribe to all subnet topics when gossiping"
name: "subscribe-all-subnets" }: bool name: "subscribe-all-subnets" .}: bool
slashingDbKind* {. slashingDbKind* {.
hidden hidden
defaultValue: SlashingDbKind.v2 defaultValue: SlashingDbKind.v2
desc: "The slashing DB flavour to use" desc: "The slashing DB flavour to use"
name: "slashing-db-kind" }: SlashingDbKind name: "slashing-db-kind" .}: SlashingDbKind
numThreads* {. numThreads* {.
defaultValue: 0, defaultValue: 0,
desc: "Number of worker threads (\"0\" = use as many threads as there are CPU cores available)" desc: "Number of worker threads (\"0\" = use as many threads as there are CPU cores available)"
name: "num-threads" }: int name: "num-threads" .}: int
# https://github.com/ethereum/execution-apis/blob/v1.0.0-alpha.9/src/engine/authentication.md#key-distribution # https://github.com/ethereum/execution-apis/blob/v1.0.0-alpha.9/src/engine/authentication.md#key-distribution
jwtSecret* {. jwtSecret* {.
@ -203,51 +203,51 @@ type
case cmd* {. case cmd* {.
command command
defaultValue: BNStartUpCmd.noCommand }: BNStartUpCmd defaultValue: BNStartUpCmd.noCommand .}: BNStartUpCmd
of BNStartUpCmd.noCommand: of BNStartUpCmd.noCommand:
runAsServiceFlag* {. runAsServiceFlag* {.
windowsOnly windowsOnly
defaultValue: false, defaultValue: false,
desc: "Run as a Windows service" desc: "Run as a Windows service"
name: "run-as-service" }: bool name: "run-as-service" .}: bool
bootstrapNodes* {. bootstrapNodes* {.
desc: "Specifies one or more bootstrap nodes to use when connecting to the network" desc: "Specifies one or more bootstrap nodes to use when connecting to the network"
abbr: "b" abbr: "b"
name: "bootstrap-node" }: seq[string] name: "bootstrap-node" .}: seq[string]
bootstrapNodesFile* {. bootstrapNodesFile* {.
desc: "Specifies a line-delimited file of bootstrap Ethereum network addresses" desc: "Specifies a line-delimited file of bootstrap Ethereum network addresses"
defaultValue: "" defaultValue: ""
name: "bootstrap-file" }: InputFile name: "bootstrap-file" .}: InputFile
listenAddress* {. listenAddress* {.
desc: "Listening address for the Ethereum LibP2P and Discovery v5 traffic" desc: "Listening address for the Ethereum LibP2P and Discovery v5 traffic"
defaultValue: defaultListenAddress defaultValue: defaultListenAddress
defaultValueDesc: "0.0.0.0" defaultValueDesc: "0.0.0.0"
name: "listen-address" }: ValidIpAddress name: "listen-address" .}: ValidIpAddress
tcpPort* {. tcpPort* {.
desc: "Listening TCP port for Ethereum LibP2P traffic" desc: "Listening TCP port for Ethereum LibP2P traffic"
defaultValue: defaultEth2TcpPort defaultValue: defaultEth2TcpPort
defaultValueDesc: "9000" defaultValueDesc: "9000"
name: "tcp-port" }: Port name: "tcp-port" .}: Port
udpPort* {. udpPort* {.
desc: "Listening UDP port for node discovery" desc: "Listening UDP port for node discovery"
defaultValue: defaultEth2TcpPort defaultValue: defaultEth2TcpPort
defaultValueDesc: "9000" defaultValueDesc: "9000"
name: "udp-port" }: Port name: "udp-port" .}: Port
maxPeers* {. maxPeers* {.
desc: "The target number of peers to connect to" desc: "The target number of peers to connect to"
defaultValue: 160 # 5 (fanout) * 64 (subnets) / 2 (subs) for a heathy mesh defaultValue: 160 # 5 (fanout) * 64 (subnets) / 2 (subs) for a heathy mesh
name: "max-peers" }: int name: "max-peers" .}: int
hardMaxPeers* {. hardMaxPeers* {.
desc: "The maximum number of peers to connect to. Defaults to maxPeers * 1.5" desc: "The maximum number of peers to connect to. Defaults to maxPeers * 1.5"
name: "hard-max-peers" }: Option[int] name: "hard-max-peers" .}: Option[int]
nat* {. nat* {.
desc: "Specify method to use for determining public address. " & desc: "Specify method to use for determining public address. " &
@ -265,7 +265,7 @@ type
weakSubjectivityCheckpoint* {. weakSubjectivityCheckpoint* {.
desc: "Weak subjectivity checkpoint in the format block_root:epoch_number" desc: "Weak subjectivity checkpoint in the format block_root:epoch_number"
name: "weak-subjectivity-checkpoint" }: Option[Checkpoint] name: "weak-subjectivity-checkpoint" .}: Option[Checkpoint]
lightClientEnable* {. lightClientEnable* {.
hidden hidden
@ -275,66 +275,66 @@ type
lightClientTrustedBlockRoot* {. lightClientTrustedBlockRoot* {.
hidden hidden
desc: "BETA: Recent trusted finalized block root to initialize light client from." desc: "BETA: Recent trusted finalized block root to initialize light client from."
name: "light-client-trusted-block-root" }: Option[Eth2Digest] name: "light-client-trusted-block-root" .}: Option[Eth2Digest]
finalizedCheckpointState* {. finalizedCheckpointState* {.
desc: "SSZ file specifying a recent finalized state" desc: "SSZ file specifying a recent finalized state"
name: "finalized-checkpoint-state" }: Option[InputFile] name: "finalized-checkpoint-state" .}: Option[InputFile]
finalizedCheckpointBlock* {. finalizedCheckpointBlock* {.
desc: "SSZ file specifying a recent finalized block" desc: "SSZ file specifying a recent finalized block"
name: "finalized-checkpoint-block" }: Option[InputFile] name: "finalized-checkpoint-block" .}: Option[InputFile]
nodeName* {. nodeName* {.
desc: "A name for this node that will appear in the logs. " & desc: "A name for this node that will appear in the logs. " &
"If you set this to 'auto', a persistent automatically generated ID will be selected for each --data-dir folder" "If you set this to 'auto', a persistent automatically generated ID will be selected for each --data-dir folder"
defaultValue: "" defaultValue: ""
name: "node-name" }: string name: "node-name" .}: string
graffiti* {. graffiti* {.
desc: "The graffiti value that will appear in proposed blocks. " & desc: "The graffiti value that will appear in proposed blocks. " &
"You can use a 0x-prefixed hex encoded string to specify raw bytes" "You can use a 0x-prefixed hex encoded string to specify raw bytes"
name: "graffiti" }: Option[GraffitiBytes] name: "graffiti" .}: Option[GraffitiBytes]
verifyFinalization* {. verifyFinalization* {.
hidden hidden
desc: "Specify whether to verify finalization occurs on schedule (debug only)" desc: "Specify whether to verify finalization occurs on schedule (debug only)"
defaultValue: false defaultValue: false
name: "verify-finalization" }: bool name: "verify-finalization" .}: bool
stopAtEpoch* {. stopAtEpoch* {.
hidden hidden
desc: "The wall-time epoch at which to exit the program. (for testing purposes)" desc: "The wall-time epoch at which to exit the program. (for testing purposes)"
defaultValue: 0 defaultValue: 0
name: "stop-at-epoch" }: uint64 name: "stop-at-epoch" .}: uint64
stopAtSyncedEpoch* {. stopAtSyncedEpoch* {.
hidden hidden
desc: "The synced epoch at which to exit the program. (for testing purposes)" desc: "The synced epoch at which to exit the program. (for testing purposes)"
defaultValue: 0 defaultValue: 0
name: "stop-at-synced-epoch" }: uint64 name: "stop-at-synced-epoch" .}: uint64
metricsEnabled* {. metricsEnabled* {.
desc: "Enable the metrics server" desc: "Enable the metrics server"
defaultValue: false defaultValue: false
name: "metrics" }: bool name: "metrics" .}: bool
metricsAddress* {. metricsAddress* {.
desc: "Listening address of the metrics server" desc: "Listening address of the metrics server"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "metrics-address" }: ValidIpAddress name: "metrics-address" .}: ValidIpAddress
metricsPort* {. metricsPort* {.
desc: "Listening HTTP port of the metrics server" desc: "Listening HTTP port of the metrics server"
defaultValue: 8008 defaultValue: 8008
name: "metrics-port" }: Port name: "metrics-port" .}: Port
statusBarEnabled* {. statusBarEnabled* {.
posixOnly posixOnly
desc: "Display a status bar at the bottom of the terminal screen" desc: "Display a status bar at the bottom of the terminal screen"
defaultValue: true defaultValue: true
name: "status-bar" }: bool name: "status-bar" .}: bool
statusBarContents* {. statusBarContents* {.
posixOnly posixOnly
@ -346,130 +346,130 @@ type
"sync: $sync_status|" & "sync: $sync_status|" &
"ETH: $attached_validators_balance" "ETH: $attached_validators_balance"
defaultValueDesc: "" defaultValueDesc: ""
name: "status-bar-contents" }: string name: "status-bar-contents" .}: string
rpcEnabled* {. rpcEnabled* {.
hidden hidden
desc: "Enable the JSON-RPC server (deprecated for removal)" desc: "Enable the JSON-RPC server (deprecated for removal)"
defaultValue: false defaultValue: false
name: "rpc" }: bool name: "rpc" .}: bool
rpcPort* {. rpcPort* {.
hidden hidden
desc: "HTTP port for the JSON-RPC service (deprecated for removal)" desc: "HTTP port for the JSON-RPC service (deprecated for removal)"
defaultValue: 9190 defaultValue: 9190
defaultValueDesc: "9190" defaultValueDesc: "9190"
name: "rpc-port" }: Port name: "rpc-port" .}: Port
rpcAddress* {. rpcAddress* {.
hidden hidden
desc: "Listening address of the RPC server (deprecated for removal)" desc: "Listening address of the RPC server (deprecated for removal)"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "rpc-address" }: ValidIpAddress name: "rpc-address" .}: ValidIpAddress
restEnabled* {. restEnabled* {.
desc: "Enable the REST server" desc: "Enable the REST server"
defaultValue: false defaultValue: false
name: "rest" }: bool name: "rest" .}: bool
restPort* {. restPort* {.
desc: "Port for the REST server" desc: "Port for the REST server"
defaultValue: DefaultEth2RestPort defaultValue: DefaultEth2RestPort
defaultValueDesc: "5052" defaultValueDesc: "5052"
name: "rest-port" }: Port name: "rest-port" .}: Port
restAddress* {. restAddress* {.
desc: "Listening address of the REST server" desc: "Listening address of the REST server"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "rest-address" }: ValidIpAddress name: "rest-address" .}: ValidIpAddress
restAllowedOrigin* {. restAllowedOrigin* {.
desc: "Limit the access to the REST API to a particular hostname " & desc: "Limit the access to the REST API to a particular hostname " &
"(for CORS-enabled clients such as browsers)" "(for CORS-enabled clients such as browsers)"
name: "rest-allow-origin" }: Option[string] name: "rest-allow-origin" .}: Option[string]
restCacheSize* {. restCacheSize* {.
defaultValue: 3 defaultValue: 3
desc: "The maximum number of recently accessed states that are kept in " & desc: "The maximum number of recently accessed states that are kept in " &
"memory. Speeds up requests obtaining information for consecutive " & "memory. Speeds up requests obtaining information for consecutive " &
"slots or epochs." "slots or epochs."
name: "rest-statecache-size" }: Natural name: "rest-statecache-size" .}: Natural
restCacheTtl* {. restCacheTtl* {.
defaultValue: 60 defaultValue: 60
desc: "The number of seconds to keep recently accessed states in memory" desc: "The number of seconds to keep recently accessed states in memory"
name: "rest-statecache-ttl" }: Natural name: "rest-statecache-ttl" .}: Natural
restRequestTimeout* {. restRequestTimeout* {.
defaultValue: 0 defaultValue: 0
defaultValueDesc: "infinite" defaultValueDesc: "infinite"
desc: "The number of seconds to wait until complete REST request " & desc: "The number of seconds to wait until complete REST request " &
"will be received" "will be received"
name: "rest-request-timeout" }: Natural name: "rest-request-timeout" .}: Natural
restMaxRequestBodySize* {. restMaxRequestBodySize* {.
defaultValue: 16_384 defaultValue: 16_384
desc: "Maximum size of REST request body (kilobytes)" desc: "Maximum size of REST request body (kilobytes)"
name: "rest-max-body-size" }: Natural name: "rest-max-body-size" .}: Natural
restMaxRequestHeadersSize* {. restMaxRequestHeadersSize* {.
defaultValue: 64 defaultValue: 64
desc: "Maximum size of REST request headers (kilobytes)" desc: "Maximum size of REST request headers (kilobytes)"
name: "rest-max-headers-size" }: Natural name: "rest-max-headers-size" .}: Natural
keymanagerEnabled* {. keymanagerEnabled* {.
desc: "Enable the REST keymanager API (BETA version)" desc: "Enable the REST keymanager API (BETA version)"
defaultValue: false defaultValue: false
name: "keymanager" }: bool name: "keymanager" .}: bool
keymanagerPort* {. keymanagerPort* {.
desc: "Listening port for the REST keymanager API" desc: "Listening port for the REST keymanager API"
defaultValue: DefaultEth2RestPort defaultValue: DefaultEth2RestPort
defaultValueDesc: "5052" defaultValueDesc: "5052"
name: "keymanager-port" }: Port name: "keymanager-port" .}: Port
keymanagerAddress* {. keymanagerAddress* {.
desc: "Listening port for the REST keymanager API" desc: "Listening port for the REST keymanager API"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "keymanager-address" }: ValidIpAddress name: "keymanager-address" .}: ValidIpAddress
keymanagerAllowedOrigin* {. keymanagerAllowedOrigin* {.
desc: "Limit the access to the Keymanager API to a particular hostname " & desc: "Limit the access to the Keymanager API to a particular hostname " &
"(for CORS-enabled clients such as browsers)" "(for CORS-enabled clients such as browsers)"
name: "keymanager-allow-origin" }: Option[string] name: "keymanager-allow-origin" .}: Option[string]
keymanagerTokenFile* {. keymanagerTokenFile* {.
desc: "A file specifying the authorization token required for accessing the keymanager API" desc: "A file specifying the authorization token required for accessing the keymanager API"
name: "keymanager-token-file" }: Option[InputFile] name: "keymanager-token-file" .}: Option[InputFile]
lightClientDataServe* {. lightClientDataServe* {.
hidden hidden
desc: "BETA: Serve data for enabling light clients to stay in sync with the network" desc: "BETA: Serve data for enabling light clients to stay in sync with the network"
name: "light-client-data-serve"}: Option[bool] name: "light-client-data-serve" .}: Option[bool]
lightClientDataImportMode* {. lightClientDataImportMode* {.
hidden hidden
desc: "BETA: Which classes of light client data to import. " & 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)" "Must be one of: none, only-new, full (slow startup), on-demand (may miss validator duties)"
name: "light-client-data-import-mode"}: Option[LightClientDataImportMode] name: "light-client-data-import-mode" .}: Option[LightClientDataImportMode]
inProcessValidators* {. 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" 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"
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. 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.
name: "in-process-validators" }: bool name: "in-process-validators" .}: bool
discv5Enabled* {. discv5Enabled* {.
desc: "Enable Discovery v5" desc: "Enable Discovery v5"
defaultValue: true defaultValue: true
name: "discv5" }: bool name: "discv5" .}: bool
dumpEnabled* {. dumpEnabled* {.
desc: "Write SSZ dumps of blocks, attestations and states to data dir" desc: "Write SSZ dumps of blocks, attestations and states to data dir"
defaultValue: false defaultValue: false
name: "dump" }: bool name: "dump" .}: bool
directPeers* {. 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." 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."
@ -478,15 +478,14 @@ type
doppelgangerDetection* {. doppelgangerDetection* {.
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." 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."
defaultValue: true defaultValue: true
name: "doppelganger-detection" name: "doppelganger-detection" .}: bool
}: bool
syncHorizon* {. syncHorizon* {.
hidden hidden
desc: "Number of empty slots to process before considering the client out of sync" desc: "Number of empty slots to process before considering the client out of sync"
defaultValue: MaxEmptySlotCount defaultValue: MaxEmptySlotCount
defaultValueDesc: "50" defaultValueDesc: "50"
name: "sync-horizon" }: uint64 name: "sync-horizon" .}: uint64
# TODO nim-confutils on 32-bit platforms overflows decoding integers # TODO nim-confutils on 32-bit platforms overflows decoding integers
# requiring 64-bit representations and doesn't build when specifying # requiring 64-bit representations and doesn't build when specifying
@ -494,22 +493,21 @@ type
terminalTotalDifficultyOverride* {. terminalTotalDifficultyOverride* {.
hidden hidden
desc: "Override pre-configured TERMINAL_TOTAL_DIFFICULTY parameter" desc: "Override pre-configured TERMINAL_TOTAL_DIFFICULTY parameter"
name: "terminal-total-difficulty-override" name: "terminal-total-difficulty-override" .}: Option[string]
}: Option[string]
validatorMonitorAuto* {. validatorMonitorAuto* {.
desc: "Automatically monitor locally active validators (BETA)" desc: "Automatically monitor locally active validators (BETA)"
defaultValue: false defaultValue: false
name: "validator-monitor-auto" }: bool name: "validator-monitor-auto" .}: bool
validatorMonitorPubkeys* {. validatorMonitorPubkeys* {.
desc: "One or more validators to monitor - works best when --subscribe-all-subnets is enabled (BETA)" desc: "One or more validators to monitor - works best when --subscribe-all-subnets is enabled (BETA)"
name: "validator-monitor-pubkey" }: seq[ValidatorPubKey] name: "validator-monitor-pubkey" .}: seq[ValidatorPubKey]
validatorMonitorTotals* {. validatorMonitorTotals* {.
desc: "Publish metrics to single 'totals' label for better collection performance when monitoring many validators (BETA)" desc: "Publish metrics to single 'totals' label for better collection performance when monitoring many validators (BETA)"
defaultValue: false defaultValue: false
name: "validator-monitor-totals" }: bool name: "validator-monitor-totals" .}: bool
# https://github.com/ethereum/consensus-specs/blob/v1.2.0-rc.1/sync/optimistic.md#fork-choice-poisoning # https://github.com/ethereum/consensus-specs/blob/v1.2.0-rc.1/sync/optimistic.md#fork-choice-poisoning
safeSlotsToImportOptimistically* {. safeSlotsToImportOptimistically* {.
@ -517,7 +515,7 @@ type
desc: "Modify SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY" desc: "Modify SAFE_SLOTS_TO_IMPORT_OPTIMISTICALLY"
# https://github.com/ethereum/consensus-specs/blob/v1.2.0-rc.1/sync/optimistic.md#constants # https://github.com/ethereum/consensus-specs/blob/v1.2.0-rc.1/sync/optimistic.md#constants
defaultValue: 128 defaultValue: 128
name: "safe-slots-to-import-optimistically" }: uint16 name: "safe-slots-to-import-optimistically" .}: uint16
# Same option as appears in Lighthouse and Prysm # Same option as appears in Lighthouse and Prysm
# https://lighthouse-book.sigmaprime.io/suggested-fee-recipient.html # https://lighthouse-book.sigmaprime.io/suggested-fee-recipient.html
@ -529,60 +527,60 @@ type
of BNStartUpCmd.createTestnet: of BNStartUpCmd.createTestnet:
testnetDepositsFile* {. testnetDepositsFile* {.
desc: "A LaunchPad deposits file for the genesis state validators" desc: "A LaunchPad deposits file for the genesis state validators"
name: "deposits-file" }: InputFile name: "deposits-file" .}: InputFile
totalValidators* {. totalValidators* {.
desc: "The number of validator deposits in the newly created chain" desc: "The number of validator deposits in the newly created chain"
name: "total-validators" }: uint64 name: "total-validators" .}: uint64
bootstrapAddress* {. bootstrapAddress* {.
desc: "The public IP address that will be advertised as a bootstrap node for the testnet" desc: "The public IP address that will be advertised as a bootstrap node for the testnet"
defaultValue: init(ValidIpAddress, "127.0.0.1") defaultValue: init(ValidIpAddress, "127.0.0.1")
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "bootstrap-address" }: ValidIpAddress name: "bootstrap-address" .}: ValidIpAddress
bootstrapPort* {. bootstrapPort* {.
desc: "The TCP/UDP port that will be used by the bootstrap node" desc: "The TCP/UDP port that will be used by the bootstrap node"
defaultValue: defaultEth2TcpPort defaultValue: defaultEth2TcpPort
defaultValueDesc: "9000" defaultValueDesc: "9000"
name: "bootstrap-port" }: Port name: "bootstrap-port" .}: Port
genesisOffset* {. genesisOffset* {.
desc: "Seconds from now to add to genesis time" desc: "Seconds from now to add to genesis time"
defaultValue: 5 defaultValue: 5
name: "genesis-offset" }: int name: "genesis-offset" .}: int
outputGenesis* {. outputGenesis* {.
desc: "Output file where to write the initial state snapshot" desc: "Output file where to write the initial state snapshot"
name: "output-genesis" }: OutFile name: "output-genesis" .}: OutFile
outputBootstrapFile* {. outputBootstrapFile* {.
desc: "Output file with list of bootstrap nodes for the network" desc: "Output file with list of bootstrap nodes for the network"
name: "output-bootstrap-file" }: OutFile name: "output-bootstrap-file" .}: OutFile
of BNStartUpCmd.wallets: of BNStartUpCmd.wallets:
case walletsCmd* {.command.}: WalletsCmd case walletsCmd* {.command.}: WalletsCmd
of WalletsCmd.create: of WalletsCmd.create:
nextAccount* {. nextAccount* {.
desc: "Initial value for the 'nextaccount' property of the wallet" desc: "Initial value for the 'nextaccount' property of the wallet"
name: "next-account" }: Option[Natural] name: "next-account" .}: Option[Natural]
createdWalletNameFlag* {. createdWalletNameFlag* {.
desc: "An easy-to-remember name for the wallet of your choice" desc: "An easy-to-remember name for the wallet of your choice"
name: "name"}: Option[WalletName] name: "name" .}: Option[WalletName]
createdWalletFileFlag* {. createdWalletFileFlag* {.
desc: "Output wallet file" desc: "Output wallet file"
name: "out" }: Option[OutFile] name: "out" .}: Option[OutFile]
of WalletsCmd.restore: of WalletsCmd.restore:
restoredWalletNameFlag* {. restoredWalletNameFlag* {.
desc: "An easy-to-remember name for the wallet of your choice" desc: "An easy-to-remember name for the wallet of your choice"
name: "name"}: Option[WalletName] name: "name" .}: Option[WalletName]
restoredWalletFileFlag* {. restoredWalletFileFlag* {.
desc: "Output wallet file" desc: "Output wallet file"
name: "out" }: Option[OutFile] name: "out" .}: Option[OutFile]
restoredDepositsCount* {. restoredDepositsCount* {.
desc: "Expected number of deposits to recover. If not specified, " & desc: "Expected number of deposits to recover. If not specified, " &
@ -599,33 +597,33 @@ type
totalDeposits* {. totalDeposits* {.
desc: "Number of deposits to generate" desc: "Number of deposits to generate"
defaultValue: 1 defaultValue: 1
name: "count" }: int name: "count" .}: int
existingWalletId* {. existingWalletId* {.
desc: "An existing wallet ID. If not specified, a new wallet will be created" desc: "An existing wallet ID. If not specified, a new wallet will be created"
name: "wallet" }: Option[WalletName] name: "wallet" .}: Option[WalletName]
outValidatorsDir* {. outValidatorsDir* {.
desc: "Output folder for validator keystores" desc: "Output folder for validator keystores"
defaultValue: "validators" defaultValue: "validators"
name: "out-validators-dir" }: string name: "out-validators-dir" .}: string
outSecretsDir* {. outSecretsDir* {.
desc: "Output folder for randomly generated keystore passphrases" desc: "Output folder for randomly generated keystore passphrases"
defaultValue: "secrets" defaultValue: "secrets"
name: "out-secrets-dir" }: string name: "out-secrets-dir" .}: string
outDepositsFile* {. outDepositsFile* {.
desc: "The name of generated deposits file" desc: "The name of generated deposits file"
name: "out-deposits-file" }: Option[OutFile] name: "out-deposits-file" .}: Option[OutFile]
newWalletNameFlag* {. newWalletNameFlag* {.
desc: "An easy-to-remember name for the wallet of your choice" desc: "An easy-to-remember name for the wallet of your choice"
name: "new-wallet-name" }: Option[WalletName] name: "new-wallet-name" .}: Option[WalletName]
newWalletFileFlag* {. newWalletFileFlag* {.
desc: "Output wallet file" desc: "Output wallet file"
name: "new-wallet-file" }: Option[OutFile] name: "new-wallet-file" .}: Option[OutFile]
#[ #[
of DepositsCmd.status: of DepositsCmd.status:
@ -635,22 +633,22 @@ type
of DepositsCmd.`import`: of DepositsCmd.`import`:
importedDepositsDir* {. importedDepositsDir* {.
argument argument
desc: "A directory with keystores to import" }: Option[InputDir] desc: "A directory with keystores to import" .}: Option[InputDir]
of DepositsCmd.exit: of DepositsCmd.exit:
exitedValidator* {. exitedValidator* {.
name: "validator" name: "validator"
desc: "Validator index or a public key of the exited validator" }: string desc: "Validator index or a public key of the exited validator" .}: string
exitAtEpoch* {. exitAtEpoch* {.
name: "epoch" name: "epoch"
desc: "The desired exit epoch" }: Option[uint64] desc: "The desired exit epoch" .}: Option[uint64]
restUrlForExit* {. restUrlForExit* {.
desc: "URL of the beacon node REST service" desc: "URL of the beacon node REST service"
defaultValue: defaultBeaconNode defaultValue: defaultBeaconNode
defaultValueDesc: "http://127.0.0.1:5052" defaultValueDesc: "http://127.0.0.1:5052"
name: "rest-url" }: string name: "rest-url" .}: string
of BNStartUpCmd.record: of BNStartUpCmd.record:
case recordCmd* {.command.}: RecordCmd case recordCmd* {.command.}: RecordCmd
@ -688,7 +686,7 @@ type
web3TestUrl* {. web3TestUrl* {.
argument argument
desc: "The web3 provider URL to test" desc: "The web3 provider URL to test"
name: "url" }: Uri name: "url" .}: Uri
of BNStartUpCmd.slashingdb: of BNStartUpCmd.slashingdb:
case slashingdbCmd* {.command.}: SlashProtCmd case slashingdbCmd* {.command.}: SlashProtCmd
@ -701,10 +699,10 @@ type
desc: "Limit the export to specific validators " & desc: "Limit the export to specific validators " &
"(specified as numeric indices or public keys)" "(specified as numeric indices or public keys)"
abbr: "v" abbr: "v"
name: "validator" }: seq[PubKey0x] name: "validator" .}: seq[PubKey0x]
exportedInterchangeFile* {. exportedInterchangeFile* {.
desc: "EIP-3076 slashing protection interchange file to export" desc: "EIP-3076 slashing protection interchange file to export"
argument }: OutFile argument .}: OutFile
of BNStartUpCmd.trustedNodeSync: of BNStartUpCmd.trustedNodeSync:
trustedNodeUrl* {. trustedNodeUrl* {.
@ -722,163 +720,163 @@ type
backfillBlocks* {. backfillBlocks* {.
desc: "Backfill blocks directly from REST server instead of fetching via API" desc: "Backfill blocks directly from REST server instead of fetching via API"
defaultValue: true defaultValue: true
name: "backfill"}: bool name: "backfill" .}: bool
reindex* {. reindex* {.
desc: "Recreate historical state index at end of backfill, allowing full history access (requires full backfill)" desc: "Recreate historical state index at end of backfill, allowing full history access (requires full backfill)"
defaultValue: false}: bool defaultValue: false .}: bool
ValidatorClientConf* = object ValidatorClientConf* = object
configFile* {. configFile* {.
desc: "Loads the configuration from a TOML file" desc: "Loads the configuration from a TOML file"
name: "config-file" }: Option[InputFile] name: "config-file" .}: Option[InputFile]
logLevel* {. logLevel* {.
desc: "Sets the log level" desc: "Sets the log level"
defaultValue: "INFO" defaultValue: "INFO"
name: "log-level" }: string name: "log-level" .}: string
logStdout* {. logStdout* {.
hidden hidden
desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)" desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)"
defaultValueDesc: "auto" defaultValueDesc: "auto"
defaultValue: StdoutLogKind.Auto defaultValue: StdoutLogKind.Auto
name: "log-format" }: StdoutLogKind name: "log-format" .}: StdoutLogKind
logFile* {. logFile* {.
desc: "Specifies a path for the written Json log file (deprecated)" desc: "Specifies a path for the written Json log file (deprecated)"
name: "log-file" }: Option[OutFile] name: "log-file" .}: Option[OutFile]
dataDir* {. dataDir* {.
desc: "The directory where nimbus will store all blockchain data" desc: "The directory where nimbus will store all blockchain data"
defaultValue: config.defaultDataDir() defaultValue: config.defaultDataDir()
defaultValueDesc: "" defaultValueDesc: ""
abbr: "d" abbr: "d"
name: "data-dir" }: OutDir name: "data-dir" .}: OutDir
nonInteractive* {. nonInteractive* {.
desc: "Do not display interative prompts. Quit on missing configuration" desc: "Do not display interative prompts. Quit on missing configuration"
name: "non-interactive" }: bool name: "non-interactive" .}: bool
validatorsDirFlag* {. validatorsDirFlag* {.
desc: "A directory containing validator keystores" desc: "A directory containing validator keystores"
name: "validators-dir" }: Option[InputDir] name: "validators-dir" .}: Option[InputDir]
secretsDirFlag* {. secretsDirFlag* {.
desc: "A directory containing validator keystore passwords" desc: "A directory containing validator keystore passwords"
name: "secrets-dir" }: Option[InputDir] name: "secrets-dir" .}: Option[InputDir]
keymanagerEnabled* {. keymanagerEnabled* {.
desc: "Enable the REST keymanager API (BETA version)" desc: "Enable the REST keymanager API (BETA version)"
defaultValue: false defaultValue: false
name: "keymanager" }: bool name: "keymanager" .}: bool
keymanagerPort* {. keymanagerPort* {.
desc: "Listening port for the REST keymanager API" desc: "Listening port for the REST keymanager API"
defaultValue: DefaultEth2RestPort defaultValue: DefaultEth2RestPort
defaultValueDesc: "5052" defaultValueDesc: "5052"
name: "keymanager-port" }: Port name: "keymanager-port" .}: Port
keymanagerAddress* {. keymanagerAddress* {.
desc: "Listening port for the REST keymanager API" desc: "Listening port for the REST keymanager API"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "keymanager-address" }: ValidIpAddress name: "keymanager-address" .}: ValidIpAddress
keymanagerTokenFile* {. keymanagerTokenFile* {.
desc: "A file specifying the authorizition token required for accessing the keymanager API" desc: "A file specifying the authorizition token required for accessing the keymanager API"
name: "keymanager-token-file" }: Option[InputFile] name: "keymanager-token-file" .}: Option[InputFile]
graffiti* {. graffiti* {.
desc: "The graffiti value that will appear in proposed blocks. " & desc: "The graffiti value that will appear in proposed blocks. " &
"You can use a 0x-prefixed hex encoded string to specify " & "You can use a 0x-prefixed hex encoded string to specify " &
"raw bytes" "raw bytes"
name: "graffiti" }: Option[GraffitiBytes] name: "graffiti" .}: Option[GraffitiBytes]
stopAtEpoch* {. stopAtEpoch* {.
desc: "A positive epoch selects the epoch at which to stop" desc: "A positive epoch selects the epoch at which to stop"
defaultValue: 0 defaultValue: 0
name: "stop-at-epoch" }: uint64 name: "stop-at-epoch" .}: uint64
beaconNodes* {. beaconNodes* {.
desc: "URL addresses to one or more beacon node HTTP REST APIs", desc: "URL addresses to one or more beacon node HTTP REST APIs",
defaultValue: @[defaultBeaconNode] defaultValue: @[defaultBeaconNode]
defaultValueDesc: "http://127.0.0.1:5052" defaultValueDesc: "http://127.0.0.1:5052"
name: "beacon-node" }: seq[string] name: "beacon-node" .}: seq[string]
SigningNodeConf* = object SigningNodeConf* = object
configFile* {. configFile* {.
desc: "Loads the configuration from a TOML file" desc: "Loads the configuration from a TOML file"
name: "config-file" }: Option[InputFile] name: "config-file" .}: Option[InputFile]
logLevel* {. logLevel* {.
desc: "Sets the log level" desc: "Sets the log level"
defaultValue: "INFO" defaultValue: "INFO"
name: "log-level" }: string name: "log-level" .}: string
logStdout* {. logStdout* {.
desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)" desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)"
defaultValueDesc: "auto" defaultValueDesc: "auto"
defaultValue: StdoutLogKind.Auto defaultValue: StdoutLogKind.Auto
name: "log-stdout" }: StdoutLogKind name: "log-stdout" .}: StdoutLogKind
logFile* {. logFile* {.
desc: "Specifies a path for the written Json log file" desc: "Specifies a path for the written Json log file"
name: "log-file" }: Option[OutFile] name: "log-file" .}: Option[OutFile]
nonInteractive* {. nonInteractive* {.
desc: "Do not display interative prompts. Quit on missing configuration" desc: "Do not display interative prompts. Quit on missing configuration"
name: "non-interactive" }: bool name: "non-interactive" .}: bool
dataDir* {. dataDir* {.
desc: "The directory where nimbus will store validator's keys" desc: "The directory where nimbus will store validator's keys"
defaultValue: config.defaultDataDir() defaultValue: config.defaultDataDir()
defaultValueDesc: "" defaultValueDesc: ""
abbr: "d" abbr: "d"
name: "data-dir" }: OutDir name: "data-dir" .}: OutDir
validatorsDirFlag* {. validatorsDirFlag* {.
desc: "A directory containing validator keystores" desc: "A directory containing validator keystores"
name: "validators-dir" }: Option[InputDir] name: "validators-dir" .}: Option[InputDir]
secretsDirFlag* {. secretsDirFlag* {.
desc: "A directory containing validator keystore passwords" desc: "A directory containing validator keystore passwords"
name: "secrets-dir" }: Option[InputDir] name: "secrets-dir" .}: Option[InputDir]
serverIdent* {. serverIdent* {.
desc: "Server identifier which will be used in HTTP Host header" desc: "Server identifier which will be used in HTTP Host header"
name: "server-ident" }: Option[string] name: "server-ident" .}: Option[string]
requestTimeout* {. requestTimeout* {.
desc: "Request timeout, maximum time that node will wait for remote " & desc: "Request timeout, maximum time that node will wait for remote " &
"client request (in seconds)" "client request (in seconds)"
defaultValue: defaultSigningNodeRequestTimeout defaultValue: defaultSigningNodeRequestTimeout
name: "request-timeout" }: int name: "request-timeout" .}: int
bindPort* {. bindPort* {.
desc: "Port for the REST (BETA version) HTTP server" desc: "Port for the REST (BETA version) HTTP server"
defaultValue: DefaultEth2RestPort defaultValue: DefaultEth2RestPort
defaultValueDesc: "5052" defaultValueDesc: "5052"
name: "bind-port" }: Port name: "bind-port" .}: Port
bindAddress* {. bindAddress* {.
desc: "Listening address of the REST (BETA version) HTTP server" desc: "Listening address of the REST (BETA version) HTTP server"
defaultValue: defaultAdminListenAddress defaultValue: defaultAdminListenAddress
defaultValueDesc: "127.0.0.1" defaultValueDesc: "127.0.0.1"
name: "bind-address" }: ValidIpAddress name: "bind-address" .}: ValidIpAddress
tlsEnabled* {. tlsEnabled* {.
desc: "Use secure TLS communication for REST (BETA version) server" desc: "Use secure TLS communication for REST (BETA version) server"
defaultValue: false defaultValue: false
name: "tls" }: bool name: "tls" .}: bool
tlsCertificate* {. tlsCertificate* {.
desc: "Path to SSL certificate file" desc: "Path to SSL certificate file"
name: "tls-cert" }: Option[InputFile] name: "tls-cert" .}: Option[InputFile]
tlsPrivateKey* {. tlsPrivateKey* {.
desc: "Path to SSL ceritificate's private key" desc: "Path to SSL ceritificate's private key"
name: "tls-key" }: Option[InputFile] name: "tls-key" .}: Option[InputFile]
AnyConf* = BeaconNodeConf | ValidatorClientConf | SigningNodeConf AnyConf* = BeaconNodeConf | ValidatorClientConf | SigningNodeConf

View File

@ -20,68 +20,68 @@ type LightClientConf* = object
# Config # Config
configFile* {. configFile* {.
desc: "Loads the configuration from a TOML file" desc: "Loads the configuration from a TOML file"
name: "config-file" }: Option[InputFile] name: "config-file" .}: Option[InputFile]
# Logging # Logging
logLevel* {. logLevel* {.
desc: "Sets the log level" desc: "Sets the log level"
defaultValue: "INFO" defaultValue: "INFO"
name: "log-level" }: string name: "log-level" .}: string
logStdout* {. logStdout* {.
hidden hidden
desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)" desc: "Specifies what kind of logs should be written to stdout (auto, colors, nocolors, json)"
defaultValueDesc: "auto" defaultValueDesc: "auto"
defaultValue: StdoutLogKind.Auto defaultValue: StdoutLogKind.Auto
name: "log-format" }: StdoutLogKind name: "log-format" .}: StdoutLogKind
logFile* {. logFile* {.
desc: "Specifies a path for the written Json log file (deprecated)" desc: "Specifies a path for the written Json log file (deprecated)"
name: "log-file" }: Option[OutFile] name: "log-file" .}: Option[OutFile]
# Network # Network
eth2Network* {. eth2Network* {.
desc: "The Eth2 network to join" desc: "The Eth2 network to join"
defaultValueDesc: "mainnet" defaultValueDesc: "mainnet"
name: "network" }: Option[string] name: "network" .}: Option[string]
# Libp2p # Libp2p
bootstrapNodes* {. bootstrapNodes* {.
desc: "Specifies one or more bootstrap nodes to use when connecting to the network" desc: "Specifies one or more bootstrap nodes to use when connecting to the network"
abbr: "b" abbr: "b"
name: "bootstrap-node" }: seq[string] name: "bootstrap-node" .}: seq[string]
bootstrapNodesFile* {. bootstrapNodesFile* {.
desc: "Specifies a line-delimited file of bootstrap Ethereum network addresses" desc: "Specifies a line-delimited file of bootstrap Ethereum network addresses"
defaultValue: "" defaultValue: ""
name: "bootstrap-file" }: InputFile name: "bootstrap-file" .}: InputFile
listenAddress* {. listenAddress* {.
desc: "Listening address for the Ethereum LibP2P and Discovery v5 traffic" desc: "Listening address for the Ethereum LibP2P and Discovery v5 traffic"
defaultValue: defaultListenAddress defaultValue: defaultListenAddress
defaultValueDesc: "0.0.0.0" defaultValueDesc: "0.0.0.0"
name: "listen-address" }: ValidIpAddress name: "listen-address" .}: ValidIpAddress
tcpPort* {. tcpPort* {.
desc: "Listening TCP port for Ethereum LibP2P traffic" desc: "Listening TCP port for Ethereum LibP2P traffic"
defaultValue: defaultEth2TcpPort defaultValue: defaultEth2TcpPort
defaultValueDesc: "9000" defaultValueDesc: "9000"
name: "tcp-port" }: Port name: "tcp-port" .}: Port
udpPort* {. udpPort* {.
desc: "Listening UDP port for node discovery" desc: "Listening UDP port for node discovery"
defaultValue: defaultEth2TcpPort defaultValue: defaultEth2TcpPort
defaultValueDesc: "9000" defaultValueDesc: "9000"
name: "udp-port" }: Port name: "udp-port" .}: Port
maxPeers* {. maxPeers* {.
desc: "The target number of peers to connect to" desc: "The target number of peers to connect to"
defaultValue: 160 # 5 (fanout) * 64 (subnets) / 2 (subs) for a heathy mesh defaultValue: 160 # 5 (fanout) * 64 (subnets) / 2 (subs) for a heathy mesh
name: "max-peers" }: int name: "max-peers" .}: int
hardMaxPeers* {. hardMaxPeers* {.
desc: "The maximum number of peers to connect to. Defaults to maxPeers * 1.5" desc: "The maximum number of peers to connect to. Defaults to maxPeers * 1.5"
name: "hard-max-peers" }: Option[int] name: "hard-max-peers" .}: Option[int]
nat* {. nat* {.
desc: "Specify method to use for determining public address. " & desc: "Specify method to use for determining public address. " &
@ -100,12 +100,12 @@ type LightClientConf* = object
agentString* {. agentString* {.
defaultValue: "nimbus", defaultValue: "nimbus",
desc: "Node agent string which is used as identifier in network" desc: "Node agent string which is used as identifier in network"
name: "agent-string" }: string name: "agent-string" .}: string
discv5Enabled* {. discv5Enabled* {.
desc: "Enable Discovery v5" desc: "Enable Discovery v5"
defaultValue: true defaultValue: true
name: "discv5" }: bool name: "discv5" .}: bool
directPeers* {. 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." 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."
@ -114,11 +114,11 @@ type LightClientConf* = object
# Light client # Light client
trustedBlockRoot* {. trustedBlockRoot* {.
desc: "Recent trusted finalized block root to initialize light client from" desc: "Recent trusted finalized block root to initialize light client from"
name: "trusted-block-root" }: Eth2Digest name: "trusted-block-root" .}: Eth2Digest
# Testing # Testing
stopAtEpoch* {. stopAtEpoch* {.
hidden hidden
desc: "The wall-time epoch at which to exit the program. (for testing purposes)" desc: "The wall-time epoch at which to exit the program. (for testing purposes)"
defaultValue: 0 defaultValue: 0
name: "stop-at-epoch" }: uint64 name: "stop-at-epoch" .}: uint64