Sha256: aea0dd76e8289eebc406be2195a916678b8edc087b568b9a6140881981798332

Contents?: true

Size: 1.79 KB

Versions: 5

Compression:

Stored size: 1.79 KB

Contents

# frozen_string_literal: true

module Isolator
  # Wrapper over different notifications methods (exceptions, logging, uniform notifier)
  class Notifier
    attr_reader :exception, :backtrace

    def initialize(exception, backtrace = caller)
      @exception = exception
      @backtrace = backtrace
    end

    def call
      log_exception
      send_notifications if send_notifications?
      raise(exception.class, exception.message, filtered_backtrace) if raise_exceptions?
    end

    private

    def raise_exceptions?
      Isolator.config.raise_exceptions?
    end

    def send_notifications?
      Isolator.config.send_notifications?
    end

    def log_exception
      return unless Isolator.config.logger

      separator = " ↳ "

      begin
        msg = "[ISOLATOR EXCEPTION]\n" \
              "#{exception.message}"

        filtered_backtrace.each do |offense_line|
          msg += "\n #{separator}#{offense_line}"
        end

        Isolator.config.logger.warn(msg)
      rescue Encoding::CompatibilityError
        should_retry = separator != " - "
        separator = " - "
        retry if should_retry
      end
    end

    def send_notifications
      return unless uniform_notifier_loaded?

      ::UniformNotifier.active_notifiers.each do |notifier|
        notifier.out_of_channel_notify exception.message
      end
    end

    def filtered_backtrace
      Isolator.config.backtrace_filter.call(backtrace)
    end

    def uniform_notifier_loaded?
      return true if defined?(::UniformNotifier)

      begin
        require "uniform_notifier"
      rescue LoadError
        warn(
          "Please, install and configure 'uniform_notifier' to send notifications:\n" \
          "# Gemfile\n" \
          "gem 'uniform_notifer', '~> 1.11', require: false"
        )
      end
    end
  end
end

Version data entries

5 entries across 5 versions & 1 rubygems

Version Path
isolator-1.1.1 lib/isolator/notifier.rb
isolator-1.1.0 lib/isolator/notifier.rb
isolator-1.0.1 lib/isolator/notifier.rb
isolator-1.0.0 lib/isolator/notifier.rb
isolator-0.11.0 lib/isolator/notifier.rb