vyper is a Pythonic Smart Contract Language for the EVM. Vyper handles AugAssign statements by first caching the target location to avoid double evaluation. However, in the case when target is an access to a DynArray and the rhs modifies the array, the cached target will evaluate first, and the bounds check will not be re-evaluated during the write portion of the statement. This issue has been addressed in version 0.4.1 and all users are advised to upgrade. There are no known workarounds for this vulnerability.
History

Fri, 21 Feb 2025 21:45:00 +0000

Type Values Removed Values Added
Description vyper is a Pythonic Smart Contract Language for the EVM. Vyper handles AugAssign statements by first caching the target location to avoid double evaluation. However, in the case when target is an access to a DynArray and the rhs modifies the array, the cached target will evaluate first, and the bounds check will not be re-evaluated during the write portion of the statement. This issue has been addressed in version 0.4.1 and all users are advised to upgrade. There are no known workarounds for this vulnerability.
Title AugAssign evaluation order causing OOB write within the object in Vyper
Weaknesses CWE-787
References
Metrics cvssV4_0

{'score': 2.3, 'vector': 'CVSS:4.0/AV:N/AC:L/AT:P/PR:L/UI:N/VC:L/VI:L/VA:L/SC:N/SI:N/SA:N'}


cve-icon MITRE

Status: PUBLISHED

Assigner: GitHub_M

Published:

Updated: 2025-02-21T21:27:28.056Z

Reserved: 2025-02-18T16:44:48.766Z

Link: CVE-2025-27105

cve-icon Vulnrichment

No data.

cve-icon NVD

Status : Received

Published: 2025-02-21T22:15:13.910

Modified: 2025-02-21T22:15:13.910

Link: CVE-2025-27105

cve-icon Redhat

No data.