Sha256: 99d241ce7abb518cd9a3d10d150352f4ddb5b7ed034a4b61958e3885d5df0951

Contents?: true

Size: 1.45 KB

Versions: 2

Compression:

Stored size: 1.45 KB

Contents

require 'time'
module SemanticLogger
  module Formatters
    class Base
      attr_accessor :time_format, :log_host, :log_application

      # Time precision varies by Ruby interpreter
      # JRuby 9.1.8.0 supports microseconds
      PRECISION   =
        if defined?(JRuby)
          if (JRUBY_VERSION.to_f >= 9.1)
            maint = JRUBY_VERSION.match(/\A\d\.\d\.(\d)\./)[1].to_i
            (maint >= 8) || (JRUBY_VERSION.to_f > 9.1) ? 6 : 3
          else
            3
          end
        else
          6
        end
      TIME_FORMAT = "%Y-%m-%d %H:%M:%S.%#{PRECISION}N"

      # Parameters
      #   time_format: [String|Symbol|nil]
      #     See Time#strftime for the format of this string
      #     :iso_8601 Outputs an ISO8601 Formatted timestamp
      #     nil:      Returns Empty string for time ( no time is output ).
      #     Default: '%Y-%m-%d %H:%M:%S.%6N'
      def initialize(time_format: TIME_FORMAT, log_host: true, log_application: true)
        @time_format     = time_format
        @log_host        = log_host
        @log_application = log_application
      end

      # Date & time
      def time
        format_time(log.time) if time_format
      end

      private

      # Return the Time as a formatted string
      def format_time(time)
        case time_format
        when :iso_8601
          time.utc.iso8601(PRECISION)
        when nil
          ''
        else
          time.strftime(time_format)
        end
      end

    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
semantic_logger-4.1.1 lib/semantic_logger/formatters/base.rb
semantic_logger-4.1.0 lib/semantic_logger/formatters/base.rb