Sha256: 74f712659a36358531b90a1edc411ecac0eae2dd383db297753abbd30dda3fa6

Contents?: true

Size: 1.92 KB

Versions: 4

Compression:

Stored size: 1.92 KB

Contents

module LogStasher
  class Railtie < ::Rails::Railtie
    config.logstasher = ::ActiveSupport::OrderedOptions.new
    config.logstasher.enabled = false
    config.logstasher.include_parameters = true
    config.logstasher.serialize_parameters = true
    config.logstasher.silence_standard_logging = false
    config.logstasher.logger = nil
    config.logstasher.log_level = ::Logger::INFO

    initializer 'logstasher.configure' do
      options = config.logstasher

      ::LogStasher.enabled                  = options.enabled
      ::LogStasher.include_parameters       = options.include_parameters
      ::LogStasher.serialize_parameters     = options.serialize_parameters
      ::LogStasher.silence_standard_logging = options.silence_standard_logging
      ::LogStasher.logger                   = options.logger || default_logger
      ::LogStasher.logger.level             = options.log_level
    end

    initializer 'logstasher.load' do
      if ::LogStasher.enabled?
        ::ActiveSupport.on_load(:action_controller) do
          require 'logstasher/log_subscriber'
          require 'logstasher/context_wrapper'

          include ::LogStasher::ContextWrapper
        end
      end
    end

    config.after_initialize do
      if ::LogStasher.enabled? && ::LogStasher.silence_standard_logging?
        require 'logstasher/silent_logger'

        ::Rails::Rack::Logger.send(:include, ::LogStasher::SilentLogger)

        ::ActiveSupport::LogSubscriber.log_subscribers.each do |subscriber|
          if subscriber.is_a?(::ActiveSupport::LogSubscriber)
            subscriber.class.send(:include, ::LogStasher::SilentLogger)
          end
        end
      end
    end

    def default_logger
      unless @default_logger
        path = ::Rails.root.join('log', "logstash_#{::Rails.env}.log")
        ::FileUtils.touch(path) # prevent autocreate messages in log

        @default_logger =  ::Logger.new(path)
      end

      @default_logger
    end
  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
md-logstasher-1.0.4 lib/logstasher/railtie.rb
md-logstasher-1.0.3 lib/logstasher/railtie.rb
md-logstasher-1.0.2 lib/logstasher/railtie.rb
md-logstasher-1.0.1 lib/logstasher/railtie.rb