From 8fa9e7cb09d7cd3247dbe321ed1547274b75be0d Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Jonathan=20Beli=C3=ABn?= Date: Mon, 11 Sep 2023 22:46:15 +0200 Subject: [PATCH] =?UTF-8?q?=F0=9F=90=9B=20Fix=20language=20redirection?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- config/services.yaml | 1 + src/EventSubscriber/LocaleSubscriber.php | 20 ++++++++++++++++---- 2 files changed, 17 insertions(+), 4 deletions(-) diff --git a/config/services.yaml b/config/services.yaml index a2c36599a..f3c93f4a4 100644 --- a/config/services.yaml +++ b/config/services.yaml @@ -31,6 +31,7 @@ services: App\EventSubscriber\LocaleSubscriber: arguments: $defaultLocale: "%kernel.default_locale%" + $locales: "%app.locales%" App\Service\RegionsProvider: arguments: $projectDirectory: "%kernel.project_dir%" diff --git a/src/EventSubscriber/LocaleSubscriber.php b/src/EventSubscriber/LocaleSubscriber.php index c50759294..b1bbed276 100644 --- a/src/EventSubscriber/LocaleSubscriber.php +++ b/src/EventSubscriber/LocaleSubscriber.php @@ -8,11 +8,18 @@ class LocaleSubscriber implements EventSubscriberInterface { - public function __construct(private readonly string $defaultLocale) - { + /** + * @param string[] $locales + * + * @return void + */ + public function __construct( + private readonly string $defaultLocale, + private readonly array $locales + ) { } - public function onKernelRequest(RequestEvent $event) + public function onKernelRequest(RequestEvent $event): void { $request = $event->getRequest(); @@ -36,7 +43,12 @@ public function onKernelRequest(RequestEvent $event) } elseif (\count($request->getLanguages()) > 0) { // if we still don't have a locale defined, use the browser languages $languages = $request->getLanguages(); - $request->setLocale($languages[0]); + foreach ($languages as $lang) { + if (\in_array($lang, $this->locales, true)) { + $request->setLocale($lang); + break; + } + } } else { // or use the default locale $request->setLocale($this->defaultLocale);