Module: Bellman
- Includes:
- ActiveSupport::Configurable
- Defined in:
- lib/bellman/bellman.rb,
lib/bellman/version.rb,
lib/bellman/handlers/sentry.rb,
lib/bellman/handlers/handler.rb,
lib/bellman/handlers/base_handler.rb,
lib/bellman/handlers/rails_logger.rb
Overview
Bellman
Unified way to take all of the log messages and direct them to the right place.
By default all messages will be logged using the Rails standard logger and any message with severity of :error or :fatal will also be sent to Sentry.
For historical details on a bellman/town crier see:
https://en.wikipedia.org/wiki/Town_crier
Defined Under Namespace
Modules: Handlers
Constant Summary collapse
- VERSION =
'0.1.0'
Class Method Summary collapse
- .configure ⇒ Object
- .error_handler(id:) ⇒ Object
-
.handle(error, severity: nil, trace_id: nil, objects: nil, data: nil, include_backtrace: false, handlers: nil) ⇒ Object
rubocop:disable Metrics/ParameterLists.
- .handler ⇒ Object
Class Method Details
.configure ⇒ Object
18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 |
# File 'lib/bellman/bellman.rb', line 18 def self.configure # Set the defaults config.severities = i[debug info warn error fatal].freeze config.default_severity = :error config.handlers = [ { id: :log, class: Bellman::Handlers::RailsLogger, severities: i[debug info warn error fatal] }, { id: :sentry, class: Bellman::Handlers::Sentry, severities: i[error fatal] } ] super # Create an instance of the handler that can be used @handler = Handlers::Handler.new end |
.error_handler(id:) ⇒ Object
45 46 47 |
# File 'lib/bellman/bellman.rb', line 45 def self.error_handler(id:) @handler.handlers.find { |hndlr| hndlr[:id] == id.to_sym } end |
.handle(error, severity: nil, trace_id: nil, objects: nil, data: nil, include_backtrace: false, handlers: nil) ⇒ Object
rubocop:disable Metrics/ParameterLists
50 51 52 53 54 55 56 57 58 |
# File 'lib/bellman/bellman.rb', line 50 def self.handle( error, severity: nil, trace_id: nil, objects: nil, data: nil, include_backtrace: false, handlers: nil ) @handler.handle( error, severity:, trace_id:, objects:, data:, include_backtrace:, handlers: ) end |
.handler ⇒ Object
41 42 43 |
# File 'lib/bellman/bellman.rb', line 41 def self.handler @handler end |