CVE-2024-32646
MEDIUM5.3EPSS 0.69%vyper performs double eval of the slice start/length args in certain cases
Published: 4/25/2024Modified: 2/4/2026
Description
Vyper is a pythonic Smart Contract Language for the Ethereum virtual machine. In versions 0.3.10 and prior, using the `slice` builtin can result in a double eval vulnerability when the buffer argument is either `msg.data`, `self.code` or `<address>.code` and either the `start` or `length` arguments have side-effects. It can be easily triggered only with the versions `<0.3.4` as `0.3.4` introduced the unique symbol fence. No vulnerable production contracts were found. Additionally, double evaluation of side-effects should be easily discoverable in client tests. As such, the impact is low. As of time of publication, no fixed versions are available.
Affected packages (2)
- PyPI/vyperfrom 0, < 0.4.0
- PyPI/vyperfrom 0, < 0.4.0
CVSS scores
| Source | Version | Severity | Vector |
|---|---|---|---|
| osv | CVSS 3.1 | MEDIUM5.3 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:L/A:N |
References (5)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2024-32646
- PATCHhttps://github.com/vyperlang/vyper
- WEBhttps://github.com/pypa/advisory-database/tree/main/vulns/vyper/PYSEC-2024-207.yaml
- WEBhttps://github.com/vyperlang/vyper/pull/2914
- WEBhttps://github.com/vyperlang/vyper/security/advisories/GHSA-r56x-j438-vw5m