CVE-2026-26996
ADVISORY - githubSummary
Summary
minimatch is vulnerable to Regular Expression Denial of Service (ReDoS) when a glob pattern contains many consecutive * wildcards followed by a literal character that doesn't appear in the test string. Each * compiles to a separate [^/]*? regex group, and when the match fails, V8's regex engine backtracks exponentially across all possible splits.
The time complexity is O(4^N) where N is the number of * characters. With N=15, a single minimatch() call takes ~2 seconds. With N=34, it hangs effectively forever.
Details
Give all details on the vulnerability. Pointing to the incriminated source code is very helpful for the maintainer.
PoC
When minimatch compiles a glob pattern, each * becomes [^/]*? in the generated regex. For a pattern like ***************X***:
/^(?!\.)[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?[^/]*?X[^/]*?[^/]*?[^/]*?$/
When the test string doesn't contain X, the regex engine must try every possible way to distribute the characters across all the [^/]*? groups before concluding no match exists. With N groups and M characters, this is O(C(N+M, N)) — exponential.
Impact
Any application that passes user-controlled strings to minimatch() as the pattern argument is vulnerable to DoS. This includes:
- File search/filter UIs that accept glob patterns
.gitignore-style filtering with user-defined rules- Build tools that accept glob configuration
- Any API that exposes glob matching to untrusted input
Thanks to @ljharb for back-porting the fix to legacy versions of minimatch.
Common Weakness Enumeration (CWE)
Inefficient Regular Expression Complexity
Inefficient Regular Expression Complexity
Inefficient Regular Expression Complexity
NIST
3.9
CVSS SCORE
8.7highGitHub
-
CVSS SCORE
8.7highDebian
-
Ubuntu
3.9
CVSS SCORE
7.5mediumRed Hat
3.9
CVSS SCORE
7.5highChainguard
CGA-4mrr-cgvh-9w95
-
minimos
MINI-2f7v-wv4v-874p
-
minimos
MINI-4jw5-c4r6-4mx7
-
minimos
MINI-637w-6gg8-h8h6
-
minimos
MINI-64xp-6xmw-wpqm
-
minimos
MINI-6pm7-mh76-25rf
-
minimos
MINI-6vfh-882g-mff5
-
minimos
MINI-7gfh-wjf8-j349
-
minimos
MINI-86hg-5j62-fxhj
-
minimos
MINI-9hg3-vc2v-6rm2
-
minimos
MINI-9w7h-3r25-wqvx
-
minimos
MINI-c4rh-gfcp-9xgf
-
minimos
MINI-cqcr-m7f7-9v4g
-
minimos
MINI-h6p5-v2q7-4v4f
-
minimos
MINI-h7cw-q4hg-mxfg
-
minimos
MINI-j57h-wpfr-fv8w
-
minimos
MINI-x5vm-34f5-542r
-
minimos
MINI-x7r8-p7r7-x24p
-