2025-05-29 17:28:06 +08:00
|
|
|
# frozen_string_literal: true
|
|
|
|
|
|
|
|
module Jobs
|
|
|
|
class DetectTranslatePost < ::Jobs::Base
|
2025-06-18 13:24:02 +08:00
|
|
|
cluster_concurrency 1
|
2025-05-29 17:28:06 +08:00
|
|
|
sidekiq_options retry: false
|
|
|
|
|
|
|
|
def execute(args)
|
2025-07-09 22:21:51 +08:00
|
|
|
return if !DiscourseAi::Translation.enabled?
|
2025-05-29 17:28:06 +08:00
|
|
|
return if args[:post_id].blank?
|
|
|
|
|
|
|
|
post = Post.find_by(id: args[:post_id])
|
|
|
|
return if post.blank? || post.raw.blank? || post.deleted_at.present? || post.user_id <= 0
|
|
|
|
|
2025-06-13 00:55:52 +08:00
|
|
|
topic = post.topic
|
|
|
|
return if topic.blank?
|
|
|
|
|
2025-05-29 17:28:06 +08:00
|
|
|
if SiteSetting.ai_translation_backfill_limit_to_public_content
|
2025-06-13 00:55:52 +08:00
|
|
|
return if topic.category&.read_restricted? || topic.archetype == Archetype.private_message
|
|
|
|
else
|
|
|
|
if topic.archetype == Archetype.private_message &&
|
|
|
|
!TopicAllowedGroup.exists?(topic_id: topic.id)
|
2025-05-29 17:28:06 +08:00
|
|
|
return
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
2025-06-11 11:00:22 +08:00
|
|
|
# the user may fill locale in manually
|
|
|
|
if (detected_locale = post.locale).blank?
|
|
|
|
begin
|
|
|
|
detected_locale = DiscourseAi::Translation::PostLocaleDetector.detect_locale(post)
|
|
|
|
rescue FinalDestination::SSRFDetector::LookupFailedError
|
|
|
|
# this job is non-critical
|
|
|
|
# the backfill job will handle failures
|
|
|
|
return
|
|
|
|
end
|
2025-05-29 17:28:06 +08:00
|
|
|
end
|
|
|
|
|
2025-07-09 22:21:51 +08:00
|
|
|
return if detected_locale.blank?
|
2025-06-19 12:23:56 +08:00
|
|
|
locales = SiteSetting.content_localization_supported_locales.split("|")
|
2025-05-29 17:28:06 +08:00
|
|
|
return if locales.blank?
|
|
|
|
|
|
|
|
locales.each do |locale|
|
2025-07-09 22:21:51 +08:00
|
|
|
next if DiscourseAi::Translation::LocaleNormalizer.is_same?(locale, detected_locale)
|
|
|
|
regionless_locale = locale.split("_").first
|
|
|
|
next if post.post_localizations.where("locale LIKE ?", "#{regionless_locale}%").exists?
|
2025-05-29 17:28:06 +08:00
|
|
|
|
|
|
|
begin
|
|
|
|
DiscourseAi::Translation::PostLocalizer.localize(post, locale)
|
|
|
|
rescue FinalDestination::SSRFDetector::LookupFailedError
|
|
|
|
# do nothing, there are too many sporadic lookup failures
|
|
|
|
rescue => e
|
|
|
|
DiscourseAi::Translation::VerboseLogger.log(
|
2025-06-23 21:11:20 +08:00
|
|
|
"Failed to translate post #{post.id} to #{locale}: #{e.message}\n\n#{e.backtrace[0..3].join("\n")}",
|
2025-05-29 17:28:06 +08:00
|
|
|
)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
|
|
|
|
MessageBus.publish("/topic/#{post.topic_id}", type: :localized, id: post.id)
|
|
|
|
end
|
|
|
|
end
|
|
|
|
end
|