123456789_123456789_123456789_123456789_123456789_

Class: Rack::BodyProxy

Relationships & Source Files
Extension / Inclusion / Inheritance Descendants
Subclasses:
Inherits: Object
Defined in: lib/rack/body_proxy.rb

Overview

Proxy for response bodies allowing calling a block when the response body is closed (after the response has been fully sent to the client).

Class Method Summary

Instance Attribute Summary

Instance Method Summary

Constructor Details

.new(body, &block) ⇒ BodyProxy

Set the response body to wrap, and the block to call when the response has been fully sent.

[ GitHub ]

  
# File 'lib/rack/body_proxy.rb', line 10

def initialize(body, &block)
  @body = body
  @block = block
  @closed = false
end

Dynamic Method Handling

This class handles dynamic methods through the method_missing method

#method_missing(method_name, *args, &block)

Delegate missing methods to the wrapped body.

[ GitHub ]

  
# File 'lib/rack/body_proxy.rb', line 45

def method_missing(method_name, *args, &block)
  case method_name
  when :to_str
    super
  when :to_ary
    begin
      @body.__send__(method_name, *args, &block)
    ensure
      close
    end
  else
    @body.__send__(method_name, *args, &block)
  end
end

Instance Attribute Details

#closed?Boolean (readonly)

Whether the proxy is closed. The proxy starts as not closed, and becomes closed on the first call to close.

[ GitHub ]

  
# File 'lib/rack/body_proxy.rb', line 40

def closed?
  @closed
end

Instance Method Details

#close

If not already closed, close the wrapped body and then call the block the proxy was initialized with.

[ GitHub ]

  
# File 'lib/rack/body_proxy.rb', line 28

def close
  return if @closed
  @closed = true
  begin
    @body.close if @body.respond_to?(:close)
  ensure
    @block.call
  end
end

#respond_to_missing?(method_name, include_all = false) ⇒ Boolean

Return whether the wrapped body responds to the method.

[ GitHub ]

  
# File 'lib/rack/body_proxy.rb', line 17

def respond_to_missing?(method_name, include_all = false)
  case method_name
  when :to_str
    false
  else
    super or @body.respond_to?(method_name, include_all)
  end
end