Sha256: c070225dff9079671d1785176759dcd476da148506096cedca8033c14d117a8a

Contents?: true

Size: 1.45 KB

Versions: 4

Compression:

Stored size: 1.45 KB

Contents

# frozen_string_literal: true

module RailsMiniProfiler
  class FlamegraphGuard
    def initialize(request_context, configuration: RailsMiniProfiler.configuration)
      @request_context = request_context
      @request = request_context.request
      @configuration = configuration
    end

    def record(&block)
      return block.call unless enabled?

      if StackProf.running?
        RailsMiniProfiler.logger.error('Stackprof is already running, cannot record Flamegraph')
        return block.call
      end

      flamegraph, result = record_flamegraph(block)
      unless flamegraph
        RailsMiniProfiler.logger.error('Failed to record Flamegraph, possibly due to concurrent requests')
        return result
      end

      @request_context.flamegraph = flamegraph.to_json
      result
    end

    private

    def record_flamegraph(block)
      sample_rate = @configuration.flamegraph_sample_rate
      result = nil
      flamegraph = StackProf.run(mode: :wall, raw: true, aggregate: false, interval: (sample_rate * 1000).to_i) do
        result = block.call
      end
      [flamegraph, result]
    end

    def enabled?
      defined?(StackProf) && StackProf.respond_to?(:run) && config_enabled?
    end

    def config_enabled?
      params = CGI.parse(@request.query_string).transform_values(&:first).with_indifferent_access
      return params[:rmp_flamegraph] if params[:rmp_flamegraph]

      RailsMiniProfiler.configuration.flamegraph_enabled
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
rails_mini_profiler-0.7.3 lib/rails_mini_profiler/flamegraph_guard.rb
rails_mini_profiler-0.7.2 lib/rails_mini_profiler/flamegraph_guard.rb
rails_mini_profiler-0.7.1 lib/rails_mini_profiler/flamegraph_guard.rb
rails_mini_profiler-0.7.0 lib/rails_mini_profiler/flamegraph_guard.rb