Vulnerability Description
ASTEVAL is an evaluator of Python expressions and statements. Prior to version 1.0.6, if an attacker can control the input to the `asteval` library, they can bypass asteval's restrictions and execute arbitrary Python code in the context of the application using the library. The vulnerability is rooted in how `asteval` performs handling of `FormattedValue` AST nodes. In particular, the `on_formattedvalue` value uses the dangerous format method of the str class. The code allows an attacker to manipulate the value of the string used in the dangerous call `fmt.format(__fstring__=val)`. This vulnerability can be exploited to access protected attributes by intentionally triggering an `AttributeError` exception. The attacker can then catch the exception and use its `obj` attribute to gain arbitrary access to sensitive or protected object properties. Version 1.0.6 fixes this issue.
CVSS Score
HIGH
Related Weaknesses (CWE)
References
- https://github.com/lmfit/asteval/blob/cfb57f0beebe0dc0520a1fbabc35e66060c7ea71/a
- https://github.com/lmfit/asteval/security/advisories/GHSA-3wwr-3g9f-9gc7
- https://lucumr.pocoo.org/2016/12/29/careful-with-str-format
FAQ
What is CVE-2025-24359?
CVE-2025-24359 is a vulnerability with a CVSS score of 8.4 (HIGH). ASTEVAL is an evaluator of Python expressions and statements. Prior to version 1.0.6, if an attacker can control the input to the `asteval` library, they can bypass asteval's restrictions and execute ...
How severe is CVE-2025-24359?
CVE-2025-24359 has been rated HIGH with a CVSS base score of 8.4/10. Review the CVSS metrics above for detailed severity breakdown.
Is there a patch for CVE-2025-24359?
Check the references section above for vendor advisories and patch information. Review vendor security bulletins for remediation guidance.