From 7bb28aa786baefca0f26028f24124e1b1850cf99 Mon Sep 17 00:00:00 2001 From: Lucy Fu Date: Thu, 20 Jul 2017 12:39:19 -0400 Subject: [PATCH] Move kube/openshift specific template code into its provider directory. --- app/models/container_template.rb | 66 ------------------- .../container_manager/container_template.rb | 2 + 2 files changed, 2 insertions(+), 66 deletions(-) create mode 100644 app/models/manageiq/providers/container_manager/container_template.rb diff --git a/app/models/container_template.rb b/app/models/container_template.rb index 0a859dc06e0..ebae1a30862 100644 --- a/app/models/container_template.rb +++ b/app/models/container_template.rb @@ -12,70 +12,4 @@ class ContainerTemplate < ApplicationRecord serialize :objects, Array acts_as_miq_taggable - - MIQ_ENTITY_MAPPING = { - "Route" => ContainerRoute, - "Build" => ContainerBuildPod, - "BuildConfig" => ContainerBuild, - "Template" => ContainerTemplate, - "ResourceQuota" => ContainerQuota, - "LimitRange" => ContainerLimit, - "ReplicationController" => ContainerReplicator, - "PersistentVolumeClaim" => PersistentVolumeClaim, - "Pod" => ContainerGroup, - "Service" => ContainerService, - }.freeze - - def instantiate(params, project = nil) - project ||= container_project.name - processed_template = process_template(ext_management_system.connect, - :metadata => { - :name => name, - :namespace => project - }, - :objects => objects, - :parameters => params) - create_objects(processed_template['objects'], project) - @created_objects.each { |obj| obj[:miq_class] = MIQ_ENTITY_MAPPING[obj[:kind]] } - end - - def process_template(client, template) - client.process_template(template) - rescue KubeException => e - raise MiqException::MiqProvisionError, "Unexpected Exception while processing template: #{e}" - end - - def create_objects(objects, project) - @created_objects = [] - objects.each { |obj| @created_objects << create_object(obj, project).to_h } - end - - def create_object(obj, project) - obj = obj.symbolize_keys - obj[:metadata][:namespace] = project - method_name = "create_#{obj[:kind].underscore}" - begin - ext_management_system.connect_client(obj[:apiVersion], method_name).send(method_name, obj) - rescue KubeException => e - rollback_objects(@created_objects) - raise MiqException::MiqProvisionError, "Unexpected Exception while creating object: #{e}" - end - end - - # rollback_objects cannot catch children objects created during the template instantiation and therefore those objects - # will remain in the cluster. - def rollback_objects(objects) - objects.each { |obj| rollback_object(obj) } - end - - def rollback_object(obj) - method_name = "delete_#{obj[:kind].underscore}" - begin - ext_management_system.connect_client(obj[:apiVersion], method_name).send(method_name, - obj[:metadata][:name], - obj[:metadata][:namespace]) - rescue KubeException => e - _log.error("Unexpected Exception while deleting object: #{e}") - end - end end diff --git a/app/models/manageiq/providers/container_manager/container_template.rb b/app/models/manageiq/providers/container_manager/container_template.rb new file mode 100644 index 00000000000..8053b1a0325 --- /dev/null +++ b/app/models/manageiq/providers/container_manager/container_template.rb @@ -0,0 +1,2 @@ +class ManageIQ::Providers::ContainerManager::ContainerTemplate < ContainerTemplate +end