Module: Applicaster::Logger

Defined in:
lib/applicaster/logger.rb,
lib/applicaster/logger/railtie.rb,
lib/applicaster/logger/version.rb,
lib/applicaster/logger/formatter.rb

Defined Under Namespace

Classes: Formatter, Railtie

Constant Summary collapse

VERSION =
"0.6.2"
HOST =
::Socket.gethostname

Class Method Summary collapse

Class Method Details

.current_thread_dataObject



65
66
67
# File 'lib/applicaster/logger.rb', line 65

def self.current_thread_data
  Thread.current[:logger_thread_data] || {}
end

.setup_logger(app) ⇒ Object



22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# File 'lib/applicaster/logger.rb', line 22

def self.setup_logger(app)
  logstash_config = app.config.applicaster_logger.logstash_config

  app.config.logger = LogStashLogger.new(logstash_config)
  app.config.logger.level = app.config.applicaster_logger.level
  app.config.logger.formatter =
    Applicaster::Logger::Formatter.new(facility: "rails_logger")

  if defined?(Delayed)
    Delayed::Worker.logger = LogStashLogger.new(logstash_config)
    Delayed::Worker.logger.level = app.config.applicaster_logger.level
    Delayed::Worker.logger.formatter =
      Applicaster::Logger::Formatter.new(facility: "delayed_job")
  end

  if defined?(::Sidekiq)
    require 'sidekiq/api'

    ::Sidekiq.configure_server do |config|
      config.server_middleware do |chain|
        chain.remove ::Sidekiq::Middleware::Server::Logging
        chain.add Applicaster::Sidekiq::Middleware::Server::LogstashLogging
      end
    end
  end

  if defined?(Sidetiq)
    Sidetiq.logger = LogStashLogger.new(logstash_config)
    Sidetiq.logger.level = app.config.applicaster_logger.level
    Sidetiq.logger.formatter =
      Applicaster::Logger::Formatter.new(facility: "sidetiq")
  end
end

.setup_lograge(app) ⇒ Object



7
8
9
10
11
12
13
14
15
16
17
18
19
20
# File 'lib/applicaster/logger.rb', line 7

def self.setup_lograge(app)
  app.config.lograge.enabled = true
  app.config.lograge.formatter = Lograge::Formatters::Logstash.new
  app.config.lograge.custom_options = lambda do |event|
    {
      params: event.payload[:params].except('controller', 'action', 'format'),
      facility: "action_controller",
      user_id: event.payload[:user_id],
    }
  end

  app.middleware.insert_after ActionDispatch::RequestId,
    Applicaster::Rack::RequestData
end

.with_thread_data(data) ⇒ Object



56
57
58
59
60
61
62
63
# File 'lib/applicaster/logger.rb', line 56

def self.with_thread_data(data)
  old, Thread.current[:logger_thread_data] =
    Thread.current[:logger_thread_data], data

  yield
ensure
  Thread.current[:logger_thread_data] = old
end