diff --git a/library/Icingadb/Model/HoststateSummary.php b/library/Icingadb/Model/HoststateSummary.php index a55a2d3f..e544acc5 100644 --- a/library/Icingadb/Model/HoststateSummary.php +++ b/library/Icingadb/Model/HoststateSummary.php @@ -4,67 +4,80 @@ namespace Icinga\Module\Icingadb\Model; +use ipl\Sql\Connection; use ipl\Sql\Expression; class HoststateSummary extends Host { + public function getSummaryColumns() + { + return [ + 'hosts_acknowledged' => new Expression( + 'SUM(CASE WHEN host_state.is_acknowledged = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_active_checks_enabled' => new Expression( + 'SUM(CASE WHEN host.active_checks_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_passive_checks_enabled' => new Expression( + 'SUM(CASE WHEN host.passive_checks_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_down_handled' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 1' + . ' AND host_state.is_handled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_down_unhandled' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 1' + . ' AND host_state.is_handled = \'n\' THEN 1 ELSE 0 END)' + ), + 'hosts_event_handler_enabled' => new Expression( + 'SUM(CASE WHEN host.event_handler_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_flapping_enabled' => new Expression( + 'SUM(CASE WHEN host.flapping_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_notifications_enabled' => new Expression( + 'SUM(CASE WHEN host.notifications_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_pending' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 99 THEN 1 ELSE 0 END)' + ), + 'hosts_problems_unacknowledged' => new Expression( + 'SUM(CASE WHEN host_state.is_problem = \'y\'' + . ' AND host_state.is_acknowledged = \'n\' THEN 1 ELSE 0 END)' + ), + 'hosts_total' => new Expression( + 'SUM(CASE WHEN host.id IS NOT NULL THEN 1 ELSE 0 END)' + ), + 'hosts_unreachable' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 2 THEN 1 ELSE 0 END)' + ), + 'hosts_unreachable_handled' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 2' + . ' AND host_state.is_handled = \'y\' THEN 1 ELSE 0 END)' + ), + 'hosts_unreachable_unhandled' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 2' + . ' AND host_state.is_handled = \'n\' THEN 1 ELSE 0 END)' + ), + 'hosts_up' => new Expression( + 'SUM(CASE WHEN host_state.soft_state = 0 THEN 1 ELSE 0 END)' + ) + ]; + } + + public static function on(Connection $db) + { + $q = parent::on($db); + /** @var static $m */ + $m = $q->getModel(); + $q->columns($m->getSummaryColumns()); + + return $q; + } + public function getColumns() { - return array_merge( - parent::getColumns(), - [ - 'hosts_acknowledged' => new Expression( - 'SUM(CASE WHEN host_state.is_acknowledged = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_active_checks_enabled' => new Expression( - 'SUM(CASE WHEN host.active_checks_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_passive_checks_enabled' => new Expression( - 'SUM(CASE WHEN host.passive_checks_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_down_handled' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 1' - . ' AND host_state.is_handled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_down_unhandled' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 1' - . ' AND host_state.is_handled = \'n\' THEN 1 ELSE 0 END)' - ), - 'hosts_event_handler_enabled' => new Expression( - 'SUM(CASE WHEN host.event_handler_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_flapping_enabled' => new Expression( - 'SUM(CASE WHEN host.flapping_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_notifications_enabled' => new Expression( - 'SUM(CASE WHEN host.notifications_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_pending' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 99 THEN 1 ELSE 0 END)' - ), - 'hosts_problems_unacknowledged' => new Expression( - 'SUM(CASE WHEN host_state.is_problem = \'y\'' - . ' AND host_state.is_acknowledged = \'n\' THEN 1 ELSE 0 END)' - ), - 'hosts_total' => new Expression( - 'SUM(CASE WHEN host.id IS NOT NULL THEN 1 ELSE 0 END)' - ), - 'hosts_unreachable' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 2 THEN 1 ELSE 0 END)' - ), - 'hosts_unreachable_handled' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 2' - . ' AND host_state.is_handled = \'y\' THEN 1 ELSE 0 END)' - ), - 'hosts_unreachable_unhandled' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 2' - . ' AND host_state.is_handled = \'n\' THEN 1 ELSE 0 END)' - ), - 'hosts_up' => new Expression( - 'SUM(CASE WHEN host_state.soft_state = 0 THEN 1 ELSE 0 END)' - ) - ] - ); + return array_merge(parent::getColumns(), $this->getSummaryColumns()); } public function getDefaultSort() diff --git a/library/Icingadb/Model/ServicestateSummary.php b/library/Icingadb/Model/ServicestateSummary.php index 062580ce..a2209c62 100644 --- a/library/Icingadb/Model/ServicestateSummary.php +++ b/library/Icingadb/Model/ServicestateSummary.php @@ -4,72 +4,85 @@ namespace Icinga\Module\Icingadb\Model; +use ipl\Sql\Connection; use ipl\Sql\Expression; class ServicestateSummary extends Service { + public function getSummaryColumns() + { + return [ + 'services_acknowledged' => new Expression( + 'SUM(CASE WHEN service_state.is_acknowledged = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_active_checks_enabled' => new Expression( + 'SUM(CASE WHEN service.active_checks_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_passive_checks_enabled' => new Expression( + 'SUM(CASE WHEN service.passive_checks_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_critical_handled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 2' + . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_critical_unhandled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 2' + . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' + ), + 'services_event_handler_enabled' => new Expression( + 'SUM(CASE WHEN service.event_handler_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_flapping_enabled' => new Expression( + 'SUM(CASE WHEN service.flapping_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_notifications_enabled' => new Expression( + 'SUM(CASE WHEN service.notifications_enabled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_ok' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 0 THEN 1 ELSE 0 END)' + ), + 'services_pending' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 99 THEN 1 ELSE 0 END)' + ), + 'services_problems_unacknowledged' => new Expression( + 'SUM(CASE WHEN service_state.is_problem = \'y\'' + . ' AND service_state.is_acknowledged = \'n\' THEN 1 ELSE 0 END)' + ), + 'services_total' => new Expression( + 'SUM(CASE WHEN service.id IS NOT NULL THEN 1 ELSE 0 END)' + ), + 'services_unknown_handled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 3' + . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_unknown_unhandled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 3' + . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' + ), + 'services_warning_handled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 1' + . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' + ), + 'services_warning_unhandled' => new Expression( + 'SUM(CASE WHEN service_state.soft_state = 1' + . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' + ) + ]; + } + + public static function on(Connection $db) + { + $q = parent::on($db); + /** @var static $m */ + $m = $q->getModel(); + $q->columns($m->getSummaryColumns()); + + return $q; + } + public function getColumns() { - return array_merge( - parent::getColumns(), - [ - 'services_acknowledged' => new Expression( - 'SUM(CASE WHEN service_state.is_acknowledged = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_active_checks_enabled' => new Expression( - 'SUM(CASE WHEN service.active_checks_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_passive_checks_enabled' => new Expression( - 'SUM(CASE WHEN service.passive_checks_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_critical_handled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 2' - . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_critical_unhandled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 2' - . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' - ), - 'services_event_handler_enabled' => new Expression( - 'SUM(CASE WHEN service.event_handler_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_flapping_enabled' => new Expression( - 'SUM(CASE WHEN service.flapping_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_notifications_enabled' => new Expression( - 'SUM(CASE WHEN service.notifications_enabled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_ok' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 0 THEN 1 ELSE 0 END)' - ), - 'services_pending' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 99 THEN 1 ELSE 0 END)' - ), - 'services_problems_unacknowledged' => new Expression( - 'SUM(CASE WHEN service_state.is_problem = \'y\'' - . ' AND service_state.is_acknowledged = \'n\' THEN 1 ELSE 0 END)' - ), - 'services_total' => new Expression( - 'SUM(CASE WHEN service.id IS NOT NULL THEN 1 ELSE 0 END)' - ), - 'services_unknown_handled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 3' - . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_unknown_unhandled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 3' - . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' - ), - 'services_warning_handled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 1' - . ' AND service_state.is_handled = \'y\' THEN 1 ELSE 0 END)' - ), - 'services_warning_unhandled' => new Expression( - 'SUM(CASE WHEN service_state.soft_state = 1' - . ' AND service_state.is_handled = \'n\' THEN 1 ELSE 0 END)' - ) - ] - ); + return array_merge(parent::getColumns(), $this->getSummaryColumns()); } public function getDefaultSort()