Passed
Push — master ( ab2165...ca8ef1 )
by Jan
03:01
created

SymfonyDebugToolbarSubscriber   A

Complexity

Total Complexity 4

Size/Duplication

Total Lines 42
Duplicated Lines 0 %

Importance

Changes 0
Metric Value
eloc 8
dl 0
loc 42
rs 10
c 0
b 0
f 0
wmc 4

3 Methods

Rating   Name   Duplication   Size   Complexity  
A getSubscribedEvents() 0 3 1
A onKernelResponse() 0 8 2
A __construct() 0 3 1
1
<?php
2
/**
3
 *
4
 * part-db version 0.1
5
 * Copyright (C) 2005 Christoph Lechner
6
 * http://www.cl-projects.de/
7
 *
8
 * part-db version 0.2+
9
 * Copyright (C) 2009 K. Jacobs and others (see authors.php)
10
 * http://code.google.com/p/part-db/
11
 *
12
 * Part-DB Version 0.4+
13
 * Copyright (C) 2016 - 2019 Jan Böhmer
14
 * https://github.com/jbtronics
15
 *
16
 * This program is free software; you can redistribute it and/or
17
 * modify it under the terms of the GNU General Public License
18
 * as published by the Free Software Foundation; either version 2
19
 * of the License, or (at your option) any later version.
20
 *
21
 * This program is distributed in the hope that it will be useful,
22
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
23
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
24
 * GNU General Public License for more details.
25
 *
26
 * You should have received a copy of the GNU General Public License
27
 * along with this program; if not, write to the Free Software
28
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA
29
 *
30
 */
31
32
namespace App\EventSubscriber;
33
34
use Symfony\Component\DependencyInjection\ContainerInterface;
35
use Symfony\Component\EventDispatcher\EventSubscriberInterface;
36
use Symfony\Component\EventDispatcher\Tests\Debug\EventSubscriber;
37
use Symfony\Component\HttpKernel\Event\FilterResponseEvent;
38
39
class SymfonyDebugToolbarSubscriber implements EventSubscriberInterface
40
{
41
42
    protected $kernel;
43
44
    public function __construct(ContainerInterface $kernel)
45
    {
46
        $this->kernel = $kernel;
47
    }
48
49
    /**
50
     * Returns an array of event names this subscriber wants to listen to.
51
     *
52
     * The array keys are event names and the value can be:
53
     *
54
     *  * The method name to call (priority defaults to 0)
55
     *  * An array composed of the method name to call and the priority
56
     *  * An array of arrays composed of the method names to call and respective
57
     *    priorities, or 0 if unset
58
     *
59
     * For instance:
60
     *
61
     *  * ['eventName' => 'methodName']
62
     *  * ['eventName' => ['methodName', $priority]]
63
     *  * ['eventName' => [['methodName1', $priority], ['methodName2']]]
64
     *
65
     * @return array The event names to listen to
66
     */
67
    public static function getSubscribedEvents()
68
    {
69
        return ['kernel.response' => 'onKernelResponse'];
70
    }
71
72
73
    public function onKernelResponse(FilterResponseEvent $event)
74
    {
75
        if (!$this->kernel->getParameter('kernel.debug')) {
76
            return;
77
        }
78
79
        $response = $event->getResponse();
80
        $response->headers->set('Symfony-Debug-Toolbar-Replace', 1);
81
    }
82
83
}