Sha256: d6083de6df94d595aea6e0fc035edc0ec75427dc08bcd495608105699d14970f

Contents?: true

Size: 1.48 KB

Versions: 23

Compression:

Stored size: 1.48 KB

Contents

# frozen_string_literal: true

# Copyright The OpenTelemetry Authors
#
# SPDX-License-Identifier: Apache-2.0

module OpenTelemetry
  module Trace
    # A link to a {Span}. Used (for example) in batching operations, where a
    # single batch handler processes multiple requests from different traces.
    # A Link can be also used to reference spans from the same trace. A Link
    # and its attributes are immutable.
    class Link
      EMPTY_ATTRIBUTES = {}.freeze

      private_constant :EMPTY_ATTRIBUTES

      # Returns the {SpanContext} for this link
      #
      # @return [SpanContext]
      attr_reader :span_context

      # Returns the frozen attributes for this link.
      #
      # @return [Hash{String => String, Numeric, Boolean, Array<String, Numeric, Boolean>}]
      attr_reader :attributes

      # Returns a new immutable {Link}.
      #
      # @param [SpanContext] span_context The context of the linked {Span}.
      # @param [optional Hash{String => String, Numeric, Boolean, Array<String, Numeric, Boolean>}]
      #   attributes A hash of attributes for this link. Attributes will be
      #   frozen during Link initialization.
      # @return [Link]
      def initialize(span_context, attributes = nil)
        @span_context = span_context
        @attributes = attributes.freeze || EMPTY_ATTRIBUTES
      end

      # Returns true if two {Link}s are equal.
      def ==(other)
        other.span_context == @span_context && other.attributes == @attributes
      end
    end
  end
end

Version data entries

23 entries across 23 versions & 1 rubygems

Version Path
opentelemetry-api-0.12.1 lib/opentelemetry/trace/link.rb
opentelemetry-api-0.12.0 lib/opentelemetry/trace/link.rb
opentelemetry-api-0.11.0 lib/opentelemetry/trace/link.rb