src/Security/UserAuthenticator.php line 53

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace App\Security;
  4. use Symfony\Component\HttpFoundation\Request;
  5. use Symfony\Component\HttpFoundation\Response;
  6. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  7. use Symfony\Component\Security\Core\Exception\AuthenticationException;
  8. use Symfony\Component\Security\Http\Authenticator\AbstractAuthenticator;
  9. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  10. use Symfony\Component\Security\Http\Authenticator\Passport\Passport;
  11. use Symfony\Component\Security\Http\Authenticator\Passport\SelfValidatingPassport;
  12. class UserAuthenticator extends AbstractAuthenticator
  13. {
  14.     public function __construct(private UserProvider $userProvider)
  15.     {
  16.     }
  17.     public function supports(Request $request): bool
  18.     {
  19.         return true;
  20.     }
  21.     public function onAuthenticationFailure(Request $requestAuthenticationException $exception): ?Response
  22.     {
  23.         return null;
  24.     }
  25.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  26.     {
  27.         return null;
  28.     }
  29.     public function getCredentials(Request $request): array
  30.     {
  31.         return [
  32.             'id' => $request->headers?->get('User-Id'),
  33.         ];
  34.     }
  35.     public function authenticate(Request $request): Passport
  36.     {
  37.         if (!(
  38.             ($userId $this->getCredentials($request)['id'])
  39.             && ($user $this->userProvider->loadUserByIdentifier($userId))
  40.         )) {
  41.             $user $this->userProvider->makeUser();
  42.         }
  43.         return new SelfValidatingPassport(new UserBadge($user->getUserIdentifier(), fn () => $user));
  44.     }
  45.     public function supportsRememberMe(): bool
  46.     {
  47.         return false;
  48.     }
  49. }