diff --git a/go/node/cmd/cli.go b/go/node/cmd/cli.go index fd82d60ddd..d631846e3c 100644 --- a/go/node/cmd/cli.go +++ b/go/node/cmd/cli.go @@ -43,6 +43,7 @@ type NodeConfigCLI struct { isInboundP2PDisabled bool batchInterval string // format like 500ms or 2s (any time parsable by time.ParseDuration()) rollupInterval string // format like 500ms or 2s (any time parsable by time.ParseDuration()) + l1ChainID int } // ParseConfigCLI returns a NodeConfigCLI based the cli params and defaults. @@ -77,6 +78,7 @@ func ParseConfigCLI() *NodeConfigCLI { isInboundP2PDisabled := flag.Bool(isInboundP2PDisabledFlag, false, flagUsageMap[isInboundP2PDisabledFlag]) batchInterval := flag.String(batchIntervalFlag, "1s", flagUsageMap[batchIntervalFlag]) rollupInterval := flag.String(rollupIntervalFlag, "3s", flagUsageMap[rollupIntervalFlag]) + l1ChainID := flag.Int(l1ChainIDFlag, 1337, flagUsageMap[l1ChainIDFlag]) flag.Parse() cfg.nodeName = *nodeName @@ -106,6 +108,7 @@ func ParseConfigCLI() *NodeConfigCLI { cfg.isInboundP2PDisabled = *isInboundP2PDisabled cfg.batchInterval = *batchInterval cfg.rollupInterval = *rollupInterval + cfg.l1ChainID = *l1ChainID cfg.nodeAction = flag.Arg(0) if !validateNodeAction(cfg.nodeAction) { diff --git a/go/node/cmd/cli_flags.go b/go/node/cmd/cli_flags.go index 9a7b953bd8..21234bc663 100644 --- a/go/node/cmd/cli_flags.go +++ b/go/node/cmd/cli_flags.go @@ -29,6 +29,7 @@ const ( isInboundP2PDisabledFlag = "is_inbound_p2p_disabled" batchIntervalFlag = "batch_interval" rollupIntervalFlag = "rollup_interval" + l1ChainIDFlag = "l1_chain_id" ) // Returns a map of the flag usages. @@ -62,5 +63,6 @@ func getFlagUsageMap() map[string]string { isInboundP2PDisabledFlag: "Disables inbound p2p (for testing)", batchIntervalFlag: "Duration between each batch. Can be formatted like 500ms or 1s", rollupIntervalFlag: "Duration between each rollup. Can be formatted like 500ms or 1s", + l1ChainIDFlag: "Chain ID of the L1 network", } } diff --git a/go/node/cmd/main.go b/go/node/cmd/main.go index 219740df47..098b5c85d9 100644 --- a/go/node/cmd/main.go +++ b/go/node/cmd/main.go @@ -35,6 +35,7 @@ func main() { node.WithInboundP2PDisabled(cliConfig.isInboundP2PDisabled), node.WithBatchInterval(cliConfig.batchInterval), node.WithRollupInterval(cliConfig.rollupInterval), + node.WithL1ChainID(cliConfig.l1ChainID), ) dockerNode := node.NewDockerNode(nodeCfg) diff --git a/go/node/config.go b/go/node/config.go index 2a77968cf0..def6a4bc32 100644 --- a/go/node/config.go +++ b/go/node/config.go @@ -51,10 +51,15 @@ type Config struct { l1BlockTime time.Duration batchInterval string rollupInterval string + l1ChainID int } func NewNodeConfig(opts ...Option) *Config { - defaultConfig := &Config{} + defaultConfig := &Config{ + batchInterval: "1s", + rollupInterval: "3s", + l1ChainID: 1337, + } for _, opt := range opts { opt(defaultConfig) @@ -114,6 +119,7 @@ func (c *Config) ToHostConfig() *config.HostInputConfig { cfg.SequencerID = gethcommon.HexToAddress(c.sequencerID) cfg.IsInboundP2PDisabled = c.isInboundP2PDisabled cfg.L1BlockTime = c.l1BlockTime + cfg.L1ChainID = int64(c.l1ChainID) return cfg } @@ -311,3 +317,9 @@ func WithRollupInterval(d string) Option { c.rollupInterval = d } } + +func WithL1ChainID(i int) Option { + return func(c *Config) { + c.l1ChainID = i + } +} diff --git a/go/node/docker_node.go b/go/node/docker_node.go index f17ad39b2c..8a7230e584 100644 --- a/go/node/docker_node.go +++ b/go/node/docker_node.go @@ -119,6 +119,7 @@ func (d *DockerNode) startHost() error { fmt.Sprintf("-rollupInterval=%s", d.cfg.rollupInterval), fmt.Sprintf("-logLevel=%d", d.cfg.logLevel), fmt.Sprintf("-isInboundP2PDisabled=%t", d.cfg.isInboundP2PDisabled), + fmt.Sprintf("-l1ChainID=%d", d.cfg.l1ChainID), } if !d.cfg.hostInMemDB { cmd = append(cmd, "-levelDBPath", _hostDataDir)