Passed
Push — master ( af341e...2b2ec9 )
by Jonas
07:18 queued 05:16
created

MySqlGrammar   A

Complexity

Total Complexity 3

Size/Duplication

Total Lines 36
Duplicated Lines 0 %

Test Coverage

Coverage 100%

Importance

Changes 1
Bugs 0 Features 0
Metric Value
eloc 6
c 1
b 0
f 0
dl 0
loc 36
ccs 8
cts 8
cp 1
rs 10
wmc 3

3 Methods

Rating   Name   Duplication   Size   Complexity  
A compileJsonArray() 0 3 1
A compileJsonObject() 0 5 1
A compileJsonValueSelect() 0 3 1
1
<?php
2
3
namespace Staudenmeir\EloquentJsonRelations\Grammars;
4
5
use Illuminate\Database\Query\Grammars\MySqlGrammar as Base;
6
7
class MySqlGrammar extends Base implements JsonGrammar
8
{
9
    /**
10
     * Compile a "JSON array" statement into SQL.
11
     *
12
     * @param string $column
13
     * @return string
14
     */
15 25
    public function compileJsonArray($column)
16
    {
17 25
        return 'json_array('.$this->wrap($column).')';
18
    }
19
20
    /**
21
     * Compile a "JSON object" statement into SQL.
22
     *
23
     * @param string $column
24
     * @param int $levels
25
     * @return string
26
     */
27 22
    public function compileJsonObject($column, $levels)
28
    {
29 22
        return str_repeat('json_object(?, ', $levels)
30 22
                .$this->wrap($column)
31 22
                .str_repeat(')', $levels);
32
    }
33
34
    /**
35
     * Compile a "JSON value select" statement into SQL.
36
     *
37
     * @param string $column
38
     * @return string
39
     */
40 11
    public function compileJsonValueSelect(string $column): string
41
    {
42 11
        return $this->wrap($column);
43
    }
44
}
45