aboutsummaryrefslogtreecommitdiffstats
path: root/actionpack/lib/action_dispatch/middleware
diff options
context:
space:
mode:
authorPiotr Sarnacki <drogus@gmail.com>2012-04-30 00:16:10 -0700
committerPiotr Sarnacki <drogus@gmail.com>2012-04-30 00:16:10 -0700
commit88b5f943e67745e38b903d4a4cb0afe121b46857 (patch)
treef2b845cf9c9b02bf4b6ce3175c447664b39228d2 /actionpack/lib/action_dispatch/middleware
parent4cff1a28095ca93f865eaaa7b4ce0132b5256340 (diff)
parent5638adfd87dbec20183443204793c1de41ee9bb7 (diff)
downloadrails-88b5f943e67745e38b903d4a4cb0afe121b46857.tar.gz
rails-88b5f943e67745e38b903d4a4cb0afe121b46857.tar.bz2
rails-88b5f943e67745e38b903d4a4cb0afe121b46857.zip
Merge pull request #6034 from willbryant/flash_must_not_load_session_on_every_request_master
Fix the Flash middleware loading the session on every request
Diffstat (limited to 'actionpack/lib/action_dispatch/middleware')
-rw-r--r--actionpack/lib/action_dispatch/middleware/flash.rb9
1 files changed, 3 insertions, 6 deletions
diff --git a/actionpack/lib/action_dispatch/middleware/flash.rb b/actionpack/lib/action_dispatch/middleware/flash.rb
index c92c91df65..54f2669f43 100644
--- a/actionpack/lib/action_dispatch/middleware/flash.rb
+++ b/actionpack/lib/action_dispatch/middleware/flash.rb
@@ -4,7 +4,7 @@ module ActionDispatch
# read a notice you put there or <tt>flash["notice"] = "hello"</tt>
# to put a new one.
def flash
- @env[Flash::KEY] ||= (session["flash"] || Flash::FlashHash.new)
+ @env[Flash::KEY] ||= (session["flash"] || Flash::FlashHash.new).tap(&:sweep)
end
end
@@ -217,10 +217,6 @@ module ActionDispatch
end
def call(env)
- if (session = env['rack.session']) && (flash = session['flash'])
- flash.sweep
- end
-
@app.call(env)
ensure
session = env['rack.session'] || {}
@@ -237,7 +233,8 @@ module ActionDispatch
env[KEY] = new_hash
end
- if session.key?('flash') && session['flash'].empty?
+ if (!session.respond_to?(:loaded?) || session.loaded?) && # (reset_session uses {}, which doesn't implement #loaded?)
+ session.key?('flash') && session['flash'].empty?
session.delete('flash')
end
end