2 declare(strict_types = 1);
49 foreach ($queriedTables as $tableAlias => $tableName) {
50 if (!in_array($tableName, [
'sys_file',
'sys_file_metadata'])) {
56 return $expressionBuilder->
orX(...$constraints);
69 $searchTerm = $this->searchDemand->getSearchTerm();
72 $searchTermParts = str_getcsv($searchTerm,
' ');
73 foreach ($searchTermParts as $searchTermPart) {
74 $searchTermPart = trim($searchTermPart);
75 if ($searchTermPart ===
'') {
78 $constraintsForParts = [];
79 $like =
'%' . $this->queryBuilder->escapeLikeWildcards($searchTermPart) .
'%';
80 foreach ($fieldsToSearchWithin as $fieldName) {
81 if (!isset(
$GLOBALS[
'TCA'][$tableName][
'columns'][$fieldName])) {
84 $fieldConfig =
$GLOBALS[
'TCA'][$tableName][
'columns'][$fieldName][
'config'];
85 $fieldType = $fieldConfig[
'type'];
86 $evalRules = $fieldConfig[
'eval'] ??
'';
89 if (is_array($fieldConfig[
'search']) && in_array(
'case', $fieldConfig[
'search'],
true)) {
91 $searchConstraint = $this->queryBuilder->expr()->andX(
92 $this->queryBuilder->expr()->like(
93 $tableAlias .
'.' . $fieldName,
94 $this->queryBuilder->createNamedParameter($like, \PDO::PARAM_STR)
98 $searchConstraint = $this->queryBuilder->expr()->andX(
100 $this->queryBuilder->expr()->comparison(
101 'LOWER(' . $this->queryBuilder->quoteIdentifier($tableAlias .
'.' . $fieldName) .
')',
103 $this->queryBuilder->createNamedParameter(mb_strtolower($like), \PDO::PARAM_STR)
109 if ($fieldType ===
'text'
110 || $fieldType ===
'flex'
111 || ($fieldType ===
'input' && (!$evalRules || !preg_match(
'/\b(?:date|time|int)\b/', $evalRules)))
113 $constraintsForParts[] = $searchConstraint;
116 $constraints[] = $this->queryBuilder->expr()->orX(...$constraintsForParts);
119 return $this->queryBuilder->expr()->andX(...$constraints);
130 if ($searchFields = $this->searchDemand->getSearchFields()) {
131 if (empty($searchFields[$tableName])) {
134 foreach ($searchFields[$tableName] as $searchField) {
135 if (!isset(
$GLOBALS[
'TCA'][$tableName][
'columns'][$searchField])) {
136 throw new \RuntimeException(sprintf(
'Cannot use search field "%s" because it is not defined in TCA.', $searchField), 1556367071);
140 return $searchFields;
142 $fieldListArray = [];
144 if (isset(
$GLOBALS[
'TCA'][$tableName][
'ctrl'][
'searchFields'])) {
145 $fieldListArray = GeneralUtility::trimExplode(
',',
$GLOBALS[
'TCA'][$tableName][
'ctrl'][
'searchFields'],
true);
148 return $fieldListArray;