Module: Exceptional

Defined in:
lib/exceptional.rb,
lib/exceptional/config.rb,
lib/exceptional/remote.rb,
lib/exceptional/catcher.rb,
lib/exceptional/startup.rb,
lib/exceptional/version.rb,
lib/exceptional/log_factory.rb,
lib/exceptional/exception_data.rb,
lib/exceptional/integration/tester.rb,
lib/exceptional/rack_exception_data.rb,
lib/exceptional/application_environment.rb,
lib/exceptional/controller_exception_data.rb

Defined Under Namespace

Modules: Integration Classes: ApplicationEnvironment, Catcher, Config, ControllerExceptionData, ExceptionData, LogFactory, RackExceptionData, Remote, Startup, StartupException

Constant Summary collapse

PROTOCOL_VERSION =
5
CLIENT_NAME =
'getexceptional-gem'
VERSION =
'2.0.8'

Class Method Summary collapse

Class Method Details

.clear!Object



52
53
54
# File 'lib/exceptional.rb', line 52

def self.clear!
  Thread.current[:exceptional_context] = nil
end

.configure(api_key) ⇒ Object



23
24
25
# File 'lib/exceptional.rb', line 23

def self.configure(api_key)
  Exceptional::Config.api_key = api_key
end

.context(hash = {}) ⇒ Object



56
57
58
59
60
# File 'lib/exceptional.rb', line 56

def self.context(hash = {})
  Thread.current[:exceptional_context] ||= {}
  Thread.current[:exceptional_context].merge!(hash)
  self
end

.handle(exception, name = nil) ⇒ Object



27
28
29
# File 'lib/exceptional.rb', line 27

def self.handle(exception, name=nil)
  Exceptional::Catcher.handle(exception, name)
end

.loggerObject



19
20
21
# File 'lib/exceptional.rb', line 19

def self.logger
  ::Exceptional::LogFactory.logger
end

.rescue(name = nil, context = nil, &block) ⇒ Object



31
32
33
34
35
36
37
38
39
# File 'lib/exceptional.rb', line 31

def self.rescue(name=nil, context=nil, &block)
  begin
    self.context(context) unless context.nil?
    block.call
  rescue Exception => e
    Exceptional::Catcher.handle(e,name)
    self.clear!
  end
end

.rescue_and_reraise(name = nil, context = nil, &block) ⇒ Object



41
42
43
44
45
46
47
48
49
50
# File 'lib/exceptional.rb', line 41

def self.rescue_and_reraise(name=nil, context=nil, &block)
  begin
    self.context(context) unless context.nil?
    block.call
  rescue Exception => e
    Exceptional::Catcher.handle(e,name)
    self.clear!
    raise(e)
  end
end