Class: Legion::Extensions::MicrosoftTeams::Actor::ObservedChatPoller

Inherits:
Actors::Every
  • Object
show all
Includes:
Helpers::Client, Helpers::HighWaterMark
Defined in:
lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb

Constant Summary

Constants included from Helpers::HighWaterMark

Helpers::HighWaterMark::HWM_TTL

Instance Method Summary collapse

Methods included from Helpers::HighWaterMark

#get_extended_hwm, #get_hwm, #hwm_key, #memory_runner, #new_messages, #persist_hwm_as_trace, #restore_hwm_from_traces, #set_extended_hwm, #set_hwm, #update_extended_hwm, #update_hwm_from_messages

Methods included from Helpers::Client

#bot_connection, #graph_connection, #oauth_connection, #user_path

Constructor Details

#initialize(**opts) ⇒ ObservedChatPoller

Returns a new instance of ObservedChatPoller.



11
12
13
14
15
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 11

def initialize(**opts)
  return unless enabled?

  super
end

Instance Method Details

#check_subtask?Boolean

Returns:

  • (Boolean)


23
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 23

def check_subtask?  = false

#delayObject



20
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 20

def delay           = 180

#enabled?Boolean

Returns:

  • (Boolean)


26
27
28
29
30
31
32
33
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 26

def enabled?
  settings.dig(:observed_chat_poller, :enabled) &&
    defined?(Legion::Extensions::MicrosoftTeams::Runners::Bot) &&
    Legion.const_defined?(:Transport, false)
rescue StandardError => e
  handle_exception(e, level: :debug, operation: 'ObservedChatPoller#enabled?')
  false
end

#generate_task?Boolean

Returns:

  • (Boolean)


24
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 24

def generate_task?  = false

#manualObject



39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 39

def manual
  log.debug('ObservedChatPoller#manual starting')
  token = delegated_token
  return unless token

  subscriptions = subscription_registry.active_subscriptions
  log.debug("ObservedChatPoller#manual subscriptions=#{subscriptions.length}")
  subscriptions.each do |sub|
    poll_observed_chat(
      chat_id: sub[:chat_id], owner_id: sub[:owner_id],
      peer_name: sub[:peer_name], token: token
    )
  end
rescue StandardError => e
  handle_exception(e, level: :error, operation: 'ObservedChatPoller#manual')
end

#run_now?Boolean

Returns:

  • (Boolean)


21
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 21

def run_now?        = false

#runner_classObject



17
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 17

def runner_class    = Legion::Extensions::MicrosoftTeams::Runners::Bot

#runner_functionObject



18
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 18

def runner_function = 'observe_message'

#subscription_registryObject



35
36
37
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 35

def subscription_registry
  @subscription_registry ||= Legion::Extensions::MicrosoftTeams::Helpers::SubscriptionRegistry.new
end

#timeObject



19
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 19

def time            = settings.dig(:observed_chat_poller, :interval)

#use_runner?Boolean

Returns:

  • (Boolean)


22
# File 'lib/legion/extensions/microsoft_teams/actors/observed_chat_poller.rb', line 22

def use_runner?     = false