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 |