src/EventSubscriber/LocaleSubscriber.php line 23

Open in your IDE?
  1. <?php
  2. namespace App\EventSubscriber;
  3. use Psr\Log\LoggerInterface;
  4. use Symfony\Bridge\Monolog\Logger;
  5. use Symfony\Component\HttpKernel\KernelEvents;
  6. use Symfony\Component\HttpKernel\Event\RequestEvent;
  7. use Symfony\Component\EventDispatcher\EventSubscriberInterface;
  8. use Symfony\Contracts\EventDispatcher\Event;
  9. class LocaleSubscriber implements EventSubscriberInterface
  10. {
  11.     private $defaultLocale;
  12.     private $logger;
  13.     public function __construct(LoggerInterface $loggerstring $defaultLocale "en")
  14.     {
  15.         $this->defaultLocale $defaultLocale;
  16.         $this->logger $logger;
  17.     }
  18.     public function onKernelRequest(RequestEvent $event)
  19.     {
  20.         /*
  21.         *    NOTE : the $request->getLanguages() method assumes that languages are sorted by descending quality.
  22.         *    e.g : fr_FR, fr;q=0.5, en;q=0.8 will return the same result as fr_FR, fr;q=0.8, en;q=0.5 : 
  23.         *    ['fr_FR', 'fr', 'en'].
  24.         *    But it manages non iso 639 languages wich can be registered with the i prefix like i-cherokee.
  25.         */
  26.         $this->logger->info('=> BEGIN LocaleSubscriber::onKernelRequest');
  27.         $request $event->getRequest();
  28.         $server_accept_languages = ['fr''en'];
  29.         $client_accept_languages $request->getLanguages();
  30.         $default_language 'en';
  31.         $match false;
  32.         $language $default_language;
  33.         $this->logger->info('* client_accept_languages => ' json_encode($client_accept_languages));
  34.         
  35.         foreach($client_accept_languages as $client_language)
  36.         {
  37.             if(in_array($client_language$server_accept_languages))
  38.             {
  39.                 $this->logger->info('* client_selected_language => ' json_encode($client_language));
  40.                 $request->setLocale($client_language);
  41.                 $language $client_language;
  42.                 $match true;
  43.                 break;
  44.             }
  45.         }
  46.         $this->logger->info('=> END LocaleSubscriber::onKernelRequest');
  47.     }
  48.     public static function getSubscribedEvents()
  49.     {
  50.         return [
  51.             KernelEvents::REQUEST => [['onKernelRequest'20]],
  52.         ];
  53.     }
  54. }