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

JWTClearTokenListener   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 23
Duplicated Lines 0 %

Test Coverage

Coverage 0%

Importance

Changes 0
Metric Value
eloc 6
dl 0
loc 23
ccs 0
cts 8
cp 0
rs 10
c 0
b 0
f 0
wmc 4

4 Methods

Rating   Name   Duplication   Size   Complexity  
A onJwtExpired() 0 3 1
A onJwtInvalid() 0 3 1
A clearJwtCookie() 0 3 1
A __construct() 0 4 1
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