module Logster::Rails

Public Class Methods

initialize!(app) click to toggle source
# File lib/logster/rails/railtie.rb, line 31
def self.initialize!(app)
  return unless Logster.config.environments.include?(Rails.env.to_sym)

  if Logster::Logger === Rails.logger
    if Logster.config.enable_js_error_reporting
      app.middleware.insert_before ActionDispatch::ShowExceptions, Logster::Middleware::Reporter
    end

    if Rails::VERSION::MAJOR == 3
      app.middleware.insert_before ActionDispatch::DebugExceptions, Logster::Middleware::DebugExceptions
    else
      app.middleware.insert_before ActionDispatch::DebugExceptions, Logster::Middleware::DebugExceptions, Rails.application
    end

    app.middleware.delete ActionDispatch::DebugExceptions
    app.config.colorize_logging = false

    unless Logster.config.application_version
      git_version = `cd #{Rails.root} && git rev-parse --short HEAD 2> /dev/null`
      if git_version.present?
        Logster.config.application_version = git_version.strip
      end
    end
  end
end
set_logger(config) click to toggle source
# File lib/logster/rails/railtie.rb, line 9
def self.set_logger(config)
  return unless Logster.config.environments.include?(Rails.env.to_sym)

  require 'logster/middleware/debug_exceptions'
  require 'logster/middleware/reporter'

  store = Logster.store ||= Logster::RedisStore.new
  store.level = Logger::Severity::WARN if Rails.env.production?

  if Rails.env.development?
    require 'logster/defer_logger'
    logger = Logster::DeferLogger.new(store)
  else
    logger = Logster::Logger.new(store)
  end

  logger.chain(::Rails.logger)
  logger.level = ::Rails.logger.level

  Logster.logger = ::Rails.logger = config.logger = logger
end