Module: ActiveRecord::SessionStore::Extension::LoggerSilencer

Extended by:
ActiveSupport::Concern
Defined in:
lib/active_record/session_store/extension/logger_silencer.rb

Instance Method Summary collapse

Instance Method Details

#add_with_threadsafety(severity, message = nil, progname = nil, &block) ⇒ Object



34
35
36
37
38
39
40
# File 'lib/active_record/session_store/extension/logger_silencer.rb', line 34

def add_with_threadsafety(severity, message = nil, progname = nil, &block)
  if (defined?(@logdev) && @logdev.nil?) || (severity || UNKNOWN) < level
    true
  else
    add_without_threadsafety(severity, message, progname, &block)
  end
end

#level_with_threadsafetyObject



30
31
32
# File 'lib/active_record/session_store/extension/logger_silencer.rb', line 30

def level_with_threadsafety
  thread_level || level_without_threadsafety
end

#silence_logger(temporary_level = Logger::ERROR) ⇒ Object

Silences the logger for the duration of the block.



43
44
45
46
47
48
49
50
51
52
53
54
# File 'lib/active_record/session_store/extension/logger_silencer.rb', line 43

def silence_logger(temporary_level = Logger::ERROR)
  if silencer
    begin
      self.thread_level = temporary_level
      yield self
    ensure
      self.thread_level = nil
    end
  else
    yield self
  end
end

#thread_levelObject



22
23
24
# File 'lib/active_record/session_store/extension/logger_silencer.rb', line 22

def thread_level
  Thread.current[thread_hash_level_key]
end

#thread_level=(level) ⇒ Object



26
27
28
# File 'lib/active_record/session_store/extension/logger_silencer.rb', line 26

def thread_level=(level)
  Thread.current[thread_hash_level_key] = level
end