- Do not override locale if user has choosen a locale from the login screen.
- Add some tests about locale url
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException;
use Symfony\Component\Routing\Annotation\Route;
+use Symfony\Component\Validator\Constraints\Locale as LocaleConstraint;
use Wallabag\CoreBundle\Entity\Config;
use Wallabag\CoreBundle\Entity\TaggingRule;
use Wallabag\CoreBundle\Form\Type\ChangePasswordType;
*/
public function setLocaleAction(Request $request, $language = null)
{
- if (null !== $language) {
- $this->get('session')->set('_locale', $language);
+ $errors = $this->get('validator')->validate($language, (new LocaleConstraint()));
+
+ if (0 === \count($errors)) {
+ $request->getSession()->set('_locale', $language);
}
- return $this->redirect($request->headers->get('referer'));
+ return $this->redirect($request->headers->get('referer', $this->generateUrl('homepage')));
}
/**
use Symfony\Component\Security\Http\Event\InteractiveLoginEvent;
/**
- * Stores the locale of the user in the session after the
- * login. This can be used by the LocaleListener afterwards.
+ * Stores the locale of the user in the session after the login.
+ * If no locale are defined (if user doesn't change it from the login screen), override it with the user's config one.
+ *
+ * This can be used by the LocaleListener afterwards.
*
* @see http://symfony.com/doc/master/cookbook/session/locale_sticky_session.html
*/
{
$user = $event->getAuthenticationToken()->getUser();
- if (null !== $user->getConfig()->getLanguage()) {
+ if (null !== $user->getConfig()->getLanguage() && null === $this->session->get('_locale')) {
$this->session->set('_locale', $user->getConfig()->getLanguage());
}
}
{% endblock fos_user_content %}
</div>
<div class="center">
- <a href="{{ path('changeLocale', {'language': 'de'}) }}">Deutsch</a>
- <a href="{{ path('changeLocale', {'language': 'en'}) }}">English</a>
+ <a href="{{ path('changeLocale', {'language': 'de'}) }}">Deutsch</a> –
+ <a href="{{ path('changeLocale', {'language': 'en'}) }}">English</a> –
<a href="{{ path('changeLocale', {'language': 'fr'}) }}">Français</a>
</div>
</div>
$client->request('GET', '/config/view-mode');
}
+
+ public function testChangeLocaleWithoutReferer()
+ {
+ $client = $this->getClient();
+
+ $client->request('GET', '/locale/de');
+ $client->followRedirect();
+
+ $this->assertSame('de', $client->getRequest()->getLocale());
+ $this->assertSame('de', $client->getContainer()->get('session')->get('_locale'));
+ }
+
+ public function testChangeLocaleWithReferer()
+ {
+ $client = $this->getClient();
+
+ $client->request('GET', '/login');
+ $client->request('GET', '/locale/de');
+ $client->followRedirect();
+
+ $this->assertSame('de', $client->getRequest()->getLocale());
+ $this->assertSame('de', $client->getContainer()->get('session')->get('_locale'));
+ }
+
+ public function testChangeLocaleToBadLocale()
+ {
+ $client = $this->getClient();
+
+ $client->request('GET', '/login');
+ $client->request('GET', '/locale/yuyuyuyu');
+ $client->followRedirect();
+
+ $this->assertNotSame('yuyuyuyu', $client->getRequest()->getLocale());
+ $this->assertNotSame('yuyuyuyu', $client->getContainer()->get('session')->get('_locale'));
+ }
}
$this->assertNull($session->get('_locale'));
}
+
+ public function testWithLanguageFromSession()
+ {
+ $session = new Session(new MockArraySessionStorage());
+ $listener = new UserLocaleListener($session);
+ $session->set('_locale', 'de');
+
+ $user = new User();
+ $user->setEnabled(true);
+
+ $config = new Config($user);
+ $config->setLanguage('fr');
+
+ $user->setConfig($config);
+
+ $userToken = new UsernamePasswordToken($user, '', 'test');
+ $request = Request::create('/');
+ $event = new InteractiveLoginEvent($request, $userToken);
+
+ $listener->onInteractiveLogin($event);
+
+ $this->assertSame('de', $session->get('_locale'));
+ }
}
use Symfony\Component\EventDispatcher\EventDispatcher;
use Symfony\Component\HttpFoundation\Request;
use Symfony\Component\HttpFoundation\Response;
+use Symfony\Component\HttpFoundation\Session\Session;
+use Symfony\Component\HttpFoundation\Session\Storage\MockArraySessionStorage;
use Wallabag\CoreBundle\Entity\Config;
use Wallabag\UserBundle\Entity\User;
use Wallabag\UserBundle\EventListener\CreateConfigListener;
protected function setUp()
{
+ $session = new Session(new MockArraySessionStorage());
$this->em = $this->getMockBuilder('Doctrine\ORM\EntityManager')
->disableOriginalConstructor()
->getMock();
'fr',
1,
1,
- 1
+ 1,
+ $session
);
$this->dispatcher = new EventDispatcher();