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

QueryBuilderRepositoryHelper   A

Complexity

Total Complexity 6

Size/Duplication

Total Lines 48
Duplicated Lines 0 %

Coupling/Cohesion

Components 0
Dependencies 3

Importance

Changes 0
Metric Value
dl 0
loc 48
c 0
b 0
f 0
wmc 6
lcom 0
cbo 3
rs 10

2 Methods

Rating   Name   Duplication   Size   Complexity  
A queryBuilderRule2SQL() 0 9 2
A queryBuilderRuleSet2SQL() 0 23 4
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