icingaweb2-module-director/application/tables/IcingaServiceTable.php

140 lines
4.1 KiB
PHP
Raw Normal View History

<?php
namespace Icinga\Module\Director\Tables;
use Icinga\Data\Filter\Filter;
use Icinga\Exception\IcingaException;
use Icinga\Module\Director\IcingaConfig\AssignRenderer;
2016-03-24 13:08:35 +01:00
use Icinga\Module\Director\Web\Table\QuickTable;
2016-03-24 13:08:35 +01:00
class IcingaServiceTable extends QuickTable
{
protected $searchColumns = array(
'service',
);
public function getColumns()
{
return array(
'id' => 's.id',
'service' => 's.object_name',
'object_type' => 's.object_type',
2016-03-24 13:08:35 +01:00
'check_command_id' => 's.check_command_id',
);
}
2016-03-24 13:08:35 +01:00
protected function listTableClasses()
{
return array_merge(array('assignment-table'), parent::listTableClasses());
}
protected function getActionUrl($row)
{
// TODO: Remove once we got a separate apply table
if ($row->object_type === 'apply') {
$params['id'] = $row->id;
} else {
$params = array('name' => $row->service);
}
return $this->url('director/service', $params);
}
2016-03-24 13:08:35 +01:00
protected function renderRow($row)
{
$v = $this->view();
$extra = $this->appliedOnes($row->id);
$htm = " <tr" . $this->getRowClassesString($row) . ">\n";
$htm .= '<td>' . $v->qlink($row->service, $this->getActionUrl($row));
if (empty($extra)) {
if ($row->check_command_id) {
$htm .= ' ' . $v->qlink(
'Create apply-rule',
'director/service/add',
array('apply' => $row->service),
array('class' => 'icon-plus')
);
2016-03-24 13:08:35 +01:00
}
} else {
$htm .= '. Related apply rules: <table class="apply-rules">';
foreach ($extra as $service) {
$href = $v->url('director/service', array('id' => $service->id));
$htm .= "<tr href=\"$href\">";
try {
$prettyFilter = AssignRenderer::forFilter(
Filter::fromQueryString($service->assign_filter)
)->renderAssign();
}
catch (IcingaException $e) {
// ignore errors in filter rendering
$prettyFilter = 'Error in Filter rendering: ' . $e->getMessage();
}
$htm .= "<td><a href=\"$href\">" . $service->object_name . '</a></td>';
$htm .= '<td>' . $prettyFilter . '</td>';
$htm .= '<tr>';
2016-03-24 13:08:35 +01:00
}
$htm .= '</table>';
2016-03-24 13:08:35 +01:00
$htm .= $v->qlink(
'Add more',
2016-03-26 16:15:26 +01:00
'director/service/add',
array('apply' => $row->service),
2016-03-24 13:08:35 +01:00
array('class' => 'icon-plus')
);
}
$htm .= '</td>';
return $htm . " </tr>\n";
}
public function getTitles()
{
$view = $this->view();
return array(
'service' => $view->translate('Servicename'),
);
}
public function getUnfilteredQuery()
{
$db = $this->connection()->getConnection();
$query = $db->select()->from(
array('s' => 'icinga_service'),
array()
);
return $query;
}
2016-03-24 13:08:35 +01:00
protected function appliedOnes($id)
{
$db = $this->connection()->getConnection();
$query = $db->select()->from(
array('s' => 'icinga_service'),
array(
'id' => 's.id',
'object_name' => 's.object_name',
'assign_filter' => 's.assign_filter',
2016-03-24 13:08:35 +01:00
)
)->join(
array('i' => 'icinga_service_inheritance'),
'i.service_id = s.id',
array()
)->where('i.parent_service_id = ?', $id)
->where('s.object_type = ?', 'apply');
2016-03-24 13:08:35 +01:00
return $db->fetchAll($query);
2016-03-24 13:08:35 +01:00
}
public function getBaseQuery()
{
return $this->getUnfilteredQuery()->where(
's.object_type IN (?)',
2016-03-24 13:08:35 +01:00
array('template')
)->order('CASE WHEN s.check_command_id IS NULL THEN 1 ELSE 0 END')
->order('s.object_name');
}
}