2015-04-24 14:27:22 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Icinga\Module\Director\Tables;
|
|
|
|
|
2015-07-23 16:19:22 +02:00
|
|
|
use Icinga\Data\Limitable;
|
2015-12-15 17:16:07 +01:00
|
|
|
use Icinga\Module\Director\Web\Table\IcingaObjectTable;
|
2015-04-24 14:27:22 +02:00
|
|
|
|
2015-12-15 17:16:07 +01:00
|
|
|
class IcingaHostTable extends IcingaObjectTable
|
2015-04-24 14:27:22 +02:00
|
|
|
{
|
2015-07-29 15:30:10 +02:00
|
|
|
protected $searchColumns = array(
|
|
|
|
'host',
|
|
|
|
);
|
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
public function getColumns()
|
|
|
|
{
|
2016-03-02 13:42:37 +01:00
|
|
|
if ($this->connection()->isPgsql()) {
|
2016-03-01 04:27:04 +01:00
|
|
|
$parents = "ARRAY_TO_STRING(ARRAY_AGG(ih.object_name ORDER BY hi.weight), ', ')";
|
|
|
|
} else {
|
2016-03-01 00:22:28 +01:00
|
|
|
$parents = "GROUP_CONCAT(ih.object_name ORDER BY hi.weight SEPARATOR ', ')";
|
2016-03-01 04:27:04 +01:00
|
|
|
}
|
2016-03-01 00:22:28 +01:00
|
|
|
|
2015-04-24 14:27:22 +02:00
|
|
|
return array(
|
2015-12-15 17:16:07 +01:00
|
|
|
'id' => 'h.id',
|
|
|
|
'host' => 'h.object_name',
|
|
|
|
'object_type' => 'h.object_type',
|
|
|
|
'address' => 'h.address',
|
|
|
|
'zone' => 'z.object_name',
|
2016-03-01 00:22:28 +01:00
|
|
|
'parents' => $parents,
|
2015-04-24 14:27:22 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-06-01 12:42:40 +02:00
|
|
|
protected function getActionUrl($row)
|
2015-04-24 14:27:22 +02:00
|
|
|
{
|
2015-07-02 14:31:35 +02:00
|
|
|
return $this->url('director/host', array('name' => $row->host));
|
2015-04-24 14:27:22 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitles()
|
|
|
|
{
|
|
|
|
$view = $this->view();
|
|
|
|
return array(
|
|
|
|
'host' => $view->translate('Hostname'),
|
2015-07-28 15:20:39 +02:00
|
|
|
'parents' => $view->translate('Imports'),
|
2015-04-24 14:27:22 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2015-07-28 15:20:39 +02:00
|
|
|
protected function getUnfilteredQuery()
|
2015-04-24 14:27:22 +02:00
|
|
|
{
|
|
|
|
$db = $this->connection()->getConnection();
|
|
|
|
$query = $db->select()->from(
|
|
|
|
array('h' => 'icinga_host'),
|
2015-07-23 16:19:22 +02:00
|
|
|
array()
|
2015-04-24 14:27:22 +02:00
|
|
|
)->joinLeft(
|
|
|
|
array('z' => 'icinga_zone'),
|
|
|
|
'h.zone_id = z.id',
|
|
|
|
array()
|
2015-07-28 15:20:39 +02:00
|
|
|
)->joinLeft(
|
|
|
|
array('hi' => 'icinga_host_inheritance'),
|
|
|
|
'hi.host_id = h.id',
|
|
|
|
array()
|
|
|
|
)->joinLeft(
|
|
|
|
array('ih' => 'icinga_host'),
|
|
|
|
'hi.parent_host_id = ih.id',
|
|
|
|
array()
|
2016-03-01 04:27:04 +01:00
|
|
|
)->group('h.id')
|
|
|
|
->group('z.id')
|
|
|
|
->order('h.object_name');
|
2015-04-24 14:27:22 +02:00
|
|
|
|
2015-07-23 16:19:22 +02:00
|
|
|
return $query;
|
2015-04-24 14:27:22 +02:00
|
|
|
}
|
2015-07-28 15:20:39 +02:00
|
|
|
|
|
|
|
public function count()
|
|
|
|
{
|
|
|
|
$db = $this->connection()->getConnection();
|
|
|
|
$sub = clone($this->getBaseQuery());
|
|
|
|
$sub->columns($this->getColumns());
|
2016-04-22 17:03:49 +02:00
|
|
|
$this->applyFiltersToQuery($sub);
|
2015-07-28 15:20:39 +02:00
|
|
|
$query = $db->select()->from(
|
|
|
|
array('sub' => $sub),
|
|
|
|
'COUNT(*)'
|
|
|
|
);
|
|
|
|
|
|
|
|
return $db->fetchOne($query);
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getBaseQuery()
|
|
|
|
{
|
2015-12-15 19:01:48 +01:00
|
|
|
return $this->getUnfilteredQuery();
|
2015-07-28 15:20:39 +02:00
|
|
|
}
|
2015-04-24 14:27:22 +02:00
|
|
|
}
|