Rack::Session::Cookie secrets: decrypt failure fallback enables secretless session forgery and Marshal deserialization
Rack::Session is a session management implementation for Rack. From 2.0.0 to before 2.1.2, Rack::Session::Cookie incorrectly handles decryption failures when configured with secrets:. If cookie decryption fails, the implementation falls back to a default decoder instead of rejecting the cookie. This allows an unauthenticated attacker to supply a crafted session cookie that is accepted as valid session data without knowledge of any configured secret. Because this mechanism is used to load session state, an attacker can manipulate session contents and potentially gain unauthorized access. This vulnerability is fixed in 2.1.2.
References
-
https://github.com/rack/rack-session/security/advisories/GHSA-33qg-7wpp-89cq x_refsource_CONFIRM
Affected products
rack-session
- ==>= 2.0.0, < 2.1.2
Matching in nixpkgs
pkgs.rubyPackages.rack-session
None
pkgs.rubyPackages_3_1.rack-session
None
pkgs.rubyPackages_3_2.rack-session
None
pkgs.rubyPackages_3_3.rack-session
None
pkgs.rubyPackages_3_4.rack-session
None