Symfony 2 & FosuserBundle: аутентифицировать пользователя после сброса пароля
-
13-12-2019 - |
Вопрос
При переопределении пароля пароля FosuserBundle Reet, есть функциональный вызов для «AuthentiTicuser» метода (строка 104):
....
$this->authenticateUser($user);
....
.
Моя проблема в том, что я уже переопределяю обработчик аутентификации Symfony и имею свою собственную логику, когда пользователь входит в систему.
<?php
/* ... all includes ... */
class AuthenticationHandler implements AuthenticationSuccessHandlerInterface, LogoutSuccessHandlerInterface
{
private $router;
private $container;
public function __construct(Router $router, ContainerInterface $container)
{
$this->router = $router;
$this->container = $container;
}
public function onAuthenticationSuccess(Request $request, TokenInterface $token)
{
// retrieve user and session id
$user = $token->getUser();
/* ... here I do things in database when logging in, and dont want to write it again and again ... */
// prepare redirection URL
if($targetPath = $request->getSession()->get('_security.target_path')) {
$url = $targetPath;
}
else {
$url = $this->router->generate('my_route');
}
return new RedirectResponse($url);
}
}
.
Итак, как я мог бы назвать метод «OnauthenticationsucessCess» из моего обработчика аутентификации в ResettingController? Чтобы не переписать тот же код ...
Спасибо за вашу помощь!
Aurel
Решение
Вы должны позвонить вашему методу Onauthenticationscess, загружая его как услугу.В вашем config.yml:
authentication_handler:
class: Acme\Bundle\Service\AuthenticationHandler
arguments:
container: "@service_container"
.
, а затем позвоните в функцию аутентитивно-пропускателя:
protected function authenticateUser(UserInterface $user) {
try {
$this->container->get('fos_user.user_checker')->checkPostAuth($user);
} catch (AccountStatusException $e) {
// Don't authenticate locked, disabled or expired users
return;
}
$providerKey = $this->container->getParameter('fos_user.firewall_name');
$token = new UsernamePasswordToken($user, null, $providerKey, $user->getRoles());
$this->container->get('security.context')->setToken($token);
$request = $this->container->get('request');
$this->container->get('authentication_handler')->onAuthenticationSuccess($request, $token);
}
.
Это делает трюк и пройти через ваш пользовательский обработчик Auth. Дополнительная информация .