{"vuid":"VU#263614","idnumber":"263614","name":"Vulnerability in expr-eval JavaScript library can lead to arbitrary code execution","keywords":null,"overview":"## Overview\r\nThe npm package *expr-eval* is a JavaScript library that evaluates mathematical expressions and is used in various applications, including NLP and AI. A vulnerability in this library has been disclosed that could allow arbitrary code execution by an attacker using maliciously crafted input.\r\n\r\n## Description\r\n\r\nThe npm projects *expr-eval* and *expr-eval-fork* are JavaScript libraries used to parse and evaluate mathematical expressions, extending NLP applications that process mathematical expressions and their numerical data. This capability is particularly useful in generative AI systems that need to interpret mathematical expressions within user prompts. The `Parser` class and its `evaluate()` method is designed to provide user-defined expressions in a safer way than JavaScript’s native `eval()` function. This design choice is critical for npm-based projects, especially those running in server environments where access to a system's local resources could pose security risks. According to [npmjs.com](https://www.npmjs.com/package/expr-eval), *expr-eval* has over 250 dependent packages, including integrations such as *oplangchain*, a JavaScript implementation of the popular LangChain framework. The related project *expr-eval-fork* was created to address a prior [Prototype Pollution vulnerability (Issue #266)](https://github.com/silentmatt/expr-eval/issues/266) that remained unresolved in the original *expr-eval* repository, which appears to be unmaintained by the original author, with last release date of 2019-09-28.\r\n\r\n\r\nA newly discovered vulnerability allows an attacker to define arbitrary functions within the `context` object used by the parser. This capability can be exploited to inject malicious code that executes system-level commands, potentially accessing sensitive local resources or exfiltrating data. This issue has been patched via [Pull Request #288](https://github.com/silentmatt/expr-eval/pull/288). The vulnerability is tracked with [CVE-2025-12735](https://www.cve.org/CVERecord?id=CVE-2025-12735),  as well as the GitHub Advisory [GHSA-jc85-fpwf-qm7x](https://github.com/advisories/GHSA-jc85-fpwf-qm7x).  These identifiers enable automated tools such as `npm audit` to detect the vulnerability in affected projects. The [CVE-2025-13204](https://www.cve.org/CVERecord?id=CVE-2025-13204) has also been published for the earlier [Prototype Pollution vulnerability](Prototype Pollution vulnerability) identified in 2021 that is not fixed in *expr-eval*, however the *expr-eval-fork* released in 2024-01-10.  \r\n\r\n## Impact\r\n\r\nAn attacker with the ability to influence input fields processed by *expr-eval* can craft malicious payloads that trigger arbitrary command execution on the host system.  \r\nThis constitutes a *Technical Impact = Total* under the [SSVC](https://certcc.github.io/SSVC/reference/decision_points/technical_impact/) framework, meaning:\r\n> The vulnerability gives the adversary total control over the behavior of the software or total disclosure of all information on the affected system.\r\n\r\n## Solution\r\nDevelopers and Users are  advised either to:\r\n\r\n1. *Apply the security patch* from [Pull Request #288](https://github.com/silentmatt/expr-eval/pull/288), or  \r\n2. *Upgrade to the latest patched version* of the *expr-eval* or *expr-eval-fork* package as they become available. The newly released [expr-eval-fork 3.0.1](hhttps://www.npmjs.com/package/expr-eval-fork/v/3.0.1 ) has been tested to resolve this issue.\r\n\r\nNote: The patch introduces:\r\n\r\n* A defined *AllowList* of safe functions accessible via `evaluate()`\r\n* A mandatory *registration mechanism* for custom functions.\r\n* Updated test cases ensuring enforcement of these constraints can be understood and applied\r\n\r\n\r\n## Acknowledgements\r\nThanks to the reporter Jangwoo Choe (UKO)  for responsibly disclosing this issue. Thanks to [huydoppaze](https://github.com/huydoppaz) for improving the suggested patch. We also acknowledge *GitHub Security* and *npm* for their proactive security advisories and automated vulnerability audits. This document was written by Vijay Sarvepalli and Renae Metcalf.","clean_desc":null,"impact":null,"resolution":null,"workarounds":null,"sysaffected":null,"thanks":null,"author":null,"public":["https://github.com/silentmatt/expr-eval","https://github.com/jorenbroekema/expr-eval","https://www.npmjs.com/package/expr-eval-fork","https://www.npmjs.com/package/expr-eval","https://github.com/silentmatt/expr-eval/pull/288","https://github.com/silentmatt/expr-eval/issues/289"],"cveids":["CVE-2025-12735","CVE-2025-13204"],"certadvisory":null,"uscerttechnicalalert":null,"datecreated":"2025-11-07T21:48:35.864701Z","publicdate":"2025-11-07T21:48:35.687782Z","datefirstpublished":"2025-11-07T21:48:35.885881Z","dateupdated":"2025-12-09T15:19:56.076430Z","revision":6,"vrda_d1_directreport":null,"vrda_d1_population":null,"vrda_d1_impact":null,"cam_widelyknown":null,"cam_exploitation":null,"cam_internetinfrastructure":null,"cam_population":null,"cam_impact":null,"cam_easeofexploitation":null,"cam_attackeraccessrequired":null,"cam_scorecurrent":null,"cam_scorecurrentwidelyknown":null,"cam_scorecurrentwidelyknownexploited":null,"ipprotocol":null,"cvss_accessvector":null,"cvss_accesscomplexity":null,"cvss_authentication":null,"cvss_confidentialityimpact":null,"cvss_integrityimpact":null,"cvss_availabilityimpact":null,"cvss_exploitablity":null,"cvss_remediationlevel":null,"cvss_reportconfidence":null,"cvss_collateraldamagepotential":null,"cvss_targetdistribution":null,"cvss_securityrequirementscr":null,"cvss_securityrequirementsir":null,"cvss_securityrequirementsar":null,"cvss_basescore":null,"cvss_basevector":null,"cvss_temporalscore":null,"cvss_environmentalscore":null,"cvss_environmentalvector":null,"metric":null,"vulnote":148}