The zksync-ethers package provides a modified version of the ethers library that is compatible with Abstract and the ZKsync VM. Install the package by running the following command:
Enter the private key of a new wallet you created for this step.
Copy
✔ Enter value: · ****************************************************************
Do NOT use a private key associated with real funds. Create a new wallet for this step.
3
Get ETH in the deployer account
The deployer account requires ETH to deploy a smart contract.
Testnet: Claim ETH via a faucet, or
bridge ETH from Sepolia.
Mainnet: Use a bridge to transfer ETH to Abstract mainnet.
4
Write the deployment script
Create a new Hardhat script located at /deploy/deploy.ts:
Copy
mkdir deploy && touch deploy/deploy.ts
Add the following code to the deploy.ts file:
Copy
import { Wallet } from "zksync-ethers";import { HardhatRuntimeEnvironment } from "hardhat/types";import { Deployer } from "@matterlabs/hardhat-zksync";import { vars } from "hardhat/config";// An example of a deploy script that will deploy and call a simple contract.export default async function (hre: HardhatRuntimeEnvironment) { console.log(`Running deploy script`); // Initialize the wallet using your private key. const wallet = new Wallet(vars.get("DEPLOYER_PRIVATE_KEY")); // Create deployer object and load the artifact of the contract we want to deploy. const deployer = new Deployer(hre, wallet); // Load contract const artifact = await deployer.loadArtifact("HelloAbstract"); // Deploy this contract. The returned object will be of a `Contract` type, // similar to the ones in `ethers`. const tokenContract = await deployer.deploy(artifact); console.log( `${ artifact.contractName } was deployed to ${await tokenContract.getAddress()}` );}
5
Deploy your smart contract
Run the following command to deploy your smart contracts:
The second argument to the deploy function is an array of constructor arguments.
To deploy your smart contract with constructor arguments, provide an array containing your constructor arguments as the second argument to the deploy function.
Copy
import { Wallet } from "zksync-ethers";import { HardhatRuntimeEnvironment } from "hardhat/types";import { Deployer } from "@matterlabs/hardhat-zksync";import { vars } from "hardhat/config";// An example of a deploy script that will deploy and call a simple contract.export default async function (hre: HardhatRuntimeEnvironment) { const wallet = new Wallet(vars.get("DEPLOYER_PRIVATE_KEY")); const deployer = new Deployer(hre, wallet); const artifact = await deployer.loadArtifact("HelloAbstract"); // Provide the constructor arguments const constructorArgs = ["Hello, Abstract!"]; const tokenContract = await deployer.deploy(artifact, constructorArgs); console.log( `${ artifact.contractName } was deployed to ${await tokenContract.getAddress()}` );}
Factory smart contracts (contracts that can deploy other contracts) require the bytecode of the contracts they can deploy
to be provided within the factory dependencies array.