Documentation ¶
Index ¶
Constants ¶
View Source
const ( RollupCategory = "1. ROLLUP" L1RPCCategory = "2. L1 RPC" SequencerCategory = "3. SEQUENCER" OperationsCategory = "4. LOGGING, METRICS, DEBUGGING, AND API" P2PCategory = "5. PEER-TO-PEER" PlasmaCategory = "6. PLASMA (EXPERIMENTAL)" MiscCategory = "7. MISC" )
View Source
const EnvVarPrefix = "NODE"
Variables ¶
View Source
var ( /* Required Flags */ L1NodeAddr = &cli.StringFlag{ Name: "l1", Usage: "Address of L1 User JSON-RPC endpoint to use (eth namespace required)", Value: "http://127.0.0.1:8545", EnvVars: prefixEnvVars("L1_ETH_RPC"), Category: RollupCategory, } L2EngineAddr = &cli.StringFlag{ Name: "l2", Usage: "Address of L2 Engine JSON-RPC endpoints to use (engine and eth namespace required)", EnvVars: prefixEnvVars("L2_ENGINE_RPC"), Category: RollupCategory, } L2EngineJWTSecret = &cli.StringFlag{ Name: "l2.jwt-secret", Usage: "Path to JWT secret key. Keys are 32 bytes, hex encoded in a file. A new key will be generated if the file is empty.", EnvVars: prefixEnvVars("L2_ENGINE_AUTH"), Value: "", Destination: new(string), Category: RollupCategory, } BeaconAddr = &cli.StringFlag{ Name: "l1.beacon", Usage: "Address of L1 Beacon-node HTTP endpoint to use.", Required: false, EnvVars: prefixEnvVars("L1_BEACON"), Category: RollupCategory, } /* Optional Flags */ BeaconHeader = &cli.StringFlag{ Name: "l1.beacon-header", Usage: "Optional HTTP header to add to all requests to the L1 Beacon endpoint. Format: 'X-Key: Value'", Required: false, EnvVars: prefixEnvVars("L1_BEACON_HEADER"), Category: L1RPCCategory, } BeaconArchiverAddr = &cli.StringFlag{ Name: "l1.beacon-archiver", Usage: "Address of L1 Beacon-node compatible HTTP endpoint to use. This is used to fetch blobs that the --l1.beacon does not have (i.e expired blobs).", Required: false, EnvVars: prefixEnvVars("L1_BEACON_ARCHIVER"), Category: L1RPCCategory, } BeaconCheckIgnore = &cli.BoolFlag{ Name: "l1.beacon.ignore", Usage: "When false, halts op-node startup if the healthcheck to the Beacon-node endpoint fails.", Required: false, Value: false, EnvVars: prefixEnvVars("L1_BEACON_IGNORE"), Category: L1RPCCategory, } BeaconFetchAllSidecars = &cli.BoolFlag{ Name: "l1.beacon.fetch-all-sidecars", Usage: "If true, all sidecars are fetched and filtered locally. Workaround for buggy Beacon nodes.", Required: false, Value: false, EnvVars: prefixEnvVars("L1_BEACON_FETCH_ALL_SIDECARS"), Category: L1RPCCategory, } SyncModeFlag = &cli.GenericFlag{ Name: "syncmode", Usage: fmt.Sprintf("Blockchain sync mode (options: %s)", openum.EnumString(sync.ModeStrings)), EnvVars: prefixEnvVars("SYNCMODE"), Value: func() *sync.Mode { out := sync.CLSync return &out }(), Category: RollupCategory, } RPCListenAddr = &cli.StringFlag{ Name: "rpc.addr", Usage: "RPC listening address", EnvVars: prefixEnvVars("RPC_ADDR"), Value: "127.0.0.1", Category: OperationsCategory, } RPCListenPort = &cli.IntFlag{ Name: "rpc.port", Usage: "RPC listening port", EnvVars: prefixEnvVars("RPC_PORT"), Value: 9545, Category: OperationsCategory, } RPCEnableAdmin = &cli.BoolFlag{ Name: "rpc.enable-admin", Usage: "Enable the admin API (experimental)", EnvVars: prefixEnvVars("RPC_ENABLE_ADMIN"), Category: OperationsCategory, } RPCAdminPersistence = &cli.StringFlag{ Name: "rpc.admin-state", Usage: "File path used to persist state changes made via the admin API so they persist across restarts. Disabled if not set.", EnvVars: prefixEnvVars("RPC_ADMIN_STATE"), Category: OperationsCategory, } L1TrustRPC = &cli.BoolFlag{ Name: "l1.trustrpc", Usage: "Trust the L1 RPC, sync faster at risk of malicious/buggy RPC providing bad or inconsistent L1 data", EnvVars: prefixEnvVars("L1_TRUST_RPC"), Category: L1RPCCategory, } L1RPCProviderKind = &cli.GenericFlag{ Name: "l1.rpckind", Usage: "The kind of RPC provider, used to inform optimal transactions receipts fetching, and thus reduce costs. Valid options: " + openum.EnumString(sources.RPCProviderKinds), EnvVars: prefixEnvVars("L1_RPC_KIND"), Value: func() *sources.RPCProviderKind { out := sources.RPCKindStandard return &out }(), Category: L1RPCCategory, } L1RethDBPath = &cli.StringFlag{ Name: "l1.rethdb", Usage: "The L1 RethDB path, used to fetch receipts for L1 blocks. Only applicable when using the `reth_db` RPC kind with `l1.rpckind`.", EnvVars: prefixEnvVars("L1_RETHDB"), Hidden: true, Category: L1RPCCategory, } L1RPCMaxConcurrency = &cli.IntFlag{ Name: "l1.max-concurrency", Usage: "Maximum number of concurrent RPC requests to make to the L1 RPC provider.", EnvVars: prefixEnvVars("L1_MAX_CONCURRENCY"), Value: 10, Category: L1RPCCategory, } L1RPCRateLimit = &cli.Float64Flag{ Name: "l1.rpc-rate-limit", Usage: "Optional self-imposed global rate-limit on L1 RPC requests, specified in requests / second. Disabled if set to 0.", EnvVars: prefixEnvVars("L1_RPC_RATE_LIMIT"), Value: 0, Category: L1RPCCategory, } L1RPCMaxBatchSize = &cli.IntFlag{ Name: "l1.rpc-max-batch-size", Usage: "Maximum number of RPC requests to bundle, e.g. during L1 blocks receipt fetching. The L1 RPC rate limit counts this as N items, but allows it to burst at once.", EnvVars: prefixEnvVars("L1_RPC_MAX_BATCH_SIZE"), Value: 20, Category: L1RPCCategory, } L1HTTPPollInterval = &cli.DurationFlag{ Name: "l1.http-poll-interval", Usage: "Polling interval for latest-block subscription when using an HTTP RPC provider. Ignored for other types of RPC endpoints.", EnvVars: prefixEnvVars("L1_HTTP_POLL_INTERVAL"), Value: time.Second * 12, Category: L1RPCCategory, } VerifierL1Confs = &cli.Uint64Flag{ Name: "verifier.l1-confs", Usage: "Number of L1 blocks to keep distance from the L1 head before deriving L2 data from. Reorgs are supported, but may be slow to perform.", EnvVars: prefixEnvVars("VERIFIER_L1_CONFS"), Value: 0, Category: L1RPCCategory, } SequencerEnabledFlag = &cli.BoolFlag{ Name: "sequencer.enabled", Usage: "Enable sequencing of new L2 blocks. A separate batch submitter has to be deployed to publish the data for verifiers.", EnvVars: prefixEnvVars("SEQUENCER_ENABLED"), Category: SequencerCategory, } SequencerStoppedFlag = &cli.BoolFlag{ Name: "sequencer.stopped", Usage: "Initialize the sequencer in a stopped state. The sequencer can be started using the admin_startSequencer RPC", EnvVars: prefixEnvVars("SEQUENCER_STOPPED"), Category: SequencerCategory, } SequencerMaxSafeLagFlag = &cli.Uint64Flag{ Name: "sequencer.max-safe-lag", Usage: "Maximum number of L2 blocks for restricting the distance between L2 safe and unsafe. Disabled if 0.", EnvVars: prefixEnvVars("SEQUENCER_MAX_SAFE_LAG"), Value: 0, Category: SequencerCategory, } SequencerL1Confs = &cli.Uint64Flag{ Name: "sequencer.l1-confs", Usage: "Number of L1 blocks to keep distance from the L1 head as a sequencer for picking an L1 origin.", EnvVars: prefixEnvVars("SEQUENCER_L1_CONFS"), Value: 4, Category: SequencerCategory, } L1EpochPollIntervalFlag = &cli.DurationFlag{ Name: "l1.epoch-poll-interval", Usage: "Poll interval for retrieving new L1 epoch updates such as safe and finalized block changes. Disabled if 0 or negative.", EnvVars: prefixEnvVars("L1_EPOCH_POLL_INTERVAL"), Value: time.Second * 12 * 32, Category: L1RPCCategory, } RuntimeConfigReloadIntervalFlag = &cli.DurationFlag{ Name: "l1.runtime-config-reload-interval", Usage: "Poll interval for reloading the runtime config, useful when config events are not being picked up. Disabled if 0 or negative.", EnvVars: prefixEnvVars("L1_RUNTIME_CONFIG_RELOAD_INTERVAL"), Value: time.Minute * 10, Category: L1RPCCategory, } MetricsEnabledFlag = &cli.BoolFlag{ Name: "metrics.enabled", Usage: "Enable the metrics server", EnvVars: prefixEnvVars("METRICS_ENABLED"), Category: OperationsCategory, } MetricsAddrFlag = &cli.StringFlag{ Name: "metrics.addr", Usage: "Metrics listening address", Value: "0.0.0.0", EnvVars: prefixEnvVars("METRICS_ADDR"), Category: OperationsCategory, } MetricsPortFlag = &cli.IntFlag{ Name: "metrics.port", Usage: "Metrics listening port", Value: 7300, EnvVars: prefixEnvVars("METRICS_PORT"), Category: OperationsCategory, } SnapshotLog = &cli.StringFlag{ Name: "snapshotlog.file", Usage: "Path to the snapshot log file", EnvVars: prefixEnvVars("SNAPSHOT_LOG"), Category: OperationsCategory, } HeartbeatEnabledFlag = &cli.BoolFlag{ Name: "heartbeat.enabled", Usage: "Enables or disables heartbeating", EnvVars: prefixEnvVars("HEARTBEAT_ENABLED"), Category: OperationsCategory, } HeartbeatMonikerFlag = &cli.StringFlag{ Name: "heartbeat.moniker", Usage: "Sets a moniker for this node", EnvVars: prefixEnvVars("HEARTBEAT_MONIKER"), Category: OperationsCategory, } HeartbeatURLFlag = &cli.StringFlag{ Name: "heartbeat.url", Usage: "Sets the URL to heartbeat to", EnvVars: prefixEnvVars("HEARTBEAT_URL"), Value: "https://heartbeat.optimism.io", Category: OperationsCategory, } RollupHalt = &cli.StringFlag{ Name: "rollup.halt", Usage: "Opt-in option to halt on incompatible protocol version requirements of the given level (major/minor/patch/none), as signaled onchain in L1", EnvVars: prefixEnvVars("ROLLUP_HALT"), Category: RollupCategory, Hidden: true, } RollupLoadProtocolVersions = &cli.BoolFlag{ Name: "rollup.load-protocol-versions", Usage: "Load protocol versions from the superchain L1 ProtocolVersions contract (if available), and report in logs and metrics", EnvVars: prefixEnvVars("ROLLUP_LOAD_PROTOCOL_VERSIONS"), Category: RollupCategory, Hidden: true, } SafeDBPath = &cli.StringFlag{ Name: "safedb.path", Usage: "File path used to persist safe head update data. Disabled if not set.", EnvVars: prefixEnvVars("SAFEDB_PATH"), Category: OperationsCategory, } /* Deprecated Flags */ L2EngineSyncEnabled = &cli.BoolFlag{ Name: "l2.engine-sync", Usage: "WARNING: Deprecated. Use --syncmode=execution-layer instead", EnvVars: prefixEnvVars("L2_ENGINE_SYNC_ENABLED"), Value: false, Hidden: true, } SkipSyncStartCheck = &cli.BoolFlag{ Name: "l2.skip-sync-start-check", Usage: "Skip sanity check of consistency of L1 origins of the unsafe L2 blocks when determining the sync-starting point. " + "This defers the L1-origin verification, and is recommended to use in when utilizing l2.engine-sync", EnvVars: prefixEnvVars("L2_SKIP_SYNC_START_CHECK"), Value: false, Hidden: true, } BetaExtraNetworks = &cli.BoolFlag{ Name: "beta.extra-networks", Usage: "Legacy flag, ignored, all superchain-registry networks are enabled by default.", EnvVars: prefixEnvVars("BETA_EXTRA_NETWORKS"), Hidden: true, } BackupL2UnsafeSyncRPC = &cli.StringFlag{ Name: "l2.backup-unsafe-sync-rpc", Usage: "Set the backup L2 unsafe sync RPC endpoint.", EnvVars: prefixEnvVars("L2_BACKUP_UNSAFE_SYNC_RPC"), Hidden: true, } BackupL2UnsafeSyncRPCTrustRPC = &cli.StringFlag{ Name: "l2.backup-unsafe-sync-rpc.trustrpc", Usage: "Like l1.trustrpc, configure if response data from the RPC needs to be verified, e.g. blockhash computation." + "This does not include checks if the blockhash is part of the canonical chain.", EnvVars: prefixEnvVars("L2_BACKUP_UNSAFE_SYNC_RPC_TRUST_RPC"), Hidden: true, } ConductorEnabledFlag = &cli.BoolFlag{ Name: "conductor.enabled", Usage: "Enable the conductor service", EnvVars: prefixEnvVars("CONDUCTOR_ENABLED"), Value: false, Hidden: true, Category: SequencerCategory, } ConductorRpcFlag = &cli.StringFlag{ Name: "conductor.rpc", Usage: "Conductor service rpc endpoint", EnvVars: prefixEnvVars("CONDUCTOR_RPC"), Value: "http://127.0.0.1:8547", Hidden: true, Category: SequencerCategory, } ConductorRpcTimeoutFlag = &cli.DurationFlag{ Name: "conductor.rpc-timeout", Usage: "Conductor service rpc timeout", EnvVars: prefixEnvVars("CONDUCTOR_RPC_TIMEOUT"), Value: time.Second * 1, Hidden: true, Category: SequencerCategory, } )
View Source
var ( DisableP2PName = "p2p.disable" NoDiscoveryName = "p2p.no-discovery" ScoringName = "p2p.scoring" PeerScoringName = "p2p.scoring.peers" PeerScoreBandsName = "p2p.score.bands" BanningName = "p2p.ban.peers" BanningThresholdName = "p2p.ban.threshold" BanningDurationName = "p2p.ban.duration" TopicScoringName = "p2p.scoring.topics" P2PPrivPathName = "p2p.priv.path" P2PPrivRawName = "p2p.priv.raw" ListenIPName = "p2p.listen.ip" ListenTCPPortName = "p2p.listen.tcp" ListenUDPPortName = "p2p.listen.udp" AdvertiseIPName = "p2p.advertise.ip" AdvertiseTCPPortName = "p2p.advertise.tcp" AdvertiseUDPPortName = "p2p.advertise.udp" BootnodesName = "p2p.bootnodes" StaticPeersName = "p2p.static" NetRestrictName = "p2p.netrestrict" HostMuxName = "p2p.mux" HostSecurityName = "p2p.security" PeersLoName = "p2p.peers.lo" PeersHiName = "p2p.peers.hi" PeersGraceName = "p2p.peers.grace" NATName = "p2p.nat" UserAgentName = "p2p.useragent" TimeoutNegotiationName = "p2p.timeout.negotiation" TimeoutAcceptName = "p2p.timeout.accept" TimeoutDialName = "p2p.timeout.dial" PeerstorePathName = "p2p.peerstore.path" DiscoveryPathName = "p2p.discovery.path" SequencerP2PKeyName = "p2p.sequencer.key" GossipMeshDName = "p2p.gossip.mesh.d" GossipMeshDloName = "p2p.gossip.mesh.lo" GossipMeshDhiName = "p2p.gossip.mesh.dhi" GossipMeshDlazyName = "p2p.gossip.mesh.dlazy" GossipFloodPublishName = "p2p.gossip.mesh.floodpublish" SyncReqRespName = "p2p.sync.req-resp" P2PPingName = "p2p.ping" )
View Source
var DeprecatedFlags = []cli.Flag{ L2EngineSyncEnabled, SkipSyncStartCheck, BetaExtraNetworks, BackupL2UnsafeSyncRPC, BackupL2UnsafeSyncRPCTrustRPC, }
View Source
var Flags []cli.Flag
Flags contains the list of configuration options available to the binary.
Functions ¶
func CheckRequired ¶
func CheckRequired(ctx *cli.Context) error
Types ¶
This section is empty.
Click to show internal directories.
Click to hide internal directories.