105 lines
2.8 KiB
Nim
Raw Normal View History

import
os, options,
confutils/defs, chronicles/options as chroniclesOptions,
milagro_crypto, json_serialization,
spec/[crypto, datatypes], randao, time
export
json_serialization
type
ValidatorKeyPath* = distinct string
StartUpCommand* = enum
noCommand
createChain
ChainStartupData* = object
validatorDeposits*: seq[Deposit]
genesisTime*: Timestamp
PrivateValidatorData* = object
privKey*: ValidatorPrivKey
randao*: Randao
2018-11-29 03:08:34 +02:00
BeaconNodeConf* = object
logLevel* {.
desc: "Sets the log level",
defaultValue: enabledLogLevel
.}: LogLevel
case cmd* {.
command
defaultValue: noCommand.}: StartUpCommand
of noCommand:
dataDir* {.
desc: "The directory where nimbus will store all blockchain data."
shortform: "d"
defaultValue: getConfigDir() / "nimbus".}: DirPath
bootstrapNodes* {.
desc: "Specifies one or more bootstrap nodes to use when connecting to the network."
longform: "bootstrapNode"
shortform: "b".}: seq[string]
bootstrapNodesFile* {.
desc: "Specifies a line-delimited file of bootsrap Ethereum network addresses"
shortform: "f"
defaultValue: "".}: FilePath
tcpPort* {.
desc: "TCP listening port".}: int
udpPort* {.
desc: "UDP listening port".}: int
validators* {.
required
desc: "A path to a pair of public and private keys for a validator. " &
"Nimbus will automatically add the extensions .privkey and .pubkey."
longform: "validator"
shortform: "v".}: seq[PrivateValidatorData]
stateSnapshot* {.
desc: "Json file specifying a recent state snapshot"
shortform: "s".}: Option[BeaconState]
of createChain:
chainStartupData* {.
desc: ""
shortform: "c".}: ChainStartupData
outputStateFile* {.
desc: "Output file where to write the initial state snapshot"
longform: "out"
shortform: "o".}: OutFilePath
2018-12-09 10:25:02 +02:00
proc readFileBytes(path: string): seq[byte] =
cast[seq[byte]](readFile(path))
2018-12-05 15:58:41 +02:00
proc loadPrivKey*(p: ValidatorKeyPath): ValidatorPrivKey =
2018-12-09 10:25:02 +02:00
initSigKey(readFileBytes(string(p) & ".privkey"))
2018-12-05 15:58:41 +02:00
2018-12-08 16:17:47 +02:00
proc loadRandao*(p: ValidatorKeyPath): Randao =
2018-12-09 10:25:02 +02:00
initRandao(readFileBytes(string(p) & ".randao"))
2018-12-05 15:58:41 +02:00
proc parseCmdArg*(T: type ValidatorKeyPath, input: TaintedString): T =
2018-12-08 16:17:47 +02:00
result = T(input)
discard loadPrivKey(result)
discard loadRandao(result)
2018-11-29 03:08:34 +02:00
template mustBeFilePath(input: TaintedString) =
if not fileExists(string input):
raise newException(ValueError, "")
template handledAsJsonFilename(T: untyped) {.dirty.} =
proc parseCmdArg*(_: type T, input: TaintedString): T =
input.mustBeFilePath
return Json.loadFile(string(input), T)
handledAsJsonFilename BeaconState
handledAsJsonFilename ChainStartupData
handledAsJsonFilename PrivateValidatorData