Sha256: 7ae69828f8c91674ebc27b08d8b5b416157d8a42c832297df10cdc0ecd5ea1bc

Contents?: true

Size: 1.65 KB

Versions: 2

Compression:

Stored size: 1.65 KB

Contents

# frozen_string_literal: true

module SlackBot
  module Events
    module Middleware
      class EventTracer
        def call(type:, socket_event:, schema: nil, parsed_data: nil, **params)
          start_time = Process.clock_gettime(Process::CLOCK_MONOTONIC)
          temp_type = type.dup.to_s
          case type
          when :close
            additional_info = "code: #{socket_event.code} reason:#{socket_event.reason}"
          when :message
            accurate_type = parsed_data.dig("payload","event","subtype") || parsed_data.dig("payload","event","type")
            p_type = [
              parsed_data.dig("type"),
              accurate_type
            ].compact.join(":")
            case p_type
            when "app_rate_limited"
              # https://api.slack.com/apis/rate-limits#events
              # Total allowed workspace events are 30,000 per hour
              # This message type is received once you have gone beyond that
              temp_type += ":#{p_type}"
              additional_info = "minute_rate_limited:#{parsed_data["minute_rate_limited"]} " \
                "team_id:#{parsed_data["team_id"]} " \
                "api_app_id:#{parsed_data["api_app_id"]}"
            else
              # Expected other types are `events_api` and `hello`
              temp_type += ":#{p_type}"
            end
          end

          Events.logger.info { "[Event Received] #{temp_type} #{additional_info}" }

          yield

          elapsed_time = Process.clock_gettime(Process::CLOCK_MONOTONIC) - start_time
          Events.logger.info { "[Event Finished] #{temp_type} [#{(elapsed_time * 1000).round(2)}ms]" }
        end
      end
    end
  end
end

Version data entries

2 entries across 2 versions & 1 rubygems

Version Path
slack_bot-events-0.4.1 lib/slack_bot/events/middleware/event_tracer.rb
slack_bot-events-0.4.0 lib/slack_bot/events/middleware/event_tracer.rb