Vulnerability Details CVE-2026-40295
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.
Exploit prediction scoring system (EPSS) score
EPSS Score 0.001
EPSS Ranking 20.8%
CVSS Severity
CVSS v3 Score 6.1
Products affected by CVE-2026-40295
-
cpe:2.3:a:heartcombo:devise:-
-
cpe:2.3:a:heartcombo:devise:0.7.5
-
cpe:2.3:a:heartcombo:devise:0.8.0
-
cpe:2.3:a:heartcombo:devise:0.8.1
-
cpe:2.3:a:heartcombo:devise:0.8.2
-
cpe:2.3:a:heartcombo:devise:0.9.0
-
cpe:2.3:a:heartcombo:devise:0.9.1
-
cpe:2.3:a:heartcombo:devise:0.9.2
-
cpe:2.3:a:heartcombo:devise:1.0.0
-
cpe:2.3:a:heartcombo:devise:1.0.1
-
cpe:2.3:a:heartcombo:devise:1.0.11
-
cpe:2.3:a:heartcombo:devise:1.0.2
-
cpe:2.3:a:heartcombo:devise:1.0.3
-
cpe:2.3:a:heartcombo:devise:1.0.4
-
cpe:2.3:a:heartcombo:devise:1.0.5
-
cpe:2.3:a:heartcombo:devise:1.0.6
-
cpe:2.3:a:heartcombo:devise:1.0.7
-
cpe:2.3:a:heartcombo:devise:1.0.8
-
cpe:2.3:a:heartcombo:devise:1.0.9
-
cpe:2.3:a:heartcombo:devise:1.1.0
-
cpe:2.3:a:heartcombo:devise:1.1.1
-
cpe:2.3:a:heartcombo:devise:1.1.2
-
cpe:2.3:a:heartcombo:devise:1.1.3
-
cpe:2.3:a:heartcombo:devise:1.1.4
-
cpe:2.3:a:heartcombo:devise:1.1.5
-
cpe:2.3:a:heartcombo:devise:1.1.6
-
cpe:2.3:a:heartcombo:devise:1.1.7
-
cpe:2.3:a:heartcombo:devise:1.1.8
-
cpe:2.3:a:heartcombo:devise:1.1.9
-
cpe:2.3:a:heartcombo:devise:1.2.0
-
cpe:2.3:a:heartcombo:devise:1.2.1
-
cpe:2.3:a:heartcombo:devise:1.3.0
-
cpe:2.3:a:heartcombo:devise:1.3.1
-
cpe:2.3:a:heartcombo:devise:1.3.2
-
cpe:2.3:a:heartcombo:devise:1.3.3
-
cpe:2.3:a:heartcombo:devise:1.3.4
-
cpe:2.3:a:heartcombo:devise:1.4.0
-
cpe:2.3:a:heartcombo:devise:1.4.1
-
cpe:2.3:a:heartcombo:devise:1.4.2
-
cpe:2.3:a:heartcombo:devise:1.4.3
-
cpe:2.3:a:heartcombo:devise:1.4.4
-
cpe:2.3:a:heartcombo:devise:1.4.5
-
cpe:2.3:a:heartcombo:devise:1.4.6
-
cpe:2.3:a:heartcombo:devise:1.4.7
-
cpe:2.3:a:heartcombo:devise:1.4.8
-
cpe:2.3:a:heartcombo:devise:1.4.9
-
cpe:2.3:a:heartcombo:devise:1.5.0
-
cpe:2.3:a:heartcombo:devise:1.5.1
-
cpe:2.3:a:heartcombo:devise:1.5.2
-
cpe:2.3:a:heartcombo:devise:1.5.3
-
cpe:2.3:a:heartcombo:devise:1.5.4
-
cpe:2.3:a:heartcombo:devise:2.0.0
-
cpe:2.3:a:heartcombo:devise:2.0.1
-
cpe:2.3:a:heartcombo:devise:2.0.2
-
cpe:2.3:a:heartcombo:devise:2.0.3
-
cpe:2.3:a:heartcombo:devise:2.0.4
-
cpe:2.3:a:heartcombo:devise:2.0.5
-
cpe:2.3:a:heartcombo:devise:2.0.6
-
cpe:2.3:a:heartcombo:devise:2.1.0
-
cpe:2.3:a:heartcombo:devise:2.1.1
-
cpe:2.3:a:heartcombo:devise:2.1.2
-
cpe:2.3:a:heartcombo:devise:2.1.3
-
cpe:2.3:a:heartcombo:devise:2.1.4
-
cpe:2.3:a:heartcombo:devise:2.2.0
-
cpe:2.3:a:heartcombo:devise:2.2.1
-
cpe:2.3:a:heartcombo:devise:2.2.2
-
cpe:2.3:a:heartcombo:devise:2.2.3
-
cpe:2.3:a:heartcombo:devise:2.2.4
-
cpe:2.3:a:heartcombo:devise:2.2.5
-
cpe:2.3:a:heartcombo:devise:2.2.6
-
cpe:2.3:a:heartcombo:devise:2.2.7
-
cpe:2.3:a:heartcombo:devise:2.2.8
-
cpe:2.3:a:heartcombo:devise:3.0.0
-
cpe:2.3:a:heartcombo:devise:3.0.1
-
cpe:2.3:a:heartcombo:devise:3.0.2
-
cpe:2.3:a:heartcombo:devise:3.0.3
-
cpe:2.3:a:heartcombo:devise:3.0.4
-
cpe:2.3:a:heartcombo:devise:3.1.0
-
cpe:2.3:a:heartcombo:devise:3.1.1
-
cpe:2.3:a:heartcombo:devise:3.1.2
-
cpe:2.3:a:heartcombo:devise:3.2.0
-
cpe:2.3:a:heartcombo:devise:3.2.1
-
cpe:2.3:a:heartcombo:devise:3.2.2
-
cpe:2.3:a:heartcombo:devise:3.2.3
-
cpe:2.3:a:heartcombo:devise:3.2.4
-
cpe:2.3:a:heartcombo:devise:3.3.0
-
cpe:2.3:a:heartcombo:devise:3.4.0
-
cpe:2.3:a:heartcombo:devise:3.4.1
-
cpe:2.3:a:heartcombo:devise:3.5.0
-
cpe:2.3:a:heartcombo:devise:3.5.1
-
cpe:2.3:a:heartcombo:devise:3.5.10
-
cpe:2.3:a:heartcombo:devise:3.5.2
-
cpe:2.3:a:heartcombo:devise:3.5.3
-
cpe:2.3:a:heartcombo:devise:3.5.4
-
cpe:2.3:a:heartcombo:devise:3.5.5
-
cpe:2.3:a:heartcombo:devise:3.5.6
-
cpe:2.3:a:heartcombo:devise:3.5.7
-
cpe:2.3:a:heartcombo:devise:3.5.8
-
cpe:2.3:a:heartcombo:devise:3.5.9
-
cpe:2.3:a:heartcombo:devise:4.0.0
-
cpe:2.3:a:heartcombo:devise:4.0.1
-
cpe:2.3:a:heartcombo:devise:4.0.2
-
cpe:2.3:a:heartcombo:devise:4.0.3
-
cpe:2.3:a:heartcombo:devise:4.1.0
-
cpe:2.3:a:heartcombo:devise:4.1.1
-
cpe:2.3:a:heartcombo:devise:4.2.0
-
cpe:2.3:a:heartcombo:devise:4.2.1
-
cpe:2.3:a:heartcombo:devise:4.3.0
-
cpe:2.3:a:heartcombo:devise:4.4.0
-
cpe:2.3:a:heartcombo:devise:4.4.1
-
cpe:2.3:a:heartcombo:devise:4.4.2
-
cpe:2.3:a:heartcombo:devise:4.4.3
-
cpe:2.3:a:heartcombo:devise:4.5.0
-
cpe:2.3:a:heartcombo:devise:4.6.0
-
cpe:2.3:a:heartcombo:devise:4.6.1
-
cpe:2.3:a:heartcombo:devise:4.6.2
-
cpe:2.3:a:heartcombo:devise:4.7.0
-
cpe:2.3:a:heartcombo:devise:4.7.1
-
cpe:2.3:a:heartcombo:devise:4.7.2
-
cpe:2.3:a:heartcombo:devise:4.7.3
-
cpe:2.3:a:heartcombo:devise:4.8.0
-
cpe:2.3:a:heartcombo:devise:4.8.1
-
cpe:2.3:a:heartcombo:devise:4.9.0
-
cpe:2.3:a:heartcombo:devise:4.9.1
-
cpe:2.3:a:heartcombo:devise:4.9.2
-
cpe:2.3:a:heartcombo:devise:4.9.3
-
cpe:2.3:a:heartcombo:devise:4.9.4
-
cpe:2.3:a:heartcombo:devise:5.0.0
-
cpe:2.3:a:heartcombo:devise:5.0.1
-
cpe:2.3:a:heartcombo:devise:5.0.2
-
cpe:2.3:a:heartcombo:devise:5.0.3