Completed
Push — master ( 332a47...cbc99e )
by WEBEWEB
03:08
created

setKernelEventListener()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 3

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 4
rs 10
c 0
b 0
f 0
cc 1
eloc 3
nc 1
nop 1
1
<?php
2
3
/**
4
 * This file is part of the bootstrap-bundle package.
5
 *
6
 * (c) 2018 WEBEWEB
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
namespace WBW\Bundle\BootstrapBundle\EventListener;
13
14
use WBW\Bundle\BootstrapBundle\Event\NotificationEvent;
15
16
/**
17
 * Notification event listener.
18
 *
19
 * @author webeweb <https://github.com/webeweb/>
20
 * @package WBW\Bundle\BootstrapBundle\EventListener
21
 */
22
class NotificationEventListener {
23
24
    /**
25
     * Service name.
26
     *
27
     * @var string
28
     */
29
    const SERVICE_NAME = "webeweb.bundle.bootstrapbundle.eventlistener.notification";
30
31
    /**
32
     * Kernel event listener.
33
     *
34
     * @var KernelEventListener
35
     */
36
    private $kernelEventListener;
37
38
    /**
39
     * Constructor.
40
     *
41
     * @param KernelEventListener $kernelEventListener The kernel event listener.
42
     */
43
    public function __construct(KernelEventListener $kernelEventListener) {
44
        $this->setKernelEventListener($kernelEventListener);
45
    }
46
47
    /**
48
     * Get the kernel event listener.
49
     *
50
     * @return KernelEventListener Returns the kernel event listener.
51
     */
52
    public function getKernelEventListener() {
53
        return $this->kernelEventListener;
54
    }
55
56
    /**
57
     * On notify.
58
     *
59
     * @param NotificationEvent $event The notification event.
60
     * @return void
61
     */
62
    public function onNotify(NotificationEvent $event) {
63
        $this->getKernelEventListener()->getRequest()->getSession()->getFlashBag()->add($event->getType(), $event->getNotification());
64
    }
65
66
    /**
67
     * Set the kernel event listener.
68
     *
69
     * @param KernelEventListener $kernelEventListener The kernel event listener.
70
     * @return NotificationEventListener Returns this notification event listener.
71
     */
72
    protected function setKernelEventListener(KernelEventListener $kernelEventListener) {
73
        $this->kernelEventListener = $kernelEventListener;
74
        return $this;
75
    }
76
77
}
78