Stream   A
last analyzed

Complexity

Total Complexity 8

Size/Duplication

Total Lines 72
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 4

Test Coverage

Coverage 92.31%

Importance

Changes 0
Metric Value
wmc 8
lcom 1
cbo 4
dl 0
loc 72
ccs 24
cts 26
cp 0.9231
rs 10
c 0
b 0
f 0

5 Methods

Rating   Name   Duplication   Size   Complexity  
A attachEvents() 0 9 1
A streamStart() 0 6 2
A streamServer() 0 10 3
A features() 0 5 1
A isBlocking() 0 4 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\Stream;
38
39
use Fabiang\Xmpp\Event\XMLEvent;
40
use Fabiang\Xmpp\EventListener\AbstractEventListener;
41
use Fabiang\Xmpp\EventListener\BlockingEventListenerInterface;
42
43
/**
44
 * Listener
45
 *
46
 * @package Xmpp\EventListener
47
 */
48
class Stream extends AbstractEventListener implements BlockingEventListenerInterface
49
{
50
51
    /**
52
     * Listener blocks stream.
53
     *
54
     * @var boolean
55
     */
56
    protected $blocking = false;
57
58
    /**
59
     * {@inheritDoc}
60
     */
61 3
    public function attachEvents()
62
    {
63 3
        $this->getOutputEventManager()
64 3
            ->attach('{http://etherx.jabber.org/streams}stream', [$this, 'streamStart']);
65
66 3
        $input = $this->getInputEventManager();
67 3
        $input->attach('{http://etherx.jabber.org/streams}stream', [$this, 'streamServer']);
68 3
        $input->attach('{http://etherx.jabber.org/streams}features', [$this, 'features']);
69 3
    }
70
71
    /**
72
     * Stream starts.
73
     *
74
     * @param XMLEvent $event XMLEvent
75
     * @return void
76
     */
77 3
    public function streamStart(XMLEvent $event)
78
    {
79 3
        if (true === $event->isStartTag()) {
80 3
            $this->blocking = true;
81 3
        }
82 3
    }
83
84
    /**
85
     * Stream server.
86
     *
87
     * @param XMLEvent $event XMLEvent
88
     * @return void
89
     */
90 3
    public function streamServer(XMLEvent $event)
91
    {
92 3
        if (false === $event->isStartTag()) {
93 3
            $this->blocking = false;
94
95 3
            if ($this->getConnection()->isConnected()) {
96
                $this->getConnection()->disconnect();
97
            }
98 3
        }
99 3
    }
100
101
    /**
102
     * Server send stream start.
103
     *
104
     * @return void
105
     */
106 3
    public function features()
107
    {
108 3
        $this->blocking = false;
109 3
        $this->getConnection()->setReady(true);
110 3
    }
111
112
    /**
113
     * {@inheritDoc}
114
     */
115 3
    public function isBlocking()
116
    {
117 3
        return $this->blocking;
118
    }
119
}
120