ManageIQ/manageiq-providers-amazon

View on GitHub
app/models/manageiq/providers/amazon/cloud_manager/provision_workflow.rb

Summary

Maintainability
A
0 mins
Test Coverage
B
89%
class ManageIQ::Providers::Amazon::CloudManager::ProvisionWorkflow < ManageIQ::Providers::CloudManager::ProvisionWorkflow
  def allowed_instance_types(_options = {})
    source = load_ar_obj(get_source_vm)
    architecture = source.try(:hardware).try(:bitness)
    virtualization_type = source.try(:hardware).try(:virtualization_type)
    root_device_type = source.try(:hardware).try(:root_device_type)

    available = get_targets_for_ems(source, :cloud_filter, Flavor, 'flavors')
    return {} if available.empty?

    methods = ["supports_#{architecture}_bit?".to_sym, "supports_#{virtualization_type}?".to_sym]
    methods << :supports_instance_store? if root_device_type == 'instance_store'

    methods.each { |m| available = available.select(&m) if ManageIQ::Providers::Amazon::CloudManager::Flavor.method_defined?(m) }

    available.each_with_object({}) { |f, hash| hash[f.id] = display_name_for_name_description(f) }
  end

  def allowed_security_groups(_options = {})
    src = resources_for_ui
    return {} if src[:ems].nil?

    security_groups = if src[:cloud_network]
                        source = load_ar_obj(src[:cloud_network])
                        get_targets_for_source(source, :cloud_filter, SecurityGroup, 'security_groups')
                      else
                        source = load_ar_obj(src[:ems])
                        get_targets_for_ems(source, :cloud_filter, SecurityGroup, 'security_groups.non_cloud_network')
                      end

    security_groups.each_with_object({}) { |sg, hash| hash[sg.id] = display_name_for_name_description(sg) }
  end

  def allowed_floating_ip_addresses(_options = {})
    src = resources_for_ui
    return {} if src[:ems].nil?

    load_ar_obj(src[:ems]).floating_ips.available.each_with_object({}) do |ip, hash|
      next unless ip_available_for_selected_network?(ip, src)
      hash[ip.id] = ip.address
    end
  end

  def allowed_availability_zones(_options = {})
    source = load_ar_obj(get_source_vm)
    targets = get_targets_for_ems(source, :cloud_filter, AvailabilityZone, 'availability_zones.available')
    allowed_ci(:availability_zones, [:cloud_network, :cloud_subnet, :security_group], targets.map(&:id))
  end

  def self.provider_model
    ManageIQ::Providers::Amazon::CloudManager
  end

  private

  def dialog_name_from_automate(message = 'get_dialog_name')
    super(message, {'platform' => 'amazon'})
  end

  def security_group_to_availability_zones(src)
    return nil unless src[:cloud_network]

    selected_group_ids = @values[:security_groups].to_a.compact
    return nil if selected_group_ids.blank?

    SecurityGroup.where(:id => selected_group_ids).each_with_object({}) do |sg, hash|
      next if sg.cloud_network.nil?
      sg.cloud_network.cloud_subnets.each do |cs|
        az = cs.availability_zone
        hash[az.id] = az.name
      end
    end
  end

  def cloud_network_to_availability_zones(src)
    return nil unless src[:cloud_network]

    load_ar_obj(src[:cloud_network]).cloud_subnets.each_with_object({}) do |cs, hash|
      az = cs.availability_zone
      hash[az.id] = az.name
    end
  end

  def cloud_subnet_to_availability_zones(src)
    availability_zones = if src[:cloud_subnet]
                           [load_ar_obj(src[:cloud_subnet]).availability_zone]
                         else
                           load_ar_obj(src[:ems]).availability_zones.available
                         end

    availability_zones.each_with_object({}) { |az, hash| hash[az.id] = az.name }
  end

  def ip_available_for_selected_network?(ip, src)
    ip.cloud_network_only? != src[:cloud_network_id].nil?
  end
end