Completed
Push — master ( e9cf55...72c4df )
by Brian
03:18
created

DeviceState   A

Complexity

Total Complexity 5

Size/Duplication

Total Lines 57
Duplicated Lines 0 %

Coupling/Cohesion

Components 1
Dependencies 1

Test Coverage

Coverage 46.67%

Importance

Changes 2
Bugs 0 Features 0
Metric Value
wmc 5
c 2
b 0
f 0
lcom 1
cbo 1
dl 0
loc 57
ccs 7
cts 15
cp 0.4667
rs 10

5 Methods

Rating   Name   Duplication   Size   Complexity  
A getName() 0 4 1
A getState() 0 4 1
A onDeviceStateChange() 0 4 1
A onceDeviceStateChange() 0 4 1
A __construct() 0 7 1
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\Resources;
20
21
use phparia\Client\AriClient;
22
use phparia\Events\Event;
23
24
/**
25
 * Represents the state of a device.
26
 *
27
 * @author Brian Smith <[email protected]>
28
 */
29
class DeviceState extends Resource
30
{
31
    /**
32
     * @var string Name of the device.
33
     */
34
    private $name;
35
36
    /**
37
     * @var string Device's state
38
     */
39
    private $state;
40
41
    /**
42
     * @return string Name of the device.
43
     */
44
    public function getName()
45
    {
46
        return $this->name;
47
    }
48
49
    /**
50
     * @return string Device's state
51
     */
52 1
    public function getState()
53
    {
54 1
        return $this->state;
55
    }
56
57
    /**
58
     * @param callable $callback
59
     */
60
    public function onDeviceStateChange(callable $callback)
61
    {
62
        $this->on(Event::DEVICE_STATE_CHANGE.'_'.$this->getName(), $callback);
63
    }
64
65
    /**
66
     * @param callable $callback
67
     */
68
    public function onceDeviceStateChange(callable $callback)
69
    {
70
        $this->once(Event::DEVICE_STATE_CHANGE.'_'.$this->getName(), $callback);
71
    }
72
73
    /**
74
     * @param AriClient $client
75
     * @param string $response
76
     */
77 4
    public function __construct(AriClient $client, $response)
78
    {
79 4
        parent::__construct($client, $response);
80
81 4
        $this->name = $this->response->name;
82 4
        $this->state = $this->response->state;
83 4
    }
84
85
}
86