aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_dispatch/middleware/session/abstract_store.rb
diff options
context:
space:
mode:
authorW. Andrew Loe III <andrew@andrewloe.com>2010-09-13 14:29:25 -0700
committerAaron Patterson <aaron.patterson@gmail.com>2010-09-13 15:11:46 -0700
commit9cd094b8da492b711002dd4b1f2792f315e9bde0 (patch)
treeba8839bfda54d59d7861aeb3e63f4fae4fca9bbd /actionpack/lib/action_dispatch/middleware/session/abstract_store.rb
parent0522b26cdf15ba1b5c89fc64f9069e1a13cafcff (diff)
downloadrails-9cd094b8da492b711002dd4b1f2792f315e9bde0.tar.gz
rails-9cd094b8da492b711002dd4b1f2792f315e9bde0.tar.bz2
rails-9cd094b8da492b711002dd4b1f2792f315e9bde0.zip
Only send secure cookies over SSL.
Diffstat (limited to 'actionpack/lib/action_dispatch/middleware/session/abstract_store.rb')
-rw-r--r--actionpack/lib/action_dispatch/middleware/session/abstract_store.rb5
1 files changed, 4 insertions, 1 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/session/abstract_store.rb b/actionpack/lib/action_dispatch/middleware/session/abstract_store.rb
index dd82294644..348a2d1eb2 100644
--- a/actionpack/lib/action_dispatch/middleware/session/abstract_store.rb
+++ b/actionpack/lib/action_dispatch/middleware/session/abstract_store.rb
@@ -152,6 +152,10 @@ module ActionDispatch
options = env[ENV_SESSION_OPTIONS_KEY]
if !session_data.is_a?(AbstractStore::SessionHash) || session_data.loaded? || options[:expire_after]
+ request = ActionDispatch::Request.new(env)
+
+ return response if (options[:secure] && !request.ssl?)
+
session_data.send(:load!) if session_data.is_a?(AbstractStore::SessionHash) && !session_data.loaded?
sid = options[:id] || generate_sid
@@ -165,7 +169,6 @@ module ActionDispatch
cookie[:expires] = Time.now + options.delete(:expire_after)
end
- request = ActionDispatch::Request.new(env)
set_cookie(request, cookie.merge!(options))
end