Sha256: 2837307aa7c80b77a6a3d0df9849644f479d6ab676173a8f92dcd17e8d879f05

Contents?: true

Size: 1.94 KB

Versions: 32

Compression:

Stored size: 1.94 KB

Contents

# frozen_string_literal: true

module Logster::Rails

  # this magically registers logster.js in the asset pipeline
  class Engine < Rails::Engine
  end

  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

  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

  class Railtie < ::Rails::Railtie

    config.before_initialize do
      Logster::Rails.set_logger(config)
    end

    initializer "logster.configure_rails_initialization" do |app|
      Logster::Rails.initialize!(app)
    end
  end
end

Version data entries

32 entries across 32 versions & 1 rubygems

Version Path
logster-2.12.2 lib/logster/rails/railtie.rb
logster-2.12.1 lib/logster/rails/railtie.rb
logster-2.11.4 lib/logster/rails/railtie.rb
logster-2.11.3 lib/logster/rails/railtie.rb
logster-2.11.2 lib/logster/rails/railtie.rb
logster-2.11.1 lib/logster/rails/railtie.rb
logster-2.11.0 lib/logster/rails/railtie.rb
logster-2.10.1 lib/logster/rails/railtie.rb
logster-2.10.0 lib/logster/rails/railtie.rb
logster-2.9.8 lib/logster/rails/railtie.rb
logster-2.9.7 lib/logster/rails/railtie.rb
logster-2.9.6 lib/logster/rails/railtie.rb
logster-2.9.5 lib/logster/rails/railtie.rb
logster-2.9.4 lib/logster/rails/railtie.rb
logster-2.9.3 lib/logster/rails/railtie.rb
logster-2.9.2 lib/logster/rails/railtie.rb
logster-2.9.1 lib/logster/rails/railtie.rb
logster-2.9.0 lib/logster/rails/railtie.rb
logster-2.8.0 lib/logster/rails/railtie.rb
logster-2.7.1 lib/logster/rails/railtie.rb