mirror of
https://github.com/github/rails.git
synced 2026-04-04 03:00:58 -04:00
Added Base#expires_in(seconds)/Base#expires_now to control HTTP content cache headers #1755 [Thomas Fuchs]
git-svn-id: http://svn-commit.rubyonrails.org/rails/trunk@1845 5ecf4fe2-1ee6-0310-87b1-e25e094e27de
This commit is contained in:
@@ -1,5 +1,7 @@
|
||||
*SVN*
|
||||
|
||||
* Added Base#expires_in(seconds)/Base#expires_now to control HTTP content cache headers #1755 [Thomas Fuchs]
|
||||
|
||||
* Fixed line number reporting for Builder template errors #1753 [piotr]
|
||||
|
||||
* Fixed assert_routing so that testing controllers in modules works as expected [Nicholas Seckar, Rick Olson]
|
||||
|
||||
@@ -712,6 +712,29 @@ module ActionController #:nodoc:
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
# Sets a HTTP 1.1 Cache-Control header. Defaults to issuing a "private" instruction, so that
|
||||
# intermediate caches shouldn't cache the response.
|
||||
#
|
||||
# Examples:
|
||||
# expires_in 20.minutes
|
||||
# expires_in 3.hours, :private => false
|
||||
# expires in 3.hours, 'max-stale' => 5.hours, :private => nil, :public => true
|
||||
#
|
||||
# This method will overwrite an existing Cache-Control header.
|
||||
# See http://www.w3.org/Protocols/rfc2616/rfc2616-sec14.html for more possibilities.
|
||||
def expires_in(seconds, options = {})
|
||||
cache_options = { 'max-age' => seconds, 'private' => true }.symbolize_keys.merge!(options.symbolize_keys)
|
||||
cache_options.delete_if { |k,v| v.nil? or v == false }
|
||||
cache_control = cache_options.map{ |k,v| v == true ? k.to_s : "#{k.to_s}=#{v.to_s}"}
|
||||
@response.headers["Cache-Control"] = cache_control.join(', ')
|
||||
end
|
||||
|
||||
# Sets a HTTP 1.1 Cache-Control header of "no-cache" so no caching should occur by the browser or
|
||||
# intermediate caches (like caching proxy servers).
|
||||
def expires_now
|
||||
@response.headers["Cache-Control"] = "no-cache"
|
||||
end
|
||||
|
||||
# Resets the session by clearing out all the objects stored within and initializing a new session object.
|
||||
def reset_session #:doc:
|
||||
|
||||
Reference in New Issue
Block a user