From 42ea1e3427795c4328bd070fd97799018f69fd18 Mon Sep 17 00:00:00 2001 From: moklidia Date: Thu, 2 Jun 2022 11:08:55 +0200 Subject: [PATCH 1/2] [uffizzi_app][147] added support for build parser module --- .../uffizzi_core/dependency_injection_concern.rb | 6 ++++++ .../config_file_serializer.rb | 4 ++-- .../compose_file/services_options_service.rb | 12 ++++++++++-- 3 files changed, 18 insertions(+), 4 deletions(-) diff --git a/core/app/controllers/concerns/uffizzi_core/dependency_injection_concern.rb b/core/app/controllers/concerns/uffizzi_core/dependency_injection_concern.rb index 39ee0711..4dd2c366 100644 --- a/core/app/controllers/concerns/uffizzi_core/dependency_injection_concern.rb +++ b/core/app/controllers/concerns/uffizzi_core/dependency_injection_concern.rb @@ -7,6 +7,12 @@ def user_access_module module_class(:rbac).new end + def build_parser_module + return unless module_exists?(:github) + + module_class(:github).new + end + private def module_exists?(module_name) diff --git a/core/app/serializers/uffizzi_core/controller/deploy_containers/container_serializer/container_config_file_serializer/config_file_serializer.rb b/core/app/serializers/uffizzi_core/controller/deploy_containers/container_serializer/container_config_file_serializer/config_file_serializer.rb index 3cc891b9..1444ea17 100644 --- a/core/app/serializers/uffizzi_core/controller/deploy_containers/container_serializer/container_config_file_serializer/config_file_serializer.rb +++ b/core/app/serializers/uffizzi_core/controller/deploy_containers/container_serializer/container_config_file_serializer/config_file_serializer.rb @@ -1,8 +1,8 @@ # frozen_string_literal: true -# rubocop:disable Metrics/LineLength +# rubocop:disable Layout/LineLength class UffizziCore::Controller::DeployContainers::ContainerSerializer::ContainerConfigFileSerializer::ConfigFileSerializer < UffizziCore::BaseSerializer - # rubocop:enable Metrics/LineLength + # rubocop:enable Layout/LineLength attributes :id, :filename, :kind, :payload end diff --git a/core/app/services/uffizzi_core/compose_file/services_options_service.rb b/core/app/services/uffizzi_core/compose_file/services_options_service.rb index 512f6c97..24ddbe0b 100644 --- a/core/app/services/uffizzi_core/compose_file/services_options_service.rb +++ b/core/app/services/uffizzi_core/compose_file/services_options_service.rb @@ -2,6 +2,8 @@ class UffizziCore::ComposeFile::ServicesOptionsService class << self + include UffizziCore::DependencyInjectionConcern + def parse(services, global_configs_data, global_secrets_data, compose_payload) raise UffizziCore::ComposeFile::ParseError, I18n.t('compose.no_services') if services.nil? || services.keys.empty? @@ -18,7 +20,7 @@ def parse(services, global_configs_data, global_secrets_data, compose_payload) private - def prepare_service_data(service_name, service_data, global_configs_data, global_secrets_data, _compose_payload) + def prepare_service_data(service_name, service_data, global_configs_data, global_secrets_data, compose_payload) options_data = {} service_data.each_pair do |key, value| service_key = key.to_sym @@ -27,7 +29,7 @@ def prepare_service_data(service_name, service_data, global_configs_data, global when :image UffizziCore::ComposeFile::ServicesOptions::ImageService.parse(value) when :build - raise UffizziCore::ComposeFile::ParseError, I18n.t('compose.not_implemented', option: :build) + check_and_parse_build_option(value, compose_payload) when :env_file UffizziCore::ComposeFile::ServicesOptions::EnvFileService.parse(value) when :environment @@ -51,5 +53,11 @@ def prepare_service_data(service_name, service_data, global_configs_data, global options_data end + + def check_and_parse_build_option(value, compose_payload) + raise UffizziCore::ComposeFile::ParseError, I18n.t('compose.not_implemented', option: :build) unless build_parser_module + + build_parser_module.parse(value, compose_payload) + end end end From 95c2d88bb19416ae3a6eea0b97482afdd7087673 Mon Sep 17 00:00:00 2001 From: moklidia Date: Thu, 2 Jun 2022 11:14:43 +0200 Subject: [PATCH 2/2] [uffizzi_app][147] fixed rubocop errors --- .../uffizzi_core/compose_file/services_options_service.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/core/app/services/uffizzi_core/compose_file/services_options_service.rb b/core/app/services/uffizzi_core/compose_file/services_options_service.rb index 24ddbe0b..a147e678 100644 --- a/core/app/services/uffizzi_core/compose_file/services_options_service.rb +++ b/core/app/services/uffizzi_core/compose_file/services_options_service.rb @@ -56,7 +56,7 @@ def prepare_service_data(service_name, service_data, global_configs_data, global def check_and_parse_build_option(value, compose_payload) raise UffizziCore::ComposeFile::ParseError, I18n.t('compose.not_implemented', option: :build) unless build_parser_module - + build_parser_module.parse(value, compose_payload) end end