Skip to content

Foundry plugin for zksync era contract deployment

Notifications You must be signed in to change notification settings

casmirconsensys/foundry-zksync-era

 
 

Repository files navigation

Foundry Plugin for zkSync Era

Preview

Overview

This plugin allows for the compilation & deployment of contracts to the zkSync Era network within a foundry project. zkSync Era uses a custom compiler and deployment process different from other EVM networks, this plugin simplifies this process.

Requirements

This plugin assumes you have solc installed and in your path.

Installation / Setup

Install this project as a dependancy:

forge install omurovec/foundry-zksync-era

Import Deployer.sol into your deployment script and use as follows:

// Script.s.sol

import "lib/foundry-zksync-era/script/Deployer.sol";

...
// Diamond proxy addresses, last updated 24.03.2023
address DIAMOND_PROXY_MAINNET = 0x32400084C286CF3E17e7B677ea9583e60a000324;
address DIAMOND_PROXY_GOERLI = 0x1908e2BF4a88F91E4eF0DC72f02b8Ea36BEa2319;

// Provide zkSync compiler version and address of the diamond proxy on L1
Deployer deployer = new Deployer("1.3.7", DIAMOND_PROXY_MAINNET);

// Provide path to contract, input params & salt
// Returns deployment address on L2
deployer.deployFromL1("src/Counter.sol", new bytes(0), bytes32(uint256(1337)));

Note: The Diamond Proxy address is the address of the L1 contract that handles all interactions with the zkSync network. This address will always be the same as the bridge and can be found by attempting to bridge assets at https://portal.zksync.io/bridge

Ensure your private key is in your env:

PRIVATE_KEY=""

Enable read/write permissions in your foundry.toml:

fs_permissions = [{ access = "read-write", path = "./"}]

Deploy your contracts using the script you created:

forge script script/Script.s.sol --ffi --broadcast --rpc-url L1_RPC_URL

The contract address is returned from the deployFromL1() function. The transaction hash of the deployment on L2 will be returned in the execution of the transaction. It is dependant on the block timestamp so it can not be accurately derrived within the script.

Note: It's also recommended to add lib/zksolc* to your project's .gitignore

Notes

This is a work in progress so it does not have all the features of it's counterparty hardhat-zksync. Some things to note:

  • This project currently only supports deployment from L1. Direct deployment from L2 requires custom data to be passed in to the EIP-712 transaction (see zkSync docs).

  • The _l2GasLimit & _l2GasPerPubdataByteLimit params for requestL2Transaction() are currently hardcoded to their max values for convenience.

Contribution

This has just been a quick passion project so far but would love any help on making this a more feature rich project & a go-to for anyone using foundry + zksync era so feel free to open any issues or PRs that you think would be useful.

About

Foundry plugin for zksync era contract deployment

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Solidity 100.0%