Completed
Pull Request — master (#7)
by
unknown
17:47
created

updateContentElements()   A

Complexity

Conditions 2
Paths 1

Size

Total Lines 15

Duplication

Lines 0
Ratio 0 %

Importance

Changes 0
Metric Value
dl 0
loc 15
rs 9.7666
c 0
b 0
f 0
cc 2
nc 1
nop 3
1
<?php
2
3
/***************************************************************
4
 *  Copyright notice
5
 *
6
 *  (c) 2020 AOE GmbH <[email protected]>
7
 *
8
 *  All rights reserved
9
 *
10
 *  This script is part of the TYPO3 project. The TYPO3 project is
11
 *  free software; you can redistribute it and/or modify
12
 *  it under the terms of the GNU General Public License as published by
13
 *  the Free Software Foundation; either version 3 of the License, or
14
 *  (at your option) any later version.
15
 *
16
 *  The GNU General Public License can be found at
17
 *  http://www.gnu.org/copyleft/gpl.html.
18
 *
19
 *  This script is distributed in the hope that it will be useful,
20
 *  but WITHOUT ANY WARRANTY; without even the implied warranty of
21
 *  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
22
 *  GNU General Public License for more details.
23
 *
24
 *  This copyright notice MUST APPEAR in all copies of the script!
25
 ***************************************************************/
26
27
use TYPO3\CMS\Core\Database\Connection;
28
use TYPO3\CMS\Core\Database\ConnectionPool;
29
use TYPO3\CMS\Core\Database\Query\QueryBuilder;
30
use TYPO3\CMS\Core\Utility\GeneralUtility;
31
32
/**
33
 * Class Tx_FeatureFlag_System_Db_FeatureFlagData
34
 */
35
class Tx_FeatureFlag_System_Db_FeatureFlagData
36
{
37
    /**
38
     * @var string
39
     */
40
    const TABLE_MAPPING = 'tx_featureflag_domain_model_mapping';
41
42
    /**
43
     * @var string
44
     */
45
    const TABLE_FLAGS = 'tx_featureflag_domain_model_featureflag';
46
47
    /**
48
     * @param $table
49
     * @param $behavior
50
     * @param $enabled
51
     *
52
     * @return array
53
     */
54
    public function getContentElements($table, $behavior, $enabled)
55
    {
56
        /** @var QueryBuilder $queryBuilder */
57
        $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
58
            ->getQueryBuilderForTable($table);
59
60
        $queryBuilder->getRestrictions()->removeAll();
61
62
        $queryBuilder
63
            ->select($table . '.uid')
64
            ->from($table)
65
            ->from(self::TABLE_MAPPING)
66
            ->from(self::TABLE_FLAGS)
67
            ->where(
68
                $queryBuilder->expr()->andX(
69
                    $queryBuilder->expr()->eq(
70
                        self::TABLE_MAPPING . '.feature_flag',
71
                        self::TABLE_FLAGS . '.uid'
72
                    ),
73
                    $queryBuilder->expr()->eq(
74
                        $table . '.uid',
75
                            self::TABLE_MAPPING . '.foreign_table_uid'
76
                    ),
77
                    $queryBuilder->expr()->eq(
78
                        self::TABLE_FLAGS . '.enabled', $queryBuilder->createNamedParameter(
79
                            $enabled,
80
                            Connection::PARAM_INT
81
                        )
82
                    ),
83
                    $queryBuilder->expr()->eq(
84
                        self::TABLE_MAPPING . '.foreign_table_name', $queryBuilder->createNamedParameter(
85
                            $table,
86
                            Connection::PARAM_STR
87
                        )
88
                    ),
89
                    $queryBuilder->expr()->eq(
90
                        self::TABLE_MAPPING . '.behavior', $queryBuilder->createNamedParameter(
91
                            $behavior,
92
                            Connection::PARAM_INT
93
                        )
94
                    )
95
                )
96
            );
97
98
        return $queryBuilder->execute()->fetchAll();
99
    }
100
101
    /**
102
     * @param $table
103
     * @param array $uids
104
     * @param $isVisible
105
     */
106
    public function updateContentElements($table, array $uids, $isVisible)
107
    {
108
        /** @var QueryBuilder $queryBuilder */
109
        $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
110
            ->getQueryBuilderForTable($table);
111
112
        $queryBuilder->getRestrictions()->removeAll();
113
114
        $query = $queryBuilder
115
            ->update($table)
116
            ->set('hidden', $isVisible === true ? 0 : 1)
117
            ->add('where', $queryBuilder->expr()->in('uid', $uids));
118
119
        $query->execute();
120
    }
121
122
    /**
123
     * @param $table
124
     * @param $uid
125
     *
126
     * @return string
127
     */
128
    public function getContentElementsPIDs($table, $uid)
129
    {
130
        /** @var QueryBuilder $queryBuilder */
131
        $queryBuilder = GeneralUtility::makeInstance(ConnectionPool::class)
132
            ->getQueryBuilderForTable($table);
133
134
        $queryBuilder->getRestrictions()->removeAll();
135
136
        $query = $queryBuilder
137
            ->select($table . '.pid')
138
            ->from($table)
139
            ->where(
140
                $queryBuilder->expr()->eq(
141
                    $table . '.uid', $queryBuilder->createNamedParameter($uid, Connection::PARAM_INT)
142
                )
143
            );
144
145
        return $query->execute()->fetchColumn(0);
146
    }
147
}
148