Skip to content

Commit

Permalink
chore(deps): update dependency @openzeppelin/contracts to v5.1.0 (#58)
Browse files Browse the repository at this point in the history
This PR contains the following updates:

| Package | Type | Update | Change | OpenSSF |
|---|---|---|---|---|
| [@openzeppelin/contracts](https://openzeppelin.com/contracts/)
([source](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts))
| dependencies | minor | [`5.0.2` ->
`5.1.0`](https://renovatebot.com/diffs/npm/@openzeppelin%2fcontracts/5.0.2/5.1.0)
| [![OpenSSF
Scorecard](https://api.securityscorecards.dev/projects/github.com/OpenZeppelin/openzeppelin-contracts/badge)](https://securityscorecards.dev/viewer/?uri=github.com/OpenZeppelin/openzeppelin-contracts)
|

---

### Release Notes

<details>
<summary>OpenZeppelin/openzeppelin-contracts
(@&#8203;openzeppelin/contracts)</summary>

###
[`v5.1.0`](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/releases/tag/v5.1.0)

[Compare
Source](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/compare/v5.0.2...v5.1.0)

##### Breaking changes

- `ERC1967Utils`: Removed duplicate declaration of the `Upgraded`,
`AdminChanged` and `BeaconUpgraded` events. These events are still
available through the `IERC1967` interface located under the
`contracts/interfaces/` directory. Minimum pragma version is now 0.8.21.
- `Governor`, `GovernorCountingSimple`: The `_countVote` virtual
function now returns an `uint256` with the total votes casted. This
change allows for more flexibility for partial and fractional voting.
Upgrading users may get a compilation error that can be fixed by adding
a return statement to the `_countVote` function.

##### Custom error changes

This version comes with changes to the custom error identifiers.
Contracts previously depending on the following errors should be
replaced accordingly:

-   Replace `Address.FailedInnerCall` with `Errors.FailedCall`
- Replace `Address.AddressInsufficientBalance` with
`Errors.InsufficientBalance`
- Replace `Clones.Create2InsufficientBalance` with
`Errors.InsufficientBalance`
- Replace `Clones.ERC1167FailedCreateClone` with
`Errors.FailedDeployment`
- Replace `Clones.Create2FailedDeployment` with
`Errors.FailedDeployment`
- `SafeERC20`: Replace `Address.AddressEmptyCode` with
`SafeERC20FailedOperation` if there is no code at the token's address.
- `SafeERC20`: Replace generic `Error(string)` with
`SafeERC20FailedOperation` if the returned data can't be decoded as
`bool`.
- `SafeERC20`: Replace generic `SafeERC20FailedOperation` with the
revert message from the contract call if it fails.

##### Changes by category

##### General

- `AccessManager`, `VestingWallet`, `TimelockController` and
`ERC2771Forwarder`: Added a public `initializer` function in their
corresponding upgradeable variants.
([#&#8203;5008](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5008))

##### Access

- `AccessControlEnumerable`: Add a `getRoleMembers` method to return all
accounts that have `role`.
([#&#8203;4546](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4546))
- `AccessManager`: Allow the `onlyAuthorized` modifier to restrict
functions added to the manager.
([#&#8203;5014](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5014))

##### Finance

- `VestingWalletCliff`: Add an extension of the `VestingWallet` contract
with an added cliff.
([#&#8203;4870](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4870))

##### Governance

- `GovernorCountingFractional`: Add a governor counting module that
allows distributing voting power amongst 3 options (For, Against,
Abstain).
([#&#8203;5045](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5045))
- `Votes`: Set `_moveDelegateVotes` visibility to internal instead of
private.
([#&#8203;5007](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5007))

##### Proxy

- `Clones`: Add version of `clone` and `cloneDeterministic` that support
sending value at creation.
([#&#8203;4936](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4936))
- `TransparentUpgradeableProxy`: Make internal `_proxyAdmin()` getter
have `view` visibility.
([#&#8203;4688](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4688))
- `ProxyAdmin`: Fixed documentation for `UPGRADE_INTERFACE_VERSION`
getter.
([#&#8203;5031](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5031))

##### Tokens

- `ERC1363`: Add implementation of the token payable standard allowing
execution of contract code after transfers and approvals.
([#&#8203;4631](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4631))
- `ERC20TemporaryApproval`: Add an ERC-20 extension that implements
temporary approval using transient storage, based on ERC7674 (draft).
([#&#8203;5071](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5071))
- `SafeERC20`: Add "relaxed" function for interacting with ERC-1363
functions in a way that is compatible with EOAs.
([#&#8203;4631](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4631))
- `SafeERC20`: Document risks of `safeIncreaseAllowance` and
`safeDecreaseAllowance` when associated with ERC-7674.
([#&#8203;5262](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5262))
- `ERC721Utils` and `ERC1155Utils`: Add reusable libraries with
functions to perform acceptance checks on `IERC721Receiver` and
`IERC1155Receiver` implementers.
([#&#8203;4845](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4845))
- `ERC1363Utils`: Add helper similar to the existing ERC721Utils and
ERC1155Utils.
([#&#8203;5133](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5133))

##### Utils

- `Arrays`: add a `sort` functions for `address[]`, `bytes32[]` and
`uint256[]` memory arrays.
([#&#8203;4846](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4846))
- `Arrays`: add new functions `lowerBound`, `upperBound`,
`lowerBoundMemory` and `upperBoundMemory` for lookups in sorted arrays
with potential duplicates.
([#&#8203;4842](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4842))
- `Arrays`: deprecate `findUpperBound` in favor of the new `lowerBound`.
([#&#8203;4842](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4842))
- `Base64`: Add `encodeURL` following section 5 of RFC4648 for URL
encoding
([#&#8203;4822](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4822))
- `Comparator`: A library of comparator functions, useful for
customizing the behavior of the Heap structure.
([#&#8203;5084](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5084))
- `Create2`: Bubbles up returndata from a deployed contract that
reverted during construction.
([#&#8203;5052](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5052))
- `Create2`, `Clones`: Mask `computeAddress` and `cloneDeterministic`
outputs to produce a clean value for an `address` type (i.e. only use 20
bytes)
([#&#8203;4941](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4941))
- `Errors`: New library of common custom errors.
([#&#8203;4936](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4936))
- `Hashes`: A library with commonly used hash functions.
([#&#8203;3617](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/3617))
- `Packing`: Added a new utility for packing, extracting and replacing
bytesXX values.
([#&#8203;4992](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4992))
- `Panic`: Add a library for reverting with panic codes.
([#&#8203;3298](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/3298))
- `ReentrancyGuardTransient`: Added a variant of `ReentrancyGuard` that
uses transient storage.
([#&#8203;4988](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4988))
- `Strings`: Added a utility function for converting an address to
checksummed string.
([#&#8203;5067](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5067))
- `SlotDerivation`: Add a library of methods for derivating common
storage slots.
([#&#8203;4975](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4975))
- `TransientSlot`: Add primitives for operating on the transient storage
space using a typed-slot representation.
([#&#8203;4980](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4980))

##### Cryptography

- `SignatureChecker`: refactor `isValidSignatureNow` to avoid validating
ECDSA signatures if there is code deployed at the signer's address.
([#&#8203;4951](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4951))
- `MerkleProof`: Add variations of `verify`, `processProof`,
`multiProofVerify` and `processMultiProof` (and equivalent calldata
version) with support for custom hashing functions.
([#&#8203;4887](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4887))
- `P256`: Library for verification and public key recovery of P256 (aka
secp256r1) signatures.
([#&#8203;4881](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4881))
- `RSA`: Library to verify signatures according to RFC 8017 Signature
Verification Operation
([#&#8203;4952](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4952))

##### Math

- `Math`: add an `invMod` function to get the modular multiplicative
inverse of a number in Z/nZ.
([#&#8203;4839](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4839))
- `Math`: Add `modExp` function that exposes the `EIP-198` precompile.
Includes `uint256` and `bytes memory` versions.
([#&#8203;3298](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/3298))
- `Math`: Custom errors replaced with native panic codes.
([#&#8203;3298](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/3298))
- `Math`, `SignedMath`: Add a branchless `ternary` function that
computes`cond ? a : b` in constant gas cost.
([#&#8203;4976](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4976))
- `SafeCast`: Add `toUint(bool)` for operating on `bool` values as
`uint256`.
([#&#8203;4878](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4878))

##### Structures

- `CircularBuffer`: Add a data structure that stores the last `N` values
pushed to it.
([#&#8203;4913](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4913))
- `DoubleEndedQueue`: Custom errors replaced with native panic codes.
([#&#8203;4872](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4872))
- `EnumerableMap`: add `UintToBytes32Map`, `AddressToAddressMap`,
`AddressToBytes32Map` and `Bytes32ToAddressMap`.
([#&#8203;4843](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/4843))
- `Heap`: A data structure that implements a heap-based priority queue.
([#&#8203;5084](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/5084))
- `MerkleTree`: A data structure that allows inserting elements into a
merkle tree and updating its root hash.
([#&#8203;3617](https://redirect.github.com/OpenZeppelin/openzeppelin-contracts/pull/3617))

</details>

---

### Configuration

📅 **Schedule**: Branch creation - "after 10pm every weekday,before 5am
every weekday,every weekend" (UTC), Automerge - At any time (no schedule
defined).

🚦 **Automerge**: Enabled.

♻ **Rebasing**: Whenever PR becomes conflicted, or you tick the
rebase/retry checkbox.

🔕 **Ignore**: Close this PR and you won't be reminded about this update
again.

---

- [ ] <!-- rebase-check -->If you want to rebase/retry this PR, check
this box

---

This PR was generated by [Mend Renovate](https://mend.io/renovate/).
View the [repository job
log](https://developer.mend.io/github/settlemint/solidity-diamond-bond).

<!--renovate-debug:eyJjcmVhdGVkSW5WZXIiOiIzOC4xMjAuMSIsInVwZGF0ZWRJblZlciI6IjM4LjEyMC4xIiwidGFyZ2V0QnJhbmNoIjoibWFpbiIsImxhYmVscyI6WyJkZXBlbmRlbmNpZXMiXX0=-->

Signed-off-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
Co-authored-by: renovate[bot] <29139614+renovate[bot]@users.noreply.github.com>
  • Loading branch information
renovate[bot] authored Oct 18, 2024
1 parent dc2d556 commit d520645
Show file tree
Hide file tree
Showing 2 changed files with 6 additions and 5 deletions.
9 changes: 5 additions & 4 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -41,7 +41,7 @@
"@nomicfoundation/hardhat-ignition-viem": "0.15.6",
"@nomicfoundation/hardhat-toolbox-viem": "3.0.0",
"@nomiclabs/hardhat-solhint": "4.0.1",
"@openzeppelin/contracts": "5.0.2",
"@openzeppelin/contracts": "5.1.0",
"@openzeppelin/subgraphs": "0.1.8-5",
"hardhat": "2.22.13",
"solhint": "5.0.3",
Expand Down

0 comments on commit d520645

Please sign in to comment.