GHSA-73rr-hh4g-fpgx · Severity: low · Ecosystem: npm — jsdiff has a Denial of Service vulnerability in parsePatch and applyPatch
jsdiff is a JavaScript text differencing implementation. Prior to versions 8.0.3, 5.2.2, 4.0.4, and 3.5.1, attempting to parse a patch whose filename headers contain the line break characters `\r`, `\u2028`, or `\u2029` can cause the `parsePatch` method to enter an infinite loop. It then consumes memory without limit until the process crashes due to running out of memory. Applications are therefore likely to be vulnerable to a denial-of-service attack if they call `parsePatch` with a user-provided patch as input. A large payload is not needed to trigger the vulnerability, so size limits on user input do not provide any protection. Furthermore, some applications may be vulnerable even when calling `parsePatch` on a patch generated by the application itself if the user is nonetheless able to control the filename headers (e.g. by directly providing the filenames of the files to be diffed). The `applyPatch` method is similarly affected if (and only if) called with a string representation of a patch as an argument, since under the hood it parses that string using `parsePatch`. Other methods of the library are unaffected. Finally, a second and lesser interdependent bug - a ReDOS - also exhibits when those same line break characters are present in a patch's *patch* header (also known as its "leading garbage"). A maliciously-crafted patch header of length *n* can take `parsePatch` O(*n*³) time to parse. Versions 8.0.3, 5.2.2, 4.0.4, and 3.5.1 contain a fix. As a workaround, do not attempt to parse patches that contain any of these characters: `\r`, `\u2028`, or `\u2029`.
Conclusion & alert: CVE-2026-24001 is rated Low Risk (25.1/100): CVSS Low severity, with low exploitation likelihood (EPSS 0.51%). Mandatory action: Monitor for updates and reassess as exploit intelligence or EPSS changes.
Risk is dynamic; we continuously reassess and refresh what is shown on this page as upstream context changes.
EPSS lead: Daily EPSS estimates relative likelihood of exploitation; percentile ranks this CVE among scored vulnerabilities (higher = more severe relative rank).
| # | Date | Old EPSS score | New EPSS score | Delta (New - Old) |
|---|---|---|---|---|
| 1 | 2026-06-15 | 0.02% | 0.51% | +0.49% |
| 2 | 2026-02-18 | 0.06% | 0.02% | -0.04% |
| 3 | 2026-01-28 | — | 0.06% | — |
Full EPSS history (4 records total)
CVSS metrics for this CVE.
| Base score | Version | Severity | Vector | Exploitability | Impact | Score source |
|---|---|---|---|---|---|---|
| 2.7 | 4.0 | LOW |
|
— | — | [email protected] |
| 7.5 | 3.1 | HIGH |
|
3.9 | 3.6 | [email protected] |
GHSA-73rr-hh4g-fpgx · Severity: low · Ecosystem: npm — jsdiff has a Denial of Service vulnerability in parsePatch and applyPatch
| vendor | priority | summary | link |
|---|---|---|---|
debian
|
not yet assigned | CVE-2026-24001 not yet assigned priority: Debian including 1 source packages (node-diff), 5 status rows across 5 suites (bookworm, bullseye, forky, sid, trixie): open 3, resolved 2. | https://security-tracker.debian.org/tracker/CVE-2026-24001 |
redhat
|
high | — | https://access.redhat.com/security/cve/CVE-2026-24001 |
ubuntu
|
medium | CVE-2026-24001 medium priority: Ubuntu including 1 source packages (node-diff), 7 status rows across 7 suites (bionic, focal, jammy, noble, questing, upstream, xenial): needs-triage 7. | https://ubuntu.com/security/CVE-2026-24001 |
| Vendor | Product | Version | Raw CPE |
|---|---|---|---|
| kpdecker | jsdiff | < 3.5.1 | cpe:2.3:a:kpdecker:jsdiff:*:*:*:*:*:node.js:*:* |
| kpdecker | jsdiff | >= 4.0.0, < 4.0.4 | cpe:2.3:a:kpdecker:jsdiff:*:*:*:*:*:node.js:*:* |
| kpdecker | jsdiff | >= 5.0.0, < 5.2.2 | cpe:2.3:a:kpdecker:jsdiff:*:*:*:*:*:node.js:*:* |
| kpdecker | jsdiff | >= 6.0.0, < 8.0.3 | cpe:2.3:a:kpdecker:jsdiff:*:*:*:*:*:node.js:*:* |
| URL | Tags |
|---|---|
| https://github.com/kpdecker/jsdiff/commit/15a1585230748c8ae6f8274c202e0c87309142f5 | Patch |
| https://github.com/kpdecker/jsdiff/issues/653 | Issue Tracking |
| https://github.com/kpdecker/jsdiff/pull/649 | Issue Tracking Patch |
| https://github.com/kpdecker/jsdiff/security/advisories/GHSA-73rr-hh4g-fpgx | Vendor Advisory |