CVE-2026-22860
HIGH7.5EPSS 0.12%ruby-rack - security update
描述
## Summary `Rack::Directory`’s path check used a string prefix match on the expanded path. A request like `/../root_example/` can escape the configured root if the target path starts with the root string, allowing directory listing outside the intended root. ## Details In `directory.rb`, `File.expand_path(File.join(root, path_info)).start_with?(root)` does not enforce a path boundary. If the server root is `/var/www/root`, a path like `/var/www/root_backup` passes the check because it shares the same prefix, so `Rack::Directory` will list that directory also. ## Impact Information disclosure via directory listing outside the configured root when `Rack::Directory` is exposed to untrusted clients and a directory shares the root prefix (e.g., `public2`, `www_backup`). ## Mitigation * Update to a patched version of Rack that correctly checks the root prefix. * Don't name directories with the same prefix as one which is exposed via `Rack::Directory`.
受影響套件(4)
- Debian/ruby-rackfrom 0, < 2.1.4-3+deb11u5
- Debian/ruby-rackfrom 0, < 2.1.4-3+deb11u5
- Debian/ruby-rackfrom 0, < 2.2.22-0+deb12u1
- RubyGems/rackfrom 0, < 2.2.22
CVSS 分數
| 來源 | 版本 | 嚴重程度 | 向量 |
|---|---|---|---|
| osv | CVSS 3.1 | HIGH7.5 | CVSS:3.1/AV:N/AC:L/PR:N/UI:N/S:U/C:H/I:N/A:N |
參考連結(6)
- ADVISORYhttps://nvd.nist.gov/vuln/detail/CVE-2026-22860
- ADVISORYhttps://security-tracker.debian.org/tracker/CVE-2026-22860
- PATCHhttps://github.com/rack/rack
- WEBhttps://github.com/rack/rack/commit/75c5745c286637a8f049a33790c71237762069e7
- WEBhttps://github.com/rack/rack/security/advisories/GHSA-mxw3-3hh2-x2mh
- WEBhttps://github.com/rubysec/ruby-advisory-db/blob/master/gems/rack/CVE-2026-22860.yml