Class: Rack::ConditionalGet
- Inherits:
-
Object
- Object
- Rack::ConditionalGet
- Defined in:
- lib/rack/conditional_get.rb
Overview
Middleware that enables conditional GET using if-none-match and if-modified-since. The application should set either or both of the last-modified or etag response headers according to RFC 2616. When either of the conditions is met, the response body is set to be zero length and the response status is set to 304 Not Modified.
Applications that defer response body generation until the body’s each message is received will avoid response body generation completely when a conditional GET matches.
Adapted from Michael Klishin’s Merb implementation: github.com/wycats/merb/blob/master/merb-core/lib/merb-core/rack/middleware/conditional_get.rb
Instance Method Summary collapse
-
#call(env) ⇒ Object
Return empty 304 response if the response has not been modified since the last request.
-
#initialize(app) ⇒ ConditionalGet
constructor
A new instance of ConditionalGet.
Constructor Details
#initialize(app) ⇒ ConditionalGet
Returns a new instance of ConditionalGet.
22 23 24 |
# File 'lib/rack/conditional_get.rb', line 22 def initialize(app) @app = app end |
Instance Method Details
#call(env) ⇒ Object
Return empty 304 response if the response has not been modified since the last request.
28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 |
# File 'lib/rack/conditional_get.rb', line 28 def call(env) case env[REQUEST_METHOD] when "GET", "HEAD" status, headers, body = response = @app.call(env) if status == 200 && fresh?(env, headers) response[0] = 304 headers.delete(CONTENT_TYPE) headers.delete(CONTENT_LENGTH) response[2] = Rack::BodyProxy.new([]) do body.close if body.respond_to?(:close) end end response else @app.call(env) end end |