In OpenZeppelin <=v4.4.0, initializer functions that are invoked separate from contract creation (the most prominent example being minimal proxies) may be reentered if they make an untrusted non-view external call. Once an initializer has finished running it can never be re-executed. However, an exception put in place to support multiple inheritance made reentrancy possible, breaking the expectation that there is a single execution.
References
Link | Resource |
---|---|
https://github.com/OpenZeppelin/openzeppelin-contracts/security/advisories/GHSA-9c22-pwxw-p6hx | Third Party Advisory |
https://github.com/OpenZeppelin/openzeppelin-contracts/security/advisories/GHSA-9c22-pwxw-p6hx | Third Party Advisory |
Configurations
History
21 Nov 2024, 06:33
Type | Values Removed | Values Added |
---|---|---|
References | () https://github.com/OpenZeppelin/openzeppelin-contracts/security/advisories/GHSA-9c22-pwxw-p6hx - Third Party Advisory |
Information
Published : 2022-02-04 12:15
Updated : 2024-11-21 06:33
NVD link : CVE-2021-46320
Mitre link : CVE-2021-46320
CVE.ORG link : CVE-2021-46320
JSON object : View
Products Affected
openzeppelin
- openzeppelin
CWE
CWE-665
Improper Initialization