src/Security/AdminLoginFormAuthenticator.php line 20

Open in your IDE?
  1. <?php
  2. namespace App\Security;
  3. use Symfony\Component\HttpFoundation\Request;
  4. use Symfony\Component\HttpFoundation\Response;
  5. use Symfony\Component\HttpFoundation\RedirectResponse;
  6. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  7. use Symfony\Component\Security\Http\Authenticator\AbstractLoginFormAuthenticator;
  8. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  9. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\CsrfTokenBadge;
  10. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  11. use Symfony\Component\Security\Core\Exception\CustomUserMessageAuthenticationException;
  12. use Symfony\Component\Security\Core\Exception\AuthenticationException;
  13. use Symfony\Component\Security\Http\Authenticator\Passport\Credentials\PasswordCredentials;
  14. use Symfony\Component\Routing\RouterInterface;
  15. use Doctrine\ORM\EntityManagerInterface;
  16. use App\Entity\Admin;
  17. class AdminLoginFormAuthenticator extends AbstractLoginFormAuthenticator
  18. {
  19.     public function __construct(
  20.         protected EntityManagerInterface $entityManager,
  21.         protected RouterInterface $router,
  22.     ) {}
  23.     /**
  24.      * Called on every request to decide if this authenticator should be
  25.      * used for the request. Returning `false` will cause this authenticator
  26.      * to be skipped.
  27.      */
  28.     public function supports(Request $request): bool
  29.     {        
  30.         return 'admin.login' === $request->attributes->get('_route') && $request->isMethod('POST');
  31.     }
  32.     /**
  33.      * Return the URL to the login page.
  34.      */
  35.     protected function getLoginUrl(Request $request): string
  36.     {
  37.         return $this->router->generate('admin.login');
  38.     }
  39.     public function authenticate(Request $request): Passport
  40.     {
  41.         $password $request->request->get('password');
  42.         $username $request->request->get('username');
  43.         $csrfToken $request->request->get('csrf_token');
  44.         return new Passport(
  45.             new UserBadge($username),
  46.             new PasswordCredentials($password),
  47.             [new CsrfTokenBadge('authenticate'$csrfToken), ]
  48.         ); 
  49.     }
  50.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  51.     {
  52.         // on success, let the request continue
  53.         //设置session 店铺 TODO
  54.         return new RedirectResponse($this->router->generate('admin_auth.admin'));
  55.     }
  56. }