50 lines
1.5 KiB
Ruby
50 lines
1.5 KiB
Ruby
# frozen_string_literal: true
|
|
|
|
module Jobs
|
|
class DetectTranslateTopic < ::Jobs::Base
|
|
sidekiq_options retry: false
|
|
|
|
def execute(args)
|
|
return if !SiteSetting.discourse_ai_enabled
|
|
return if !SiteSetting.ai_translation_enabled
|
|
return if args[:topic_id].blank?
|
|
|
|
topic = Topic.find_by(id: args[:topic_id])
|
|
if topic.blank? || topic.title.blank? || topic.deleted_at.present? || topic.user_id <= 0
|
|
return
|
|
end
|
|
|
|
if SiteSetting.ai_translation_backfill_limit_to_public_content
|
|
return if topic.category&.read_restricted?
|
|
end
|
|
|
|
begin
|
|
detected_locale = DiscourseAi::Translation::TopicLocaleDetector.detect_locale(topic)
|
|
rescue FinalDestination::SSRFDetector::LookupFailedError
|
|
# this job is non-critical
|
|
# the backfill job will handle failures
|
|
return
|
|
end
|
|
|
|
locales = SiteSetting.experimental_content_localization_supported_locales.split("|")
|
|
return if locales.blank?
|
|
|
|
locales.each do |locale|
|
|
next if locale == detected_locale
|
|
|
|
begin
|
|
DiscourseAi::Translation::TopicLocalizer.localize(topic, locale)
|
|
rescue FinalDestination::SSRFDetector::LookupFailedError
|
|
# do nothing, there are too many sporadic lookup failures
|
|
rescue => e
|
|
DiscourseAi::Translation::VerboseLogger.log(
|
|
"Failed to translate topic #{topic.id} to #{locale}: #{e.message}",
|
|
)
|
|
end
|
|
end
|
|
|
|
MessageBus.publish("/topic/#{topic.id}", type: :localized, id: 1)
|
|
end
|
|
end
|
|
end
|