content/automate/ManageIQ/Service/Generic/StateMachines/GenericLifecycle.class/__methods__/execute.rb
#
# Description: This method executes a job template
#
module ManageIQ
module Automate
module Service
module Generic
module StateMachines
module GenericLifecycle
class Execute
def initialize(handle = $evm)
@handle = handle
end
def main
@handle.log("info", "Starting execute")
begin
service.set_automate_timeout(@handle.field_timeout, service_action)
service.execute(service_action)
@handle.root['ae_result'] = 'ok'
@handle.log("info", "Ending execute")
rescue => err
@handle.root['ae_result'] = 'error'
@handle.root['ae_reason'] = err.message
@handle.log('error', "Error in execute: #{err.message}")
update_task(err.message)
end
end
private
def update_task(message)
@handle.root['service_template_provision_task'].try { |task| task.miq_request.user_message = message }
end
def service
@handle.root["service"].tap do |service|
if service.nil?
@handle.log(:error, 'Service is nil')
raise 'Service not found'
end
end
end
def service_action
@handle.root["service_action"].tap do |action|
unless %w(Provision Retirement Reconfigure).include?(action)
@handle.log(:error, "Invalid service action: #{action}")
raise "Invalid service_action"
end
end
end
end
end
end
end
end
end
end
ManageIQ::Automate::Service::Generic::StateMachines::GenericLifecycle::Execute.new.main