Completed
Pull Request — master (#4)
by Adrien
02:09
created

RenderSubscriber::updateTwigLexer()   A

Complexity

Conditions 4
Paths 2

Size

Total Lines 7
Code Lines 4

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 7
rs 9.2
cc 4
eloc 4
nc 2
nop 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\Event\GetResponseForExceptionEvent;
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
    public function __construct(LexerManager $twigLexerManager)
29
    {
30
        $this->twigLexerManager = $twigLexerManager;
31
    }
32
33
    /**
34
     * {@inheritdoc}
35
     */
36
    public static function getSubscribedEvents()
37
    {
38
        return [
39
            'kernel.request'   => ['updateTwigLexer'],
40
            'kernel.response'  => ['rollbackTwigLexer'],
41
            'kernel.exception' => ['onKernelException'],
42
        ];
43
    }
44
45
    /**
46
     * Set the custom twig lexer to display custom tags on the front
47
     *
48
     * @param GetResponseEvent $event
49
     */
50
    public function updateTwigLexer(GetResponseEvent $event)
51
    {
52
        if (false === $this->stopPropagation && $event->isMasterRequest() && !$event->getRequest()->isXmlHttpRequest()) {
53
            $this->twigLexerManager->updateLexer();
54
            $this->stopPropagation = true;
55
        }
56
    }
57
58
    /**
59
     * Set the custom twig lexer to display custom tags on the front
60
     *
61
     * @param FilterResponseEvent $event
62
     */
63
    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...
64
    {
65
        $this->twigLexerManager->rollbackLexer();
66
        $this->stopPropagation = true;
67
    }
68
69
    /**
70
     * Set the default twig lexer to display default tags on exceptions
71
     *
72
     * @param GetResponseForExceptionEvent $event
73
     */
74
    public function onKernelException(GetResponseForExceptionEvent $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...
75
    {
76
        $this->twigLexerManager->rollbackLexer();
77
        $this->stopPropagation = true;
78
    }
79
}
80