From 0937f9f8e23cb8bc177cb350563fb0cf328d475b Mon Sep 17 00:00:00 2001 From: Vignesh skanda Date: Sat, 21 Sep 2024 23:46:46 +0530 Subject: [PATCH 1/2] Update en.yml --- config/locales/en.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/config/locales/en.yml b/config/locales/en.yml index 8e34768066b..084d2886c63 100644 --- a/config/locales/en.yml +++ b/config/locales/en.yml @@ -409,7 +409,7 @@ en: fa: Persian fi: Finnish fr: French - gd: Irish + ga: Irish gu: Gujarati he: Hebrew hi: Hindi From 678a0691aefb1062940e8ab86202506115fd5d99 Mon Sep 17 00:00:00 2001 From: Vignesh Skanda Date: Tue, 24 Sep 2024 09:28:25 +0530 Subject: [PATCH 2/2] Update search_index_add_worker.rb --- app/workers/search_index_add_worker.rb | 28 ++++++++++++++++++-------- 1 file changed, 20 insertions(+), 8 deletions(-) diff --git a/app/workers/search_index_add_worker.rb b/app/workers/search_index_add_worker.rb index 2cf51aaa4a7..fe2f8ae22a1 100644 --- a/app/workers/search_index_add_worker.rb +++ b/app/workers/search_index_add_worker.rb @@ -5,20 +5,32 @@ def perform(class_name, id) @class_name = class_name @id = id - if searchable_instance.nil? - logger.warn("SearchIndexAddWorker: Could not find #{class_name} with id #{id} (#{Time.zone.now.utc}).") - elsif !searchable_instance.can_index_in_search? - logger.warn("SearchIndexAddWorker: Was asked to index #{class_name} with id #{id}, but it was unindexable (#{Time.zone.now.utc}).") + searchable_instance = find_searchable_instance + return unless searchable_instance + + if searchable_instance.can_index_in_search? + add_to_search_index(searchable_instance) else - index = Whitehall::SearchIndex.for(searchable_instance.search_api_index, logger:) - index.add searchable_instance.search_index + logger.warn("SearchIndexAddWorker: Was asked to index #{class_name} with id #{id}, but it was unindexable (#{Time.zone.now.utc}).") end + rescue StandardError => e + logger.error("SearchIndexAddWorker: Error adding #{class_name} with id #{id} to search index: #{e.message}") end private - def searchable_instance - @searchable_instance ||= searchable_class.find_by(id:) + def find_searchable_instance + searchable_class.find_by(id:) + rescue StandardError => e + logger.error("SearchIndexAddWorker: Error finding #{class_name} with id #{id}: #{e.message}") + nil + end + + def add_to_search_index(searchable_instance) + index = Whitehall::SearchIndex.for(searchable_instance.search_api_index, logger:) + index.add searchable_instance.search_index + rescue StandardError => e + logger.error("SearchIndexAddWorker: Error adding #{class_name} with id #{id} to search index: #{e.message}") end def searchable_class