lib/opentelemetry/instrumentation/redis.rb in opentelemetry-instrumentation-redis-0.8.0 vs lib/opentelemetry/instrumentation/redis.rb in opentelemetry-instrumentation-redis-0.9.0

- old
+ new

@@ -8,9 +8,48 @@ module OpenTelemetry module Instrumentation # Contains the OpenTelemetry instrumentation for the Redis gem module Redis + extend self + + CURRENT_ATTRIBUTES_HASH = Context.create_key('current-attributes-hash') + + private_constant :CURRENT_ATTRIBUTES_HASH + + # Returns the attributes hash representing the Redis client context found + # in the optional context or the current context if none is provided. + # + # @param [optional Context] context The context to lookup the current + # attributes hash. Defaults to Context.current + def attributes(context = nil) + context ||= Context.current + context.value(CURRENT_ATTRIBUTES_HASH) || {} + end + + # Returns a context containing the merged attributes hash, derived from the + # optional parent context, or the current context if one was not provided. + # + # @param [optional Context] context The context to use as the parent for + # the returned context + def context_with_attributes(attributes_hash, parent_context: Context.current) + attributes_hash = attributes(parent_context).merge(attributes_hash) + parent_context.set_value(CURRENT_ATTRIBUTES_HASH, attributes_hash) + end + + # Activates/deactivates the merged attributes hash within the current Context, + # which makes the "current attributes hash" available implicitly. + # + # On exit, the attributes hash that was active before calling this method + # will be reactivated. + # + # @param [Span] span the span to activate + # @yield [Hash, Context] yields attributes hash and a context containing the + # attributes hash to the block. + def with_attributes(attributes_hash) + attributes_hash = attributes.merge(attributes_hash) + Context.with_value(CURRENT_ATTRIBUTES_HASH, attributes_hash) { |c, h| yield h, c } + end end end end require_relative './redis/instrumentation'