From e45723c4db387e0c8dc89f2d7760b25871c1070e Mon Sep 17 00:00:00 2001 From: Eric Lippmann Date: Wed, 27 Jan 2016 17:38:31 +0100 Subject: [PATCH] monitoring: Control features for multiple selected services refs #8963 --- .../controllers/ServicesController.php | 71 +++++++++---------- .../views/scripts/services/show.phtml | 2 + 2 files changed, 34 insertions(+), 39 deletions(-) diff --git a/modules/monitoring/application/controllers/ServicesController.php b/modules/monitoring/application/controllers/ServicesController.php index 2527b0f92..079c41b56 100644 --- a/modules/monitoring/application/controllers/ServicesController.php +++ b/modules/monitoring/application/controllers/ServicesController.php @@ -14,6 +14,7 @@ use Icinga\Module\Monitoring\Forms\Command\Object\RemoveAcknowledgementCommandFo use Icinga\Module\Monitoring\Forms\Command\Object\ScheduleServiceCheckCommandForm; use Icinga\Module\Monitoring\Forms\Command\Object\ScheduleServiceDowntimeCommandForm; use Icinga\Module\Monitoring\Forms\Command\Object\SendCustomNotificationCommandForm; +use Icinga\Module\Monitoring\Forms\Command\Object\ToggleObjectFeaturesCommandForm; use Icinga\Module\Monitoring\Object\ServiceList; use Icinga\Web\Url; use Icinga\Web\Widget\Tabextension\DashboardAction; @@ -34,6 +35,27 @@ class ServicesController extends Controller (string) $this->params->without(array('service_problem', 'service_handled', 'view')) )); $this->serviceList = $serviceList; + $this->serviceList->setColumns(array( + 'host_display_name', + 'host_handled', + 'host_name', + 'host_problem', + 'host_state', + 'service_acknowledged', + 'service_active_checks_enabled', + 'service_description', + 'service_display_name', + 'service_event_handler_enabled', + 'service_flap_detection_enabled', + 'service_handled', + 'service_in_downtime', + 'service_is_flapping', + 'service_last_state_change', + 'service_notifications_enabled', + 'service_passive_checks_enabled', + 'service_problem', + 'service_state' + )); $this->view->baseFilter = $this->serviceList->getFilter(); $this->view->listAllLink = Url::fromRequest()->setPath('monitoring/list/services'); $this->getTabs()->add( @@ -51,26 +73,6 @@ class ServicesController extends Controller protected function handleCommandForm(ObjectsCommandForm $form) { - $this->serviceList->setColumns(array( - 'host_display_name', - 'host_handled', - 'host_name', - 'host_problem', - 'host_state', - 'service_acknowledged', - 'service_active_checks_enabled', - 'service_description', - 'service_display_name', - 'service_handled', - 'service_in_downtime', - 'service_is_flapping', - 'service_last_state_change', - 'service_notifications_enabled', - 'service_passive_checks_enabled', - 'service_problem', - 'service_state' - )); - $form ->setObjects($this->serviceList) ->setRedirectUrl(Url::fromPath('monitoring/services/show')->setParams($this->params)) @@ -92,25 +94,6 @@ class ServicesController extends Controller ->setObjects($this->serviceList) ->handleRequest(); $this->view->checkNowForm = $checkNowForm; - $this->serviceList->setColumns(array( - 'host_display_name', - 'host_handled', - 'host_name', - 'host_problem', - 'host_state', - 'service_acknowledged', - 'service_active_checks_enabled', - 'service_description', - 'service_display_name', - 'service_handled', - 'service_in_downtime', - 'service_is_flapping', - 'service_last_state_change', - 'service_notifications_enabled', - 'service_passive_checks_enabled', - 'service_problem', - 'service_state' - )); $acknowledgedObjects = $this->serviceList->getAcknowledgedObjects(); if (! empty($acknowledgedObjects)) { @@ -121,6 +104,16 @@ class ServicesController extends Controller $this->view->removeAckForm = $removeAckForm; } + $featureStatus = $this->serviceList->getFeatureStatus(); + $toggleFeaturesForm = new ToggleObjectFeaturesCommandForm(array( + 'backend' => $this->backend, + 'objects' => $this->serviceList + )); + $toggleFeaturesForm + ->load((object) $featureStatus) + ->handleRequest(); + $this->view->toggleFeaturesForm = $toggleFeaturesForm; + $this->setAutorefreshInterval(15); $this->view->rescheduleAllLink = Url::fromRequest()->setPath('monitoring/services/reschedule-check'); $this->view->downtimeAllLink = Url::fromRequest()->setPath('monitoring/services/schedule-downtime'); diff --git a/modules/monitoring/application/views/scripts/services/show.phtml b/modules/monitoring/application/views/scripts/services/show.phtml index fe9b0a51e..167016be4 100644 --- a/modules/monitoring/application/views/scripts/services/show.phtml +++ b/modules/monitoring/application/views/scripts/services/show.phtml @@ -197,5 +197,7 @@ +

translate('Feature Commands') ?>

+