CVE-2026-40295
Description
Devise is an authentication solution for Rails based on Warden. In versions 5.0.3 and below, when the Timeoutable module is enabled in Devise, the FailureApp#redirect_url method returns request.referrer — the HTTP Referer header, which is attacker-controllable — without validation for any non-GET request that results in a session timeout. An attacker who hosts a page with an auto-submitting cross-origin form can cause a victim with an expired Devise session to be redirected to an arbitrary external URL. This contrasts with the GET timeout path (which uses server-side attempted_path) and Devise's own store_location_for mechanism (which strips external hosts via extract_path_from_location), both of which are protected; only the non-GET timeout redirect path is unprotected. Expired-session users can be silently redirected from the trusted app domain to attacker-controlled URLs, enabling phishing and malware delivery while bypassing browser warnings. Note: Rails' built-in open-redirect protection does not mitigate this issue. Devise::FailureApp is an ActionController::Metal app with its own isolated copy of the relevant redirect configuration, so config.action_controller.action_on_open_redirect = :raise (and the older raise_on_open_redirects setting) do not reach it. This issue has been fixed in version 5.0.4.
AI Insight
LLM-synthesized narrative grounded in this CVE's description and references.
Affected packages
Versions sourced from the GitHub Security Advisory.
| Package | Affected versions | Patched versions |
|---|---|---|
deviseRubyGems | < 5.0.4 | 5.0.4 |
Affected products
15<= 5.0.3+ 1 more
- (no CPE)range: <= 5.0.3
- cpe:2.3:a:heartcombo:devise:*:*:*:*:*:ruby:*:*range: <5.0.4
- osv-coords13 versionspkg:apk/chainguard/gitlab-rails-ce-18.11pkg:apk/chainguard/gitlab-rails-ce-18.3pkg:apk/chainguard/gitlab-rails-ce-18.4pkg:apk/chainguard/gitlab-rails-ce-18.5pkg:apk/chainguard/gitlab-rails-ce-18.6pkg:apk/chainguard/gitlab-rails-ce-18.9pkg:apk/chainguard/gitlab-rails-ce-fips-18.3pkg:apk/chainguard/gitlab-rails-ce-fips-18.5pkg:apk/chainguard/gitlab-rails-ce-fips-18.6pkg:apk/chainguard/gitlab-rails-ce-fips-18.7pkg:apk/chainguard/gitlab-rails-ce-fips-18.8pkg:apk/chainguard/gitlab-rails-ce-fips-18.9pkg:gem/devise
< 18.11.2-r1+ 12 more
- (no CPE)range: < 18.11.2-r1
- (no CPE)range: < 18.3.6-r6
- (no CPE)range: < 18.4.6-r5
- (no CPE)range: < 18.5.5-r3
- (no CPE)range: < 18.6.6-r4
- (no CPE)range: < 18.9.6-r2
- (no CPE)range: < 18.3.6-r7
- (no CPE)range: < 18.5.5-r3
- (no CPE)range: < 18.6.6-r4
- (no CPE)range: < 18.7.6-r3
- (no CPE)range: < 18.8.9-r1
- (no CPE)range: < 18.9.6-r2
- (no CPE)range: < 5.0.4
Patches
Vulnerability mechanics
References
5- github.com/heartcombo/devise/commit/025fe2124f9928766fc46520e999633b598d0360nvdPatchWEB
- github.com/advisories/GHSA-jp94-3292-c3xvghsaADVISORY
- github.com/heartcombo/devise/security/advisories/GHSA-jp94-3292-c3xvnvdMitigationVendor AdvisoryWEB
- nvd.nist.gov/vuln/detail/CVE-2026-40295ghsaADVISORY
- github.com/rubysec/ruby-advisory-db/blob/master/gems/devise/CVE-2026-40295.ymlghsaWEB
News mentions
0No linked articles in our index yet.