Staging Environment: Content and features may be unstable or change without notice.
Search for packages
Package details: pkg:gem/rack@3.2.5
purl pkg:gem/rack@3.2.5
Vulnerabilities affecting this package (0)
Vulnerability Summary Fixed by
This package is not known to be affected by vulnerabilities.
Vulnerabilities fixed by this package (2)
Vulnerability Summary Aliases
VCID-9rpp-9xss-duf6 Rack has a Directory Traversal via Rack:Directory ## 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`. CVE-2026-22860
GHSA-mxw3-3hh2-x2mh
VCID-skxv-7he3-xqgc Stored XSS in Rack::Directory via javascript: filenames rendered into anchor href ## Summary `Rack::Directory` generates an HTML directory index where each file entry is rendered as a clickable link. If a file exists on disk whose basename begins with the `javascript:` scheme (e.g. `javascript:alert(1)`), the generated index includes an anchor whose `href` attribute is exactly `javascript:alert(1)`. Clicking this entry executes arbitrary JavaScript in the context of the hosting application. This results in a client-side XSS condition in directory listings generated by `Rack::Directory`. ## Details `Rack::Directory` renders directory entries using an HTML row template similar to: ```html <a href='%s'>%s</a> ``` The `%s` placeholder is populated directly with the file’s basename. If the basename begins with `javascript:`, the resulting HTML contains an executable JavaScript URL: ```html <a href='javascript:alert(1)'>javascript:alert(1)</a> ``` Because the value is inserted directly into the `href` attribute without scheme validation or normalization, browsers interpret it as a JavaScript URI. When a user clicks the link, the JavaScript executes in the origin of the Rack application. ## Impact If `Rack::Directory` is used to expose filesystem contents over HTTP, an attacker who can create or upload files within that directory may introduce a malicious filename beginning with `javascript:`. When a user visits the directory listing and clicks the entry, arbitrary JavaScript executes in the application's origin. Exploitation requires user interaction (clicking the malicious entry). ## Mitigation * Update to a patched version of Rack in which `Rack::Directory` prefixes generated anchors with a relative path indicator (e.g. `./filename`). * Avoid exposing user-controlled directories via `Rack::Directory`. * Apply a strict Content Security Policy (CSP) to reduce impact of potential client-side execution issues. * Where feasible, restrict or sanitize uploaded filenames to disallow dangerous URI scheme prefixes. HackerOne profile: https://hackerone.com/thesmartshadow GitHub account owner: Ali Firas (@thesmartshadow) CVE-2026-25500
GHSA-whrj-4476-wvmp

Date Actor Action Vulnerability Source VulnerableCode Version
2026-04-12T01:42:23.028332+00:00 GitLab Importer Fixing VCID-9rpp-9xss-duf6 https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-22860.yml 38.3.0
2026-04-12T01:42:13.202987+00:00 GitLab Importer Fixing VCID-skxv-7he3-xqgc https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-25500.yml 38.3.0
2026-04-03T01:51:15.771214+00:00 GitLab Importer Fixing VCID-9rpp-9xss-duf6 https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-22860.yml 38.1.0
2026-04-03T01:51:06.618156+00:00 GitLab Importer Fixing VCID-skxv-7he3-xqgc https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-25500.yml 38.1.0
2026-04-01T16:07:59.631016+00:00 GHSA Importer Fixing VCID-skxv-7he3-xqgc https://github.com/advisories/GHSA-whrj-4476-wvmp 38.0.0
2026-04-01T16:07:59.355976+00:00 GHSA Importer Fixing VCID-9rpp-9xss-duf6 https://github.com/advisories/GHSA-mxw3-3hh2-x2mh 38.0.0
2026-04-01T12:53:52.884193+00:00 GitLab Importer Fixing VCID-9rpp-9xss-duf6 https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-22860.yml 38.0.0
2026-04-01T12:53:52.301711+00:00 GitLab Importer Fixing VCID-skxv-7he3-xqgc https://gitlab.com/gitlab-org/advisories-community/-/blob/main/gem/rack/CVE-2026-25500.yml 38.0.0
2026-04-01T12:52:59.943245+00:00 GithubOSV Importer Fixing VCID-skxv-7he3-xqgc https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-whrj-4476-wvmp/GHSA-whrj-4476-wvmp.json 38.0.0
2026-04-01T12:52:58.085881+00:00 GithubOSV Importer Fixing VCID-9rpp-9xss-duf6 https://github.com/github/advisory-database/blob/main/advisories/github-reviewed/2026/02/GHSA-mxw3-3hh2-x2mh/GHSA-mxw3-3hh2-x2mh.json 38.0.0