Completed
Push — master ( cdd5fc...46341a )
by WEBEWEB
01:20
created

QueryBuilderRepositoryHelper::quoteArrayValue()   A

Complexity

Conditions 2
Paths 2

Size

Total Lines 7

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 7
rs 10
c 0
b 0
f 0
cc 2
nc 2
nop 3
1
<?php
2
3
/*
4
 * This file is part of the jquery-querybuilder-bundle package.
5
 *
6
 * (c) 2019 WEBEWEB
7
 *
8
 * For the full copyright and license information, please view the LICENSE
9
 * file that was distributed with this source code.
10
 */
11
12
namespace WBW\Bundle\JQuery\QueryBuilderBundle\Helper;
13
14
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderConditionInterface;
15
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderOperatorInterface;
16
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRuleInterface;
17
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderRuleSetInterface;
18
use WBW\Bundle\JQuery\QueryBuilderBundle\API\QueryBuilderTypeInterface;
19
use WBW\Bundle\JQuery\QueryBuilderBundle\Decorator\QueryBuilderDecoratorFactory;
20
21
/**
22
 * QueryBuilder repository helper.
23
 *
24
 * @author webeweb <https://github.com/webeweb/>
25
 * @package WBW\Bundle\JQuery\QueryBuilderBundle\Helper
26
 */
27
class QueryBuilderRepositoryHelper implements QueryBuilderConditionInterface, QueryBuilderOperatorInterface, QueryBuilderTypeInterface {
28
29
    /**
30
     * Convert a rule into a SQL string representation.
31
     *
32
     * @param QueryBuilderRuleInterface $rule The rule.
33
     * @return string Returns the SQL string representing the rule.
34
     */
35
    public static function queryBuilderRule2SQL(QueryBuilderRuleInterface $rule) {
36
37
        $qbo = QueryBuilderDecoratorFactory::newQueryBuilderOperator($rule->getOperator());
38
        if (null === $qbo) {
39
            return "";
40
        }
41
42
        return $qbo->toSQL($rule, false);
43
    }
44
45
    /**
46
     * Convert a rule set into a SQL string representation.
47
     *
48
     * @param QueryBuilderRuleSetInterface $ruleSet The rule set.
49
     * @return string Returns the SQL string representing the rule set.
50
     */
51
    public static function queryBuilderRuleSet2SQL(QueryBuilderRuleSetInterface $ruleSet) {
52
53
        if (0 === count($ruleSet->getRules())) {
54
            return "";
55
        }
56
57
        $sql = [];
58
59
        foreach ($ruleSet->getRules() as $current) {
60
61
            if (true === ($current instanceof QueryBuilderRuleSetInterface)) {
62
63
                /** @var QueryBuilderRuleSetInterface $current */
64
                $sql[] = static::queryBuilderRuleSet2SQL($current);
65
                continue;
66
            }
67
68
            /** @var QueryBuilderRuleInterface $current */
69
            $sql[] = static::queryBuilderRule2SQL($current);
70
        }
71
72
        return "(" . implode(" " . $ruleSet->getCondition() . " ", $sql) . ")";
73
    }
74
}
75