Sha256: 4170da76e278dbfce23d39bd129fc561f91697406f7b15e10eb3ea8a8db5ae4c

Contents?: true

Size: 1.74 KB

Versions: 14

Compression:

Stored size: 1.74 KB

Contents

# Basic implementation of a tagged logger that matches the API of
# ActiveSupport::TaggedLogging.

require 'delegate'
require 'logger'

module Kafka
  class TaggedLogger < SimpleDelegator

    %i(debug info warn error).each do |method|
      define_method method do |msg_or_progname, &block|
        if block_given?
          super(msg_or_progname, &block)
        else
          super("#{tags_text}#{msg_or_progname}")
        end
      end
    end

    def tagged(*tags)
      new_tags = push_tags(*tags)
      yield self
    ensure
      pop_tags(new_tags.size)
    end

    def push_tags(*tags)
      tags.flatten.reject { |t| t.nil? || t.empty? }.tap do |new_tags|
        current_tags.concat new_tags
      end
    end

    def pop_tags(size = 1)
      current_tags.pop size
    end

    def clear_tags!
      current_tags.clear
    end

    def current_tags
      # We use our object ID here to avoid conflicting with other instances
      thread_key = @thread_key ||= "kafka_tagged_logging_tags:#{object_id}".freeze
      Thread.current[thread_key] ||= []
    end

    def tags_text
      tags = current_tags
      if tags.any?
        tags.collect { |tag| "[#{tag}] " }.join
      end
    end

    def self.new(logger_or_stream = nil)
      # don't keep wrapping the same logger over and over again
      return logger_or_stream if logger_or_stream.is_a?(TaggedLogger)
      super
    end

    def initialize(logger_or_stream = nil)
      logger = if %w(info debug warn error).all? { |s| logger_or_stream.respond_to?(s) }
        logger_or_stream
      elsif logger_or_stream
        ::Logger.new(logger_or_stream)
      else
        ::Logger.new(nil)
      end
      super(logger)
    end

    def flush
      clear_tags!
      super if defined?(super)
    end
  end

end

Version data entries

14 entries across 14 versions & 3 rubygems

Version Path
ruby-kafka-1.5.0 lib/kafka/tagged_logger.rb
ruby-kafka-aws-iam-1.4.5 lib/kafka/tagged_logger.rb
ruby-kafka-aws-iam-1.4.4 lib/kafka/tagged_logger.rb
ruby-kafka-aws-iam-1.4.3 lib/kafka/tagged_logger.rb
ruby-kafka-aws-iam-1.4.2 lib/kafka/tagged_logger.rb
ruby-kafka-aws-iam-1.4.1 lib/kafka/tagged_logger.rb
ruby-kafka-1.4.0 lib/kafka/tagged_logger.rb
ruby-kafka-temp-fork-0.0.2 lib/kafka/tagged_logger.rb
ruby-kafka-temp-fork-0.0.1 lib/kafka/tagged_logger.rb
ruby-kafka-1.3.0 lib/kafka/tagged_logger.rb
ruby-kafka-1.2.0 lib/kafka/tagged_logger.rb
ruby-kafka-1.1.0 lib/kafka/tagged_logger.rb
ruby-kafka-1.1.0.beta1 lib/kafka/tagged_logger.rb
ruby-kafka-1.0.0 lib/kafka/tagged_logger.rb