From 796742f03da77dcfe8636deac9a2d67bc9aa4c9f Mon Sep 17 00:00:00 2001 From: Johannes Meyer Date: Fri, 25 Feb 2022 17:02:42 +0100 Subject: [PATCH] monitoring/list/hosts: Don't show unhandled service counts It has too much problems. It wasn't even visible since the initial release, at least not if there were many results. It being visible was more a case of chance than guarantee. We now also identified a major issue with restrictions and the way we can assemble queries here. In short, there are too much technical difficulties that we deemed it not worthwhile to keep. --- .../controllers/ListController.php | 4 - .../views/scripts/list/hosts.phtml | 27 --- .../Query/HostserviceproblemsummaryQuery.php | 172 ------------------ .../Backend/Ido/Query/HoststatusQuery.php | 15 -- modules/monitoring/public/css/tables.less | 7 - 5 files changed, 225 deletions(-) delete mode 100644 modules/monitoring/library/Monitoring/Backend/Ido/Query/HostserviceproblemsummaryQuery.php diff --git a/modules/monitoring/application/controllers/ListController.php b/modules/monitoring/application/controllers/ListController.php index f95279b41..397b68325 100644 --- a/modules/monitoring/application/controllers/ListController.php +++ b/modules/monitoring/application/controllers/ListController.php @@ -109,12 +109,8 @@ class ListController extends Controller )); $this->applyRestriction('monitoring/filter/objects', $stats); - $summary = $hosts->getQuery()->queryServiceProblemSummary(); - $this->applyRestriction('monitoring/filter/objects', $summary); - $this->view->hosts = $hosts; $this->view->stats = $stats; - $this->view->summary = $summary->fetchPairs(); } /** diff --git a/modules/monitoring/application/views/scripts/list/hosts.phtml b/modules/monitoring/application/views/scripts/list/hosts.phtml index c412f2f52..12a9871de 100644 --- a/modules/monitoring/application/views/scripts/list/hosts.phtml +++ b/modules/monitoring/application/views/scripts/list/hosts.phtml @@ -60,33 +60,6 @@ if (! $this->compact): ?> 'class' => 'rowaction' ) ) ?> - host_name])): ?> - (qlink( - sprintf( - $this->translatePlural( - '%u unhandled service', '%u unhandled services', $summary[$host->host_name] - ), - $summary[$host->host_name] - ), - 'monitoring/list/services', - array( - 'host' => $host->host_name, - 'service_problem' => 1, - 'service_handled' => 0 - ), - array( - 'title' => sprintf( - $this->translatePlural( - 'List %s unhandled service problem on host %s', - 'List %s unhandled service problems on host %s', - $summary[$host->host_name] - ), - $summary[$host->host_name], - $host->host_name - ) - ) - ) ?>) - hostFlags($host) ?>

pluginOutput($this->ellipsis($host->host_output, 10000), true, $host->host_check_command) ?>

diff --git a/modules/monitoring/library/Monitoring/Backend/Ido/Query/HostserviceproblemsummaryQuery.php b/modules/monitoring/library/Monitoring/Backend/Ido/Query/HostserviceproblemsummaryQuery.php deleted file mode 100644 index 653834ae9..000000000 --- a/modules/monitoring/library/Monitoring/Backend/Ido/Query/HostserviceproblemsummaryQuery.php +++ /dev/null @@ -1,172 +0,0 @@ - array( - 'instance_name' => 'i.instance_name' - ), - 'services' => array( - 'host_name' => 'so.name1', - 'service_description' => 'so.name2' - ), - 'hostgroups' => array( - 'hostgroup_name' => 'hgo.name1' - ), - 'servicegroups' => array( - 'servicegroup_name' => 'sgo.name1' - ), - 'problemsummary' => array( - 'unhandled_service_count' => 'SUM( - CASE - WHEN (ss.problem_has_been_acknowledged + ss.scheduled_downtime_depth + COALESCE(hs.current_state, 0)) > 0 - THEN 0 - ELSE 1 - END - )' - ) - ); - - /** - * Set the HoststatusQuery to use - * - * @param HoststatusQuery $query - * - * @return $this - */ - public function setHoststatusQuery(HoststatusQuery $query) - { - $this->hostStatusQuery = clone $query; - $this->hostStatusQuery - ->setIsSubQuery() - ->columns(array('object_id')); - if ($this->hostStatusQuery->hasOrder()) { - /* - * This works like this: - * 1. Get automatic group by definitions - * 2. Append the order by columns to them - * 3. Pass the entire result back to the query - * 4. Rely on the fact that `array_unique` (which is eventually used by IdoQuery::getGroup()) - * keeps the first items and removes subsequent ones so that the automatic group columns - * are still first in the definition (mind blown?) - */ - $groupBy = $this->hostStatusQuery->getGroup(); - foreach ($this->hostStatusQuery->getOrder() as list($column, $_)) { - $groupBy[] = $column; - } - - $this->hostStatusQuery->group($groupBy); - } - - return $this; - } - - /** - * {@inheritdoc} - */ - protected function joinBaseTables() - { - $this->select->from( - array('so' => $this->prefix . 'objects'), - array() - )->join( - array('s' => $this->prefix . 'services'), - 's.service_object_id = so.object_id AND so.is_active = 1', - array() - ); - $this->select->group('so.name1'); - $this->joinedVirtualTables['services'] = true; - } - - /** - * Join instances - */ - protected function joinInstances() - { - $this->select->join( - array('i' => $this->prefix . 'instances'), - 'i.instance_id = so.instance_id', - array() - ); - } - - /** - * Join host groups - */ - protected function joinHostgroups() - { - $this->select->joinLeft( - array('hgm' => $this->prefix . 'hostgroup_members'), - 'hgm.host_object_id = s.host_object_id', - array() - )->joinLeft( - array('hg' => $this->prefix . 'hostgroups'), - 'hg.hostgroup_id = hgm.hostgroup_id', - array() - )->joinLeft( - array('hgo' => $this->prefix . 'objects'), - 'hgo.object_id = hg.hostgroup_object_id AND hgo.is_active = 1 AND hgo.objecttype_id = 3', - array() - ); - } - - /** - * Join service groups - */ - protected function joinServicegroups() - { - $this->select->joinLeft( - array('sgm' => $this->prefix . 'servicegroup_members'), - 'sgm.service_object_id = so.object_id', - array() - )->joinLeft( - array('sg' => $this->prefix . 'servicegroups'), - 'sgm.servicegroup_id = sg.servicegroup_id', - array() - )->joinLeft( - array('sgo' => $this->prefix . 'objects'), - 'sgo.object_id = sg.servicegroup_object_id AND sgo.is_active = 1 AND sgo.objecttype_id = 4', - array() - ); - } - - /** - * Join the statussummary - */ - protected function joinProblemsummary() - { - $this->select->join( - array('ss' => $this->prefix . 'servicestatus'), - 'ss.service_object_id = so.object_id AND ss.current_state > 0', - array() - )->join( - array('hs' => $this->prefix . 'hoststatus'), - 'hs.host_object_id = s.host_object_id', - array() - )->join( - array('h' => $this->hostStatusQuery), - 'h.object_id = s.host_object_id', - array() - ); - - $this->select->having($this->getMappedField('unhandled_service_count') . ' > 0'); - } -} diff --git a/modules/monitoring/library/Monitoring/Backend/Ido/Query/HoststatusQuery.php b/modules/monitoring/library/Monitoring/Backend/Ido/Query/HoststatusQuery.php index b4ef3d2ad..e1b548053 100644 --- a/modules/monitoring/library/Monitoring/Backend/Ido/Query/HoststatusQuery.php +++ b/modules/monitoring/library/Monitoring/Backend/Ido/Query/HoststatusQuery.php @@ -321,21 +321,6 @@ class HoststatusQuery extends IdoQuery ); } - /** - * Query the service problem summary for all hosts of this query's result set - * - * @return HostserviceproblemsummaryQuery - */ - public function queryServiceProblemSummary() - { - return $this->createSubQuery('Hostserviceproblemsummary') - ->setHostStatusQuery($this) - ->columns(array( - 'host_name', - 'unhandled_service_count' - )); - } - protected function joinSubQuery(IdoQuery $query, $name, $filter, $and, $negate, &$additionalFilter) { if ($name === 'hostgroup') { diff --git a/modules/monitoring/public/css/tables.less b/modules/monitoring/public/css/tables.less index ea1747761..c5b5f27f5 100644 --- a/modules/monitoring/public/css/tables.less +++ b/modules/monitoring/public/css/tables.less @@ -63,13 +63,6 @@ font-size: @font-size-small; } -// Link to unhandled services in the hosts overview -.host-services-incidents { - color: @color-critical; - font-family: @font-family-wide; - font-size: @font-size-small; -} - // Notification recipient in the notifications overview .notification-recipient { color: @text-color-light;