Passed
Pull Request — master (#4)
by Adrien
03:59
created

RenderSubscriber   A

Complexity

Total Complexity 7

Size/Duplication

Total Lines 57
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 3

Test Coverage

Coverage 100%

Importance

Changes 4
Bugs 1 Features 1
Metric Value
wmc 7
c 4
b 1
f 1
lcom 1
cbo 3
dl 0
loc 57
ccs 17
cts 17
cp 1
rs 10

4 Methods

Rating   Name   Duplication   Size   Complexity  
A __construct() 0 4 1
A getSubscribedEvents() 0 7 1
A updateTwigLexer() 0 7 4
A rollbackTwigLexer() 0 5 1
1
<?php
2
3
namespace Chris\Bundle\FrontRenderBundle\Subscriber;
4
5
use Chris\Bundle\FrontRenderBundle\Twig\LexerManager;
6
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
7
use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
8
use Symfony\Component\HttpKernel\Event\GetResponseEvent;
9
use Symfony\Component\HttpKernel\KernelEvents;
10
11
class RenderSubscriber implements EventSubscriberInterface
12
{
13
    /**
14
     * @var LexerManager
15
     */
16
    protected $twigLexerManager;
17
18
    /**
19
     * @var bool
20
     */
21
    protected $stopPropagation = false;
22
23
    /**
24
     * RenderSubscriber constructor.
25
     *
26
     * @param LexerManager $twigLexerManager
27
     */
28 11
    public function __construct(LexerManager $twigLexerManager)
29
    {
30 11
        $this->twigLexerManager = $twigLexerManager;
31 11
    }
32
33
    /**
34
     * {@inheritdoc}
35
     */
36 1
    public static function getSubscribedEvents()
37
    {
38
        return [
39 1
            KernelEvents::REQUEST   => ['updateTwigLexer'],
40 1
            KernelEvents::RESPONSE  => ['rollbackTwigLexer'],
41 1
        ];
42
    }
43
44
    /**
45
     * Set the custom twig lexer to display custom tags on the front
46
     *
47
     * @param GetResponseEvent $event
48
     */
49 2
    public function updateTwigLexer(GetResponseEvent $event)
50
    {
51 2
        if (false === $this->stopPropagation && $event->isMasterRequest() && !$event->getRequest()->isXmlHttpRequest()) {
52 1
            $this->twigLexerManager->updateLexer();
53 1
            $this->stopPropagation = true;
54 1
        }
55 2
    }
56
57
    /**
58
     * Set the custom twig lexer to display custom tags on the front
59
     *
60
     * @param FilterResponseEvent $event
61
     */
62 1
    public function rollbackTwigLexer(FilterResponseEvent $event)
0 ignored issues
show
Unused Code introduced by
The parameter $event is not used and could be removed.

This check looks from parameters that have been defined for a function or method, but which are not used in the method body.

Loading history...
63
    {
64 1
        $this->twigLexerManager->rollbackLexer();
65 1
        $this->stopPropagation = true;
66 1
    }
67
}
68