Completed
Push — master ( fe47f8...2aa7aa )
by Brian
09:43
created

src/wormling/phparia/Events/StasisStart.php (1 issue)

Upgrade to new PHP Analysis Engine

These results are based on our legacy PHP analysis, consider migrating to our new PHP analysis engine instead. Learn more

1
<?php
2
3
/*
4
 * Copyright 2014 Brian Smith <[email protected]>.
5
 *
6
 * Licensed under the Apache License, Version 2.0 (the "License");
7
 * you may not use this file except in compliance with the License.
8
 * You may obtain a copy of the License at
9
 *
10
 *      http://www.apache.org/licenses/LICENSE-2.0
11
 *
12
 * Unless required by applicable law or agreed to in writing, software
13
 * distributed under the License is distributed on an "AS IS" BASIS,
14
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
15
 * See the License for the specific language governing permissions and
16
 * limitations under the License.
17
 */
18
19
namespace phparia\Events;
20
21
use phparia\Client\AriClient;
22
use phparia\Resources\Channel;
23
24
/**
25
 * Notification that a channel has entered a Stasis application.
26
 *
27
 * @author Brian Smith <[email protected]>
28
 */
29 View Code Duplication
class StasisStart extends Event implements IdentifiableEventInterface
30
{
31
    /**
32
     * @var array Arguments to the application
33
     */
34
    private $args;
35
36
    /**
37
     * @var Channel
38
     */
39
    private $channel;
40
41
    /**
42
     * @var Channel (optional)
43
     */
44
    private $replaceChannel;
45
46
    /**
47
     * @return array Arguments to the application
48
     */
49
    public function getArgs()
50
    {
51
        return $this->args;
52
    }
53
54
    /**
55
     * @return Channel
56
     */
57 38
    public function getChannel()
58
    {
59 38
        return $this->channel;
60
    }
61
62
    /**
63
     * @return Channel (optional)
64
     */
65
    public function getReplaceChannel()
66
    {
67
        return $this->replaceChannel;
68
    }
69
70 38
    public function getEventId()
71
    {
72 38
        return "{$this->getType()}_{$this->getChannel()->getId()}";
73
    }
74
75
    /**
76
     * @param AriClient $client
77
     * @param string $response
78
     */
79 38
    public function __construct(AriClient $client, $response)
80
    {
81 38
        parent::__construct($client, $response);
82
83 38
        $this->args = $this->getResponseValue('args');
0 ignored issues
show
Documentation Bug introduced by
It seems like $this->getResponseValue('args') of type * is incompatible with the declared type array of property $args.

Our type inference engine has found an assignment to a property that is incompatible with the declared type of that property.

Either this assignment is in error or the assigned type should be added to the documentation/type hint for that property..

Loading history...
84 38
        $this->channel = $this->getResponseValue('channel', '\phparia\Resources\Channel', $client);
85 38
        $this->replaceChannel = $this->getResponseValue('replace_channel', '\phparia\Resources\Channel', $client);
86 38
    }
87
}
88