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.
This plugin assumes you have solc installed and in your path.
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
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 forrequestL2Transaction()
are currently hardcoded to their max values for convenience.
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.