actionpack/lib/action_controller/metal/logging.rb

Summary

Maintainability
A
0 mins
Test Coverage
# frozen_string_literal: true

# :markup: markdown

module ActionController
  module Logging
    extend ActiveSupport::Concern

    module ClassMethods
      # Set a different log level per request.
      #
      #     # Use the debug log level if a particular cookie is set.
      #     class ApplicationController < ActionController::Base
      #       log_at :debug, if: -> { cookies[:debug] }
      #     end
      #
      def log_at(level, **options)
        around_action ->(_, action) { logger.log_at(level, &action) }, **options
      end
    end
  end
end