for testing and deploying your application
for finding and fixing issues
for empowering human code reviews
<?php
/*
* This file is part of the Silverback API Components Bundle Project
*
* (c) Daniel West <[email protected]>
* For the full copyright and license information, please view the LICENSE
* file that was distributed with this source code.
*/
declare(strict_types=1);
namespace Silverback\ApiComponentsBundle\EventListener\Jwt;
use Lexik\Bundle\JWTAuthenticationBundle\Event\JWTExpiredEvent;
use Lexik\Bundle\JWTAuthenticationBundle\Event\JWTInvalidEvent;
use Lexik\Bundle\JWTAuthenticationBundle\Security\Http\Cookie\JWTCookieProvider;
use Silverback\ApiComponentsBundle\Mercure\MercureAuthorization;
use Symfony\Component\HttpFoundation\Response;
/**
* @author Daniel West <[email protected]>
class JWTClearTokenListener
{
public function __construct(
private readonly JWTCookieProvider $cookieProvider,
private readonly MercureAuthorization $mercureAuthorization
) {
}
public function onJwtInvalid(JWTInvalidEvent $event): void
$this->clearJwtCookie($event->getResponse());
public function onJwtExpired(JWTExpiredEvent $event): void
private function clearJwtCookie(Response $response): void
$response->headers->setCookie($this->cookieProvider->createCookie('x.x.x', null, 1));
$response->headers->setCookie($this->mercureAuthorization->getClearAuthorizationCookie());