Sha256: 1eb1254e08c2a8676238cca2f15dca176388760c38122cbcceda071a5787743b

Contents?: true

Size: 1.02 KB

Versions: 8

Compression:

Stored size: 1.02 KB

Contents

module Faye
  
  class << self
    attr_accessor :logger
  end
  
  self.logger = method(:puts)
  
  module Logging
    
    DEFAULT_LOG_LEVEL = :error
    
    LOG_LEVELS = {
      :error  => 3,
      :warn   => 2,
      :info   => 1,
      :debug  => 0
    }
    
    class << self
      attr_writer :log_level
      
      def log_level
        @log_level || DEFAULT_LOG_LEVEL
      end
    end
    
    attr_writer :log_level
    
    def log_level
      @log_level || Logging.log_level
    end
    
    def log(message_args, level)
      return unless Faye.logger
      return if LOG_LEVELS[log_level] > LOG_LEVELS[level]
      
      message = message_args.shift.gsub(/\?/) do
        Faye.to_json(message_args.shift)
      end
      
      timestamp = Time.now.strftime('%Y-%m-%d %H:%M:%S')
      banner = " [#{ level.to_s.upcase }] [#{ self.class.name }] "
      
      puts(timestamp + banner + message)
    end
    
    LOG_LEVELS.each do |level, value|
      define_method(level) { |*args| log(args, level) }
    end
    
  end
end

Version data entries

8 entries across 8 versions & 1 rubygems

Version Path
faye-0.7.2 lib/faye/mixins/logging.rb
faye-0.6.8 lib/faye/mixins/logging.rb
faye-0.7.1 lib/faye/mixins/logging.rb
faye-0.7.0 lib/faye/mixins/logging.rb
faye-0.6.7 lib/faye/mixins/logging.rb
faye-0.6.6 lib/faye/mixins/logging.rb
faye-0.6.5 lib/faye/mixins/logging.rb
faye-0.6.4 lib/faye/mixins/logging.rb