summaryrefslogtreecommitdiff
path: root/lib/gitlab/metrics/rack_middleware.rb
blob: 9aa975159618f27f78eeb306c0c24102c9fb69ae (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
# frozen_string_literal: true

module Gitlab
  module Metrics
    # Rack middleware for tracking Rails and Grape requests.
    class RackMiddleware
      def initialize(app)
        @app = app
      end

      # env - A Hash containing Rack environment details.
      def call(env)
        trans  = transaction_from_env(env)
        retval = nil

        begin
          retval = trans.run { @app.call(env) }

        rescue Exception => error # rubocop: disable Lint/RescueException
          trans.add_event(:rails_exception)

          raise error
        # Even in the event of an error we want to submit any metrics we
        # might've gathered up to this point.
        ensure
          trans.finish
        end

        retval
      end

      def transaction_from_env(env)
        trans = WebTransaction.new(env)

        trans.set(:request_uri, filtered_path(env), false)
        trans.set(:request_method, env['REQUEST_METHOD'], false)

        trans
      end

      private

      def filtered_path(env)
        ActionDispatch::Request.new(env).filtered_path.presence || env['REQUEST_URI']
      end
    end
  end
end