Passed
Pull Request — 2.x (#135)
by Aleksei
18:00
created

CompileJsonContainsKey::compile()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 21
Code Lines 14

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 2
eloc 14
c 1
b 0
f 0
nc 2
nop 1
dl 0
loc 21
rs 9.7998
1
<?php
2
3
/**
4
 * This file is part of Cycle ORM package.
5
 *
6
 * For the full copyright and license information, please view the LICENSE
7
 * file that was distributed with this source code.
8
 */
9
10
declare(strict_types=1);
11
12
namespace Cycle\Database\Driver\SQLServer\Injection;
13
14
class CompileJsonContainsKey extends SQLServerJsonExpression
15
{
16
    /**
17
     * @param non-empty-string $statement
0 ignored issues
show
Documentation Bug introduced by
The doc comment non-empty-string at position 0 could not be parsed: Unknown type name 'non-empty-string' at position 0 in non-empty-string.
Loading history...
18
     *
19
     * @return non-empty-string
0 ignored issues
show
Documentation Bug introduced by
The doc comment non-empty-string at position 0 could not be parsed: Unknown type name 'non-empty-string' at position 0 in non-empty-string.
Loading history...
20
     */
21
    protected function compile(string $statement): string
22
    {
23
        $path = \explode('->', $statement);
24
        $key = $this->parseJsonPathArrayKeys(\array_pop($path));
25
26
        if (\count($key) === 1) {
27
            return \sprintf(
28
                '\'%s\' IN (SELECT [key] FROM openjson(%s%s))',
29
                \array_shift($key),
30
                $this->getField($statement),
31
                $this->getPath(\implode('->', $path))
32
            );
33
        }
34
35
        $path[] = \array_shift($key);
36
37
        return \sprintf(
38
            '%s IN (SELECT [key] FROM openjson(%s%s))',
39
            \array_pop($key),
40
            $this->getField($statement),
41
            $this->getPath(\implode('->', $path))
42
        );
43
    }
44
}
45