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
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
|
<?php
// Icinga Web 2 Cube Module | (c) 2022 Icinga GmbH | GPLv2
namespace Icinga\Module\Cube\IcingaDb;
use Icinga\Module\Cube\CubeRenderer\ServiceStatusCubeRenderer;
use Icinga\Module\Icingadb\Model\CustomvarFlat;
use Icinga\Module\Icingadb\Model\Service;
use Icinga\Module\Icingadb\Model\ServicestateSummary;
use ipl\Stdlib\Filter;
class IcingaDbServiceStatusCube extends IcingaDbCube
{
public function getRenderer()
{
return new ServiceStatusCubeRenderer($this);
}
public function createDimension($name)
{
$this->registerAvailableDimensions();
if (isset($this->availableDimensions[$name])) {
return clone $this->availableDimensions[$name];
}
return new CustomVariableDimension($name);
}
public function getAvailableFactColumns()
{
return [
'services_cnt' => 'services_total',
'services_critical' => 'services_critical_handled + f.services_critical_unhandled',
'services_unhandled_critical' => 'services_critical_unhandled',
'services_warning' => 'services_warning_handled + f.services_warning_unhandled',
'services_unhandled_warning' => 'services_warning_unhandled',
'services_unknown' => 'services_unknown_handled + f.services_unknown_unhandled',
'services_unhandled_unknown' => 'services_unknown_unhandled',
];
}
public function listAvailableDimensions()
{
$db = $this->getDb();
$query = CustomvarFlat::on($db);
$this->applyRestrictions($query);
$query
->columns('flatname')
->orderBy('flatname')
->filter(Filter::like('service.id', '*'));
$query->getSelectBase()->groupBy('flatname');
$dimensions = [];
foreach ($query as $row) {
// Replaces array index notations with [*] to get results for arbitrary indexes
$name = preg_replace('/\\[\d+](?=\\.|$)/', '[*]', $row->flatname);
$dimensions[$name] = $name;
}
return $dimensions;
}
public function prepareInnerQuery()
{
$query = ServicestateSummary::on($this->getDb());
$query->columns(array_diff_key($query->getModel()->getColumns(), (new Service())->getColumns()));
$query->disableDefaultSort();
$this->applyRestrictions($query);
return $query;
}
/**
* Return Filter for Services cube.
*
* @return Filter\Any|Filter\Chain
*/
public function getObjectsFilter()
{
if ($this->objectsFilter === null) {
$this->finalizeInnerQuery();
$services = $this->innerQuery()->columns([
'host_name' => 'host.name',
'service_name' => 'service.name'
]);
$services->getSelectBase()->resetGroupBy();
$filter = Filter::any();
foreach ($services as $service) {
$filter->add(
Filter::all(
Filter::equal('service.name', $service->service_name),
Filter::equal('host.name', $service->host_name)
)
);
}
$this->objectsFilter = $filter;
}
return $this->objectsFilter;
}
}
|