Sha256: 689d025120ec464736913423f458031dc35d14f39cccac0d17046273e5101d5e

Contents?: true

Size: 1.81 KB

Versions: 37

Compression:

Stored size: 1.81 KB

Contents

module Skylight
  # @api private
  class Middleware

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

      def respond_to?(*args)
        return false if args.first.to_s =~ /^to_ary$/
        super or @body.respond_to?(*args)
      end

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

      def closed?
        @closed
      end

      # N.B. This method is a special case to address the bug described by #434.
      # We are applying this special case for #each only. Future bugs of this
      # class will be handled by requesting users to patch their ruby
      # implementation, to save adding too many methods in this class.
      def each(*args, &block)
        @body.each(*args, &block)
      end

      def method_missing(*args, &block)
        super if args.first.to_s =~ /^to_ary$/
        @body.__send__(*args, &block)
      end
    end

    include Util::Logging

    # For Util::Logging
    attr_reader :config

    def initialize(app, opts={})
      @app = app
      @config = opts[:config]
    end

    def call(env)
      if env["REQUEST_METHOD"] == "HEAD"
        t { "middleware skipping HEAD" }
        @app.call(env)
      else
        begin
          t { "middleware beginning trace" }
          trace = Skylight.trace "Rack", 'app.rack.request'
          resp = @app.call(env)
          resp[2] = BodyProxy.new(resp[2]) { trace.submit } if trace
          resp
        rescue Exception
          t { "middleware exception: #{trace}"}
          trace.submit if trace
          raise
        ensure
          t { "middleware release: #{trace}"}
          trace.release if trace
        end
      end
    end
  end
end

Version data entries

37 entries across 37 versions & 2 rubygems

Version Path
skylight-1.0.0.beta3 lib/skylight/middleware.rb
skylight-0.10.3 lib/skylight/middleware.rb
skylight-0.10.2 lib/skylight/middleware.rb
skylight-1.0.0.beta2 lib/skylight/middleware.rb
skylight-0.10.0 lib/skylight/middleware.rb
skylight-0.9.4 lib/skylight/middleware.rb
skylight-0.9.3 lib/skylight/middleware.rb
skylight-0.9.2 lib/skylight/middleware.rb
skylight-0.9.1 lib/skylight/middleware.rb
skylight-0.9.0 lib/skylight/middleware.rb
skylight-0.8.1 lib/skylight/middleware.rb
skylight-0.8.0 lib/skylight/middleware.rb
skylight-0.8.0.beta.3 lib/skylight/middleware.rb
skylight-0.8.0.beta.1 lib/skylight/middleware.rb
skylight-0.7.1 lib/skylight/middleware.rb
skylight-0.7.0.beta.3 lib/skylight/middleware.rb
truex-skylight-0.6.0 lib/skylight/middleware.rb
skylight-0.7.0.beta.2 lib/skylight/middleware.rb
skylight-0.7.0.beta.1 lib/skylight/middleware.rb
skylight-0.6.2.beta.2 lib/skylight/middleware.rb