-
Notifications
You must be signed in to change notification settings - Fork 449
Create Predeploy contracts #3022
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Closed
Closed
Changes from all commits
Commits
Show all changes
11 commits
Select commit
Hold shift + click to select a range
653bca0
Create Predeploy contracts
gmehta2 3c07ded
minor wording / grammatical nits
0xallan af52682
initial changes to custom genesis
asomani-ocl d476ac7
Merge branch 'master' into gmehta2-patch-1
asomani-ocl ce06da0
update docs for custom genesis based on latest changes
asomani-ocl b90500b
add new column for default env var
Jason-W123 ea7764a
Apply suggestions from code review
asomani-ocl d0359d4
minor fix for new line
asomani-ocl 72af2e8
Merge branch 'gmehta2-patch-1' of https://github.com/OffchainLabs/arb…
asomani-ocl 15c1cfc
updating docs to use public docker image for genesis generation
asomani-ocl be14e20
Apply suggestions from code review
pete-vielhaber File filter
Filter by extension
Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
There are no files selected for viewing
208 changes: 208 additions & 0 deletions
208
docs/launch-arbitrum-chain/02-configure-your-chain/common/use-a-custom-genesis.mdx
This file contains hidden or bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
| Original file line number | Diff line number | Diff line change | ||||
|---|---|---|---|---|---|---|
| @@ -0,0 +1,208 @@ | ||||||
| --- | ||||||
| title: 'Use a custom genesis to deploy your Arbitrum chain' | ||||||
| sidebar_label: 'Use custom genesis' | ||||||
| description: 'Start your chain with a custom genesis file' | ||||||
| author: Mehta | ||||||
| sme: Mehta | ||||||
| user_story: As a current Arbitrum chain owner, I need to start my chain with a set of predeployed contracts and account balances using genesis.json file. | ||||||
| content_type: get-started | ||||||
| --- | ||||||
|
|
||||||
| :::caution Minimum Requirement | ||||||
|
|
||||||
| - You must use Nitro contracts v3.2 or higher. This version is the first to include full support for custom `genesis.json` initialization. | ||||||
| - Nitro node v3.10.0 or higher is needed for using custom-genesis. | ||||||
| ::: | ||||||
|
|
||||||
| ## What is this feature? | ||||||
|
|
||||||
| Arbitrum chain operators are increasingly looking to deploy chains with pre-existing state, by loading an initial state in a file such as `genesis.json`. | ||||||
| Specifically, chain operators want to predeploy smart contracts (like Gnosis Safe) to an Arbitrum chain so they exist at genesis, before any user interaction or post-launch governance. | ||||||
|
|
||||||
| Initializing from a genesis state would be helpful in the following scenarios: | ||||||
|
|
||||||
| 1. Redeploying a new testnet with pre-existing state if current testnet is broken | ||||||
| 2. Deploying additional sibling chains with pre-existing contracts | ||||||
| 3. Simplifying self-serve backends for RaaSes, such that 100s of testnets can be deployed with similar contracts | ||||||
| 4. Reducing lift on 3rd-party infrastructure teams to redeploy contracts for new chains | ||||||
|
|
||||||
| ## **What Does This Feature Do?** | ||||||
|
|
||||||
| This feature allows you to initialize a new blockchain with a customized starting state and network configuration through the following options: | ||||||
|
|
||||||
| - **Predeployed contracts** - standard chains start without any smart contracts. This feature allows you to preload contract bytecode in the very first block so infrastructure is available at the launch. | ||||||
| - **Initial account state (allocations)** - you can pre-configure the ledger—including account balances and contract storage—before the network opens for transactions. | ||||||
| - **Enable advanced features** – chain operators can use this feature to launch a chain with advanced customizations like [mint / burn of gas token via third party bridges](/launch-arbitrum-chain/features/common/gas-and-fees/choose-native-mint-burn) and compliance-focused transaction filtering. | ||||||
|
|
||||||
| ## **How to use this feature?** | ||||||
|
|
||||||
| You can use the feature via the SDK or by using the [genesis-file-generator](https://github.com/OffchainLabs/genesis-file-generator) tool. | ||||||
|
|
||||||
| ### Use via chain SDK | ||||||
|
|
||||||
| :::caution | ||||||
| The feature is supported in chain SDK versions xx.xx and above. Chain SDK only allows the standard `genesis.json` creation which contains the predeploy contracts. In case you want to customize the `genesis.json` file or pass accounts / custom chain config, you should use the `genesis-file-generator` for using the feature. | ||||||
| ::: | ||||||
| The chain SDK provides an automated script that handles the entire lifecycle: building the genesis state, calculating `blockhash` and `sendRoot` hash, and creating the rollup. | ||||||
|
|
||||||
| - **SDK workflow:** the script completes the below automated steps: | ||||||
| - Generates a standard `genesis.json` file with the pre-deploys contracts. | ||||||
| - Calculates the `blockhash` and `sendRoot` hash and gives the same as output for you to use. | ||||||
| - An option to deploy the rollup. You can choose to either deploy the chain with the above `genesis.json` or just take the output of the previous step and setup the chain separately. | ||||||
|
|
||||||
| #### Configuration Reference | ||||||
|
|
||||||
| **Core Configuration** \ | ||||||
| Required to generate the `genesis.json` file. | ||||||
| | Variable | Description | | ||||||
| | :--- | :--- | | ||||||
| | `CHAIN_ID` | The unique numeric identifier for your new chain. | | ||||||
| | `IS_ANYTRUST` | Whether the chain is an AnyTrust (DAC) chain (`true`) or a standard Rollup (`false`). | | ||||||
| | `ARB_OS_VERSION` | The version of ArbOS to use for the genesis block. | | ||||||
|
Jason-W123 marked this conversation as resolved.
|
||||||
| | `CHAIN_OWNER` | The address that will have administrative ownership of the deployed chain. | | ||||||
| | `L1_BASE_FEE` | The initial L1 gas price (in Wei) used to calibrate the chain's birth. | | ||||||
| | `NITRO_NODE_IMAGE` | The Nitro node docker image used for hashing and node operations. | | ||||||
|
|
||||||
| **Deployment Configuration (Optional)** \ | ||||||
| Only required if you choose to deploy the rollup to the parent chain in Step 3. | ||||||
| | Variable | Description | | ||||||
| | :--- | :--- | | ||||||
| | `DEPLOYER_PRIVATE_KEY` | Private key of the account responsible for the rollup deployment transactions. | | ||||||
| | `BATCH_POSTER_PRIVATE_KEY` | Private key for the Sequencer's batch-posting address. | | ||||||
| | `VALIDATOR_PRIVATE_KEY` | Private key for the Validator/Staker address. | | ||||||
| | `PARENT_CHAIN_RPC` | RPC endpoint for the parent chain (e.g., Arbitrum Sepolia or Ethereum). | | ||||||
|
|
||||||
| #### Execution steps: | ||||||
|
|
||||||
| 1. **Prepare the environment** \ | ||||||
| From the root repository, install dependencies and navigate to the generator directory. | ||||||
|
|
||||||
| ```bash | ||||||
| yarn install && yarn build | ||||||
|
|
||||||
| cd examples/generate-genesis-file && cp .env.example .env | ||||||
| ``` | ||||||
|
|
||||||
| 2. **Generate Genesis** \ | ||||||
| Ensure your .env is configured (see reference above) and run the dev script. | ||||||
| `bash | ||||||
| yarn dev | ||||||
| ` | ||||||
| :::tip Configuration | ||||||
| Double-check that your .env values match your intended chain specs before running the script. | ||||||
| ::: | ||||||
| 3. **[Optional] Create rollup** \ | ||||||
| After generating the `genesis.json` file, the SDK provides an option to deploy your rollup. Follow the prompts to continue or exit the process and deploy the rollup later. | ||||||
|
|
||||||
| ### Use via [genesis-file-generator](https://github.com/OffchainLabs/genesis-file-generator) tool | ||||||
|
|
||||||
| #### Configuration Reference | ||||||
|
|
||||||
| **Environment Variables (.env)** \ | ||||||
| These parameters define the identity of your chain. | ||||||
| | Variable | Description | Default | | ||||||
| | :--- | :--- | :--- | | ||||||
| | `CHAIN_ID` | The unique numeric identifier for your new chain. | `31337` | | ||||||
| | `IS_ANYTRUST` | Whether the chain is an AnyTrust (DAC) chain (`true`) or a standard Rollup (`false`). | `false` | | ||||||
| | `ARBOS_VERSION` | The version of ArbOS to use for the genesis block. | `51` | | ||||||
| | `CHAIN_OWNER` | The address that will have administrative ownership of the deployed chain. | — | | ||||||
| | `L1_BASE_FEE` | The initial L1 gas price (in Wei) used to calibrate the chain's birth. | `1000000000` (1 gwei) | | ||||||
| | `NITRO_NODE_IMAGE` | The Nitro node Docker image used for hashing and node operations. | — | | ||||||
| | `CUSTOM_ALLOC_ACCOUNT_FILE` | _(Optional)_ Path to a JSON file containing your own account balances, contract bytecodes, and storage slots. The file should be in the standard Geth `alloc` format. | `""` (empty) | | ||||||
| | `ENABLE_NATIVE_TOKEN_SUPPLY` | _(Optional)_ Set to `true` if you want to launch your chain with native interop tokens as [gas token with mint / burn enabled](/launch-arbitrum-chain/features/common/gas-and-fees/choose-native-mint-burn) via third-party protocols. | `false` | | ||||||
| | `LOAD_DEFAULT_PREDEPLOYS` | _(Optional)_ Set to `false` if you don't want the default predeploys. | `true` | | ||||||
| | `ENABLE_TRANSACTION_FILTERING` | _(Optional)_ Set to `true` if you want to launch your chain with protocol-level transaction filtering for regulatory or compliance purposes. | `false` | | ||||||
|
|
||||||
| #### Execution Process | ||||||
|
|
||||||
| - **Prepare the genesis state:** | ||||||
|
|
||||||
| - Set up the `.env` with the required parameters | ||||||
| - Run the [offchainlabs/genesis-file-generator](https://hub.docker.com/r/offchainlabs/genesis-file-generator/tags) docker image to generate `genesis.json` file with the required pre-deployed contracts and additional configs. | ||||||
|
|
||||||
| ```bash | ||||||
| mkdir -p genesis | ||||||
|
|
||||||
| docker run --rm \ | ||||||
| --env-file .env \ | ||||||
| -v "$(pwd)/genesis":/app/genesis \ | ||||||
| offchainlabs/genesis-file-generator:v0.0.1-afad8d8 | ||||||
|
Contributor
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more.
Suggested change
|
||||||
| ``` | ||||||
|
|
||||||
| - You can also generate your own genesis.json file, but carefully read [this notice](https://github.com/OffchainLabs/genesis-file-generator#exclamation-important-note-about-the-chain-config-property) before proceeding with the next steps. | ||||||
|
|
||||||
| - **Generate required hashes:** After the genesis.json file is created, run the nitro container to compute the genesis block hash with `genesis-generator` entrypoint: | ||||||
|
|
||||||
| ```bash | ||||||
| source .env | ||||||
|
|
||||||
| docker run --rm \ | ||||||
| -v "$(pwd)/genesis":/data/genesisDir \ | ||||||
| --entrypoint genesis-generator \ | ||||||
| "$NITRO_NODE_IMAGE" \ | ||||||
| --genesis-json-file /data/genesisDir/genesis.json \ | ||||||
| ``` | ||||||
|
|
||||||
| This bind-mounts the current directory into the container so it can read the genesis.json file generated in the previous step, and outputs the genesis block hash and sendRoot hash. The block hash and sendRoot hash will be logged as: | ||||||
|
|
||||||
| ```bash | ||||||
| genesis-hash-calculator | BlockHash: 0xd636d2cae7a75bf41f471639f1cbf98fe2a24216147792510e664a65496f27ed, SendRoot: 0x0000000000000000000000000000000000000000000000000000000000000000, Batch: 1, PosInBatch: 0 | ||||||
| ``` | ||||||
|
|
||||||
| - **Deploy the rollup:** use the `blockhash`, `sendRoot`, `Batch` and `PosInBatch` in the chain SDK. The SDK will use these to generate the `assertion_hash` needed to register your rollup's core smart contracts on the parent chain. | ||||||
| ```javascript | ||||||
| const genesisAssertionState = { | ||||||
| globalState: { | ||||||
| bytes32Vals: [genesisBlockHash as `0x${string}`, sendRootHash as `0x${string}`] as [ | ||||||
| `0x${string}`, | ||||||
| `0x${string}`, | ||||||
| ], | ||||||
| // Set inbox position to 1 | ||||||
| u64Vals: [1n, 0n] as [bigint, bigint], | ||||||
| }, | ||||||
| machineStatus: 1, // FINISHED | ||||||
| endHistoryRoot: toHex(0, { size: 32 }), | ||||||
| }; | ||||||
| ``` | ||||||
| - **Configure and launch your node:** set up your node as usual, but include the following properties to point to your custom state: | ||||||
| - `--init.genesis-json-file=/path/to/genesis.json` - path to your custom `genesis.json` file | ||||||
| - **Start your chain** with the correct preloaded state. | ||||||
|
|
||||||
| ## Pre-deployed Contracts Registry | ||||||
|
|
||||||
| The following contracts are included by default in the standard `genesis.json` file. | ||||||
| | Category | Contract Name | Address | Note | | ||||||
| | :--- | :--- | :--- | :--- | | ||||||
| | **Factories** | Safe Singleton Factory v1.0.43 | `0x914d7Fec6aaC8cd542e72Bca78B30650d45643d7` | Deterministic Proxy (Safe Key) | | ||||||
| | | Create2Deployer | `0x13b0D85CcB8bf860b6b79AF3029fCA081AE9beF2` | CREATE (Deployer: `0x5542...`, Nonce 0) | | ||||||
| | | CreateX v1.0.0 | `0xba5Ed099633D3B313e4D5F7bdc1305d3c28ba5Ed` | Pre-signed Transaction | | ||||||
| | | Arachnid Proxy | `0x4e59b44847b379578588920cA78FbF26c0B4956C` | Deterministic Proxy (Arachnid) | | ||||||
| | **Safe v1.3.0** | GnosisSafe (Canonical) | `0xd9Db270c1B5E3Bd161E8c8503c55cEABeE709552` | Via Arachnid CREATE2 Proxy | | ||||||
| | | GnosisSafe (EIP-155) | `0x69f4D1788e39c87893C980c06EdF4b7f686e2938` | Via Safe Singleton Factory | | ||||||
| | | GnosisSafeL2 (Canonical) | `0x3e5c63644e683549055b9be8653de26e0b4cd36e` | Via Arachnid CREATE2 Proxy | | ||||||
| | | GnosisSafeL2 (EIP-155) | `0xfb1bffC9d739B8D520DaF37dF666da4C687191EA` | Via Safe Singleton Factory | | ||||||
| | | SafeProxyFactory (Canonical) | `0xa6B71E26C5e0845f74c812102Ca7114b6a896AB2` | Via Arachnid CREATE2 Proxy | | ||||||
| | | SafeProxyFactory (EIP-155) | `0xC22834581EbC8527d974F8a1c97E1bEA4EF910BC` | Via Safe Singleton Factory | | ||||||
| | | MultiSend v1.3.0 | `0x998739BFdAAdde7C933B942a68053933098f9EDa` | Via Safe Singleton Factory | | ||||||
| | | MultiSendCallOnly v1.3.0 | `0xA1dabEF33b3B82c7814B6D82A79e50F4AC44102B` | Via Safe Singleton Factory | | ||||||
| | **Safe v1.4.1** | Safe | `0x41675C099F32341bf84BFc5382aF534df5C7461a` | Via Safe Singleton Factory | | ||||||
| | | SafeL2 | `0x29fcB43b46531BcA003ddC8FCB67FFE91900C762` | Via Safe Singleton Factory | | ||||||
| | | SafeProxyFactory | `0x4e1DCf7AD4e460CfD30791CCC4F9c8a4f820ec67` | Via Safe Singleton Factory | | ||||||
| | | MultiSend v1.4.1 | `0x38869bf66a61cF6bDB996A6aE40D5853Fd43B526` | Via Safe Singleton Factory | | ||||||
| | | MultiSendCallOnly v1.4.1 | `0x9641d764fc13c8B624c04430C7356C1C7C8102e2` | Via Safe Singleton Factory | | ||||||
| | **ERC-4337 Core** | EntryPoint v0.6.0 | `0x5FF137D4b0FDCD49DcA30c7CF57E578a026d2789` | Standard v0.6 | | ||||||
| | | SenderCreator v0.6.0 | `0x7fc98430eAEdbb6070B35B39D798725049088348` | Created during EP v0.6.0 deploy | | ||||||
| | | EntryPoint v0.7.0 | `0x0000000071727De22E5E9d8BAf0edAc6f37da032` | Standard v0.7 | | ||||||
| | | SenderCreator v0.7.0 | `0xEFC2c1444eBCC4Db75e7613d20C6a62fF67A167C` | Created during EP v0.7.0 deploy | | ||||||
| | | EntryPoint v0.8.0 | `0x4337084d9e255ff0702461cf8895ce9e3b5ff108` | Standard v0.8 | | ||||||
| | | SenderCreator v0.8.0 | `0x449ED7C3e6Fee6a97311d4b55475DF59C44AdD33` | Created during EP v0.8.0 deploy | | ||||||
| | **Account Modules** | Safe Module Setup v0.3.0 | `0x2dd68b007B46fBe91B9A7c3EDa5A7a1063cB5b47` | ERC-4337 Initializer | | ||||||
| | | Safe 4337 Module v0.3.0 | `0x75cf11467937ce3F2f357CE24ffc3DBF8fD5c226` | Associated with Entrypoint v0.7.0 | | ||||||
| | | Kernel v3.3 | `0xd6CEDDe84be40893d153Be9d467CD6aD37875b28` | Associated with Entrypoint v0.7.0 | | ||||||
| | | KernelFactory v3.3 | `0x2577507b78c2008Ff367261CB6285d44ba5eF2E9` | Associated with Entrypoint v0.7.0 | | ||||||
| | | MetaFactory v3.0 | `0xd703aaE79538628d27099B8c4f621bE4CCd142d5` | ZeroDev FactoryStaker | | ||||||
| | | ECDSAValidator v3.1 | `0x845ADb2C711129d4f3966735eD98a9F09fC4cE57` | Compiled from commit 8f7fd99 | | ||||||
| | **Infrastructure** | Multicall3 | `0xcA11bde05977b3631167028862bE2a173976CA11` | Pre-signed Transaction | | ||||||
| | | Permit2 | `0x000000000022D473030F116dDEE9F6B43aC78BA3` | Uniswap Permit2 | | ||||||
| | | EAS v1.4.0 | `0xF4C9CCaf46A866e2c12C5Bd95A39694718044444` | Ethereum Attestation Service | | ||||||
| | | EAS SchemaRegistry | `0x822B0B93BE3f3B8Da35a2E90e877C01215be8506` | EAS Registry | | ||||||
Oops, something went wrong.
Add this suggestion to a batch that can be applied as a single commit.
This suggestion is invalid because no changes were made to the code.
Suggestions cannot be applied while the pull request is closed.
Suggestions cannot be applied while viewing a subset of changes.
Only one suggestion per line can be applied in a batch.
Add this suggestion to a batch that can be applied as a single commit.
Applying suggestions on deleted lines is not supported.
You must change the existing code in this line in order to create a valid suggestion.
Outdated suggestions cannot be applied.
This suggestion has been applied or marked resolved.
Suggestions cannot be applied from pending reviews.
Suggestions cannot be applied on multi-line comments.
Suggestions cannot be applied while the pull request is queued to merge.
Suggestion cannot be applied right now. Please check back later.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.