Sha256: 7363df95e0f8b9572da272f781f5c7a9fe3e3ff8b3f09529d676aea34dbf3219

Contents?: true

Size: 2 KB

Versions: 20

Compression:

Stored size: 2 KB

Contents

require "sentry/rails/tracing/abstract_subscriber"
require "sentry/rails/tracing/active_record_subscriber"
require "sentry/rails/tracing/action_controller_subscriber"
require "sentry/rails/tracing/action_view_subscriber"

module Sentry
  module Rails
    module Tracing
      AVAILABLE_SUBSCRIBERS = [ActionViewSubscriber, ActiveRecordSubscriber, ActionControllerSubscriber]

      def self.subscribe_tracing_events
        # need to avoid duplicated subscription
        return if @subscribed

        AVAILABLE_SUBSCRIBERS.each(&:subscribe!)

        @subscribed = true
      end

      def self.unsubscribe_tracing_events
        return unless @subscribed

        AVAILABLE_SUBSCRIBERS.each(&:unsubscribe!)

        @subscribed = false
      end

      # this is necessary because instrumentation events don't record absolute start/finish time
      # so we need to retrieve the correct time this way
      def self.patch_active_support_notifications
        unless ::ActiveSupport::Notifications::Instrumenter.ancestors.include?(SentryNotificationExtension)
          ::ActiveSupport::Notifications::Instrumenter.send(:prepend, SentryNotificationExtension)
        end

        SentryNotificationExtension.module_eval do
          def instrument(name, payload = {}, &block)
            is_public_event = name[0] != "!"

            payload[:start_timestamp] = Time.now.utc.to_f if is_public_event

            super(name, payload, &block)
          end
        end
      end

      def self.remove_active_support_notifications_patch
        if ::ActiveSupport::Notifications::Instrumenter.ancestors.include?(SentryNotificationExtension)
          SentryNotificationExtension.module_eval do
            def instrument(name, payload = {}, &block)
              super
            end
          end
        end
      end

      def self.get_current_transaction
        Sentry.get_current_scope.get_transaction
      end

      # it's just a container for the extended method
      module SentryNotificationExtension
      end
    end
  end
end

Version data entries

20 entries across 20 versions & 1 rubygems

Version Path
sentry-rails-4.3.4 lib/sentry/rails/tracing.rb
sentry-rails-4.3.3 lib/sentry/rails/tracing.rb
sentry-rails-4.3.3.pre.beta.0 lib/sentry/rails/tracing.rb
sentry-rails-4.3.2 lib/sentry/rails/tracing.rb
sentry-rails-4.3.1 lib/sentry/rails/tracing.rb
sentry-rails-4.3.0 lib/sentry/rails/tracing.rb
sentry-rails-4.2.2 lib/sentry/rails/tracing.rb
sentry-rails-4.2.1 lib/sentry/rails/tracing.rb
sentry-rails-4.2.0 lib/sentry/rails/tracing.rb
sentry-rails-4.1.7 lib/sentry/rails/tracing.rb
sentry-rails-4.1.6 lib/sentry/rails/tracing.rb
sentry-rails-4.1.5 lib/sentry/rails/tracing.rb
sentry-rails-4.1.4 lib/sentry/rails/tracing.rb
sentry-rails-4.1.3 lib/sentry/rails/tracing.rb
sentry-rails-4.1.2 lib/sentry/rails/tracing.rb
sentry-rails-4.1.1 lib/sentry/rails/tracing.rb
sentry-rails-4.1.0 lib/sentry/rails/tracing.rb
sentry-rails-4.0.0 lib/sentry/rails/tracing.rb
sentry-rails-0.3.0 lib/sentry/rails/tracing.rb
sentry-rails-0.2.0 lib/sentry/rails/tracing.rb