Releases: OpenZeppelin/openzeppelin-upgrades
@openzeppelin/hardhat-upgrades@3.0.0
This is a major version of the Hardhat Upgrades plugin that contains breaking changes. Please review the changes below.
This version deploys proxy contracts from OpenZeppelin Contracts 5.0, and no longer supports deploying proxy contracts from OpenZeppelin Contracts 4.x. However, it still supports importing and/or managing existing proxies that were deployed from previous versions.
If you are using Hardhat Verify, this plugin now requires Hardhat Verify 2.0.0 or higher.
Summary
- Deploy proxies from OpenZeppelin Contracts 5.0. (#919)
- Support
initialOwner
option when deploying a transparent proxy or beacon. If not set, the externally owned account used during deployment will be the default owner for the transparent proxy's admin or the beacon, respectively. - Update optional peer dependency on
@nomicfoundation/hardhat-verify
to v2.0.0 or higher. (#937)- Note: Fully verifying proxies is only supported with Etherscan at the moment. The Hardhat Upgrades plugin does not currently assist with Sourcify verification for proxies.
Breaking changes
deployProxy
,deployBeacon
,deployBeaconProxy
: Deploys proxy contracts from OpenZeppelin Contracts 5.0.deployProxy
:- Deploying a transparent proxy automatically causes a new proxy admin contract to be deployed along with the proxy.
- New transparent proxy deployments no longer use an existing proxy admin, even if one was previously recorded in the network file.
- New proxy admins are no longer recorded in the network file.
deployProxyAdmin
: Removed, since proxy admins are deployed automatically by transparent proxies.admin.changeProxyAdmin
: Not supported with admins or proxies from OpenZeppelin Contracts 5.0. Only supported for previously deployed admins and proxies from OpenZeppelin Contracts 4.x or below.admin.transferProxyAdminOwnership
: This function no longer uses the proxy admin from the network file. It now requires aproxyAddress
argument to be passed in.@nomicfoundation/hardhat-verify
v1.x and@nomicfoundation/hardhat-toolbox
v3.x are no longer supported with this plugin. If you are using these packages, update them to@nomicfoundation/hardhat-verify
v2.x and@nomicfoundation/hardhat-toolbox
v4.x.
@openzeppelin/hardhat-upgrades@2.5.0
- Add
defender.getDeployApprovalProcess
anddefender.getUpgradeApprovalProcess
functions. (#934) - Deprecate
defender.getDefaultApprovalProcess
function. This function is equivalent todefender.getUpgradeApprovalProcess
.
Note: OpenZeppelin Defender deployments is in beta and its functionality is subject to change.
@openzeppelin/hardhat-upgrades@3.0.0-alpha.0
Disclaimer
This is an alpha release of a new major version which contains breaking changes. Additional breaking changes may be introduced leading up to the full release.
Documentation
API documentation for this alpha release can be found here.
Summary
- Deploy proxies from OpenZeppelin Contracts 5.0.
- Support
initialOwner
option when deploying a transparent proxy or beacon. If not set, the externally owned account used during deployment will be the default owner for the transparent proxy's admin or the beacon, respectively.
Breaking changes
deployProxy
,deployBeacon
,deployBeaconProxy
: Deploys proxy contracts from OpenZeppelin Contracts 5.0.deployProxy
:- Deploying a transparent proxy automatically causes a new proxy admin contract to be deployed along with the proxy.
- New transparent proxy deployments no longer use an existing proxy admin, even if one was previously recorded in the network file.
- New proxy admins are no longer recorded in the network file.
deployProxyAdmin
: Removed, since proxy admins are deployed automatically by transparent proxies.admin.changeProxyAdmin
: Not supported with admins or proxies from OpenZeppelin Contracts 5.0. Only supported for previously deployed admins and proxies from OpenZeppelin Contracts 4.x or below.admin.transferProxyAdminOwnership
: This function no longer uses the proxy admin from the network file. It now requires aproxyAddress
argument to be passed in.
@openzeppelin/upgrades-core@1.31.3
- Fix Hardhat compile errors when contracts have overloaded functions or standalone NatSpec documentation. (#918)
@openzeppelin/upgrades-core@1.31.2
- Fix
upgradeProxy
in Hardhat from an implementation that has a fallback function and is not using OpenZeppelin Contracts 5.0. (#926)
@openzeppelin/hardhat-upgrades@2.4.3
- Bump dependency on
@openzeppelin/upgrades-core
. (#930)
@openzeppelin/hardhat-upgrades@2.4.2
- Fix
upgradeProxy
from an implementation that has a fallback function and is not using OpenZeppelin Contracts 5.0. (#926)
@openzeppelin/hardhat-upgrades@2.4.1
- Update Defender SDK. (#924)
- Throw error if not using a relayer for deployments, until other types of deployments are supported.
Note: OpenZeppelin Defender deployments is in beta and its functionality is subject to change.
@openzeppelin/hardhat-upgrades@2.4.0
- Add
createFactoryAddress
option for Defender deployments. (#920)
Note: OpenZeppelin Defender deployments is in beta and its functionality is subject to change.
@openzeppelin/upgrades-core@1.31.1
- CLI: Throw error if
--requireReference
and--unsafeSkipStorageCheck
are both enabled. (#913)