Sha256: 7520bb714fbc81e1964dbc9c86262983b86fccc06e8826c5025b9220612a0390
Contents?: true
Size: 1.76 KB
Versions: 2
Compression:
Stored size: 1.76 KB
Contents
# frozen_string_literal: true # Copyright The OpenTelemetry Authors # # SPDX-License-Identifier: Apache-2.0 # require 'delegate' module OpenTelemetry module Instrumentation module ActionView # This is a replacement for the default Fanout notifications queue, which adds special # handling around returned context from the SpanSubscriber notification handlers. # Used together, it allows us to trace arbitrary ActiveSupport::Notifications safely. class Fanout < DelegateClass(::ActiveSupport::Notifications::Fanout) def initialize(notifier = ::ActiveSupport::Notifications::Fanout.new) super(notifier) end def start(name, id, payload) listeners_for(name).map do |s| result = [s] state = s.start(name, id, payload) if state.is_a?(Array) && state[0].is_a?(OpenTelemetry::Trace::Span) && state[1] # rubocop:disable Style/IfUnlessModifier result << state end result end end def finish(name, id, payload, listeners = listeners_for(name)) listeners.each do |(s, arr)| span, token = arr if span.is_a?(OpenTelemetry::Trace::Span) && token s.finish( name, id, payload.merge( __opentelemetry_span: span, __opentelemetry_ctx_token: token ) ) else s.finish(name, id, payload) end end end def listeners_for(name) listeners = super listeners.sort_by do |l| l.instance_variable_get(:@delegate).is_a?(SpanSubscriber) ? -1 : 1 end end end end end end
Version data entries
2 entries across 2 versions & 1 rubygems