Warning
This repository is a work in progress. At a later date, it will be proposed to, and must be approved by, Optimism Governance. Until that time, the configuration described here is subject to change.
Important
We're making some changes to this repository and we've paused adding new chains for now. We'll reopen this process once the repository is ready. The Superchain itself, of course, remains open for business.
The Superchain Registry repository hosts Superchain-configuration data in a minimal human-readable form.
This includes mainnet and testnet Superchain targets, and their respective member chains.
Other configuration, such as contract-permissions and SystemConfig
parameters are hosted and governed onchain.
A list of chains in the registry can be seen in the top level chainList.toml
and chainList.json
files.
The superchain configs are stored in a minimal form, and are embedded in downstream OP-Stack software (op-node
and op-geth
).
Full deployment artifacts and genesis-states can be derived from the minimal form
using the reference op-chain-ops
tooling.
The following are the steps you need to take to add a chain to the registry:
This is to ensure your chain has a unique chain ID. Our validation suite will check your chain against https://github.com/ethereum-lists/chains.
You will need jq
and foundry
installed, as well as Go.
To contribute a standard OP-Stack chain configuration, in addition to user-supplied metadata (chain name) the following data is required: contracts deployment, rollup config, L2 genesis. We provide a tool to scrape this information from your local monorepo folder.
First, make a copy of .env.example
named .env
, and alter the variables to appropriate values.
Frontier chains are chains with customizations beyond the standard OP Stack configuration. To contribute a frontier OP-Stack chain configuration, you can run:
sh scripts/add-chain.sh frontier
A chain may meet the definition of a standard chain. Adding a standard chain is a two-step process.
First, the chain should be added as a frontier chain but with --standard-chain-candidate
flag set:
sh scripts/add-chain.sh frontier --standard-chain-candidate
The remaining steps should then be followed to merge the config data into the registry -- a prerequisite for promoting the chain to a standard chain.
The tool will write the following data:
- The main configuration source, with genesis data, and address of onchain system configuration. These are written to
superchain/configs/superchain_target/chain_short_name.yaml
.
Note Hardfork override times, where they have been set, will be included. If and when a chain becomes a standard chain, a
superchain_time
is set in the chain config. From that time on, future hardfork activation times which are missing from the chain config will be inherited from superchain-wide values in the neighboringsuperchain.yaml
file.
- Addresses of L1 contracts. (Note that all L2 addresses are statically known addresses defined in the OP-Stack specification, and thus not configured per chain.) These are written to
extra/addresses/superchain_target/chain_short_name.json
. - Genesis system config data
- Compressed
genesis.json
definitions (in theextra/genesis
directory) which pull in the bytecode by hash
The genesis largely consists of contracts common with other chains:
all contract bytecode is deduplicated and hosted in the extra/bytecodes
directory.
The format is a gzipped JSON genesis.json
file, with either:
- a
alloc
attribute, structured like a standardgenesis.json
, but withcodeHash
(bytes32,keccak256
hash of contract code) attribute per account, instead of thecode
attribute seen in standard Ethereum genesis definitions. - a
stateHash
attribute: to omit a large state (e.g. for networks with a re-genesis or migration history). Nodes can load the genesis block header, and state-sync to complete the node initialization.
Run the following command from the validation
folder to run the Go validation checks, for only the chain you added (replace the chain name or ID accordingly):
go test -run=/OP-Sepolia
or
go test -run=/11155420
You can even focus on a particular test and chain combination:
go test -run=TestGasPriceOracleParams/11155420
Omit the -run=
flag to run checks for all chains.
Note
If you set --standard-chain-candidate
, your chain will be checked against the majority of the standard configuration requirements. These are defined in the specs. However, these requirements are currently a draft, pending governance approval.
The final requirement to qualify as a standard chain concerns the ProxyAdminOwner
role. The validation check for this role will not be run until the chain is promoted to standard.
This is a tool which will rewrite certain summary files of all the chains in the registry, including the one you are adding. The output will be checked in a continuous integration checks (it is required to pass):
sh scripts/codegen.sh
Note
Please double check the diff to this file. This data may be consumed by external services, e.g. wallets. If anything looks incorrect, please get in touch.
When opening a PR:
- Open it from a non-protected branch in your fork (e.g. avoid the
main
branch). This allows maintainers to push to your branch if needed, which streamlines the review and merge process. - Open one PR per chain you would like to add. This ensures the merge of one chain is not blocked by unexpected issues.
Once the PR is opened, the same automated checks from Step 4 will then run on your PR, and your PR will be reviewed in due course. Once these checks pass the PR will be merged.
## Promote a chain to standard This process is only possible for chains already in the registry.
Run this command:
sh scripts/promote-to-standard.sh <chain-id>
This command will:
- declare the chain as a standard chain
- set the
superchain_time
, so that the chain receives future hardforks with the rest of the superchain (baked into downstream OPStack software, selected with network flags). - activate the full suite of validation checks for standard chains, including checks on the
ProxyAdminOwner
MIT License, see LICENSE
file.