AbstractEventListener::getOptions()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 0
Metric Value
dl 0
loc 4
ccs 2
cts 2
cp 1
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 0
crap 1
1
<?php
2
3
/**
4
 * Copyright 2014 Fabian Grutschus. All rights reserved.
5
 *
6
 * Redistribution and use in source and binary forms, with or without modification,
7
 * are permitted provided that the following conditions are met:
8
 *
9
 * 1. Redistributions of source code must retain the above copyright notice, this
10
 *   list of conditions and the following disclaimer.
11
 *
12
 * 2. Redistributions in binary form must reproduce the above copyright notice,
13
 *   this list of conditions and the following disclaimer in the documentation
14
 *   and/or other materials provided with the distribution.
15
 *
16
 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND
17
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
18
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
19
 * DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR
20
 * ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
21
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
22
 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
23
 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
24
 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
25
 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
26
 *
27
 * The views and conclusions contained in the software and documentation are those
28
 * of the authors and should not be interpreted as representing official policies,
29
 * either expressed or implied, of the copyright holders.
30
 *
31
 * @author    Fabian Grutschus <[email protected]>
32
 * @copyright 2014 Fabian Grutschus. All rights reserved.
33
 * @license   BSD
34
 * @link      http://github.com/fabiang/xmpp
35
 */
36
37
namespace Fabiang\Xmpp\EventListener;
38
39
use Fabiang\Xmpp\Connection\ConnectionInterface;
40
use Fabiang\Xmpp\Event\EventManagerInterface;
41
use Fabiang\Xmpp\Event\EventManager;
42
use Fabiang\Xmpp\Options;
43
44
/**
45
 * Abstract implementaion of event listener
46
 *
47
 * @package Xmpp\EventListener
48
 */
49
abstract class AbstractEventListener implements EventListenerInterface
50
{
51
    /**
52
     * Options.
53
     *
54
     * @var Options
55
     */
56
    protected $options;
57
58
    /**
59
     * Eventmanager.
60
     *
61
     * @var EventManagerInterface
62
     */
63
    protected $eventManager;
64
65
    /**
66
     * Get connection.
67
     *
68
     * @return ConnectionInterface
69
     */
70 3
    protected function getConnection()
71
    {
72 3
        return $this->getOptions()->getConnection();
73
    }
74
75
    /**
76
     * Get event manager for XML input.
77
     *
78
     * @return EventManager
79
     */
80 3
    protected function getInputEventManager()
81
    {
82 3
        return $this->getConnection()->getInputStream()->getEventManager();
83
    }
84
85
    /**
86
     * Get event manager for XML output.
87
     *
88
     * @return EventManager
89
     */
90 3
    protected function getOutputEventManager()
91
    {
92 3
        return $this->getConnection()->getOutputStream()->getEventManager();
93
    }
94
95
    /**
96
     * {@inheritDoc}
97
     */
98 3
    public function getEventManager()
99
    {
100 3
        if (null === $this->eventManager) {
101 3
            $this->setEventManager(new EventManager());
102 3
        }
103
104 3
        return $this->eventManager;
105
    }
106
107
    /**
108
     * {@inheritDoc}
109
     */
110 3
    public function setEventManager(EventManagerInterface $eventManager)
111
    {
112 3
        $this->eventManager = $eventManager;
113 3
        return $this;
114
    }
115
116
    /**
117
     * {@inheritDoc}
118
     */
119 3
    public function getOptions()
120
    {
121 3
        return $this->options;
122
    }
123
124
    /**
125
     * {@inheritDoc}
126
     */
127 3
    public function setOptions(Options $options)
128
    {
129 3
        $this->options = $options;
130 3
        return $this;
131
    }
132
}
133