Description
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.
Remediation
References
https://github.com/OpenZeppelin/openzeppelin-contracts/security/advisories/GHSA-9c22-pwxw-p6hx
Related Vulnerabilities
CVE-2019-20920 Vulnerability in npm package handlebars
CVE-2020-6462 Vulnerability in maven package org.webjars.npm:electron
CVE-2022-23496 Vulnerability in maven package nl.basjes.parse.useragent:yauaa-flink-table
CVE-2016-3092 Vulnerability in maven package commons-fileupload:commons-fileupload
CVE-2017-6056 Vulnerability in maven package org.apache.tomcat:tomcat-coyote