xmldom is a pure JavaScript W3C standard-based (XML DOM Level 2 Core) DOMParser
and XMLSerializer
module. xmldom parses XML that is not well-formed because it contains multiple top level elements, and adds all root nodes to the childNodes
collection of the Document
, without reporting any error or throwing. This breaks the assumption that there is only a single root node in the tree, which led to issuance of CVE-2022-39299 as it is a potential issue for dependents. Update to @xmldom/xmldom@~0.7.7, @xmldom/xmldom@~0.8.4 (dist-tag latest) or @xmldom/xmldom@>=0.9.0-beta.4 (dist-tag next). As a workaround, please one of the following approaches depending on your use case: instead of searching for elements in the whole DOM, only search in the documentElement
or reject a document with a document that has more then 1 childNode
.
The product receives a complex input with multiple elements or fields that must be consistent with each other, but it does not validate or incorrectly validates that the input is actually consistent.
Name | Vendor | Start Version | End Version |
---|---|---|---|
Xmldom | Xmldom_project | * | 0.6.0 (excluding) |
Xmldom | Xmldom_project | 0.7.0 (including) | 0.7.7 (excluding) |
Xmldom | Xmldom_project | 0.8.0 (including) | 0.8.4 (excluding) |
Xmldom | Xmldom_project | 0.9.0-beta1 (including) | 0.9.0-beta1 (including) |
Xmldom | Xmldom_project | 0.9.0-beta2 (including) | 0.9.0-beta2 (including) |
Xmldom | Xmldom_project | 0.9.0-beta3 (including) | 0.9.0-beta3 (including) |
Node-xmldom | Ubuntu | focal | * |
Node-xmldom | Ubuntu | jammy | * |
Node-xmldom | Ubuntu | kinetic | * |
Node-xmldom | Ubuntu | mantic | * |
Node-xmldom | Ubuntu | trusty | * |
Node-xmldom | Ubuntu | xenial | * |
Some input data can be structured with multiple elements or fields that must be consistent with each other, e.g. a number-of-items field that is followed by the expected number of elements. When such complex inputs are inconsistent, attackers could trigger unexpected errors, cause incorrect actions to take place, or exploit latent vulnerabilities.