Module: RailsErrorDashboard

Defined in:
lib/rails_error_dashboard/error_reporter.rb,
lib/rails_error_dashboard.rb,
lib/rails_error_dashboard/engine.rb,
lib/rails_error_dashboard/logger.rb,
lib/rails_error_dashboard/plugin.rb,
lib/rails_error_dashboard/version.rb,
lib/rails_error_dashboard/configuration.rb,
lib/rails_error_dashboard/plugin_registry.rb,
app/models/rails_error_dashboard/error_log.rb,
app/models/rails_error_dashboard/application.rb,
lib/rails_error_dashboard/commands/log_error.rb,
lib/rails_error_dashboard/queries/mttr_stats.rb,
lib/rails_error_dashboard/configuration_error.rb,
lib/rails_error_dashboard/queries/errors_list.rb,
app/jobs/rails_error_dashboard/application_job.rb,
app/models/rails_error_dashboard/error_comment.rb,
app/models/rails_error_dashboard/error_baseline.rb,
lib/rails_error_dashboard/manual_error_reporter.rb,
app/models/rails_error_dashboard/cascade_pattern.rb,
lib/rails_error_dashboard/commands/resolve_error.rb,
lib/rails_error_dashboard/plugins/metrics_plugin.rb,
lib/rails_error_dashboard/queries/baseline_stats.rb,
lib/rails_error_dashboard/queries/error_cascades.rb,
lib/rails_error_dashboard/queries/filter_options.rb,
lib/rails_error_dashboard/queries/similar_errors.rb,
app/helpers/rails_error_dashboard/overview_helper.rb,
app/jobs/rails_error_dashboard/baseline_alert_job.rb,
app/models/rails_error_dashboard/error_occurrence.rb,
lib/rails_error_dashboard/middleware/rate_limiter.rb,
lib/rails_error_dashboard/queries/analytics_stats.rb,
lib/rails_error_dashboard/queries/dashboard_stats.rb,
app/helpers/rails_error_dashboard/backtrace_helper.rb,
app/models/rails_error_dashboard/error_logs_record.rb,
lib/rails_error_dashboard/middleware/error_catcher.rb,
lib/rails_error_dashboard/plugins/audit_log_plugin.rb,
lib/rails_error_dashboard/queries/recurring_issues.rb,
app/helpers/rails_error_dashboard/user_agent_helper.rb,
lib/rails_error_dashboard/queries/error_correlation.rb,
lib/rails_error_dashboard/services/backtrace_parser.rb,
lib/rails_error_dashboard/services/cascade_detector.rb,
lib/rails_error_dashboard/services/error_normalizer.rb,
lib/rails_error_dashboard/services/git_blame_reader.rb,
lib/rails_error_dashboard/services/pattern_detector.rb,
app/helpers/rails_error_dashboard/application_helper.rb,
app/mailers/rails_error_dashboard/application_mailer.rb,
lib/rails_error_dashboard/services/platform_detector.rb,
lib/rails_error_dashboard/helpers/user_model_detector.rb,
lib/rails_error_dashboard/queries/co_occurring_errors.rb,
lib/rails_error_dashboard/queries/platform_comparison.rb,
lib/rails_error_dashboard/services/source_code_reader.rb,
lib/rails_error_dashboard/value_objects/error_context.rb,
app/jobs/rails_error_dashboard/async_error_logging_job.rb,
lib/rails_error_dashboard/commands/batch_delete_errors.rb,
lib/rails_error_dashboard/services/baseline_calculator.rb,
app/controllers/rails_error_dashboard/errors_controller.rb,
lib/rails_error_dashboard/commands/batch_resolve_errors.rb,
lib/rails_error_dashboard/services/github_link_generator.rb,
lib/rails_error_dashboard/services/similarity_calculator.rb,
lib/rails_error_dashboard/plugins/jira_integration_plugin.rb,
app/jobs/rails_error_dashboard/email_error_notification_job.rb,
app/jobs/rails_error_dashboard/slack_error_notification_job.rb,
app/mailers/rails_error_dashboard/error_notification_mailer.rb,
lib/rails_error_dashboard/services/baseline_alert_throttler.rb,
app/controllers/rails_error_dashboard/application_controller.rb,
app/jobs/rails_error_dashboard/discord_error_notification_job.rb,
app/jobs/rails_error_dashboard/webhook_error_notification_job.rb,
lib/generators/rails_error_dashboard/install/install_generator.rb,
app/jobs/rails_error_dashboard/pagerduty_error_notification_job.rb,
lib/generators/rails_error_dashboard/uninstall/uninstall_generator.rb,
lib/generators/rails_error_dashboard/solid_queue/solid_queue_generator.rb

