Sha256: c18df65dc400b0b96166ab59b80e5ca3314c099fac85e886811ad11e84b5f4e8

Contents?: true

Size: 1.09 KB

Versions: 34

Compression:

Stored size: 1.09 KB

Contents

require 'logger'
module Celluloid
  # Subscribes to log incident topics to report on them.
  class IncidentReporter
    include Celluloid
    include Celluloid::Notifications

    # get the time from the event
    class Formatter < ::Logger::Formatter
      def call(severity, time, progname, msg)
        super(severity, msg.time, progname, msg.message)
      end
    end

    def initialize(*args)
      subscribe(/log\.incident/, :report)
      @logger = ::Logger.new(*args)
      @logger.formatter = Formatter.new
      @silenced = false
    end

    def report(topic, incident)
      return if @silenced

      header = "INCIDENT"
      header << " AT #{incident.triggering_event.time}" if incident.triggering_event
      @logger << header
      @logger << "\n"
      @logger << "====================\n"
      incident.events.each do |event|
        @logger.add(event.severity, event, event.progname)
      end
      @logger << "====================\n"
    end

    def silence
      @silenced = true
    end

    def unsilence
      @silenced = false
    end

    def silenced?
      @silenced
    end
  end
end

Version data entries

34 entries across 32 versions & 7 rubygems

Version Path
sidekiq-statsd-0.1.1 vendor/ruby/1.9.1/gems/celluloid-0.14.0/lib/celluloid/logging/incident_reporter.rb
sidekiq-statsd-0.1.0 vendor/ruby/1.9.1/gems/celluloid-0.14.0/lib/celluloid/logging/incident_reporter.rb
celluloid-0.14.0 lib/celluloid/logging/incident_reporter.rb
celluloid-0.14.0.pre lib/celluloid/logging/incident_reporter.rb
celluloid-0.13.0 lib/celluloid/logging/incident_reporter.rb
celluloid-0.13.0.pre2 lib/celluloid/logging/incident_reporter.rb
celluloid-0.13.0.pre lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.4 lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.4.pre2 lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.4.pre lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.3 lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.2 lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.1 lib/celluloid/logging/incident_reporter.rb
celluloid-0.12.1.pre2 lib/celluloid/logging/incident_reporter.rb