Sha256: 08cae8e9069d9d8b4253d8fbf032517946d2d4c492d3c9cb3a93c05aa958a8bf

Contents?: true

Size: 1.15 KB

Versions: 1

Compression:

Stored size: 1.15 KB

Contents

module Footnotes
  module Notes
    class LogNote < AbstractNote

      autoload :NoteLogger, 'rails-footnotes/notes/log_note/note_logger'

      cattr_accessor :logs
      cattr_accessor :original_logger

      def self.start!(controller)
        self.logs = []
        self.original_logger = Rails.logger
        note_logger = NoteLogger.new(self.logs)
        note_logger.level = self.original_logger.level
        note_logger.formatter = self.original_logger.kind_of?(Logger) ? self.original_logger.formatter : Logger::SimpleFormatter.new
        # Rails 3 don't have ActiveSupport::Logger#broadcast so we backported it
        extend_module = defined?(ActiveSupport::Logger) ? ActiveSupport::Logger.broadcast(note_logger) : NoteLogger.broadcast(note_logger)
        Rails.logger = self.original_logger.dup.extend(extend_module)
      end

      def title
        "Log (#{log.count("\n")})"
      end

      def content
        result = escape(log.gsub(/\e\[.+?m/, '')).gsub("\n", '<br />')
        # Restore formatter
        Rails.logger = self.class.original_logger
        result
      end

      def log
        self.class.logs.join("\n")
      end

    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
rails-footnotes-4.0.0 lib/rails-footnotes/notes/log_note.rb