CVE-2022-39353: Improper Input Validation
(updated )
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
.
References
- github.com/advisories/GHSA-crh6-fp67-6883
- github.com/jindw/xmldom/issues/150
- github.com/xmldom/xmldom/releases/tag/0.7.7
- github.com/xmldom/xmldom/releases/tag/0.8.4
- github.com/xmldom/xmldom/releases/tag/0.9.0-beta.4
- github.com/xmldom/xmldom/security/advisories/GHSA-crh6-fp67-6883
- nvd.nist.gov/vuln/detail/CVE-2022-39353
Detect and mitigate CVE-2022-39353 with GitLab Dependency Scanning
Secure your software supply chain by verifying that all open source dependencies used in your projects contain no disclosed vulnerabilities. Learn more about Dependency Scanning →