src/Security/SlivkiMobileAuthenticator.php line 45

Open in your IDE?
  1. <?php
  2. declare(strict_types=1);
  3. namespace Slivki\Security;
  4. use Slivki\Entity\User;
  5. use Slivki\Exception\User\InvalidUserTokenException;
  6. use Slivki\Repository\User\UserRepositoryInterface;
  7. use Symfony\Component\HttpFoundation\Request;
  8. use Symfony\Component\HttpFoundation\Response;
  9. use Symfony\Component\Security\Core\Authentication\Token\TokenInterface;
  10. use Symfony\Component\Security\Core\Exception\AuthenticationException;
  11. use Symfony\Component\Security\Http\Authenticator\AbstractAuthenticator;
  12. use Symfony\Component\Security\Http\Authenticator\Passport\Badge\UserBadge;
  13. use Symfony\Component\Security\Http\Authenticator\Passport\PassportInterface;
  14. use Symfony\Component\Security\Http\Authenticator\Passport\SelfValidatingPassport;
  15. final class SlivkiMobileAuthenticator extends AbstractAuthenticator
  16. {
  17.     public const HTTP_HEADERS_USER_TOKEN 'HTTP-SLIVKi-USER-TOKEN';
  18.     private UserRepositoryInterface $userRepository;
  19.     public function __construct(UserRepositoryInterface $userRepository)
  20.     {
  21.         $this->userRepository $userRepository;
  22.     }
  23.     public function supports(Request $request): ?bool
  24.     {
  25.         return $request->headers->has(self::HTTP_HEADERS_USER_TOKEN)
  26.             && !$request->headers->has(SlivkiInternalAuthenticator::HTTP_HEADERS_USER_TOKEN);
  27.     }
  28.     public function authenticate(Request $request): PassportInterface
  29.     {
  30.         $userToken $request->headers->get(self::HTTP_HEADERS_USER_TOKEN);
  31.         if (null === $userToken) {
  32.             throw new InvalidUserTokenException();
  33.         }
  34.         return new SelfValidatingPassport(
  35.             new UserBadge((string) $userToken, fn (): ?User => $this->userRepository->findByMobileToken((string) $userToken)),
  36.         );
  37.     }
  38.     public function onAuthenticationSuccess(Request $requestTokenInterface $tokenstring $firewallName): ?Response
  39.     {
  40.         return null;
  41.     }
  42.     public function onAuthenticationFailure(Request $requestAuthenticationException $exception): ?Response
  43.     {
  44.         return null;
  45.     }
  46. }