Sha256: 21e3027d9062626521840f65f0f224423f7fd5afd485c2cc396e074cb7b873e0

Contents?: true

Size: 875 Bytes

Versions: 6

Compression:

Stored size: 875 Bytes

Contents

# frozen_string_literal: true

module VoyageAI
  # Used for logging via HTTP.
  class Instrumentation
    # @param logger [Logger]
    def initialize(logger:)
      @logger = logger
    end

    # @param name [String]
    # @param payload [Hash]
    # @option payload [Exception] :error
    def instrument(name, payload = {})
      error = payload[:error]
      return unless error

      @logger.error("#{name}: #{error.message}")
    end

    # @param payload [Hash]
    # @option payload [HTTP::Request] :request
    def start(_, payload)
      request = payload[:request]
      @logger.info("#{request.verb.upcase} #{request.uri}")
    end

    # @param payload [Hash]
    # @option payload [HTTP::Response] :response
    def finish(_, payload)
      response = payload[:response]
      @logger.info("#{response.status.code} #{response.status.reason}")
    end
  end
end

Version data entries

6 entries across 6 versions & 1 rubygems

Version Path
voyageai-1.8.0 lib/voyageai/instrumentation.rb
voyageai-1.7.0 lib/voyageai/instrumentation.rb
voyageai-1.6.0 lib/voyageai/instrumentation.rb
voyageai-1.5.0 lib/voyageai/instrumentation.rb
voyageai-1.3.0 lib/voyageai/instrumentation.rb
voyageai-1.2.0 lib/voyageai/instrumentation.rb