SqlParamBuilder::build()   A
last analyzed

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Code Coverage

Tests 2
CRAP Score 1

Importance

Changes 1
Bugs 0 Features 1
Metric Value
cc 1
eloc 1
c 1
b 0
f 1
nc 1
nop 0
dl 0
loc 3
ccs 2
cts 2
cp 1
crap 1
rs 10
1
<?php
2
/**
3
 * Copyright 2021 Aleksandar Panic
4
 *
5
 * Licensed under the Apache License, Version 2.0 (the "License");
6
 * you may not use this file except in compliance with the License.
7
 * You may obtain a copy of the License at
8
 *
9
 *   http://www.apache.org/licenses/LICENSE-2.0
10
 *
11
 * Unless required by applicable law or agreed to in writing, software
12
 * distributed under the License is distributed on an "AS IS" BASIS,
13
 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
14
 * See the License for the specific language governing permissions and
15
 * limitations under the License.
16
 */
17
18
namespace ArekX\PQL\Sql;
19
20
use ArekX\PQL\Contracts\ParamsBuilder;
21
22
/**
23
 * Represents a class for building parameters
24
 * for a SQL query.
25
 */
26
class SqlParamBuilder implements ParamsBuilder
27
{
28
    /**
29
     * Prefix to be used when wrapping values into
30
     * parameters.
31
     *
32
     * @see SqlParamBuilder::wrapValue()
33
     * @var string
34
     */
35
    public string $prefix = ':t';
36
37
    /**
38
     * List of parameters set.
39
     * @var array
40
     */
41
    protected array $parameters = [];
42
43
    /**
44
     * Index of parameter used in wrapValue.
45
     *
46
     * @see SqlParamBuilder::wrapValue()
47
     * @var int
48
     */
49
    protected int $parameterIndex = 0;
50
51
    /**
52
     * Create new intance of this class.
53
     * @return static
54
     */
55 110
    public static function create(): static
56
    {
57 110
        return new static();
58
    }
59
60
    /**
61
     * @inheritDoc
62
     */
63 63
    public function wrapValue($value, $type = null): string
64
    {
65 63
        $key = $this->prefix . $this->parameterIndex++;
66 63
        $this->add($key, $value, $type);
67
68 63
        return $key;
69
    }
70
71
    /**
72
     * @inheritDoc
73
     */
74 68
    public function add($key, $value, $type = null): void
75
    {
76 68
        $this->parameters[$key] = [$value, $type];
77
    }
78
79
    /**
80
     * @inheritDoc
81
     */
82 4
    public function get($key): mixed
83
    {
84 4
        if (!array_key_exists($key, $this->parameters)) {
85 1
            return null;
86
        }
87
88 3
        return $this->parameters[$key];
89
    }
90
91
    /**
92
     * @inheritDoc
93
     */
94 100
    public function build(): array
95
    {
96 100
        return $this->parameters;
97
    }
98
}
99