Как в Symfony получить пользователя в EventSubscriber с помощью LexicJWT - PullRequest
0 голосов
/ 14 декабря 2018

Я новичок в Symfony.Я использую токен LexicJWT.

final class ProductCreateSubscriber implements EventSubscriberInterface
{
    private $entityManager;
    private $hostRepository;

    public function __construct(EntityManagerInterface $entityManager, HostRepository $hostRepository)
    {
        $this->entityManager = $entityManager;
        $this->hostRepository = $hostRepository;
    }

    public static function getSubscribedEvents()
    {
        return [
            KernelEvents::VIEW => ['createHost', EventPriorities::PRE_WRITE],
        ];
    }

    public function createHost(GetResponseForControllerResultEvent $event)
    {
        $product = $event->getControllerResult();
        $method = $event->getRequest()->getMethod();

        - - - - - -- - - I NEED USER HERE - - - - -  - -    

        if (!$product instanceof Product || Request::METHOD_POST !== $method) {
            return;
        } 

        $parsedUrl = parse_url($product->getUrl());
        if (isset($parsedUrl['host'])) {
            $host = $this->hostRepository->findOneByName($parsedUrl['host']);
            if (!$host) {
                $host = $this->hostRepository->createByName($parsedUrl['host']);
            }
            $product->setHost($host);
        }
    }
}

Как получить пользователя в методе createHost?Как я могу получить пользователя или токен в EventSubsriber?Не можете найти информацию об этом?Где я могу прочитать об этом?

1 Ответ

0 голосов
/ 14 декабря 2018

токен JWT пропускается через заголовок, поэтому вам нужно получить доступ к заголовку в событии.

Вы можете попытаться получить доступ к заголовку следующим образом:

$request = $event->getRequest();
$headers = $request->headers->all();

Из заголовка вы можете получитьзаголовок аутентификации, внутри которого находится токен JWT, и декодирование его для получения пользователя.

ОБНОВЛЕНИЕ: Как упомянул @Jared Farrish, убедитесь, что токен действителен!

...