Module: Raygun
- Extended by:
- Testable
- Defined in:
- lib/raygun/sidekiq.rb,
lib/raygun.rb,
lib/raygun/client.rb,
lib/raygun/version.rb,
lib/raygun/testable.rb,
lib/raygun/configuration.rb,
lib/generators/raygun/install_generator.rb,
lib/raygun/middleware/rack_exception_interceptor.rb,
lib/raygun/middleware/rails_insert_affected_user.rb,
lib/raygun/services/apply_whitelist_filter_to_payload.rb
Overview
Defined Under Namespace
Modules: Middleware, Services, Testable
Classes: Client, Configuration, InstallGenerator, ItWorksException, Railtie, SidekiqMiddleware, SidekiqReporter
Constant Summary
collapse
- CLIENT_URL =
used to identify ourselves to Raygun
"https://github.com/MindscapeHQ/raygun4ruby"
- CLIENT_NAME =
"Raygun4Ruby Gem"
- VERSION =
"1.2.1"
Class Attribute Summary collapse
Class Method Summary
collapse
Methods included from Testable
track_test_exception
Class Attribute Details
.configuration ⇒ Object
37
38
39
|
# File 'lib/raygun.rb', line 37
def configuration
@configuration ||= Configuration.new
end
|
Class Method Details
45
46
47
|
# File 'lib/raygun.rb', line 45
def configured?
!!configuration.api_key
end
|
.default_configuration ⇒ Object
41
42
43
|
# File 'lib/raygun.rb', line 41
def default_configuration
configuration.defaults
end
|
.failsafe_log(message) ⇒ Object
82
83
84
|
# File 'lib/raygun.rb', line 82
def failsafe_log(message)
configuration.failsafe_logger.info(message)
end
|
.log(message) ⇒ Object
78
79
80
|
# File 'lib/raygun.rb', line 78
def log(message)
configuration.logger.info(message) if configuration.logger
end
|
.setup {|configuration| ... } ⇒ Object
33
34
35
|
# File 'lib/raygun.rb', line 33
def setup
yield(configuration)
end
|
.track_exception(exception_instance, env = {}, retry_count = 1) ⇒ Object
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
|
# File 'lib/raygun.rb', line 49
def track_exception(exception_instance, env = {}, retry_count = 1)
if should_report?(exception_instance)
log("[Raygun] Tracking Exception...")
Client.new.track_exception(exception_instance, env)
end
rescue Exception => e
if configuration.failsafe_logger
failsafe_log("Problem reporting exception to Raygun: #{e.class}: #{e.message}\n\n#{e.backtrace.join("\n")}")
end
if retry_count > 0
new_exception = e.exception("raygun4ruby encountered an exception processing your exception")
new_exception.set_backtrace(e.backtrace)
env[:custom_data] ||= {}
env[:custom_data].merge!(original_stacktrace: exception_instance.backtrace)
track_exception(new_exception, env, retry_count - 1)
else
raise e
end
end
|
.track_exceptions ⇒ Object
72
73
74
75
76
|
# File 'lib/raygun.rb', line 72
def track_exceptions
yield
rescue => e
track_exception(e)
end
|