class Sentry::Rails::CaptureExceptions
def capture_exception(exception, env)
def capture_exception(exception, env) request = ActionDispatch::Request.new(env) # the exception will be swallowed by ShowExceptions middleware return if request.show_exceptions? && !Sentry.configuration.rails.report_rescued_exceptions current_scope = Sentry.get_current_scope if original_transaction = env["sentry.original_transaction"] current_scope.set_transaction_name(original_transaction) end Sentry::Rails.capture_exception(exception).tap do |event| env[ERROR_EVENT_ID_KEY] = event.event_id if event end end
def collect_exception(env)
def collect_exception(env) return nil if env["sentry.already_captured"] super || env["action_dispatch.exception"] || env["sentry.rescued_exception"] end
def initialize(app)
def initialize(app) super if defined?(::Sprockets::Rails) @assets_regex = %r(\A/{0,2}#{::Rails.application.config.assets.prefix}) end end
def start_transaction(env, scope)
def start_transaction(env, scope) sentry_trace = env["HTTP_SENTRY_TRACE"] options = { name: scope.transaction_name, op: transaction_op } if @assets_regex && scope.transaction_name.match?(@assets_regex) options.merge!(sampled: false) end transaction = Sentry::Transaction.from_sentry_trace(sentry_trace, **options) if sentry_trace Sentry.start_transaction(transaction: transaction, custom_sampling_context: { env: env }, **options) end
def transaction_op
def transaction_op "rails.request".freeze end