Sha256: a605383123d55b4d4edd4ecb46fb56c19bd36f93f1dee0ff0b680ecebb74a73e
Contents?: true
Size: 1.78 KB
Versions: 4
Compression:
Stored size: 1.78 KB
Contents
module Sentry module Rails class CaptureExceptions < Sentry::Rack::CaptureExceptions RAILS_7_1 = Gem::Version.new(::Rails.version) >= Gem::Version.new("7.1.0.alpha") SPAN_ORIGIN = 'auto.http.rails'.freeze def initialize(_) super if Sentry.initialized? @assets_regexp = Sentry.configuration.rails.assets_regexp end end private def collect_exception(env) return nil if env["sentry.already_captured"] super || env["action_dispatch.exception"] || env["sentry.rescued_exception"] end def transaction_op "http.server".freeze end def capture_exception(exception, env) # the exception will be swallowed by ShowExceptions middleware return if show_exceptions?(exception, env) && !Sentry.configuration.rails.report_rescued_exceptions Sentry::Rails.capture_exception(exception).tap do |event| env[ERROR_EVENT_ID_KEY] = event.event_id if event end end def start_transaction(env, scope) options = { name: scope.transaction_name, source: scope.transaction_source, op: transaction_op, origin: SPAN_ORIGIN } if @assets_regexp && scope.transaction_name.match?(@assets_regexp) options.merge!(sampled: false) end transaction = Sentry.continue_trace(env, **options) Sentry.start_transaction(transaction: transaction, custom_sampling_context: { env: env }, **options) end def show_exceptions?(exception, env) request = ActionDispatch::Request.new(env) if RAILS_7_1 ActionDispatch::ExceptionWrapper.new(nil, exception).show?(request) else request.show_exceptions? end end end end end
Version data entries
4 entries across 4 versions & 1 rubygems