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.
Metrics
Affected Vendors & Products
References
History
No history.
MITRE
Status: PUBLISHED
Assigner: hackerone
Published: 2018-06-04T19:00:00Z
Updated: 2024-09-17T01:46:00.192Z
Reserved: 2017-10-29T00:00:00
Link: CVE-2017-16021
Vulnrichment
No data.
NVD
Status : Modified
Published: 2018-06-04T19:29:01.303
Modified: 2024-11-21T03:15:40.693
Link: CVE-2017-16021
Redhat
No data.