Class: RailsErrorDashboard::Services::DigestBuilder

Inherits:
Object
  • Object
show all
Defined in:
lib/rails_error_dashboard/services/digest_builder.rb

Overview

Pure algorithm: Build a digest summary of error activity for a time period. Aggregates stats from existing queries into a single hash suitable for email templates.

Examples:

DigestBuilder.call(period: :daily)
# => { period: :daily, stats: { new_errors: 12, ... }, top_errors: [...], ... }

Constant Summary collapse

PERIODS =
{
  daily: { days: 1, label: "Last 24 hours" },
  weekly: { days: 7, label: "Last 7 days" }
}.freeze

Class Method Summary collapse

Instance Method Summary collapse

Constructor Details

#initialize(period: :daily, application_id: nil) ⇒ DigestBuilder

Returns a new instance of DigestBuilder.



21
22
23
24
25
26
# File 'lib/rails_error_dashboard/services/digest_builder.rb', line 21

def initialize(period: :daily, application_id: nil)
  @period = PERIODS.key?(period) ? period : :daily
  @days = PERIODS[@period][:days]
  @application_id = application_id
  @start_date = @days.days.ago
end

Class Method Details

.call(period: :daily, application_id: nil) ⇒ Object



17
18
19
# File 'lib/rails_error_dashboard/services/digest_builder.rb', line 17

def self.call(period: :daily, application_id: nil)
  new(period: period, application_id: application_id).call
end

Instance Method Details

#callObject



28
29
30
31
32
33
34
35
36
37
38
39
40
41
# File 'lib/rails_error_dashboard/services/digest_builder.rb', line 28

def call
  {
    period: @period,
    period_label: PERIODS[@period][:label],
    generated_at: Time.current,
    stats: build_stats,
    top_errors: top_errors,
    critical_unresolved: critical_unresolved,
    comparison: build_comparison
  }
rescue => e
  Rails.logger.error("[RailsErrorDashboard] DigestBuilder failed: #{e.class}: #{e.message}")
  empty_result
end