Description
uri-js is a module that tries to fully implement RFC 3986. One of these features is validating whether or not a supplied URL is valid or not. To do this, uri-js uses a regular expression, This regular expression is vulnerable to redos. This causes the program to hang and the CPU to idle at 100% usage while uri-js is trying to validate if the supplied URL is valid or not. To check if you're vulnerable, look for a call to `require("uri-js").parse()` where a user is able to send their own input. This affects uri-js 2.1.1 and earlier.
Remediation
References
https://nodesecurity.io/advisories/100
https://github.com/garycourt/uri-js/issues/12
Related Vulnerabilities
CVE-2018-1000192 Vulnerability in maven package org.jenkins-ci.main:jenkins-core
CVE-2020-7760 Vulnerability in maven package org.webjars.bower:codemirror
CVE-2022-25858 Vulnerability in maven package org.webjars.npm:terser
CVE-2022-22885 Vulnerability in maven package cn.hutool:hutool-http
CVE-2019-10243 Vulnerability in maven package org.eclipse.kura:target-platform