Description
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`.
Remediation
References
https://github.com/jindw/xmldom/issues/150
https://github.com/xmldom/xmldom/security/advisories/GHSA-crh6-fp67-6883
https://lists.debian.org/debian-lts-announce/2023/01/msg00000.html
Related Vulnerabilities
CVE-2022-41881 Vulnerability in maven package io.netty:netty-codec-haproxy
CVE-2022-46175 Vulnerability in npm package json5
CVE-2022-44729 Vulnerability in maven package org.apache.xmlgraphics:batik-svgrasterizer
CVE-2022-37199 Vulnerability in maven package com.jflyfox:jflyfox_jfinal
CVE-2020-13822 Vulnerability in maven package org.webjars.npm:elliptic