Sha256: ce0d20ca2b03efcec58f2a336d097303f311a89ba6fb7701f8a663c6e047bca9

Contents?: true

Size: 1.15 KB

Versions: 4

Compression:

Stored size: 1.15 KB

Contents

module Errdo
  class ErrorOccurrence < ActiveRecord::Base

    self.table_name = "#{Errdo.error_name.to_s.singularize}_occurrences"

    serialize :param_values
    serialize :cookie_values
    serialize :header_values

    belongs_to :error, counter_cache: :occurrence_count
    belongs_to :experiencer, polymorphic: true

    before_save :scrub_utf

    after_create :update_last_occurrence
    after_create :update_last_experiencer

    def self.grouped_by_time(timeframe = nil)
      errors = Errdo::ErrorOccurrence.where("created_at > ?", 2.weeks.ago)
      timeframe = useful_time(Time.now - errors.first.created_at) if timeframe.nil?
      hist(errors, 24, Time.now - timeframe, timeframe)
    end

    private

    def deep_scrub(obj)
      if obj.respond_to? :each
        obj.each { |o| deep_scrub(o) }
      end
      if obj.is_a? String
        obj = obj.scrub!
      end
    end

    def scrub_utf
      deep_scrub(self.changes)
    end

    def update_last_occurrence
      error.update(last_occurred_at: created_at) if error && !created_at.nil?
    end

    def update_last_experiencer
      error.update(last_experiencer: experiencer) if error
    end

  end
end

Version data entries

4 entries across 4 versions & 1 rubygems

Version Path
errdo-0.12.14 app/models/errdo/error_occurrence.rb
errdo-0.12.13 app/models/errdo/error_occurrence.rb
errdo-0.12.12 app/models/errdo/error_occurrence.rb
errdo-0.12.11 app/models/errdo/error_occurrence.rb