module Roda::RodaPlugins::Caching::ResponseMethods
def cache_control(opts)
See RFC 2616 / 14.9 for more on standard cache control directives:
# => Cache-Control: public, max-age=60
response.cache_control :public=>true, :max_age => 60
Options can also contain value directives (:max_age, :s_maxage).
:no_store, :must_revalidate, :proxy_revalidate), with true as the value.
Options can can any non-value directives (:public, :private, :no_cache,
Specify response freshness policy for using the Cache-Control header.
def cache_control(opts) values = [] opts.each do |k, v| next unless v k = k.to_s.tr(UNDERSCORE, DASH) values << (v == true ? k : "#{k}=#{v}") end self[CACHE_CONTROL] = values.join(COMMA) unless values.empty? end
def expires(max_age, opts={})
cached for. Also sets the Expires header, useful if you have
be an integer number of seconds that the current request should be
Set Cache-Control header with the max_age given. max_age should
def expires(max_age, opts={}) cache_control(opts.merge(:max_age=>max_age)) self[EXPIRES] = (Time.now + max_age).httpdate end
def finish
def finish a = super if a[0] == 304 h = a[1] h.delete(CONTENT_TYPE) h.delete(CONTENT_LENGTH) end a end