view->tabs = $this->getTabs() ->activate($this->action_name) ->enableSpecialActions(); $this->backend = Backend::getInstance($this->_getParam('backend')); $this->view->grapher = Hook::get('grapher'); } public function hostsAction() { Benchmark::measure("hostsAction::query()"); $this->view->hosts = $this->query( 'status', array( 'host_icon_image', 'host_name', 'host_state', 'host_address', 'host_acknowledged', 'host_output', 'host_long_output', 'host_in_downtime', 'host_is_flapping', 'host_state_type', 'host_handled', 'host_last_check', 'host_last_state_change', 'host_notifications_enabled', 'host_unhandled_service_count', 'host_action_url', 'host_notes_url', 'host_last_comment' ) ); } public function servicesAction() { $state_type = $this->_getParam('_statetype', 'soft'); if ($state_type = 'soft') { $state_column = 'service_state'; $state_change_column = 'service_last_state_change'; } else { $state_column = 'service_hard_state'; $state_change_column = 'service_last_hard_state_change'; } $this->view->services = $this->query('status', array( 'host_name', 'host_state', 'host_state_type', 'host_last_state_change', 'host_address', 'host_handled', 'service_description', 'service_display_name', 'service_state' => $state_column, 'service_in_downtime', 'service_acknowledged', 'service_handled', 'service_output', 'service_last_state_change' => $state_change_column, 'service_icon_image', 'service_long_output', 'service_is_flapping', 'service_state_type', 'service_handled', 'service_severity', 'service_last_check', 'service_notifications_enabled', 'service_action_url', 'service_notes_url', 'service_last_comment' )); $this->inheritCurrentSortColumn(); } public function hostgroupsAction() { $this->view->hostgroups = $this->backend->select() ->from('hostgroup', array( 'hostgroup_name', 'hostgroup_alias', ))->applyRequest($this->_request); } public function servicegroupsAction() { $this->view->servicegroups = $this->backend->select() ->from('servicegroup', array( 'servicegroup_name', 'servicegroup_alias', ))->applyRequest($this->_request); } public function contactgroupsAction() { $this->view->contactgroups = $this->backend->select() ->from('contactgroup', array( 'contactgroup_name', 'contactgroup_alias', ))->applyRequest($this->_request); } public function contactsAction() { $this->view->contacts = $this->backend->select() ->from('contact', array( 'contact_name', 'contact_alias', 'contact_email', 'contact_pager' ))->applyRequest($this->_request); } // TODO: Search helper playground public function searchAction() { $data = array( 'service_description', 'service_state', 'service_acknowledged', 'service_handled', 'service_output', // '_host_satellite', 'service_last_state_change' ); echo json_encode($data); exit; } /** * Fetch the current downtimes and put them into the view * property 'downtimes' */ public function downtimesAction() { $query = $this->backend->select() ->from('downtime',array( 'host_name', 'object_type', 'service_description', 'downtime_entry_time', 'downtime_internal_downtime_id', 'downtime_author_name', 'downtime_comment_data', 'downtime_duration', 'downtime_scheduled_start_time', 'downtime_scheduled_end_time', 'downtime_is_fixed', 'downtime_is_in_effect', 'downtime_triggered_by_id', 'downtime_trigger_time' )); if (!$this->_getParam('sort')) { $query->order('downtime_is_in_effect'); } $this->view->downtimes = $query->applyRequest($this->_request); $this->inheritCurrentSortColumn(); } protected function query($view, $columns) { $extra = preg_split( '~,~', $this->_getParam('extracolumns', ''), -1, PREG_SPLIT_NO_EMPTY ); $this->view->extraColumns = $extra; $query = $this->backend->select() ->from($view, array_merge($columns, $extra)) ->applyRequest($this->_request); $this->handleFormatRequest($query); return $query; } protected function handleFormatRequest($query) { if ($this->_getParam('format') === 'sql') { echo '
' . htmlspecialchars(wordwrap($query->getQuery()->dump())) . ''; exit; } if ($this->_getParam('format') === 'json' || $this->_request->getHeader('Accept') === 'application/json') { header('Content-type: application/json'); echo json_encode($query->fetchAll()); exit; } if ($this->_getParam('format') === 'csv' || $this->_request->getHeader('Accept') === 'text/csv') { Csv::fromQuery($query)->dump(); exit; } } protected function getTabs() { $tabs = $this->widget('tabs'); $tabs->add('services', array( 'title' => 'All services', 'icon' => 'img/classic/service.png', 'url' => 'monitoring/list/services', )); $tabs->add('hosts', array( 'title' => 'All hosts', 'icon' => 'img/classic/server.png', 'url' => 'monitoring/list/hosts', )); $tabs->add('downtimes', array( 'title' => 'Downtimes', 'icon' => 'img/classic/downtime.gif', 'url' => 'monitoring/list/downtimes', )); /* $tabs->add('hostgroups', array( 'title' => 'Hostgroups', 'icon' => 'img/classic/servers-network.png', 'url' => 'monitoring/list/hostgroups', )); $tabs->add('servicegroups', array( 'title' => 'Servicegroups', 'icon' => 'img/classic/servers-network.png', 'url' => 'monitoring/list/servicegroups', )); $tabs->add('contacts', array( 'title' => 'Contacts', 'icon' => 'img/classic/servers-network.png', 'url' => 'monitoring/list/contacts', )); $tabs->add('contactgroups', array( 'title' => 'Contactgroups', 'icon' => 'img/classic/servers-network.png', 'url' => 'monitoring/list/contactgroups', )); */ return $tabs; } /** * Let the current response inherit the used sort column by applying it to the * view property 'sort' */ private function inheritCurrentSortColumn() { if ($this->_getParam('sort')) { $this->view->sort = $this->_getParam('sort'); } } }