Module: ActionDispatch::Http::Cache::Request

Included in:
Request
Defined in:
actionpack/lib/action_dispatch/http/cache.rb

Constant Summary collapse

HTTP_IF_MODIFIED_SINCE =
'HTTP_IF_MODIFIED_SINCE'.freeze
HTTP_IF_NONE_MATCH =
'HTTP_IF_NONE_MATCH'.freeze

Instance Method Summary collapse

Instance Method Details

#etag_matches?(etag) ⇒ Boolean

Returns:

  • (Boolean)


25
26
27
# File 'actionpack/lib/action_dispatch/http/cache.rb', line 25

def etag_matches?(etag)
  if_none_match && if_none_match == etag
end

#fresh?(response) ⇒ Boolean

Check response freshness (Last-Modified and ETag) against request If-Modified-Since and If-None-Match conditions. If both headers are supplied, both must match, or the request is not considered fresh.

Returns:

  • (Boolean)


32
33
34
35
36
37
38
39
40
41
42
# File 'actionpack/lib/action_dispatch/http/cache.rb', line 32

def fresh?(response)
  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

#if_modified_sinceObject



11
12
13
14
15
# File 'actionpack/lib/action_dispatch/http/cache.rb', line 11

def if_modified_since
  if since = env[HTTP_IF_MODIFIED_SINCE]
    Time.rfc2822(since) rescue nil
  end
end

#if_none_matchObject



17
18
19
# File 'actionpack/lib/action_dispatch/http/cache.rb', line 17

def if_none_match
  env[HTTP_IF_NONE_MATCH]
end

#not_modified?(modified_at) ⇒ Boolean

Returns:

  • (Boolean)


21
22
23
# File 'actionpack/lib/action_dispatch/http/cache.rb', line 21

def not_modified?(modified_at)
  if_modified_since && modified_at && if_modified_since >= modified_at
end