ActionDispatch::Http::Cache::Request (original) (raw)
Methods
E
F
I
N
Constants
HTTP_IF_MODIFIED_SINCE | = | "HTTP_IF_MODIFIED_SINCE" |
---|---|---|
HTTP_IF_NONE_MATCH | = | "HTTP_IF_NONE_MATCH" |
Instance Public methods
etag_matches?(etag)Link
def etag_matches?(etag) if etag validators = if_none_match_etags validators.include?(etag) || validators.include?("*") end end
fresh?(response)Link
Check response freshness (Last-Modified
and ETag
) against request If-Modified-Since
and If-None-Match
conditions. If both headers are supplied, based on configuration, either ETag
is preferred over Last-Modified
or both are considered equally. You can adjust the preference with config.action_dispatch.strict_freshness
. Reference: tools.ietf.org/html/rfc7232#section-6
def fresh?(response) if Request.strict_freshness if if_none_match etag_matches?(response.etag) elsif if_modified_since not_modified?(response.last_modified) else false end else last_modified = if_modified_since etag = if_none_match
return false unless last_modified || etag
success = true
success &&= not_modified?(response.last_modified) if last_modified
success &&= etag_matches?(response.etag) if etag
success
end end
if_modified_since()Link
def if_modified_since if since = get_header(HTTP_IF_MODIFIED_SINCE) Time.rfc2822(since) rescue nil end end
if_none_match()Link
def if_none_match get_header HTTP_IF_NONE_MATCH end
if_none_match_etags()Link
not_modified?(modified_at)Link
def not_modified?(modified_at) if_modified_since && modified_at && if_modified_since >= modified_at end