Skip to content

Commit

Permalink
Merge pull request #13423 from durandom/ansible_event_catcher
Browse files Browse the repository at this point in the history
Ansible Tower Event Catcher
  • Loading branch information
blomquisg authored Jan 23, 2017
2 parents 9704f7f + 9e8622c commit 000f511
Show file tree
Hide file tree
Showing 6 changed files with 103 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
class ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher < ManageIQ::Providers::BaseManager::EventCatcher
require_nested :Runner
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,33 @@
class ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher::Runner < ManageIQ::Providers::BaseManager::EventCatcher::Runner
def stop_event_monitor
event_monitor_handle.stop
end

def monitor_events
event_monitor_handle.start
event_monitor_handle.poll do |event|
_log.debug { "#{log_prefix} Received event #{event.id}" }
event_monitor_running
@queue.enq event
end
ensure
stop_event_monitor
end

def queue_event(event)
_log.info "#{log_prefix} Caught event [#{event.id}]"
event_hash = ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventParser.event_to_hash(event, @cfg[:ems_id])
EmsEvent.add_queue('add', @cfg[:ems_id], event_hash)
end

private

def event_monitor_handle
@event_monitor_handle ||= begin
ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher::Stream.new(
@ems,
:poll_sleep => worker_settings[:poll]
)
end
end
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
class ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher::Stream
class ProviderUnreachable < ManageIQ::Providers::BaseManager::EventCatcher::Runner::TemporaryFailure
end

def initialize(ems, options = {})
@ems = ems
@last_activity = nil
@stop_polling = false
@poll_sleep = options[:poll_sleep] || 20.seconds
end

def start
@stop_polling = false
end

def stop
@stop_polling = true
end

def poll
@ems.with_provider_connection do |ansible|
catch(:stop_polling) do
begin
loop do
ansible.api.activity_stream.all(filter).each do |activity|
throw :stop_polling if @stop_polling
yield activity
@last_activity = activity
end
sleep @poll_sleep
end
rescue => exception
raise ProviderUnreachable, exception.message
end
end
end
end

private

def filter
{
:order_by => 'timestamp',
:timestamp__gt => @last_activity ? @last_activity.timestamp : 1.minute.ago.to_s(:db)
}
end
end
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
module ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventParser
def self.event_to_hash(event, ems_id)
{
:event_type => "ansible_tower_#{event.operation}",
:source => "ANSIBLE_TOWER",
:message => event.changes.to_s,
:timestamp => event.timestamp,
:full_data => event.to_h,
:ems_id => ems_id
}
end
end
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,7 @@ module MiqServer::WorkerManagement::Monitor::ClassNames
ManageIQ::Providers::Vmware::InfraManager::RefreshWorker
ManageIQ::Providers::Nuage::NetworkManager::RefreshWorker
ManageIQ::Providers::Amazon::CloudManager::EventCatcher
ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher
ManageIQ::Providers::Azure::CloudManager::EventCatcher
ManageIQ::Providers::Hawkular::MiddlewareManager::EventCatcher
ManageIQ::Providers::Google::CloudManager::EventCatcher
Expand Down Expand Up @@ -134,6 +135,7 @@ module MiqServer::WorkerManagement::Monitor::ClassNames
ManageIQ::Providers::StorageManager::CinderManager::EventCatcher
ManageIQ::Providers::Amazon::CloudManager::EventCatcher
ManageIQ::Providers::Azure::CloudManager::EventCatcher
ManageIQ::Providers::AnsibleTower::ConfigurationManager::EventCatcher
ManageIQ::Providers::Hawkular::MiddlewareManager::EventCatcher
ManageIQ::Providers::Google::CloudManager::EventCatcher
ManageIQ::Providers::Kubernetes::ContainerManager::EventCatcher
Expand Down
6 changes: 6 additions & 0 deletions config/settings.yml
Original file line number Diff line number Diff line change
Expand Up @@ -230,6 +230,10 @@
:name: Application
:configuration:
:critical:
- ansible_tower_create
- ansible_tower_update
- ansible_tower_delete
- ansible_tower_associate
- ClusterReconfiguredEvent
- EnterMaintenanceMode_Task_Complete
- ExitMaintenanceMode_Task_Complete
Expand Down Expand Up @@ -1201,6 +1205,8 @@
:memory_threshold: 2.gigabytes
:nice_delta: 1
:poll: 1.seconds
:event_catcher_ansible_tower:
:poll: 20.seconds
:event_catcher_redhat:
:poll: 15.seconds
:event_catcher_vmware:
Expand Down

0 comments on commit 000f511

Please sign in to comment.