Неопределенная переменная 'target_locale' в плагине libre_translate.rb для Discourse Translator

Я установил плагин Discourse Translator и попытался использовать его с моим собственным экземпляром LibreTranslate. Это не сработало, и я получил следующую трассировку стека:

NameError (неопределенная локальная переменная или метод `target_locale' для класса DiscourseTranslator::LibreTranslate)
app/controllers/application_controller.rb:427:in `block in with_resolved_locale'
app/controllers/application_controller.rb:427:in `with_resolved_locale'
lib/middleware/omniauth_bypass_middleware.rb:35:in `call'
lib/content_security_policy/middleware.rb:12:in `call'
lib/middleware/anonymous_cache.rb:409:in `call'
lib/middleware/csp_script_nonce_injector.rb:12:in `call'
config/initializers/008-rack-cors.rb:14:in `call'
config/initializers/100-quiet_logger.rb:20:in `call'
config/initializers/100-silence_logger.rb:29:in `call'
lib/middleware/enforce_hostname.rb:24:in `call'
lib/middleware/processing_request.rb:12:in `call'
lib/middleware/request_tracker.rb:385:in `call'

Backtrace

plugins/discourse-translator/app/services/discourse_translator/libre_translate.rb:107:in `block in translate!'
plugins/discourse-translator/app/services/discourse_translator/base.rb:82:in `save_translation'
plugins/discourse-translator/app/services/discourse_translator/libre_translate.rb:101:in `translate!'
plugins/discourse-translator/app/services/discourse_translator/base.rb:51:in `translate'
plugins/discourse-translator/app/controllers/discourse_translator/translator_controller.rb:44:in `translate'
actionpack (7.2.2.1) lib/action_controller/metal/basic_implicit_render.rb:8:in `send_action'
actionpack (7.2.2.1) lib/abstract_controller/base.rb:226:in `process_action'
actionpack (7.2.2.1) lib/action_controller/metal/rendering.rb:193:in `process_action'
actionpack (7.2.2.1) lib/abstract_controller/callbacks.rb:261:in `block in process_action'
activesupport (7.2.2.1) lib/active_support/callbacks.rb:121:in `block in run_callbacks'
app/controllers/application_controller.rb:427:in `block in with_resolved_locale'
i18n (1.14.7) lib/i18n.rb:353:in `with_locale'

Проверив код:

    def self.translate!(translatable, target_locale_sym = I18n.locale)
      detected_lang = detect(translatable)

      save_translation(translatable, target_locale_sym) do
        res =
          result(
            translate_uri,
            q: text_for_translation(translatable),
            source: detected_lang,
            target: SUPPORTED_LANG_MAPPING[target_locale],
            format: "html",
          )
        res["translatedText"]
      end
    end

особенно строку 107, которая выглядит так:

target: SUPPORTED_LANG_MAPPING[target_locale]

—> похоже, что здесь должно быть target_locale_sym вместо target_locale, или я не прав?

Я вручную изменил это на: target: SUPPORTED_LANG_MAPPING[target_locale_sym],, сохранил и перезапустил приложение, и всё заработало.

3 лайка

Привет, спасибо за отчёт. Мы в приоритетном порядке займёмся исправлением этой ошибки.

3 лайка

@dorina, это теперь исправлено в FIX: Incorrect lang mapping using non-symbols for LibreTranslate by nattsw · Pull Request #238 · discourse/discourse-translator · GitHub. Вы можете обновить свой плагин, чтобы включить это исправление.

4 лайка

Эта тема была автоматически закрыта через 2 дня. Новые ответы больше не принимаются.