diff options
author | Jeremy Benoist <jeremy.benoist@gmail.com> | 2018-10-13 09:24:39 +0200 |
---|---|---|
committer | Jeremy Benoist <jeremy.benoist@gmail.com> | 2018-10-13 09:39:00 +0200 |
commit | 4d4147b228ac90f329fd2d40dd4fb60cb980328a (patch) | |
tree | bb18d67c8ec03bf8abd24dc6ef2138c3f81f6fa5 /src | |
parent | be417ef23685e17a239b1d192a0e9b9f484f1bfe (diff) | |
download | wallabag-4d4147b228ac90f329fd2d40dd4fb60cb980328a.tar.gz wallabag-4d4147b228ac90f329fd2d40dd4fb60cb980328a.tar.zst wallabag-4d4147b228ac90f329fd2d40dd4fb60cb980328a.zip |
Ensure language is valid
- Do not override locale if user has choosen a locale from the login screen.
- Add some tests about locale url
Diffstat (limited to 'src')
3 files changed, 13 insertions, 8 deletions
diff --git a/src/Wallabag/CoreBundle/Controller/ConfigController.php b/src/Wallabag/CoreBundle/Controller/ConfigController.php index 99576fbb..be6feb7c 100644 --- a/src/Wallabag/CoreBundle/Controller/ConfigController.php +++ b/src/Wallabag/CoreBundle/Controller/ConfigController.php | |||
@@ -8,6 +8,7 @@ use Symfony\Component\HttpFoundation\RedirectResponse; | |||
8 | use Symfony\Component\HttpFoundation\Request; | 8 | use Symfony\Component\HttpFoundation\Request; |
9 | use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; | 9 | use Symfony\Component\HttpKernel\Exception\AccessDeniedHttpException; |
10 | use Symfony\Component\Routing\Annotation\Route; | 10 | use Symfony\Component\Routing\Annotation\Route; |
11 | use Symfony\Component\Validator\Constraints\Locale as LocaleConstraint; | ||
11 | use Wallabag\CoreBundle\Entity\Config; | 12 | use Wallabag\CoreBundle\Entity\Config; |
12 | use Wallabag\CoreBundle\Entity\TaggingRule; | 13 | use Wallabag\CoreBundle\Entity\TaggingRule; |
13 | use Wallabag\CoreBundle\Form\Type\ChangePasswordType; | 14 | use Wallabag\CoreBundle\Form\Type\ChangePasswordType; |
@@ -341,11 +342,13 @@ class ConfigController extends Controller | |||
341 | */ | 342 | */ |
342 | public function setLocaleAction(Request $request, $language = null) | 343 | public function setLocaleAction(Request $request, $language = null) |
343 | { | 344 | { |
344 | if (null !== $language) { | 345 | $errors = $this->get('validator')->validate($language, (new LocaleConstraint())); |
345 | $this->get('session')->set('_locale', $language); | 346 | |
347 | if (0 === \count($errors)) { | ||
348 | $request->getSession()->set('_locale', $language); | ||
346 | } | 349 | } |
347 | 350 | ||
348 | return $this->redirect($request->headers->get('referer')); | 351 | return $this->redirect($request->headers->get('referer', $this->generateUrl('homepage'))); |
349 | } | 352 | } |
350 | 353 | ||
351 | /** | 354 | /** |
diff --git a/src/Wallabag/CoreBundle/Event/Listener/UserLocaleListener.php b/src/Wallabag/CoreBundle/Event/Listener/UserLocaleListener.php index 367cdfb0..dc1db5c7 100644 --- a/src/Wallabag/CoreBundle/Event/Listener/UserLocaleListener.php +++ b/src/Wallabag/CoreBundle/Event/Listener/UserLocaleListener.php | |||
@@ -6,8 +6,10 @@ use Symfony\Component\HttpFoundation\Session\Session; | |||
6 | use Symfony\Component\Security\Http\Event\InteractiveLoginEvent; | 6 | use Symfony\Component\Security\Http\Event\InteractiveLoginEvent; |
7 | 7 | ||
8 | /** | 8 | /** |
9 | * Stores the locale of the user in the session after the | 9 | * Stores the locale of the user in the session after the login. |
10 | * login. This can be used by the LocaleListener afterwards. | 10 | * If no locale are defined (if user doesn't change it from the login screen), override it with the user's config one. |
11 | * | ||
12 | * This can be used by the LocaleListener afterwards. | ||
11 | * | 13 | * |
12 | * @see http://symfony.com/doc/master/cookbook/session/locale_sticky_session.html | 14 | * @see http://symfony.com/doc/master/cookbook/session/locale_sticky_session.html |
13 | */ | 15 | */ |
@@ -30,7 +32,7 @@ class UserLocaleListener | |||
30 | { | 32 | { |
31 | $user = $event->getAuthenticationToken()->getUser(); | 33 | $user = $event->getAuthenticationToken()->getUser(); |
32 | 34 | ||
33 | if (null !== $user->getConfig()->getLanguage()) { | 35 | if (null !== $user->getConfig()->getLanguage() && null === $this->session->get('_locale')) { |
34 | $this->session->set('_locale', $user->getConfig()->getLanguage()); | 36 | $this->session->set('_locale', $user->getConfig()->getLanguage()); |
35 | } | 37 | } |
36 | } | 38 | } |
diff --git a/src/Wallabag/UserBundle/Resources/views/layout.html.twig b/src/Wallabag/UserBundle/Resources/views/layout.html.twig index 6934c686..b53f8746 100644 --- a/src/Wallabag/UserBundle/Resources/views/layout.html.twig +++ b/src/Wallabag/UserBundle/Resources/views/layout.html.twig | |||
@@ -16,8 +16,8 @@ | |||
16 | {% endblock fos_user_content %} | 16 | {% endblock fos_user_content %} |
17 | </div> | 17 | </div> |
18 | <div class="center"> | 18 | <div class="center"> |
19 | <a href="{{ path('changeLocale', {'language': 'de'}) }}">Deutsch</a> | 19 | <a href="{{ path('changeLocale', {'language': 'de'}) }}">Deutsch</a> – |
20 | <a href="{{ path('changeLocale', {'language': 'en'}) }}">English</a> | 20 | <a href="{{ path('changeLocale', {'language': 'en'}) }}">English</a> – |
21 | <a href="{{ path('changeLocale', {'language': 'fr'}) }}">Français</a> | 21 | <a href="{{ path('changeLocale', {'language': 'fr'}) }}">Français</a> |
22 | </div> | 22 | </div> |
23 | </div> | 23 | </div> |