Symfony 2 & FosuserBundle: аутентифицировать пользователя после сброса пароля

StackOverflow https://stackoverflow.com//questions/10701949

Вопрос

При переопределении пароля пароля FosuserBundle Reet, есть функциональный вызов для «AuthentiTicuser» метода (строка 104):

https://github.com/friendsofsymfony/fosuserbundle/Blob / Master / Controller / ResettingController.php # L104

....
$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. Дополнительная информация .

Лицензировано под: CC-BY-SA с атрибуция
Не связан с StackOverflow
scroll top