1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
|
<?php
/* Icinga DB Web | (c) 2022 Icinga GmbH | GPLv2 */
namespace Icinga\Module\Icingadb\Data;
use DateTime;
use DateTimeZone;
use Icinga\Module\Icingadb\Redis\VolatileStateResults;
use ipl\Orm\Model;
use ipl\Orm\Query;
class CsvResultSet extends VolatileStateResults
{
protected $isCacheDisabled = true;
/**
* @return array<string, ?string>
*/
public function current(): array
{
return $this->extractKeysAndValues(parent::current());
}
protected function formatValue(string $key, $value): ?string
{
if (
$value
&& (
$key === 'id'
|| substr($key, -3) === '_id'
|| substr($key, -3) === '.id'
|| substr($key, -9) === '_checksum'
|| substr($key, -4) === '_bin'
)
) {
$value = bin2hex($value);
}
if (is_bool($value)) {
return $value ? 'true' : 'false';
} elseif (is_string($value)) {
return '"' . str_replace('"', '""', $value) . '"';
} elseif (is_array($value)) {
return '"' . implode(',', $value) . '"';
} elseif ($value instanceof DateTime) {
return $value->setTimezone(new DateTimeZone('UTC'))
->format('Y-m-d\TH:i:s.vP');
} else {
return $value;
}
}
protected function extractKeysAndValues(Model $model, string $path = ''): array
{
$keysAndValues = [];
foreach ($model as $key => $value) {
$keyPath = ($path ? $path . '.' : '') . $key;
if ($value instanceof Model) {
$keysAndValues += $this->extractKeysAndValues($value, $keyPath);
} else {
$keysAndValues[$keyPath] = $this->formatValue($key, $value);
}
}
return $keysAndValues;
}
public static function stream(Query $query): void
{
$query->setResultSetClass(__CLASS__);
foreach ($query as $i => $keysAndValues) {
if ($i === 0) {
echo implode(',', array_keys($keysAndValues));
}
echo "\r\n";
echo implode(',', array_values($keysAndValues));
}
exit;
}
}
|