From d65fbc132d90fcb98ece25170220a55bf0ec9676 Mon Sep 17 00:00:00 2001 From: Jeremy Lenz Date: Thu, 12 Oct 2023 15:34:16 -0400 Subject: [PATCH] Fixes #35901 - Allow searching for CCVs based on component CVs --- .../concerns/filtered_auto_complete_search.rb | 2 +- app/models/katello/content_view.rb | 21 +++++++++++++++++++ app/models/katello/docker_tag.rb | 2 +- app/models/katello/yum_metadata_file.rb | 2 +- 4 files changed, 24 insertions(+), 3 deletions(-) diff --git a/app/controllers/katello/concerns/filtered_auto_complete_search.rb b/app/controllers/katello/concerns/filtered_auto_complete_search.rb index 1055a5a9336..0fa32c15340 100644 --- a/app/controllers/katello/concerns/filtered_auto_complete_search.rb +++ b/app/controllers/katello/concerns/filtered_auto_complete_search.rb @@ -7,7 +7,7 @@ module FilteredAutoCompleteSearch def auto_complete_search begin - options = resource_class.respond_to?(:completer_scope_options) ? resource_class.completer_scope_options : {} + options = resource_class.respond_to?(:completer_scope_options) ? resource_class.completer_scope_options(params[:search]) : {} items = resource_class.where(:id => self.index_relation).complete_for(params[:search], options) items = items.map do |item| category = ['and', 'or', 'not', 'has'].include?(item.to_s.sub(/^.*\s+/, '')) ? _('Operators') : '' diff --git a/app/models/katello/content_view.rb b/app/models/katello/content_view.rb index 316d2d452fa..5fa54ac20f0 100644 --- a/app/models/katello/content_view.rb +++ b/app/models/katello/content_view.rb @@ -111,6 +111,27 @@ class ContentView < Katello::Model scoped_search :on => :composite, :complete_value => true scoped_search :on => :generated_for, :complete_value => true scoped_search :on => :default # just for ordering + scoped_search :on => :name, :complete_value => true, + :rename => :content_views, + :operators => ['=', '!=', '~', '!~'], + :ext_method => :find_components_by_cv_name + + def self.find_components_by_cv_name(_key, operator, value) + kcv = Katello::ContentView.table_name + kcvc = Katello::ContentViewComponent.table_name + { :conditions => "#{kcv}.composite = 't' AND #{kcv}.id IN (SELECT #{kcvc}.composite_content_view_id FROM #{kcvc} WHERE #{kcvc}.content_view_id IN (SELECT #{kcv}.id FROM #{kcv} WHERE #{kcv}.name #{operator} ?))", + :parameter => [value] + } + end + + def self.completer_scope_options(search) + if search.include?('content_views') + # Don't autocomplete CCV names when searching for components + { :value_filter => { :composite => false } } + else + {} + end + end enum generated_for: { none: 0, diff --git a/app/models/katello/docker_tag.rb b/app/models/katello/docker_tag.rb index 712b6faa323..de8359588bb 100644 --- a/app/models/katello/docker_tag.rb +++ b/app/models/katello/docker_tag.rb @@ -73,7 +73,7 @@ def self.with_identifiers(ids) self.where(:id => ids) end - def self.completer_scope_options + def self.completer_scope_options(_search) {"#{Katello::Repository.table_name}" => lambda { |repo_class| repo_class.docker_type } } end diff --git a/app/models/katello/yum_metadata_file.rb b/app/models/katello/yum_metadata_file.rb index b26d2928680..760fc58a553 100644 --- a/app/models/katello/yum_metadata_file.rb +++ b/app/models/katello/yum_metadata_file.rb @@ -15,7 +15,7 @@ def repositories [repository] end - def self.completer_scope_options + def self.completer_scope_options(_search) {"#{Katello::Repository.table_name}" => lambda { |repo_class| repo_class.yum_type } } end end