GHSA-4h98-2769-gh6h · Severity: high · Ecosystem: npm — OpenZeppelin Contracts vulnerable to ECDSA signature malleability
OpenZeppelin Contracts is a library for secure smart contract development. The functions `ECDSA.recover` and `ECDSA.tryRecover` are vulnerable to a kind of signature malleability due to accepting EIP-2098 compact signatures in addition to the traditional 65 byte signature format. This is only an issue for the functions that take a single `bytes` argument, and not the functions that take `r, v, s` or `r, vs` as separate arguments. The potentially affected contracts are those that implement signature reuse or replay protection by marking the signature itself as used rather than the signed message or a nonce included in it. A user may take a signature that has already been submitted, submit it again in a different form, and bypass this protection. The issue has been patched in 4.7.3.
Conclusion & alert: CVE-2022-35961 is rated Moderate Risk (40.6/100): CVSS High severity, with low exploitation likelihood (EPSS 0.34%). Mandatory action: Review affected assets and schedule remediation.
Risk is dynamic; we continuously reassess and refresh what is shown on this page as upstream context changes.
EPSS lead: Daily EPSS estimates relative likelihood of exploitation; percentile ranks this CVE among scored vulnerabilities (higher = more severe relative rank).
| # | Date | Old EPSS score | New EPSS score | Delta (New - Old) |
|---|---|---|---|---|
| 1 | 2026-06-15 | 0.16% | 0.34% | +0.18% |
| 2 | 2025-12-07 | 0.13% | 0.16% | +0.03% |
| 3 | 2025-11-21 | — | 0.13% | — |
Full EPSS history (8 records total)
CVSS metrics for this CVE.
| Base score | Version | Severity | Vector | Exploitability | Impact | Score source |
|---|---|---|---|---|---|---|
| 7.9 | 3.1 | HIGH |
|
1.3 | 6.0 | [email protected] |
| 6.5 | 3.1 | MEDIUM |
|
2.8 | 3.6 | [email protected] |
GHSA-4h98-2769-gh6h · Severity: high · Ecosystem: npm — OpenZeppelin Contracts vulnerable to ECDSA signature malleability
| Vendor | Product | Version | Raw CPE |
|---|---|---|---|
| openzeppelin | contracts | >= 4.1.0, < 4.7.3 | cpe:2.3:a:openzeppelin:contracts:*:*:*:*:*:node.js:*:* |
| openzeppelin | contracts_upgradeable | >= 4.1.0, < 4.7.3 | cpe:2.3:a:openzeppelin:contracts_upgradeable:*:*:*:*:*:node.js:*:* |
| URL | Tags |
|---|---|
| https://github.com/OpenZeppelin/openzeppelin-contracts/pull/3610 | Patch Third Party Advisory |
| https://github.com/OpenZeppelin/openzeppelin-contracts/releases/tag/v4.7.3 | Release Notes Third Party Advisory |
| https://github.com/OpenZeppelin/openzeppelin-contracts/security/advisories/GHSA-4h98-2769-gh6h | Third Party Advisory |