Sha256: f3b9b825dcef7acfe2ccb6289cba932eec3ade01e41f4b1c437946e3fac85d55

Contents?: true

Size: 1.11 KB

Versions: 21

Compression:

Stored size: 1.11 KB

Contents

module Datadog
  module Contrib
    module ActionCable
      module Instrumentation
        # When a new WebSocket is open, we receive a Rack request resource name "GET -1".
        # This module overrides the current Rack resource name to provide a meaningful name.
        module ActionCableConnection
          def on_open
            Datadog.tracer.trace(Ext::SPAN_ON_OPEN) do |span|
              begin
                span.resource = "#{self.class}#on_open"
                span.span_type = Datadog::Ext::AppTypes::WEB

                span.set_tag(Ext::TAG_ACTION, 'on_open')
                span.set_tag(Ext::TAG_CONNECTION, self.class.to_s)

                # Set the resource name of the Rack request span
                rack_request_span = env[Datadog::Contrib::Rack::TraceMiddleware::RACK_REQUEST_SPAN]
                rack_request_span.resource = span.resource if rack_request_span
              rescue StandardError => e
                Datadog.logger.error("Error preparing span for ActionCable::Connection: #{e}")
              end

              super
            end
          end
        end
      end
    end
  end
end

Version data entries

21 entries across 21 versions & 2 rubygems

Version Path
ddtrace-0.51.1 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.51.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.50.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.49.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.48.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.47.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.46.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.45.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.44.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.43.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.42.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.41.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ls-trace-0.2.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.40.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.39.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.38.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.37.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.36.0 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.35.2 lib/ddtrace/contrib/action_cable/instrumentation.rb
ddtrace-0.35.1 lib/ddtrace/contrib/action_cable/instrumentation.rb