Completed
Push — master ( 168b8f...f2b799 )
by Tobias
02:41
created

CustomerBillingAddress::getZipCode()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 4
Ratio 100 %

Code Coverage

Tests 0
CRAP Score 2

Importance

Changes 0
Metric Value
dl 4
loc 4
ccs 0
cts 2
cp 0
rs 10
c 0
b 0
f 0
cc 1
eloc 2
nc 1
nop 0
crap 2
1
<?php
2
3
namespace Billogram\Model\Customer;
4
5
use Billogram\Model\CreatableFromArray;
6
7
/**
8
 * @author Ibrahim Hizeoui <[email protected]>
9
 */
10 View Code Duplication
class CustomerBillingAddress implements CreatableFromArray
0 ignored issues
show
Duplication introduced by
This class seems to be duplicated in your project.

Duplicated code is one of the most pungent code smells. If you need to duplicate the same code in three or more different places, we strongly encourage you to look into extracting the code into a single class or operation.

You can also find more detailed suggestions in the “Code” section of your repository.

Loading history...
11
{
12
    /**
13
     * @var string
14
     */
15
    private $careOf;
16
17
    /**
18
     * @var bool
19
     */
20
    private $useCareOfAsAttention;
21
22
    /**
23
     * @var string
24
     */
25
    private $streetAddress;
26
27
    /**
28
     * @var string
29
     */
30
    private $zipCode;
31
32
    /**
33
     * @var string
34
     */
35
    private $city;
36
37
    /**
38
     * @var string
39
     */
40
    private $country;
41
42
    /**
43
     * @return string
44
     */
45
    public function getCareOf()
46
    {
47
        return $this->careOf;
48
    }
49
50
    /**
51
     * @param string $careOf
52
     *
53
     * @return CustomerBillingAddress
54
     */
55
    public function withCareOf(string $careOf)
56
    {
57
        $new = clone $this;
58
        $new->careOf = $careOf;
59
60
        return $new;
61
    }
62
63
    /**
64
     * @return bool
65
     */
66
    public function isUseCareOfAsAttention()
67
    {
68
        return $this->useCareOfAsAttention;
69
    }
70
71
    /**
72
     * @param bool $useCareOfAsAttention
73
     *
74
     * @return CustomerBillingAddress
75
     */
76
    public function withUseCareOfAsAttention(bool $useCareOfAsAttention)
77
    {
78
        $new = clone $this;
79
        $new->useCareOfAsAttention = $useCareOfAsAttention;
80
81
        return $new;
82
    }
83
84
    /**
85
     * @return string
86
     */
87
    public function getStreetAddress()
88
    {
89
        return $this->streetAddress;
90
    }
91
92
    /**
93
     * @param string $streetAddress
94
     *
95
     * @return CustomerBillingAddress
96
     */
97
    public function withStreetAddress(string $streetAddress)
98
    {
99
        $new = clone $this;
100
        $new->streetAddress = $streetAddress;
101
102
        return $new;
103
    }
104
105
    /**
106
     * @return string
107
     */
108
    public function getZipCode()
109
    {
110
        return $this->zipCode;
111
    }
112
113
    /**
114
     * @param string $zipCode
115
     *
116
     * @return CustomerBillingAddress
117
     */
118
    public function withZipCode(string $zipCode)
119
    {
120
        $new = clone $this;
121
        $new->zipCode = $zipCode;
122
123
        return $new;
124
    }
125
126
    /**
127
     * @return string
128
     */
129
    public function getCity()
130
    {
131
        return $this->city;
132
    }
133
134
    /**
135
     * @param string $city
136
     *
137
     * @return CustomerBillingAddress
138
     */
139
    public function withCity(string $city)
140
    {
141
        $new = clone $this;
142
        $new->city = $city;
143
144
        return $new;
145
    }
146
147
    /**
148
     * @return string
149
     */
150
    public function getCountry()
151
    {
152
        return $this->country;
153
    }
154
155
    /**
156
     * @param string $country
157
     *
158
     * @return CustomerBillingAddress
159
     */
160
    public function withCountry(string $country)
161
    {
162
        $new = clone $this;
163
        $new->country = $country;
164
165
        return $new;
166
    }
167
168 2
    public function toArray()
169
    {
170 2
        $data = [];
171 2
        if ($this->careOf !== null) {
172 2
            $data['careof'] = $this->careOf;
173
        }
174 2
        if ($this->useCareOfAsAttention !== null) {
175 2
            $data['use_careof_as_attention'] = $this->useCareOfAsAttention;
176
        }
177 2
        if ($this->streetAddress !== null) {
178 2
            $data['street_address'] = $this->streetAddress;
179
        }
180 2
        if ($this->zipCode !== null) {
181 2
            $data['zipcode'] = $this->zipCode;
182
        }
183 2
        if ($this->city !== null) {
184 2
            $data['city'] = $this->city;
185
        }
186 2
        if ($this->country !== null) {
187 2
            $data['country'] = $this->country;
188
        }
189
190 2
        return $data;
191
    }
192
193
    /**
194
     * Create an API response object from the HTTP response from the API server.
195
     *
196
     * @param array $data
197
     *
198
     * @return self
199
     */
200 7
    public static function createFromArray(array $data)
201
    {
202 7
        $model = new self();
203 7
        $model->careOf = $data['careof'] ?? null;
204 7
        $model->useCareOfAsAttention = $data['use_careof_as_attention'] ?? null;
205 7
        $model->streetAddress = $data['street_address'] ?? null;
206 7
        $model->zipCode = $data['zipcode'] ?? null;
207 7
        $model->city = $data['city'] ?? null;
208 7
        $model->country = $data['country'] ?? null;
209
210 7
        return $model;
211
    }
212
}
213