2015-06-01 12:18:13 +02:00
|
|
|
<?php
|
|
|
|
|
|
|
|
namespace Icinga\Module\Director\Tables;
|
|
|
|
|
2016-11-03 16:06:18 +01:00
|
|
|
use Icinga\Module\Director\Util;
|
2015-06-01 12:18:13 +02:00
|
|
|
use Icinga\Module\Director\Web\Table\QuickTable;
|
|
|
|
|
|
|
|
class ActivityLogTable extends QuickTable
|
|
|
|
{
|
2015-06-30 11:19:31 +02:00
|
|
|
protected $filters = array();
|
|
|
|
|
2016-03-16 22:45:29 +01:00
|
|
|
protected $lastDeployedId;
|
|
|
|
|
2015-11-17 21:16:09 +01:00
|
|
|
protected $extraParams = array();
|
|
|
|
|
2016-05-18 21:49:20 +02:00
|
|
|
protected $lastDay;
|
|
|
|
|
|
|
|
protected $columnCount;
|
|
|
|
|
|
|
|
protected $isUsEnglish;
|
|
|
|
|
2016-11-07 22:04:51 +01:00
|
|
|
protected $searchColumns = array(
|
|
|
|
//'log_message'
|
|
|
|
'author',
|
|
|
|
'object_name',
|
|
|
|
'object_type',
|
|
|
|
'action',
|
|
|
|
);
|
|
|
|
|
2015-06-01 12:18:13 +02:00
|
|
|
public function getColumns()
|
|
|
|
{
|
|
|
|
return array(
|
2016-11-07 22:04:51 +01:00
|
|
|
'log_message' => "'[' || l.author || '] ' || l.action_name || ' '"
|
|
|
|
. " || REPLACE(l.object_type, 'icinga_', '')"
|
|
|
|
. " || ' \"' || l.object_name || '\"'",
|
|
|
|
'author' => 'l.author',
|
|
|
|
'action' => 'l.action_name',
|
|
|
|
'object_name' => 'l.object_name',
|
|
|
|
'object_type' => 'l.object_type',
|
2015-06-01 12:18:13 +02:00
|
|
|
'id' => 'l.id',
|
|
|
|
'change_time' => 'l.change_time',
|
2016-05-18 21:49:20 +02:00
|
|
|
'ts_change_time' => 'UNIX_TIMESTAMP(l.change_time)',
|
2015-06-01 12:18:13 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-03-16 22:45:29 +01:00
|
|
|
public function setLastDeployedId($id)
|
|
|
|
{
|
|
|
|
$this->lastDeployedId = $id;
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2016-02-28 11:16:06 +01:00
|
|
|
protected function listTableClasses()
|
|
|
|
{
|
2016-11-03 16:06:18 +01:00
|
|
|
if (Util::hasPermission('director/showconfig')) {
|
|
|
|
return array_merge(array('activity-log'), parent::listTableClasses());
|
|
|
|
} else {
|
|
|
|
return array('simple', 'common-table', 'activity-log');
|
|
|
|
}
|
2016-02-28 11:16:06 +01:00
|
|
|
}
|
|
|
|
|
2016-05-19 15:23:49 +02:00
|
|
|
public function render()
|
|
|
|
{
|
|
|
|
$data = $this->fetchData();
|
|
|
|
|
|
|
|
$htm = '<table' . $this->createClassAttribute($this->listTableClasses()) . '>' . "\n"
|
|
|
|
. $this->renderTitles($this->getTitles());
|
|
|
|
foreach ($data as $row) {
|
|
|
|
$htm .= $this->renderRow($row);
|
|
|
|
}
|
|
|
|
return $htm . "</tbody>\n</table>\n";
|
|
|
|
}
|
|
|
|
|
2016-05-18 21:49:20 +02:00
|
|
|
protected function renderRow($row)
|
|
|
|
{
|
|
|
|
$row->change_time = strftime('%H:%M:%S', $row->ts_change_time);
|
|
|
|
return $this->renderDayIfNew($row) . parent::renderRow($row);
|
|
|
|
}
|
|
|
|
|
2016-03-16 22:45:29 +01:00
|
|
|
protected function getRowClasses($row)
|
|
|
|
{
|
2016-11-07 22:04:51 +01:00
|
|
|
$action = 'action-' . $row->action. ' ';
|
2016-03-16 22:45:29 +01:00
|
|
|
|
|
|
|
if ($row->id > $this->lastDeployedId) {
|
|
|
|
return $action . 'undeployed';
|
|
|
|
} else {
|
|
|
|
return $action . 'deployed';
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-06-01 12:42:40 +02:00
|
|
|
protected function getActionUrl($row)
|
2015-06-01 12:18:13 +02:00
|
|
|
{
|
2016-11-03 16:06:18 +01:00
|
|
|
if (Util::hasPermission('director/showconfig')) {
|
|
|
|
return $this->url(
|
|
|
|
'director/show/activitylog',
|
|
|
|
array_merge(array('id' => $row->id), $this->extraParams)
|
|
|
|
);
|
|
|
|
|
|
|
|
} else {
|
|
|
|
return false;
|
|
|
|
}
|
2015-06-01 12:18:13 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
public function getTitles()
|
|
|
|
{
|
|
|
|
$view = $this->view();
|
|
|
|
return array(
|
2016-05-18 21:49:20 +02:00
|
|
|
// 'author' => $view->translate('Author'),
|
|
|
|
'log_message' => $view->translate('Action'),
|
2015-11-17 21:16:37 +01:00
|
|
|
'change_time' => $view->translate('Timestamp'),
|
2015-06-01 12:18:13 +02:00
|
|
|
);
|
|
|
|
}
|
|
|
|
|
2016-05-18 21:49:20 +02:00
|
|
|
protected function renderTitles($row)
|
|
|
|
{
|
|
|
|
return '';
|
|
|
|
}
|
|
|
|
|
|
|
|
protected function isUsEnglish()
|
|
|
|
{
|
|
|
|
if ($this->isUsEnglish === null) {
|
|
|
|
$this->isUsEnglish = in_array(setlocale(LC_ALL, 0), array('en_US.UTF-8', 'C'));
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->isUsEnglish;
|
|
|
|
}
|
|
|
|
|
2016-11-07 22:04:51 +01:00
|
|
|
/**
|
|
|
|
* @param object $row
|
|
|
|
* @return string
|
|
|
|
*/
|
2016-05-18 21:49:20 +02:00
|
|
|
protected function renderDayIfNew($row)
|
|
|
|
{
|
|
|
|
$view = $this->view();
|
|
|
|
|
|
|
|
if ($this->isUsEnglish()) {
|
|
|
|
$day = date('l, jS F Y', (int) $row->ts_change_time);
|
|
|
|
} else {
|
|
|
|
$day = strftime('%A, %e. %B, %Y', (int) $row->ts_change_time);
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->lastDay === $day) {
|
2016-11-07 22:04:51 +01:00
|
|
|
return '';
|
2016-05-18 21:49:20 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->lastDay === null) {
|
|
|
|
$htm = "<thead>\n <tr>\n";
|
|
|
|
} else {
|
|
|
|
$htm = "</tbody>\n<thead>\n <tr>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
if ($this->columnCount === null) {
|
|
|
|
$this->columnCount = count($this->getTitles());
|
|
|
|
}
|
|
|
|
|
2016-11-07 22:04:51 +01:00
|
|
|
$htm .= '<th colspan="' . $this->columnCount . '">' . $view->escape($day) . '</th>' . "\n";
|
2016-05-18 21:49:20 +02:00
|
|
|
if ($this->lastDay === null) {
|
|
|
|
$htm .= " </tr>\n";
|
|
|
|
} else {
|
|
|
|
$htm .= " </tr>\n</thead>\n";
|
|
|
|
}
|
|
|
|
|
|
|
|
$this->lastDay = $day;
|
|
|
|
|
|
|
|
return $htm . "<tbody>\n";
|
|
|
|
}
|
|
|
|
|
2015-06-30 11:19:31 +02:00
|
|
|
public function filterObject($type, $name)
|
|
|
|
{
|
|
|
|
$this->filters[] = array('l.object_type = ?', $type);
|
|
|
|
$this->filters[] = array('l.object_name = ?', $name);
|
2015-11-17 21:16:09 +01:00
|
|
|
$this->extraParams = array(
|
|
|
|
'type' => $type,
|
|
|
|
'name' => $name,
|
|
|
|
);
|
2015-06-30 11:19:31 +02:00
|
|
|
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-07-23 16:19:22 +02:00
|
|
|
public function getBaseQuery()
|
2015-06-01 12:18:13 +02:00
|
|
|
{
|
2016-11-02 14:27:23 +01:00
|
|
|
$query = $this->db()->select()->from(
|
2015-06-01 12:18:13 +02:00
|
|
|
array('l' => 'director_activity_log'),
|
2015-07-23 16:19:22 +02:00
|
|
|
array()
|
2016-02-24 21:34:13 +01:00
|
|
|
)->order('change_time DESC')->order('id DESC');
|
2015-06-01 12:18:13 +02:00
|
|
|
|
2015-06-30 11:19:31 +02:00
|
|
|
foreach ($this->filters as $filter) {
|
|
|
|
$query->where($filter[0], $filter[1]);
|
|
|
|
}
|
|
|
|
|
2015-07-23 16:19:22 +02:00
|
|
|
return $query;
|
2015-06-01 12:18:13 +02:00
|
|
|
}
|
2016-12-28 16:01:48 +01:00
|
|
|
|
|
|
|
public function count()
|
|
|
|
{
|
|
|
|
$db = $this->db();
|
|
|
|
$sub = clone($this->getBaseQuery());
|
|
|
|
$sub->reset('order')->columns('l.id')->limit(2501);
|
|
|
|
$this->applyFiltersToQuery($sub);
|
|
|
|
$query = $db->select()->from(
|
|
|
|
array('s' => $sub),
|
|
|
|
array('c' => 'COUNT(*)')
|
|
|
|
);
|
|
|
|
|
|
|
|
return $db->fetchOne($query);
|
|
|
|
}
|
2015-06-01 12:18:13 +02:00
|
|
|
}
|