Overview

Rack Middleware: Final safety net for uncaught errors This catches errors that somehow escape controller error handling Positioned at the Rack layer (outermost layer of Rails)

Middleware stack order (outer to inner):

  1. ErrorCatcher (this file) ← Catches everything

  2. ActionDispatch middleware

  3. Rails routing

  4. Controllers (with ErrorHandler concern)

This ensures NO error goes unreported

Defined Under Namespace

Modules: ApplicationHelper, BacktraceHelper, Commands, Generators, Helpers, Logger, Middleware, OverviewHelper, Plugins, Queries, Services, UserAgentHelper, ValueObjects Classes: Application, ApplicationController, ApplicationJob, ApplicationMailer, AsyncErrorLoggingJob, BaselineAlertJob, CascadePattern, Configuration, ConfigurationError, DiscordErrorNotificationJob, EmailErrorNotificationJob, Engine, ErrorBaseline, ErrorComment, ErrorLog, ErrorLogsRecord, ErrorNotificationMailer, ErrorOccurrence, ErrorReporter, ErrorsController, ManualErrorReporter, PagerdutyErrorNotificationJob, Plugin, PluginRegistry, SlackErrorNotificationJob, WebhookErrorNotificationJob

Constant Summary collapse

VERSION =
"0.1.35"

Class Attribute Summary collapse

Class Method Summary collapse

Class Attribute Details

.configurationObject

Get or initialize configuration



61
62
63
# File 'lib/rails_error_dashboard.rb', line 61

def configuration
  @configuration ||= Configuration.new
end

Class Method Details

.configure {|configuration| ... } ⇒ Object

Configure the gem

Yields:



66
67
68
# File 'lib/rails_error_dashboard.rb', line 66

def configure
  yield(configuration)
end

.on_critical_error(&block) ⇒ Object

Register a callback for when a critical error is logged

Examples:

RailsErrorDashboard.on_critical_error do |error_log|
  PagerDuty.trigger(error_log)
end

Parameters:

  • block (Proc)

    The callback to execute, receives error_log as parameter



111
112
113
# File 'lib/rails_error_dashboard.rb', line 111

def self.on_critical_error(&block)
  configuration.notification_callbacks[:critical_error] << block if block_given?
end

.on_error_logged(&block) ⇒ Object

Register a callback for when any error is logged

Examples:

RailsErrorDashboard.on_error_logged do |error_log|
  puts "Error logged: #{error_log.error_type}"
end

Parameters:

  • block (Proc)

    The callback to execute, receives error_log as parameter



101
102
103
# File 'lib/rails_error_dashboard.rb', line 101

def self.on_error_logged(&block)
  configuration.notification_callbacks[:error_logged] << block if block_given?
end

.on_error_resolved(&block) ⇒ Object

Register a callback for when an error is resolved

Examples:

RailsErrorDashboard.on_error_resolved do |error_log|
  Slack.notify("Error #{error_log.id} resolved")
end

Parameters:

  • block (Proc)

    The callback to execute, receives error_log as parameter



121
122
123
# File 'lib/rails_error_dashboard.rb', line 121

def self.on_error_resolved(&block)
  configuration.notification_callbacks[:error_resolved] << block if block_given?
end

.pluginsArray<Plugin>

Get all registered plugins

Returns:

  • (Array<Plugin>)

    List of registered plugins



91
92
93
# File 'lib/rails_error_dashboard.rb', line 91

def self.plugins
  PluginRegistry.plugins
end

.register_plugin(plugin) ⇒ Boolean

Register a plugin

Parameters:

  • plugin (Plugin)

    The plugin instance to register

Returns:

  • (Boolean)

    True if registered successfully, false otherwise



79
80
81
# File 'lib/rails_error_dashboard.rb', line 79

def self.register_plugin(plugin)
  PluginRegistry.register(plugin)
end

.reset_configuration!Object

Reset configuration to defaults



71
72
73
# File 'lib/rails_error_dashboard.rb', line 71

def reset_configuration!
  @configuration = Configuration.new
end

.unregister_plugin(plugin_name) ⇒ Object

Unregister a plugin by name

Parameters:

  • plugin_name (String)

    The name of the plugin to unregister



85
86
87
# File 'lib/rails_error_dashboard.rb', line 85

def self.unregister_plugin(plugin_name)
  PluginRegistry.unregister(plugin_name)
end