Sha256: 3adbd94188db41c168ab5b9b1549c08127936768c291d3b980624fcc87905f4c

Contents?: true

Size: 1.35 KB

Versions: 3

Compression:

Stored size: 1.35 KB

Contents

# frozen_string_literal: true

# rubocop:disable Lint/UnusedMethodArgument
require "opentracing"
require "grpc"

module Labkit
  module Tracing
    # GRPCInterceptor is a client-side GRPC interceptor
    # for instrumenting GRPC calls with distributed tracing
    class GRPCInterceptor < GRPC::ClientInterceptor
      include Common
      include Singleton

      def request_response(request:, call:, method:, metadata:)
        wrap_with_tracing(method, "unary", metadata) { yield }
      end

      def client_streamer(requests:, call:, method:, metadata:)
        wrap_with_tracing(method, "client_stream", metadata) { yield }
      end

      def server_streamer(request:, call:, method:, metadata:)
        wrap_with_tracing(method, "server_stream", metadata) { yield }
      end

      def bidi_streamer(requests:, call:, method:, metadata:)
        wrap_with_tracing(method, "bidi_stream", metadata) { yield }
      end

      private

      def wrap_with_tracing(method, grpc_type, metadata)
        tags = { "component" => "grpc", "span.kind" => "client", "grpc.method" => method, "grpc.type" => grpc_type }

        in_tracing_span(operation_name: "grpc:#{method}", tags: tags) do |span|
          OpenTracing.inject(span.context, OpenTracing::FORMAT_TEXT_MAP, metadata)

          yield
        end
      end
    end
  end
end

# rubocop:enable Lint/UnusedMethodArgument

Version data entries

3 entries across 3 versions & 1 rubygems

Version Path
gitlab-labkit-0.1.2 lib/labkit/tracing/grpc_interceptor.rb
gitlab-labkit-0.1.0.pre.1.pre.gcb57c95 lib/labkit/tracing/grpc_interceptor.rb
gitlab-labkit-0.1.0 lib/labkit/tracing/grpc_interceptor.rb