2013-10-10 14:40:13 +02:00
|
|
|
<?php
|
2016-02-08 15:41:00 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013 Icinga Development Team | GPLv2+ */
|
2013-10-10 14:40:13 +02:00
|
|
|
|
|
|
|
namespace Icinga\Module\Monitoring;
|
|
|
|
|
2015-06-18 16:42:27 +02:00
|
|
|
use Icinga\Exception\ConfigurationError;
|
|
|
|
use Icinga\Exception\QueryException;
|
2015-01-27 14:22:37 +01:00
|
|
|
use Icinga\Data\Filter\Filter;
|
2015-01-27 14:24:56 +01:00
|
|
|
use Icinga\Data\Filterable;
|
2015-01-27 14:22:37 +01:00
|
|
|
use Icinga\File\Csv;
|
2015-04-08 15:08:14 +02:00
|
|
|
use Icinga\Web\Controller as IcingaWebController;
|
2014-06-20 12:26:00 +02:00
|
|
|
use Icinga\Web\Url;
|
2013-10-10 14:40:13 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Base class for all monitoring action controller
|
|
|
|
*/
|
2015-04-08 15:08:14 +02:00
|
|
|
class Controller extends IcingaWebController
|
2013-10-10 14:40:13 +02:00
|
|
|
{
|
2014-06-17 14:55:43 +02:00
|
|
|
/**
|
|
|
|
* The backend used for this controller
|
|
|
|
*
|
|
|
|
* @var Backend
|
|
|
|
*/
|
|
|
|
protected $backend;
|
|
|
|
|
|
|
|
protected function moduleInit()
|
|
|
|
{
|
|
|
|
$this->backend = Backend::createBackend($this->_getParam('backend'));
|
2014-06-20 12:26:00 +02:00
|
|
|
$this->view->url = Url::fromRequest();
|
2014-06-17 14:55:43 +02:00
|
|
|
}
|
|
|
|
|
2013-10-22 15:57:30 +02:00
|
|
|
protected function handleFormatRequest($query)
|
2013-10-10 14:40:13 +02:00
|
|
|
{
|
2014-03-06 10:17:55 +01:00
|
|
|
if ($this->_getParam('format') === 'sql') {
|
2013-10-10 14:40:13 +02:00
|
|
|
echo '<pre>'
|
|
|
|
. htmlspecialchars(wordwrap($query->dump()))
|
|
|
|
. '</pre>';
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
if ($this->_getParam('format') === 'json'
|
2013-10-17 21:40:02 +02:00
|
|
|
|| $this->_request->getHeader('Accept') === 'application/json') {
|
2013-10-10 14:40:13 +02:00
|
|
|
header('Content-type: application/json');
|
2014-06-21 00:09:11 +02:00
|
|
|
echo json_encode($query->getQuery()->fetchAll());
|
2013-10-10 14:40:13 +02:00
|
|
|
exit;
|
|
|
|
}
|
|
|
|
if ($this->_getParam('format') === 'csv'
|
|
|
|
|| $this->_request->getHeader('Accept') === 'text/csv') {
|
|
|
|
Csv::fromQuery($query)->dump();
|
|
|
|
exit;
|
|
|
|
}
|
|
|
|
}
|
2015-01-27 14:22:37 +01:00
|
|
|
|
|
|
|
/**
|
2015-08-20 13:07:57 +02:00
|
|
|
* Apply a restriction of the authenticated on the given filterable
|
2015-01-27 14:22:37 +01:00
|
|
|
*
|
2015-08-20 13:07:57 +02:00
|
|
|
* @param string $name Name of the restriction
|
|
|
|
* @param Filterable $filterable Filterable to restrict
|
2015-01-27 14:22:37 +01:00
|
|
|
*
|
2015-08-20 13:07:57 +02:00
|
|
|
* @return Filterable The filterable having the restriction applied
|
2015-01-27 14:22:37 +01:00
|
|
|
*/
|
2015-08-20 13:07:57 +02:00
|
|
|
protected function applyRestriction($name, Filterable $filterable)
|
2015-01-27 14:22:37 +01:00
|
|
|
{
|
2015-08-20 14:24:06 +02:00
|
|
|
$filterable->applyFilter($this->getRestriction($name));
|
2015-08-20 13:07:57 +02:00
|
|
|
return $filterable;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get a restriction of the authenticated
|
|
|
|
*
|
|
|
|
* @param string $name Name of the restriction
|
|
|
|
*
|
|
|
|
* @return Filter|null Filter object or null if the authenticated user is not restricted
|
|
|
|
* @throws ConfigurationError If the restriction contains invalid filter columns
|
|
|
|
*/
|
|
|
|
protected function getRestriction($name)
|
|
|
|
{
|
|
|
|
$restriction = Filter::matchAny();
|
|
|
|
$restriction->setAllowedFilterColumns(array(
|
2015-06-18 16:42:27 +02:00
|
|
|
'host_name',
|
|
|
|
'hostgroup_name',
|
2015-09-07 11:33:44 +02:00
|
|
|
'instance_name',
|
2015-06-18 16:42:27 +02:00
|
|
|
'service_description',
|
|
|
|
'servicegroup_name',
|
|
|
|
function ($c) {
|
2015-09-28 16:01:13 +02:00
|
|
|
return preg_match('/^_(?:host|service)_/i', $c);
|
2015-06-18 16:42:27 +02:00
|
|
|
}
|
|
|
|
));
|
2015-08-20 13:07:57 +02:00
|
|
|
foreach ($this->getRestrictions($name) as $filter) {
|
2015-08-04 16:28:45 +02:00
|
|
|
if ($filter === '*') {
|
2015-08-20 14:24:06 +02:00
|
|
|
return Filter::matchAny();
|
2015-08-04 16:28:45 +02:00
|
|
|
}
|
2015-06-18 16:42:27 +02:00
|
|
|
try {
|
2015-08-20 13:07:57 +02:00
|
|
|
$restriction->addFilter(Filter::fromQueryString($filter));
|
2015-06-18 16:42:27 +02:00
|
|
|
} catch (QueryException $e) {
|
|
|
|
throw new ConfigurationError(
|
|
|
|
$this->translate(
|
|
|
|
'Cannot apply restriction %s using the filter %s. You can only use the following columns: %s'
|
|
|
|
),
|
2015-08-20 13:07:57 +02:00
|
|
|
$name,
|
2015-06-18 16:42:27 +02:00
|
|
|
$filter,
|
|
|
|
implode(', ', array(
|
2015-08-25 16:39:40 +02:00
|
|
|
'instance_name',
|
2015-06-18 16:42:27 +02:00
|
|
|
'host_name',
|
|
|
|
'hostgroup_name',
|
|
|
|
'service_description',
|
|
|
|
'servicegroup_name',
|
|
|
|
'_(host|service)_<customvar-name>'
|
|
|
|
)),
|
|
|
|
$e
|
|
|
|
);
|
|
|
|
}
|
2015-01-27 14:22:37 +01:00
|
|
|
}
|
2015-08-20 13:07:57 +02:00
|
|
|
return $restriction;
|
2015-01-27 14:22:37 +01:00
|
|
|
}
|
2013-10-10 14:40:13 +02:00
|
|
|
}
|