Completed
Pull Request — master (#27)
by Matt
03:42
created

functions.php ➔ is_json_integer()   B

Complexity

Conditions 7
Paths 9

Size

Total Lines 12
Code Lines 6

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 5
CRAP Score 7.2269

Importance

Changes 1
Bugs 1 Features 0
Metric Value
cc 7
eloc 6
c 1
b 1
f 0
nc 9
nop 1
dl 0
loc 12
ccs 5
cts 6
cp 0.8333
crap 7.2269
rs 8.2222
1
<?php
2
3
namespace League\JsonGuard;
4
5
/**
6
 * @param string $json
7
 * @param bool   $assoc
8
 * @param int    $depth
9
 * @param int    $options
10
 * @return mixed
11
 * @throws \InvalidArgumentException
12
 */
13
function json_decode($json, $assoc = false, $depth = 512, $options = 0)
14
{
15 28
    $data = \json_decode($json, $assoc, $depth, $options);
16
17 28
    if (json_last_error() !== JSON_ERROR_NONE) {
18
        throw new \InvalidArgumentException(sprintf('Invalid JSON: %s', json_last_error_msg()));
19
    }
20
21 28
    return $data;
22
}
23
24
/**
25
 * @param $string
26
 * @return int
27
 */
28
function strlen($string)
29
{
30 8
    if (extension_loaded('intl')) {
31 8
        return grapheme_strlen($string);
32
    }
33
34
    if (extension_loaded('mbstring')) {
35
        return mb_strlen($string, mb_detect_encoding($string));
36
    }
37
38
    return strlen($string);
39
}
40
41
/**
42
 * Returns the string representation of a value.
43
 *
44
 * @param mixed $value
45
 * @return string
46
 */
47
function as_string($value)
48
{
49 62
    if (is_string($value)) {
50 32
        return $value;
51
    }
52
53 50
    if (is_int($value)) {
54 40
        return (string)$value;
55
    }
56
57 28
    if (is_bool($value)) {
58 8
        return $value ? '<TRUE>' : '<FALSE>';
59
    }
60
61 24
    if (is_object($value)) {
62 6
        return get_class($value);
63
    }
64
65 24
    if (is_array($value)) {
66 8
        return '<ARRAY>';
67
    }
68
69 20
    if (is_resource($value)) {
70
        return '<RESOURCE>';
71
    }
72
73 20
    if (is_null($value)) {
74 6
        return '<NULL>';
75
    }
76
77 16
    return '<UNKNOWN>';
78
}
79
80
/**
81
 * Get the properties matching $pattern from the $data.
82
 *
83
 * @param string       $pattern
84
 * @param array|object $data
85
 * @return array
86
 */
87
function properties_matching_pattern($pattern, $data)
88
{
89
    // If an object is supplied, extract an array of the property names.
90 4
    if (is_object($data)) {
91 4
        $data = array_keys(get_object_vars($data));
92 4
    }
93
94 4
    return preg_grep(delimit_pattern($pattern), $data);
95
}
96
97
/**
98
 * Delimit a regular expression pattern.
99
 *
100
 * The regular expression syntax used for JSON schema is ECMA 262, from Javascript,
101
 * and does not use delimiters.  Since the PCRE functions do, this function will
102
 * delimit a pattern and escape the delimiter if found in the pattern.
103
 *
104
 * @see http://json-schema.org/latest/json-schema-validation.html#anchor6
105
 * @see http://php.net/manual/en/regexp.reference.delimiters.php
106
 *
107
 * @param string $pattern
108
 *
109
 * @return string
110
 */
111
function delimit_pattern($pattern)
112
{
113 6
    return '/' . str_replace('/', '\\/', $pattern) . '/';
114
}
115
116
/**
117
 * Escape a JSON Pointer.
118
 *
119
 * @param  string $pointer
120
 * @return string
121
 */
122
function escape_pointer($pointer)
123
{
124 62
    $pointer = str_replace('~', '~0', $pointer);
125 62
    return str_replace('/', '~1', $pointer);
126
}
127
128
/**
129
 * Determines if the value is an integer or an integer that was cast to a string
130
 * because it is larger than PHP_INT_MAX.
131
 *
132
 * @param  mixed  $value
133
 * @return boolean
134
 */
135
function is_json_integer($value)
136
{
137 42
    if (!function_exists('bccomp')) {
138
        return is_int($value);
139
    }
140
141 42
    if (is_string($value) && $value[0] === '-') {
142 4
        $value = substr($value, 1);
143 4
    }
144
145 42
    return is_int($value) || (is_string($value) && ctype_digit($value) && bccomp($value, PHP_INT_MAX, 0) === 1);
146
}
147