Passed
Push — main ( c0ff50...6ab7a3 )
by Daniel
05:37
created

JWTClearTokenListener::onJwtExpired()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
cc 1
eloc 1
nc 1
nop 1
dl 0
loc 3
ccs 0
cts 2
cp 0
crap 2
rs 10
c 0
b 0
f 0
1
<?php
2
3
/*
4
 * This file is part of the Silverback API Components Bundle Project
5
 *
6
 * (c) Daniel West <[email protected]>
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
declare(strict_types=1);
13
14
namespace Silverback\ApiComponentsBundle\EventListener\Jwt;
15
16
use Lexik\Bundle\JWTAuthenticationBundle\Event\JWTExpiredEvent;
17
use Lexik\Bundle\JWTAuthenticationBundle\Event\JWTInvalidEvent;
18
use Lexik\Bundle\JWTAuthenticationBundle\Security\Http\Cookie\JWTCookieProvider;
19
use Symfony\Component\HttpFoundation\Response;
20
21
/**
22
 * @author Daniel West <[email protected]>
23
 */
24
class JWTClearTokenListener
25
{
26
    private JWTCookieProvider $cookieProvider;
27
28
    public function __construct(
29
        JWTCookieProvider $cookieProvider
30
    ) {
31
        $this->cookieProvider = $cookieProvider;
32
    }
33
34
    public function onJwtInvalid(JWTInvalidEvent $event): void
35
    {
36
        $this->clearJwtCookie($event->getResponse());
37
    }
38
39
    public function onJwtExpired(JWTExpiredEvent $event): void
40
    {
41
        $this->clearJwtCookie($event->getResponse());
42
    }
43
44
    private function clearJwtCookie(Response $response): void
45
    {
46
        $response->headers->setCookie($this->cookieProvider->createCookie('x.x.x', null, 1));
47
    }
48
}
49