Sha256: aecce46122a1920e375a774b40b07bf6bc7bddd21882ba1ae15cf5175bcf06ac

Contents?: true

Size: 1.73 KB

Versions: 1

Compression:

Stored size: 1.73 KB

Contents

# frozen_string_literal: true

module SlackWebhookLogger
  class Formatter < ::Logger::Formatter
    attr_writer :format

    MAX_LENGTH = 3000

    class << self
      def fetch_text(hash)
        hash[:blocks].last[:text][:text]
      end
    end

    def format
      @format ||= proc do |severity, time, _progname, msg|
        heading = case severity
        when "FATAL"
          "📛 *#{severity}*"
        when "ERROR"
          "🛑 *#{severity}*"
        when "WARN"
          "⚠ī¸ *#{severity}*"
        when "INFO"
          "ℹī¸ *#{severity}*"
        when "DEBUG"
          "🐛 *#{severity}*"
        else
          "đŸĒĩ *Logger*"
        end

        title = "#{heading} (#{time}) [#{ENV.fetch("RAILS_ENV", nil)}]"

        text = <<~MSG
          #{msg2str(msg)}
        MSG

        slackify(truncate(title), truncate(text))
      end
    end

    def call(severity, time, progname, msg)
      format.call(severity, time, progname, msg)
    end

    def slackify(title, text)
      {
        blocks: [
          {
            type: "section",
            text: {
              type: "mrkdwn",
              text: title,
            },
          },
          {
            type: "divider",
          },
          {
            type: "section",
            text: {
              type: "plain_text",
              text: text,
            },
          },
        ],
      }
    end

    private def msg2str(msg)
      case msg
      when ::String
        msg
      when ::Exception
        "#{msg.message} (#{msg.class})\n" <<
          (msg.backtrace || []).join("\n")
      else
        msg.inspect
      end
    end

    private def truncate(string)
      string.length > MAX_LENGTH ? "#{string[0...MAX_LENGTH - 3]}..." : string
    end
  end
end

Version data entries

1 entries across 1 versions & 1 rubygems

Version Path
slack_webhook_logger-0.5.5 lib/slack_webhook_logger/formatter.rb