From 426b4e740119f569dd018f42f1661b94512e3ebd Mon Sep 17 00:00:00 2001 From: Dean Wunder Date: Sun, 19 Nov 2023 02:48:57 +1100 Subject: [PATCH] Add functionality to avoid infinite loops when the handle missing translation callback itself tries to translation a missing translation. --- src/Illuminate/Translation/Translator.php | 28 +++++++++++++++++++---- 1 file changed, 23 insertions(+), 5 deletions(-) diff --git a/src/Illuminate/Translation/Translator.php b/src/Illuminate/Translation/Translator.php index 2798b51ce481..86d7cc90f996 100755 --- a/src/Illuminate/Translation/Translator.php +++ b/src/Illuminate/Translation/Translator.php @@ -65,6 +65,13 @@ class Translator extends NamespacedItemResolver implements TranslatorContract */ protected $stringableHandlers = []; + /** + * Whether missing translation keys should be handled. + * + * @var bool + */ + protected $handleMissingTranslationKeys = true; + /** * The callback that is responsible for handling missing translation keys. * @@ -183,12 +190,23 @@ public function get($key, array $replace = [], $locale = null, $fallback = true) */ protected function handleMissingTranslationKey($key, $replace, $locale, $fallback) { - // Call user defined missing translation handler callback if set. - if (isset(static::$missingTranslationKeyCallback)) { - return call_user_func(static::$missingTranslationKeyCallback, - $key, $replace, $locale, $fallback - ); + // Avoid infinite loops: don't handle any missing translations which are in + // the user defined callback. + if (!$this->handleMissingTranslationKeys) { + return $key; } + + // Return the key unchanged if there is no user defined callback set. + if (!isset(static::$missingTranslationKeyCallback)) { + return $key; + } + + // Call user defined missing translation handler callback, prevent infitite loops. + $this->handleMissingTranslationKeys = false; + $key = call_user_func(static::$missingTranslationKeyCallback, + $key, $replace, $locale, $fallback + ); + $this->handleMissingTranslationKeys = true; return $key; }