CVE-2025-6985
The HTMLSectionSplitter class in langchain-text-splitters version 0.3.8 is vulnerable to XML External Entity (XXE) attacks due to unsafe XSLT parsing. This vulnerability arises because the class allows the use of arbitrary XSLT stylesheets, which are parsed using lxml.etree.parse() and lxml.etree.XSLT() without any hardening measures. In lxml versions up to 4.9.x, external entities are resolved by default, allowing attackers to read arbitrary local files or perform outbound HTTP(S) fetches. In lxml versions 5.0 and above, while entity expansion is disabled, the XSLT document() function can still read any URI unless XSLTAccessControl is applied. This vulnerability allows remote attackers to gain read-only access to any file the LangChain process can reach, including sensitive files such as SSH keys, environment files, source code, or cloud metadata. No authentication, special privileges, or user interaction are required, and the issue is exploitable in default deployments that enable custom XSLT.
EPSS 0.15% · 34.8th percentile
Risk Scores
Affected Products
| Vendor | Product | Versions |
|---|---|---|
| PyPI | langchain-text-splitters | 0 |
| langchain-ai | langchain-ai/langchain | * |
Exploit Intelligence
Timeline
- Oct 6, 2025 CVE Published
- Oct 7, 2025 EPSS Score
- Oct 7, 2025 Coalition ESS Score
- Oct 8, 2025 CVE Updated
- Oct 13, 2025 EPSS Score
- Oct 13, 2025 Coalition ESS Score
- Oct 20, 2025 EPSS Score
- Oct 26, 2025 EPSS Score
- Nov 2, 2025 EPSS Score
- Nov 8, 2025 EPSS Score
- Nov 14, 2025 EPSS Score
- Nov 14, 2025 Coalition ESS Score
References
- https://huntr.com/bounties/cf78abbb-df3b-43de-b6ee-132b73ff8331 url
- https://nvd.nist.gov/vuln/detail/CVE-2025-6985 advisory
- https://github.com/langchain-ai/langchain/pull/31819 url
- https://github.com/langchain-ai/langchain/commit/43eef435505a1c907227b724c0c760ad5fc01790 url
- https://github.com/langchain-ai/langchain package