Home

Description

minimatch is a minimal matching utility for converting glob expressions into JavaScript RegExp objects. Prior to version 10.2.3, 9.0.7, 8.0.6, 7.4.8, 6.2.2, 5.1.8, 4.2.5, and 3.1.4, nested `*()` extglobs produce regexps with nested unbounded quantifiers (e.g. `(?:(?:a|b)*)*`), which exhibit catastrophic backtracking in V8. With a 12-byte pattern `*(*(*(a|b)))` and an 18-byte non-matching input, `minimatch()` stalls for over 7 seconds. Adding a single nesting level or a few input characters pushes this to minutes. This is the most severe finding: it is triggered by the default `minimatch()` API with no special options, and the minimum viable pattern is only 12 bytes. The same issue affects `+()` extglobs equally. Versions 10.2.3, 9.0.7, 8.0.6, 7.4.8, 6.2.2, 5.1.8, 4.2.5, and 3.1.4 fix the issue.

PUBLISHED Reserved 2026-02-24 | Published 2026-02-26 | Updated 2026-02-26 | Assigner GitHub_M




HIGH: 7.5CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H

Problem types

CWE-1333: Inefficient Regular Expression Complexity

Product status

>= 10.0.0, < 10.2.3
affected

>= 9.0.0, < 9.0.7
affected

>= 8.0.0, < 8.0.6
affected

>= 7.0.0, < 7.4.8
affected

>= 6.0.0, < 6.2.2
affected

>= 5.0.0, < 5.1.8
affected

>= 4.0.0, < 4.2.5
affected

< 3.1.4
affected

References

github.com/...imatch/security/advisories/GHSA-23c5-xmqv-rm74

cve.org (CVE-2026-27904)

nvd.nist.gov (CVE-2026-27904)

Download JSON