Sha256: dc32c68d2e68491768a3c7104067b7bf14c5cbb69c54b2cf7bfad8b8767f7522

Contents?: true

Size: 1.17 KB

Versions: 5

Compression:

Stored size: 1.17 KB

Contents

require 'rails/railtie'
require 'getaround_utils/log_formatters/deep_key_value'
require 'lograge'

module GetaroundUtils; end
module GetaroundUtils::Railties; end

class GetaroundUtils::Railties::Lograge < Rails::Railtie
  module LogrageActionController
    def append_info_to_payload(payload)
      super
      payload[:lograge] ||= {}
      payload[:lograge][:host] = request.host
      payload[:lograge][:params] = request.filtered_parameters.except(:action, :controller)
      payload[:lograge][:remote_ip] = request.remote_ip
      payload[:lograge][:user_agent] = request.user_agent
      payload[:lograge][:referer] = request.referer
      payload[:lograge][:controller_action] = "#{params[:controller]}##{params[:action]}" if params
      payload[:lograge][:session_id] = session&.id
      payload[:lograge][:user_id] = current_user&.id if defined?(current_user)
    end
  end

  initializer 'getaround_utils.action_controller' do
    ActionController::Base.prepend LogrageActionController
  end

  config.lograge.enabled = true
  config.lograge.formatter = GetaroundUtils::LogFormatters::DeepKeyValue.for_lograge
  config.lograge.custom_options = ->(event) { event.payload[:lograge] }
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
getaround_utils-0.1.12 lib/getaround_utils/railties/lograge.rb
getaround_utils-0.1.11 lib/getaround_utils/railties/lograge.rb
getaround_utils-0.1.9 lib/getaround_utils/railties/lograge.rb
getaround_utils-0.1.8 lib/getaround_utils/railties/lograge.rb
getaround_utils-0.1.7 lib/getaround_utils/railties/lograge.rb