1
|
|
|
<?php |
2
|
|
|
|
3
|
|
|
/** |
4
|
|
|
* Settings log viewer action file. |
5
|
|
|
* |
6
|
|
|
* @package Action |
7
|
|
|
* |
8
|
|
|
* @copyright YetiForce S.A. |
9
|
|
|
* @license YetiForce Public License 5.0 (licenses/LicenseEN.txt or yetiforce.com) |
10
|
|
|
* @author Arkadiusz Sołek <[email protected]> |
11
|
|
|
* @author Mariusz Krzaczkowski <[email protected]> |
12
|
|
|
*/ |
13
|
|
|
/** |
14
|
|
|
* Settings log viewer action class. |
15
|
|
|
*/ |
16
|
|
|
class Settings_Log_LogsViewer_Action extends Settings_Vtiger_Basic_Action |
17
|
|
|
{ |
18
|
|
|
/** {@inheritdoc} */ |
19
|
|
|
public function process(App\Request $request) |
20
|
|
|
{ |
21
|
|
|
$type = $request->getByType('type'); |
22
|
|
|
if (!isset(\App\Log::LOGS_VIEWER_COLUMN_MAP[$type])) { |
23
|
|
|
throw new \App\Exceptions\NoPermittedForAdmin('ERR_ILLEGAL_VALUE'); |
24
|
|
|
} |
25
|
|
|
$rows = $columns = []; |
26
|
|
|
foreach ($request->getArray('columns') as $key => $value) { |
27
|
|
|
$columns[$key] = $value['name']; |
28
|
|
|
} |
29
|
|
|
$mapping = \App\Log::LOGS_VIEWER_COLUMN_MAP[$type]; |
30
|
|
|
if (\App\Db::getInstance()->isTableExists($mapping['table'])) { |
31
|
|
|
$query = (new \App\Db\Query())->from($mapping['table']); |
32
|
|
|
$logsCountAll = (int) $query->count('*'); |
33
|
|
|
$this->loadFilter($request, $mapping['filter'], $query); |
34
|
|
|
$count = (int) $query->count('*'); |
35
|
|
|
$query->limit($request->getInteger('length'))->offset($request->getInteger('start')); |
36
|
|
|
$order = current($request->getArray('order', App\Purifier::ALNUM)); |
37
|
|
|
if ($order && isset($columns[$order['column']], $mapping['columns'][$columns[$order['column']]])) { |
38
|
|
|
$query->orderBy([$columns[$order['column']] => \App\Db::ASC === strtoupper($order['dir']) ? \SORT_ASC : \SORT_DESC]); |
39
|
|
|
} |
40
|
|
|
$dataReader = $query->createCommand()->query(); |
41
|
|
|
while ($row = $dataReader->read()) { |
42
|
|
|
$r = []; |
43
|
|
|
foreach ($mapping['columns'] as $key => $value) { |
44
|
|
|
switch ($value['type']) { |
45
|
|
|
case 'DateTime': |
46
|
|
|
$r[] = \App\Fields\DateTime::formatToDisplay($row[$key]); |
47
|
|
|
break; |
48
|
|
|
case 'Date': |
49
|
|
|
$r[] = \App\Fields\Date::formatToDisplay($row[$key]); |
50
|
|
|
break; |
51
|
|
|
case 'Text': |
52
|
|
|
$r[] = $row[$key] ? \App\Layout::truncateText($row[$key], 50, true) : ''; |
53
|
|
|
break; |
54
|
|
|
case 'Owner': |
55
|
|
|
$r[] = \App\Fields\Owner::getUserLabel($row[$key]); |
56
|
|
|
break; |
57
|
|
|
case 'Reference': |
58
|
|
|
$r[] = \App\Record::getLabel($row[$key]); |
59
|
|
|
break; |
60
|
|
|
case 'Boolean': |
61
|
|
|
$r[] = \App\Language::translate(empty($row[$key]) ? 'LBL_NO' : 'LBL_YES'); |
62
|
|
|
break; |
63
|
|
|
default: |
64
|
|
|
break; |
65
|
|
|
} |
66
|
|
|
} |
67
|
|
|
$rows[] = $r; |
68
|
|
|
} |
69
|
|
|
$dataReader->close(); |
70
|
|
|
} |
71
|
|
|
header('content-type: text/json; charset=UTF-8'); |
72
|
|
|
echo \App\Json::encode([ |
73
|
|
|
'draw' => $request->getInteger('draw'), |
74
|
|
|
'iTotalRecords' => $logsCountAll ?? 0, |
75
|
|
|
'iTotalDisplayRecords' => $count ?? 0, |
76
|
|
|
'aaData' => $rows |
77
|
|
|
]); |
78
|
|
|
} |
79
|
|
|
|
80
|
|
|
/** |
81
|
|
|
* Load filter. |
82
|
|
|
* |
83
|
|
|
* @param App\Request $request |
84
|
|
|
* @param array $filter |
85
|
|
|
* @param App\Db\Query $query |
86
|
|
|
*/ |
87
|
|
|
public function loadFilter(App\Request $request, array $filter, App\Db\Query &$query) |
|
|
|
|
88
|
|
|
{ |
89
|
|
|
foreach ($filter as $key => $value) { |
90
|
|
|
if ($request->has($key) && '' !== $request->getRaw($key)) { |
91
|
|
|
switch ($value) { |
92
|
|
|
case 'DateTimeRange': |
93
|
|
|
$range = $request->getByType($key, 'DateRangeUserFormat'); |
94
|
|
|
$query->andWhere(['between', $key, $range[0] . ' 00:00:00', $range[1] . ' 23:59:59']); |
95
|
|
|
break; |
96
|
|
|
case 'Text': |
97
|
|
|
$query->andWhere(['like', $key, $request->getByType($key, 'Text')]); |
98
|
|
|
break; |
99
|
|
|
case 'Boolean': |
100
|
|
|
$query->andWhere([$key => $request->getInteger($key)]); |
101
|
|
|
break; |
102
|
|
|
default: |
103
|
|
|
break; |
104
|
|
|
} |
105
|
|
|
} |
106
|
|
|
} |
107
|
|
|
} |
108
|
|
|
} |
109
|
|
|
|