CVE-2026-27904
HIGH7.5EPSS 0.03%minimatch ReDoS: nested *() extglobs generate catastrophically backtracking regular expressions
描述
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.
受影響套件(2)
- Debian/node-minimatchfrom 0
- npm/minimatch>= 10.0.0, < 10.2.3
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 3.1 | HIGH7.5 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:N/I:N/A:H |
參考連結(5)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-27904
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-27904
- PATCHhttps://github.com/isaacs/minimatch
- WEBhttps://github.com/isaacs/minimatch/commit/11d0df6165d15a955462316b26d52e5efae06fce
- WEBhttps://github.com/isaacs/minimatch/security/advisories/GHSA-23c5-xmqv-rm74