Skip to content

Commit

Permalink
Merged 'main' into 'kiriyaga-txfusion-library-linking'
Browse files Browse the repository at this point in the history
  • Loading branch information
kiriyaga committed Oct 24, 2024
2 parents 2ef9fcb + e7a8397 commit bb66e46
Show file tree
Hide file tree
Showing 53 changed files with 602 additions and 1,013 deletions.
8 changes: 4 additions & 4 deletions .github/release-please/manifest.json
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
{
"packages/hardhat-zksync-deploy": "1.5.0",
"packages/hardhat-zksync-solc": "1.2.4",
"packages/hardhat-zksync-upgradable": "1.6.0",
"packages/hardhat-zksync-vyper": "1.1.0",
"packages/hardhat-zksync-solc": "1.2.5",
"packages/hardhat-zksync-upgradable": "1.7.0",
"packages/hardhat-zksync-vyper": "1.1.1",
"packages/hardhat-zksync-verify": "1.6.0",
"packages/hardhat-zksync": "1.1.0",
"packages/hardhat-zksync": "1.2.0",
"packages/hardhat-zksync-node": "1.1.1",
"packages/hardhat-zksync-ethers": "1.2.1",
"packages/hardhat-zksync-verify-vyper": "0.0.1-alpha.6"
Expand Down
4 changes: 2 additions & 2 deletions examples/basic-example/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,8 @@
"ethers": "^6.12.2",
"zksync-ethers": "^6.11.2",
"@matterlabs/zksync-contracts": "^0.6.1",
"@openzeppelin/contracts": "^4.9.2",
"@openzeppelin/contracts-upgradeable": "^4.9.2"
"@openzeppelin/contracts": "^4.9.6",
"@openzeppelin/contracts-upgradeable": "^4.9.6"
},
"prettier": {
"tabWidth": 4,
Expand Down
4 changes: 2 additions & 2 deletions examples/node-example/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -42,8 +42,8 @@
"ethers": "^6.12.2",
"zksync-ethers": "^6.11.2",
"@matterlabs/zksync-contracts": "^0.6.1",
"@openzeppelin/contracts": "^4.9.2",
"@openzeppelin/contracts-upgradeable": "^4.9.2"
"@openzeppelin/contracts": "^5.0.2",
"@openzeppelin/contracts-upgradeable": "^5.0.2"
},
"prettier": {
"tabWidth": 4,
Expand Down
4 changes: 2 additions & 2 deletions examples/noninline-libraries-example/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -36,8 +36,8 @@
"ethers": "^6.12.2",
"zksync-ethers": "^6.11.2",
"@matterlabs/zksync-contracts": "^0.6.1",
"@openzeppelin/contracts": "^4.9.2",
"@openzeppelin/contracts-upgradeable": "^4.9.2"
"@openzeppelin/contracts": "^5.0.2",
"@openzeppelin/contracts-upgradeable": "^5.0.2"
},
"prettier": {
"tabWidth": 4,
Expand Down
2 changes: 1 addition & 1 deletion examples/upgradable-example-l1/contracts/BoxUups.sol
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ contract BoxUups is Initializable, UUPSUpgradeable, OwnableUpgradeable {

function initialize(uint256 initValue) public initializer {
value = initValue;
__Ownable_init();
__Ownable_init(msg.sender);
__UUPSUpgradeable_init();
}

Expand Down
5 changes: 3 additions & 2 deletions examples/upgradable-example-l1/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
"clean": "rimraf dist"
},
"devDependencies": {
"@openzeppelin/contracts": "^4.9.2",
"@openzeppelin/contracts": "^5.0.2",
"@types/node": "^18.11.17",
"@typescript-eslint/eslint-plugin": "6.13.1",
"@typescript-eslint/parser": "6.13.1",
Expand All @@ -35,7 +35,8 @@
"@matterlabs/hardhat-zksync-solc": "workspace:^",
"@matterlabs/hardhat-zksync-upgradable": "workspace:^",
"@matterlabs/hardhat-zksync-verify": "workspace:^",
"@openzeppelin/contracts-upgradeable": "^4.9.2",
"@nomicfoundation/hardhat-ethers": "3.0.6",
"@openzeppelin/contracts-upgradeable": "^5.0.2",
"chalk": "^4.1.2",
"ethers": "^6.12.2",
"hardhat": "^2.22.5",
Expand Down
2 changes: 1 addition & 1 deletion examples/upgradable-example-l1/scripts/deploy-box-uups.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as hre from 'hardhat';

async function main() {
const Box = await hre.ethers.getContractFactory("BoxUups");
const box = await hre.upgrades.deployProxy(Box,[42],{ initializer: 'initialize'});
const box = await hre.upgrades.deployProxy(Box,[42],{ initializer: 'initialize' });
await box.waitForDeployment()
console.info("Box deployed address: " + await box.getAddress())
}
Expand Down
2 changes: 1 addition & 1 deletion examples/upgradable-example-l1/scripts/upgrade-box-uups.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import * as hre from 'hardhat';

async function main() {
const Box = await hre.ethers.getContractFactory("BoxUups");
const box = await hre.upgrades.deployProxy(Box,[42],{ initializer: 'initialize'});
const box = await hre.upgrades.deployProxy(Box,[42],{ initializer: 'initialize' });
await box.waitForDeployment()
console.info("Box deployed address: " + await box.getAddress())

Expand Down
2 changes: 1 addition & 1 deletion examples/upgradable-example/contracts/BoxUups.sol
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,7 @@ contract BoxUups is Initializable, UUPSUpgradeable, OwnableUpgradeable {

function initialize(uint256 initValue) public initializer {
value = initValue;
__Ownable_init();
__Ownable_init(msg.sender);
__UUPSUpgradeable_init();
}

Expand Down
6 changes: 4 additions & 2 deletions examples/upgradable-example/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@
"clean": "rimraf dist"
},
"devDependencies": {
"@openzeppelin/contracts": "^4.9.2",
"@openzeppelin/contracts": "^5.0.2",
"@types/node": "^18.11.17",
"@typescript-eslint/eslint-plugin": "6.13.1",
"@typescript-eslint/parser": "6.13.1",
Expand All @@ -38,7 +38,9 @@
"@matterlabs/hardhat-zksync-solc": "workspace:^",
"@matterlabs/hardhat-zksync-upgradable": "workspace:^",
"@matterlabs/hardhat-zksync-verify": "workspace:^",
"@openzeppelin/contracts-upgradeable": "^4.9.2",
"@nomicfoundation/hardhat-ethers": "3.0.6",
"@openzeppelin/contracts-upgradeable": "^5.0.2",
"@openzeppelin/hardhat-upgrades": "^3.2.1",
"chalk": "^4.1.2",
"zksync": "^0.13.1"
},
Expand Down
2 changes: 1 addition & 1 deletion examples/upgradable-example/scripts/deploy-box-uups.ts
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,7 @@ async function main() {
const deployer = new Deployer(hre, zkWallet);

const contract = await deployer.loadArtifact(contractName);
const box = await hre.upgrades.deployProxy(deployer.zkWallet, contract, [42], { initializer: 'initialize' });
const box = await hre.upgrades.deployProxy(deployer.zkWallet, contract, [42], { initializer: 'initialize'});

await box.waitForDeployment();

Expand Down
9 changes: 9 additions & 0 deletions packages/hardhat-zksync-solc/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,14 @@
# @matterlabs/hardhat-zksync-solc

## [1.2.5](https://github.com/matter-labs/hardhat-zksync/compare/@matterlabs/hardhat-zksync-solc-v1.2.4...@matterlabs/hardhat-zksync-solc-v1.2.5) (2024-09-25)


### Bug Fixes

* add suppressed errors and warnings ([#1375](https://github.com/matter-labs/hardhat-zksync/issues/1375)) ([a0bf6e5](https://github.com/matter-labs/hardhat-zksync/commit/a0bf6e57c17b063b292e26acfa8bf8f8d1974644))
* return default zksolc version of fetching fails ([#1438](https://github.com/matter-labs/hardhat-zksync/issues/1438)) ([b5e4582](https://github.com/matter-labs/hardhat-zksync/commit/b5e4582c36ad79a809778bfaf29e83549668c1d6))
* update fallback era compiler version to proper format ([#1446](https://github.com/matter-labs/hardhat-zksync/issues/1446)) ([c41dbcd](https://github.com/matter-labs/hardhat-zksync/commit/c41dbcd193f97296420061756c73160f078fb7b9))

## [1.2.4](https://github.com/matter-labs/hardhat-zksync/compare/@matterlabs/hardhat-zksync-solc-v1.2.3...@matterlabs/hardhat-zksync-solc-v1.2.4) (2024-09-05)


Expand Down
2 changes: 1 addition & 1 deletion packages/hardhat-zksync-solc/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@matterlabs/hardhat-zksync-solc",
"version": "1.2.4",
"version": "1.2.5",
"description": "Hardhat plugin to compile smart contracts for the ZKsync network",
"repository": "github:matter-labs/hardhat-zksync",
"homepage": "https://github.com/matter-labs/hardhat-zksync/tree/main/packages/hardhat-zksync-solc",
Expand Down
7 changes: 7 additions & 0 deletions packages/hardhat-zksync-upgradable/CHANGELOG.md
Original file line number Diff line number Diff line change
@@ -1,5 +1,12 @@
# @matterlabs/hardhat-zksync-upgradable

## [1.7.0](https://github.com/matter-labs/hardhat-zksync/compare/@matterlabs/hardhat-zksync-upgradable-v1.6.0...@matterlabs/hardhat-zksync-upgradable-v1.7.0) (2024-10-01)


### Features

* bump openzeppelin contracts to v5 ([#1463](https://github.com/matter-labs/hardhat-zksync/issues/1463)) ([ebb668b](https://github.com/matter-labs/hardhat-zksync/commit/ebb668b0f88a39f23009d8697bb6d7e534d46928))

## [1.6.0](https://github.com/matter-labs/hardhat-zksync/compare/@matterlabs/hardhat-zksync-upgradable-v1.5.2...@matterlabs/hardhat-zksync-upgradable-v1.6.0) (2024-09-16)


Expand Down
5 changes: 3 additions & 2 deletions packages/hardhat-zksync-upgradable/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -282,7 +282,7 @@ const config: HardhatUserConfig = {

### 🕹 Command list

`yarn hardhat deploy-zksync:proxy --contract-name <contract name or FQN> [<constructor arguments>] [--constructor-args <javascript module name>] [--initializer <initialize method>] [--no-compile] [--deployment-type-impl <deployment type>] [--salt-impl <salt>] [--deployment-type-proxy <deployment type>] [--salt-proxy <salt>]`
`yarn hardhat deploy-zksync:proxy --contract-name <contract name or FQN> [<constructor arguments>] [--constructor-args <javascript module name>] [--initializer <initialize method>] [--no-compile] [--initial-owner <initial owner>] [--deployment-type-impl <deployment type>] [--salt-impl <salt>] [--deployment-type-proxy <deployment type>] [--salt-proxy <salt>]`

When executed, this command will automatically determine whether the deployment is for a Transparent or UUPS proxy.
If the Transparent proxy is chosen, it will deploy implementation, admin, and proxy.
Expand All @@ -293,7 +293,7 @@ If the UUPS proxy is chosen, it will deploy implementation and proxy.
When executed, this command upgrade UUPS or Transparent implementation.
To upgrade a implementation we need to specify proxy address, add `--proxy-address <proxy address>` argument, e.g. `yarn hardhat upgrade-zksync:proxy --contract-name BoxV2 --proxy-address 0x4bbeEB066eD09B7AEd07bF39EEe0460DFa261520`.

`yarn hardhat deploy-zksync:beacon --contract-name <contract name or FQN> [<constructor arguments>] [--constructor-args <javascript module name>] [--initializer <initialize method>] [--deployment-type-impl <deployment type>] [--salt-impl <salt>] [--deployment-type-proxy <deployment type>] [--salt-proxy <salt>] [--no-compile]`
`yarn hardhat deploy-zksync:beacon --contract-name <contract name or FQN> [<constructor arguments>] [--constructor-args <javascript module name>] [--initializer <initialize method>] [--deployment-type-impl <deployment type>] [--salt-impl <salt>] [--deployment-type-proxy <deployment type>] [--salt-proxy <salt>] [--initial-owner <initial owner>] [--no-compile]`

When executed, this command deploys the provided implementation, beacon and proxy on the specified network, using the provided contract constructor arguments.

Expand All @@ -319,6 +319,7 @@ module.exports = [
```
- To provide a initializer method name at deploy tasks, add `--initializer <initializer method>`, e.g. `hardhat deploy-zksync:proxy --contract-name Contract --initializer store`. If this parameter is omitted, the default value will be `initialize`.
- To allows the task to skip the compilation process, add `--no-compile` argument, e.g. `hardhat deploy-zksync:beacon --contract-name Contract --no-compile`.
- To specify inital contract owner, add `--initial-owner` argument, e.g `hardhat deploy-zksync:beacon --contract-name Contract --initial-owner 0xa61464658AfeAf65CccaaFD3a512b69A83B77618`. If this argument is ommited wallet address will be used.
- To allows the task to specify which deployer smart contract function will be called for implementation, add `--deployment-type-impl` argument, e.g. `hardhat deploy-zksync:beacon --contract-name Greeter 'Hello' --deployment-type-impl create2`.
- To allows the task to specify which deployer smart contract function will be called for proxy, add `--deployment-type-proxy` argument, e.g. `hardhat deploy-zksync:beacon --contract-name Greeter 'Hello' --deployment-type-proxy create2`.
- To specify which salt will be used in deployment of the implementation, add `--salt-impl` argument, e.g. `hardhat deploy-zksync:beacon --contract-name Greeter 'Hello' --salt-impl 0x42737956734178574166864921632769419836642485081335718122152413290`
Expand Down
12 changes: 7 additions & 5 deletions packages/hardhat-zksync-upgradable/package.json
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
{
"name": "@matterlabs/hardhat-zksync-upgradable",
"version": "1.6.0",
"version": "1.7.0",
"description": "Hardhat plugin to deploy and update upgradable smart contracts for the ZKsync network",
"repository": "github:matter-labs/hardhat-zksync",
"homepage": "https://github.com/matter-labs/hardhat-zksync/tree/main/packages/hardhat-zksync-upgradable",
Expand Down Expand Up @@ -36,10 +36,12 @@
"@matterlabs/hardhat-zksync-deploy": "workspace:^",
"@matterlabs/hardhat-zksync-solc": "workspace:^",
"@matterlabs/hardhat-zksync-ethers": "workspace:^",
"@openzeppelin/contracts-hardhat-zksync-upgradable": "npm:@openzeppelin/contracts@^4.9.2",
"@openzeppelin/hardhat-upgrades": "~2.5.1",
"@openzeppelin/upgrades-core": "^1.31.3",
"@openzeppelin/defender-admin-client": "^1.52.0",
"@openzeppelin/contracts-hardhat-zksync-upgradable": "npm:@openzeppelin/contracts@^5.0.2",
"@openzeppelin/hardhat-upgrades": "^3.2.1",
"@openzeppelin/upgrades-core": "^1.37.0",
"@openzeppelin/defender-sdk-base-client": "^1.10.0",
"@openzeppelin/defender-sdk-deploy-client": "^1.10.0",
"@openzeppelin/defender-sdk-network-client": "^1.10.0",
"chalk": "^4.1.2",
"compare-versions": "^6.1.0",
"ethereumjs-util": "^7.1.5",
Expand Down
62 changes: 14 additions & 48 deletions packages/hardhat-zksync-upgradable/src/admin.ts
Original file line number Diff line number Diff line change
@@ -1,62 +1,28 @@
import chalk from 'chalk';
import type { HardhatRuntimeEnvironment } from 'hardhat/types';
import { getAdminAddress } from '@openzeppelin/upgrades-core';
import { Wallet, Contract } from 'zksync-ethers';
import { Manifest } from './core/manifest';
import { getAdminFactory } from './proxy-deployment/deploy-proxy-admin';
import { ZkSyncUpgradablePluginError } from './errors';
import { Wallet } from 'zksync-ethers';
import { attachProxyAdminV4 } from './utils/attach-abi';

export type ChangeAdminFunction = (proxyAddress: string, newAdmin: string, wallet: Wallet) => Promise<void>;
export type TransferProxyAdminOwnershipFunction = (newOwner: string, wallet: Wallet) => Promise<void>;
export type GetInstanceFunction = (wallet: Wallet) => Promise<Contract>;
export type TransferProxyAdminOwnershipFunction = (
proxyAddress: string,
newOwner: string,
wallet: Wallet,
) => Promise<void>;

export function makeChangeProxyAdmin(hre: HardhatRuntimeEnvironment): ChangeAdminFunction {
export function makeChangeProxyAdmin(): ChangeAdminFunction {
return async function changeProxyAdmin(proxyAddress, newAdmin, wallet: Wallet) {
const proxyAdminManifest = await getManifestAdmin(hre, wallet);

const proxyAdminAddress = await getAdminAddress(wallet.provider, proxyAddress);

if ((await proxyAdminManifest.getAddress()) !== proxyAdminAddress) {
throw new ZkSyncUpgradablePluginError('Proxy admin is not the one registered in the network manifest');
} else if ((await proxyAdminManifest.getAddress()) !== newAdmin) {
await proxyAdminManifest.changeProxyAdmin(proxyAddress, newAdmin);
}
const admin = await attachProxyAdminV4(proxyAdminAddress, wallet);
await admin.changeProxyAdmin(proxyAddress, newAdmin);
};
}

export function makeTransferProxyAdminOwnership(hre: HardhatRuntimeEnvironment): TransferProxyAdminOwnershipFunction {
return async function transferProxyAdminOwnership(newOwner, wallet: Wallet) {
const admin = await getManifestAdmin(hre, wallet);
export function makeTransferProxyAdminOwnership(): TransferProxyAdminOwnershipFunction {
return async function transferProxyAdminOwnership(proxyAddress: string, newOwner, wallet: Wallet) {
const proxyAdminAddress = await getAdminAddress(wallet.provider, proxyAddress);

const admin = await attachProxyAdminV4(proxyAdminAddress, wallet);
await admin.transferOwnership(newOwner);

const manifest = await Manifest.forNetwork(wallet.provider);
const { proxies } = await manifest.read();
for (const { address, kind } of proxies) {
if ((await admin.getAddress()) === (await getAdminAddress(wallet.provider, address))) {
console.info(chalk.green(`${address} (${kind}) proxy ownership transfered through admin proxy`));
} else {
console.info(chalk.red(`${address} (${kind}) proxy ownership not affected by admin proxy`));
}
}
};
}

export function makeGetInstanceFunction(hre: HardhatRuntimeEnvironment): GetInstanceFunction {
return async function getInstance(wallet: Wallet) {
return await getManifestAdmin(hre, wallet);
};
}

export async function getManifestAdmin(hre: HardhatRuntimeEnvironment, wallet: Wallet): Promise<Contract> {
const manifest = await Manifest.forNetwork(wallet.provider);
const manifestAdmin = await manifest.getAdmin();
const proxyAdminAddress = manifestAdmin?.address;

if (proxyAdminAddress === undefined) {
throw new ZkSyncUpgradablePluginError('No ProxyAdmin was found in the network manifest');
}

const adminFactory = await getAdminFactory(hre, wallet);
return adminFactory.attach(proxyAdminAddress);
}
18 changes: 9 additions & 9 deletions packages/hardhat-zksync-upgradable/src/core/validate.ts
Original file line number Diff line number Diff line change
Expand Up @@ -253,25 +253,25 @@ function* getStateVariableErrors(
): Generator<ValidationErrorWithName> {
for (const varDecl of contractDef.nodes) {
if (isNodeType('VariableDeclaration', varDecl)) {
if (!varDecl.constant && !isNullish(varDecl.value)) {
if (varDecl.mutability === 'immutable') {
if (
!skipCheck('state-variable-assignment', contractDef) &&
!skipCheck('state-variable-assignment', varDecl)
!skipCheck('state-variable-immutable', contractDef) &&
!skipCheck('state-variable-immutable', varDecl)
) {
yield {
kind: 'state-variable-assignment',
kind: 'state-variable-immutable',
name: varDecl.name,
src: decodeSrc(varDecl),
};
}
}
if (varDecl.mutability === 'immutable') {
} else if (!varDecl.constant && !isNullish(varDecl.value)) {
// Assignments are only a concern for non-immutable variables
if (
!skipCheck('state-variable-immutable', contractDef) &&
!skipCheck('state-variable-immutable', varDecl)
!skipCheck('state-variable-assignment', contractDef) &&
!skipCheck('state-variable-assignment', varDecl)
) {
yield {
kind: 'state-variable-immutable',
kind: 'state-variable-assignment',
name: varDecl.name,
src: decodeSrc(varDecl),
};
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -20,21 +20,18 @@ export class ZkSyncGenerator implements Generator {
const { makeDeployBeacon } = require('./proxy-deployment/deploy-beacon');
const { makeDeployBeaconProxy } = require('./proxy-deployment/deploy-beacon-proxy');
const { makeUpgradeBeacon } = require('./proxy-upgrade/upgrade-beacon');
const { makeDeployProxyAdmin } = require('./proxy-deployment/deploy-proxy-admin');
const { makeEstimateGasProxy } = require('./gas-estimation/estimate-gas-proxy');
const { makeEstimateGasBeacon } = require('./gas-estimation/estimate-gas-beacon');
const { makeEstimateGasBeaconProxy } = require('./gas-estimation/estimate-gas-beacon-proxy');
const { makeGetInstanceFunction, makeChangeProxyAdmin, makeTransferProxyAdminOwnership } = require('./admin');
const { makeChangeProxyAdmin, makeTransferProxyAdminOwnership } = require('./admin');
return {
deployProxy: wrapMakeFunction(this._hre, makeDeployProxy(this._hre)),
upgradeProxy: wrapMakeFunction(this._hre, makeUpgradeProxy(this._hre)),
validateImplementation: wrapMakeFunction(this._hre, makeValidateImplementation(this._hre)),
deployBeacon: wrapMakeFunction(this._hre, makeDeployBeacon(this._hre)),
deployBeaconProxy: wrapMakeFunction(this._hre, makeDeployBeaconProxy(this._hre)),
upgradeBeacon: wrapMakeFunction(this._hre, makeUpgradeBeacon(this._hre)),
deployProxyAdmin: wrapMakeFunction(this._hre, makeDeployProxyAdmin(this._hre)),
admin: {
getInstance: wrapMakeFunction(this._hre, makeGetInstanceFunction(this._hre)),
changeProxyAdmin: wrapMakeFunction(this._hre, makeChangeProxyAdmin(this._hre)),
transferProxyAdminOwnership: wrapMakeFunction(this._hre, makeTransferProxyAdminOwnership(this._hre)),
},
Expand Down
Loading

0 comments on commit bb66e46

Please sign in to comment.