GitHub Access Token became invalid

It seems like the GitHub access token used for retrieving details about this repository from GitHub became invalid. This might prevent certain types of inspections from being run (in particular, everything related to pull requests).
Please ask an admin of your repository to re-new the access token on this website.
Completed
Push — master ( 61aacd...05f06e )
by Alexey
18:53
created

ApiResponse::offsetUnset()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 4
Code Lines 2

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
c 1
b 0
f 0
dl 0
loc 4
rs 10
cc 1
eloc 2
nc 1
nop 1
1
<?php
2
3
namespace RetailCrm\Response;
4
5
use RetailCrm\Exception\InvalidJsonException;
6
7
/**
8
 * Response from retailCRM API
9
 */
10
class ApiResponse implements \ArrayAccess
11
{
12
    // HTTP response status code
13
    protected $statusCode;
14
15
    // response assoc array
16
    protected $response;
17
18
    public function __construct($statusCode, $responseBody = null)
19
    {
20
        $this->statusCode = (int) $statusCode;
21
22
        if (!empty($responseBody)) {
23
            $response = json_decode($responseBody, true);
24
25
            if (!$response && JSON_ERROR_NONE !== ($error = json_last_error())) {
26
                throw new InvalidJsonException(
27
                    "Invalid JSON in the API response body. Error code #$error",
28
                    $error
29
                );
30
            }
31
32
            $this->response = $response;
33
        }
34
    }
35
36
    /**
37
     * Return HTTP response status code
38
     *
39
     * @return int
40
     */
41
    public function getStatusCode()
42
    {
43
        return $this->statusCode;
44
    }
45
46
    /**
47
     * HTTP request was successful
48
     *
49
     * @return bool
50
     */
51
    public function isSuccessful()
52
    {
53
        return $this->statusCode < 400;
54
    }
55
56
    /**
57
     * Allow to access for the property throw class method
58
     *
59
     * @param  string $name
60
     * @return mixed
61
     */
62
    public function __call($name, $arguments)
63
    {
64
        // convert getSomeProperty to someProperty
65
        $propertyName = strtolower(substr($name, 3, 1)) . substr($name, 4);
66
67
        if (!isset($this->response[$propertyName])) {
68
            throw new \InvalidArgumentException("Method \"$name\" not found");
69
        }
70
71
        return $this->response[$propertyName];
72
    }
73
74
    /**
75
     * Allow to access for the property throw object property
76
     *
77
     * @param  string $name
78
     * @return mixed
79
     */
80 View Code Duplication
    public function __get($name)
0 ignored issues
show
Duplication introduced by
This method 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...
81
    {
82
        if (!isset($this->response[$name])) {
83
            throw new \InvalidArgumentException("Property \"$name\" not found");
84
        }
85
86
        return $this->response[$name];
87
    }
88
89
    /**
90
     * @param mixed $offset
91
     * @param mixed $value
92
     */
93
    public function offsetSet($offset, $value)
94
    {
95
        throw new \BadMethodCallException('This activity not allowed');
96
    }
97
98
    /**
99
     * @param mixed $offset
100
     */
101
    public function offsetUnset($offset)
102
    {
103
        throw new \BadMethodCallException('This call not allowed');
104
    }
105
106
    /**
107
     * @param mixed $offset
108
     * @return bool
109
     */
110
    public function offsetExists($offset)
111
    {
112
        return isset($this->response[$offset]);
113
    }
114
115
    /**
116
     * @param mixed $offset
117
     * @return mixed
118
     */
119 View Code Duplication
    public function offsetGet($offset)
0 ignored issues
show
Duplication introduced by
This method 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...
120
    {
121
        if (!isset($this->response[$offset])) {
122
            throw new \InvalidArgumentException("Property \"$offset\" not found");
123
        }
124
125
        return $this->response[$offset];
126
    }
127
}
128