Device::getType()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
3
/**
4
 * Platine User Agent
5
 *
6
 * Platine User Agent is a lightweight library for detecting
7
 * user browser, device, OS, CPU
8
 *
9
 * This content is released under the MIT License (MIT)
10
 *
11
 * Copyright (c) 2020 Platine User Agent
12
 *
13
 * Permission is hereby granted, free of charge, to any person obtaining a copy
14
 * of this software and associated documentation files (the "Software"), to deal
15
 * in the Software without restriction, including without limitation the rights
16
 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
17
 * copies of the Software, and to permit persons to whom the Software is
18
 * furnished to do so, subject to the following conditions:
19
 *
20
 * The above copyright notice and this permission notice shall be included in all
21
 * copies or substantial portions of the Software.
22
 *
23
 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
24
 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
25
 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
26
 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
27
 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
28
 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
29
 * SOFTWARE.
30
 */
31
32
/**
33
 *  @file Device.php
34
 *
35
 *  The device entity class
36
 *
37
 *  @package    Platine\UserAgent\Entity
38
 *  @author Platine Developers Team
39
 *  @copyright  Copyright (c) 2020
40
 *  @license    http://opensource.org/licenses/MIT  MIT License
41
 *  @link   https://www.platine-php.com
42
 *  @version 1.0.0
43
 *  @filesource
44
 */
45
46
declare(strict_types=1);
47
48
namespace Platine\UserAgent\Entity;
49
50
use Stringable;
51
52
/**
53
 * @class Device
54
 * @package Platine\UserAgent\Entity
55
 */
56
class Device extends AbstractEntity implements Stringable
57
{
58
    /**
59
     * The device model
60
     * @var string
61
     */
62
    protected string $model = '';
63
64
    /**
65
     * The device vendor
66
     * @var string
67
     */
68
    protected string $vendor = '';
69
70
    /**
71
     * The type of device
72
     * @var string
73
     */
74
    protected string $type = '';
75
76
    /**
77
     * Return the model of device
78
     * @return string
79
     */
80
    public function getModel(): string
81
    {
82
        return $this->model;
83
    }
84
85
    /**
86
     * Return the device vendor
87
     * @return string
88
     */
89
    public function getVendor(): string
90
    {
91
        return $this->vendor;
92
    }
93
94
    /**
95
     * Return the type of device
96
     * @return string
97
     */
98
    public function getType(): string
99
    {
100
        return $this->type;
101
    }
102
103
    /**
104
     * Set the device model
105
     * @param string $model
106
     * @return $this
107
     */
108
    public function setModel(string $model): self
109
    {
110
        $this->model = $model;
111
112
        return $this;
113
    }
114
115
    /**
116
     * Set the device vendor
117
     * @param string $vendor
118
     * @return $this
119
     */
120
    public function setVendor(string $vendor): self
121
    {
122
        $this->vendor = $vendor;
123
124
        return $this;
125
    }
126
127
    /**
128
     * Set the device type
129
     * @param string $type
130
     * @return $this
131
     */
132
    public function setType(string $type): self
133
    {
134
        $this->type = $type;
135
136
        return $this;
137
    }
138
139
    /**
140
     * The string representation
141
     * @return string
142
     */
143
    public function __toString(): string
144
    {
145
        return sprintf(
146
            '%s, %s %s',
147
            $this->model,
148
            $this->vendor,
149
            $this->type
150
        );
151
    }
152
}
153