Completed
Push — master ( aa02db...c8592c )
by WEBEWEB
09:51
created

queryBuilderRuleSet2Sql()   A

Complexity

Conditions 4
Paths 4

Size

Total Lines 22

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 22
rs 9.568
c 0
b 0
f 0
cc 4
nc 4
nop 1
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|null Returns the SQL string representing the rule.
34
     */
35
    public static function queryBuilderRule2Sql(QueryBuilderRuleInterface $rule): ?string {
36
37
        if (null !== $rule->getDecorator()) {
38
            return $rule->getDecorator()->toSql($rule, false);
39
        }
40
41
        $qbo = QueryBuilderDecoratorFactory::newQueryBuilderOperator($rule->getOperator());
42
43
        return $qbo->toSql($rule, false);
44
    }
45
46
    /**
47
     * Convert a rule set into a SQL string representation.
48
     *
49
     * @param QueryBuilderRuleSetInterface $ruleSet The rule set.
50
     * @return string Returns the SQL string representing the rule set.
51
     */
52
    public static function queryBuilderRuleSet2Sql(QueryBuilderRuleSetInterface $ruleSet): string {
53
54
        if (0 === count($ruleSet->getRules())) {
55
            return "";
56
        }
57
58
        $sql = [];
59
60
        foreach ($ruleSet->getRules() as $current) {
61
62
            if (true === ($current instanceof QueryBuilderRuleSetInterface)) {
63
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