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.
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.
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).
Rack::Directory.{
"nvd_published_at": "2026-02-18T19:21:43Z",
"cwe_ids": [
"CWE-22",
"CWE-548"
],
"github_reviewed_at": "2026-02-17T16:14:11Z",
"github_reviewed": true,
"severity": "HIGH"
}