2013-09-24 15:26:10 +02:00
|
|
|
<?php
|
2015-02-04 10:46:36 +01:00
|
|
|
/* Icinga Web 2 | (c) 2013-2015 Icinga Development Team | GPLv2+ */
|
2013-09-24 15:26:10 +02:00
|
|
|
|
|
|
|
namespace Icinga\Module\Monitoring\DataView;
|
|
|
|
|
2015-05-15 14:26:32 +02:00
|
|
|
use IteratorAggregate;
|
2015-08-13 14:24:24 +02:00
|
|
|
use Icinga\Data\FilterColumns;
|
2015-05-15 14:23:40 +02:00
|
|
|
use Icinga\Data\QueryInterface;
|
2015-07-28 11:41:25 +02:00
|
|
|
use Icinga\Data\SortRules;
|
2014-06-06 09:05:21 +02:00
|
|
|
use Icinga\Data\Filter\Filter;
|
2014-10-06 11:32:15 +02:00
|
|
|
use Icinga\Data\Filter\FilterMatch;
|
2014-03-12 14:41:17 +01:00
|
|
|
use Icinga\Data\PivotTable;
|
2014-06-06 09:05:21 +02:00
|
|
|
use Icinga\Data\ConnectionInterface;
|
2014-10-06 11:32:15 +02:00
|
|
|
use Icinga\Exception\QueryException;
|
2013-09-24 15:26:10 +02:00
|
|
|
use Icinga\Web\Request;
|
2014-06-06 09:05:21 +02:00
|
|
|
use Icinga\Web\Url;
|
2015-05-18 16:01:58 +02:00
|
|
|
use Icinga\Module\Monitoring\Backend\Ido\Query\IdoQuery;
|
2014-11-12 00:20:37 +01:00
|
|
|
use Icinga\Module\Monitoring\Backend\MonitoringBackend;
|
2013-09-24 15:26:10 +02:00
|
|
|
|
|
|
|
/**
|
2014-05-07 10:19:00 +02:00
|
|
|
* A read-only view of an underlying query
|
2013-09-24 15:26:10 +02:00
|
|
|
*/
|
2015-08-13 14:24:24 +02:00
|
|
|
abstract class DataView implements QueryInterface, SortRules, FilterColumns, IteratorAggregate
|
2013-09-24 15:26:10 +02:00
|
|
|
{
|
2013-10-14 13:25:25 +02:00
|
|
|
/**
|
|
|
|
* The query used to populate the view
|
|
|
|
*
|
2015-05-18 16:01:58 +02:00
|
|
|
* @var IdoQuery
|
2013-10-14 13:25:25 +02:00
|
|
|
*/
|
2014-10-08 12:30:08 +02:00
|
|
|
protected $query;
|
2014-09-19 15:42:13 +02:00
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
protected $filter;
|
|
|
|
|
|
|
|
protected $connection;
|
2013-09-24 15:26:10 +02:00
|
|
|
|
2014-09-02 12:54:38 +02:00
|
|
|
protected $isSorted = false;
|
|
|
|
|
2015-08-17 12:53:17 +02:00
|
|
|
/**
|
|
|
|
* The cache for all filter columns
|
|
|
|
*
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $filterColumns;
|
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
|
|
|
* Create a new view
|
|
|
|
*
|
2014-10-07 16:09:19 +02:00
|
|
|
* @param ConnectionInterface $connection
|
|
|
|
* @param array $columns
|
2013-09-24 15:26:10 +02:00
|
|
|
*/
|
2014-06-06 09:05:21 +02:00
|
|
|
public function __construct(ConnectionInterface $connection, array $columns = null)
|
2013-09-24 15:26:10 +02:00
|
|
|
{
|
2014-06-06 09:05:21 +02:00
|
|
|
$this->connection = $connection;
|
2014-11-11 15:49:27 +01:00
|
|
|
$this->query = $connection->query($this->getQueryName(), $columns);
|
2014-06-06 09:05:21 +02:00
|
|
|
$this->filter = Filter::matchAll();
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|
|
|
|
|
2015-05-15 14:26:32 +02:00
|
|
|
/**
|
|
|
|
* Return a iterator for all rows of the result set
|
|
|
|
*
|
2015-05-18 16:01:58 +02:00
|
|
|
* @return IdoQuery
|
2015-05-15 14:26:32 +02:00
|
|
|
*/
|
|
|
|
public function getIterator()
|
|
|
|
{
|
2015-05-18 16:01:58 +02:00
|
|
|
return $this->getQuery();
|
2015-05-15 14:26:32 +02:00
|
|
|
}
|
|
|
|
|
2015-08-06 09:39:23 +02:00
|
|
|
/**
|
|
|
|
* Return the current position of the result set's iterator
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getIteratorPosition()
|
|
|
|
{
|
|
|
|
return $this->query->getIteratorPosition();
|
|
|
|
}
|
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
2014-04-17 13:59:11 +02:00
|
|
|
* Get the query name this data view relies on
|
|
|
|
*
|
|
|
|
* By default this is this class' name without its namespace
|
2013-09-24 15:26:10 +02:00
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
2014-04-17 13:59:11 +02:00
|
|
|
public static function getQueryName()
|
2013-09-24 15:26:10 +02:00
|
|
|
{
|
|
|
|
$tableName = explode('\\', get_called_class());
|
2013-10-14 12:56:06 +02:00
|
|
|
$tableName = end($tableName);
|
2013-09-24 15:26:10 +02:00
|
|
|
return $tableName;
|
|
|
|
}
|
|
|
|
|
2014-10-07 16:09:19 +02:00
|
|
|
public function where($condition, $value = null)
|
|
|
|
{
|
|
|
|
$this->filter->addFilter(Filter::where($condition, $value));
|
|
|
|
$this->query->where($condition, $value);
|
|
|
|
return $this;
|
|
|
|
}
|
2014-06-06 09:05:21 +02:00
|
|
|
|
2014-10-07 16:09:19 +02:00
|
|
|
public function dump()
|
|
|
|
{
|
2015-01-21 09:13:10 +01:00
|
|
|
$this->order();
|
2014-10-07 16:09:19 +02:00
|
|
|
return $this->query->dump();
|
|
|
|
}
|
2014-06-06 09:05:21 +02:00
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
|
|
|
* Retrieve columns provided by this view
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
abstract public function getColumns();
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Create view from request
|
|
|
|
*
|
|
|
|
* @param Request $request
|
2013-10-14 13:25:25 +02:00
|
|
|
* @param array $columns
|
2013-09-24 15:26:10 +02:00
|
|
|
*
|
|
|
|
* @return static
|
2014-05-07 10:19:00 +02:00
|
|
|
* @deprecated Use $backend->select()->from($viewName) instead
|
2013-09-24 15:26:10 +02:00
|
|
|
*/
|
2013-10-07 16:46:20 +02:00
|
|
|
public static function fromRequest($request, array $columns = null)
|
2013-09-24 15:26:10 +02:00
|
|
|
{
|
2014-11-12 00:20:37 +01:00
|
|
|
$view = new static(MonitoringBackend::instance($request->getParam('backend')), $columns);
|
2014-06-06 09:05:21 +02:00
|
|
|
$view->applyUrlFilter($request);
|
2013-10-15 19:56:33 +02:00
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
// TODO: This is not the right place for this, move it away
|
|
|
|
protected function applyUrlFilter($request = null)
|
|
|
|
{
|
|
|
|
$url = Url::fromRequest();
|
2014-09-02 12:54:38 +02:00
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
$limit = $url->shift('limit');
|
|
|
|
$sort = $url->shift('sort');
|
|
|
|
$dir = $url->shift('dir');
|
|
|
|
$page = $url->shift('page');
|
|
|
|
$format = $url->shift('format');
|
|
|
|
$view = $url->shift('view');
|
|
|
|
$view = $url->shift('backend');
|
|
|
|
foreach ($url->getParams() as $k => $v) {
|
|
|
|
$this->where($k, $v);
|
|
|
|
}
|
|
|
|
if ($sort) {
|
|
|
|
$this->order($sort, $dir);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-10 11:33:41 +02:00
|
|
|
/**
|
|
|
|
* Create view from params
|
|
|
|
*
|
2013-10-14 13:25:25 +02:00
|
|
|
* @param array $params
|
|
|
|
* @param array $columns
|
2013-10-10 11:33:41 +02:00
|
|
|
*
|
|
|
|
* @return static
|
|
|
|
*/
|
|
|
|
public static function fromParams(array $params, array $columns = null)
|
|
|
|
{
|
2014-11-12 00:20:37 +01:00
|
|
|
$view = new static(MonitoringBackend::instance($params['backend']), $columns);
|
2013-10-17 19:48:46 +02:00
|
|
|
|
2013-10-15 19:56:33 +02:00
|
|
|
foreach ($params as $key => $value) {
|
2013-10-17 19:48:46 +02:00
|
|
|
if ($view->isValidFilterTarget($key)) {
|
2014-06-06 09:05:21 +02:00
|
|
|
$view->where($key, $value);
|
2013-10-17 19:48:46 +02:00
|
|
|
}
|
2013-10-15 19:56:33 +02:00
|
|
|
}
|
2014-06-06 09:05:21 +02:00
|
|
|
|
2014-09-02 12:54:38 +02:00
|
|
|
if (isset($params['sort'])) {
|
2013-10-15 19:56:33 +02:00
|
|
|
|
2014-09-02 12:54:38 +02:00
|
|
|
$order = isset($params['order']) ? $params['order'] : null;
|
|
|
|
if ($order !== null) {
|
|
|
|
if (strtolower($order) === 'desc') {
|
|
|
|
$order = self::SORT_DESC;
|
|
|
|
} else {
|
|
|
|
$order = self::SORT_ASC;
|
|
|
|
}
|
|
|
|
}
|
2014-06-06 09:05:21 +02:00
|
|
|
|
2014-09-02 12:54:38 +02:00
|
|
|
$view->sort($params['sort'], $order);
|
|
|
|
}
|
2013-10-10 11:33:41 +02:00
|
|
|
return $view;
|
|
|
|
}
|
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
2015-08-17 12:53:17 +02:00
|
|
|
* Check whether the given column is a valid filter column
|
2013-09-24 15:26:10 +02:00
|
|
|
*
|
2015-08-17 12:53:17 +02:00
|
|
|
* @param string $column
|
2013-09-24 15:26:10 +02:00
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2013-10-14 13:25:25 +02:00
|
|
|
public function isValidFilterTarget($column)
|
2013-09-24 15:26:10 +02:00
|
|
|
{
|
2015-08-17 12:53:17 +02:00
|
|
|
return in_array($column, $this->getFilterColumns());
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|
|
|
|
|
2015-08-17 12:53:17 +02:00
|
|
|
/**
|
|
|
|
* Return all filter columns with their optional label as key
|
|
|
|
*
|
|
|
|
* This will merge the results of self::getColumns(), self::getStaticFilterColumns() and
|
|
|
|
* self::getDynamicFilterColumns() *once*. (i.e. subsequent calls of this function will
|
|
|
|
* return the same result.)
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2013-10-14 13:25:25 +02:00
|
|
|
public function getFilterColumns()
|
2015-08-17 12:53:17 +02:00
|
|
|
{
|
|
|
|
if ($this->filterColumns === null) {
|
|
|
|
$this->filterColumns = array_merge(
|
|
|
|
$this->getColumns(),
|
|
|
|
$this->getStaticFilterColumns(),
|
|
|
|
$this->getDynamicFilterColumns()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
|
|
|
|
return $this->filterColumns;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return all static filter columns
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getStaticFilterColumns()
|
2013-10-14 13:25:25 +02:00
|
|
|
{
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
2015-08-14 11:05:22 +02:00
|
|
|
/**
|
|
|
|
* Return all dynamic filter columns such as custom variables
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getDynamicFilterColumns()
|
|
|
|
{
|
|
|
|
$columns = array();
|
|
|
|
if (! $this->query->allowsCustomVars()) {
|
|
|
|
return $columns;
|
|
|
|
}
|
|
|
|
|
|
|
|
$query = MonitoringBackend::instance()
|
|
|
|
->select()
|
|
|
|
->from('customvar', array('varname', 'object_type'))
|
|
|
|
->where('is_json', 0)
|
|
|
|
->where('object_type_id', array(1, 2))
|
|
|
|
->getQuery()->group(array('varname', 'object_type'));
|
|
|
|
foreach ($query as $row) {
|
|
|
|
if ($row->object_type === 'host') {
|
|
|
|
$label = t('Host') . ' ' . ucwords(str_replace('_', ' ', $row->varname));
|
|
|
|
$columns[$label] = '_host_' . $row->varname;
|
|
|
|
} else { // $row->object_type === 'service'
|
|
|
|
$label = t('Service') . ' ' . ucwords(str_replace('_', ' ', $row->varname));
|
|
|
|
$columns[$label] = '_service_' . $row->varname;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return $columns;
|
|
|
|
}
|
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
public function getFilter()
|
|
|
|
{
|
|
|
|
return $this->filter;
|
|
|
|
}
|
|
|
|
|
2014-03-12 14:41:17 +01:00
|
|
|
/**
|
|
|
|
* Return a pivot table for the given columns based on the current query
|
|
|
|
*
|
|
|
|
* @param string $xAxisColumn The column to use for the x axis
|
|
|
|
* @param string $yAxisColumn The column to use for the y axis
|
2015-06-24 14:37:07 +02:00
|
|
|
* @param Filter $xAxisFilter The filter to apply on a query for the x axis
|
|
|
|
* @param Filter $yAxisFilter The filter to apply on a query for the y axis
|
2014-03-12 14:41:17 +01:00
|
|
|
*
|
|
|
|
* @return PivotTable
|
|
|
|
*/
|
2015-06-24 14:37:07 +02:00
|
|
|
public function pivot($xAxisColumn, $yAxisColumn, Filter $xAxisFilter = null, Filter $yAxisFilter = null)
|
2014-03-12 14:41:17 +01:00
|
|
|
{
|
2015-06-24 14:37:07 +02:00
|
|
|
$pivot = new PivotTable($this->query, $xAxisColumn, $yAxisColumn);
|
|
|
|
return $pivot->setXAxisFilter($xAxisFilter)->setYAxisFilter($yAxisFilter);
|
2014-03-12 14:41:17 +01:00
|
|
|
}
|
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
|
|
|
* Sort the rows, according to the specified sort column and order
|
|
|
|
*
|
2014-05-07 10:19:00 +02:00
|
|
|
* @param string $column Sort column
|
2014-10-07 16:09:19 +02:00
|
|
|
* @param string $order Sort order, one of the SORT_ constants
|
2013-09-24 15:26:10 +02:00
|
|
|
*
|
2014-10-07 16:09:19 +02:00
|
|
|
* @return $this
|
|
|
|
* @throws QueryException If the sort column is not allowed
|
2013-09-24 15:26:10 +02:00
|
|
|
* @see DataView::SORT_ASC
|
|
|
|
* @see DataView::SORT_DESC
|
2014-05-07 10:19:00 +02:00
|
|
|
* @deprecated Use DataView::order() instead
|
2013-09-24 15:26:10 +02:00
|
|
|
*/
|
|
|
|
public function sort($column = null, $order = null)
|
|
|
|
{
|
|
|
|
$sortRules = $this->getSortRules();
|
2014-10-07 16:05:20 +02:00
|
|
|
if ($column === null) {
|
|
|
|
// Use first available sort rule as default
|
|
|
|
if (empty($sortRules)) {
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
$sortColumns = reset($sortRules);
|
|
|
|
if (! isset($sortColumns['columns'])) {
|
|
|
|
$sortColumns['columns'] = array(key($sortRules));
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
if (isset($sortRules[$column])) {
|
|
|
|
$sortColumns = $sortRules[$column];
|
2014-10-06 11:32:15 +02:00
|
|
|
if (! isset($sortColumns['columns'])) {
|
2014-10-07 16:05:20 +02:00
|
|
|
$sortColumns['columns'] = array($column);
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|
|
|
|
} else {
|
2014-10-07 16:05:20 +02:00
|
|
|
$sortColumns = array(
|
|
|
|
'columns' => array($column),
|
|
|
|
'order' => $order
|
|
|
|
);
|
|
|
|
};
|
|
|
|
}
|
2013-10-15 19:56:33 +02:00
|
|
|
|
2015-05-21 12:01:58 +02:00
|
|
|
$order = $order === null ? (isset($sortColumns['order']) ? $sortColumns['order'] : static::SORT_ASC) : $order;
|
|
|
|
$order = (strtoupper($order) === static::SORT_ASC) ? 'ASC' : 'DESC';
|
2013-10-15 19:56:33 +02:00
|
|
|
|
2014-10-07 16:05:20 +02:00
|
|
|
foreach ($sortColumns['columns'] as $column) {
|
2015-05-21 12:01:58 +02:00
|
|
|
list($column, $direction) = $this->query->splitOrder($column);
|
2014-10-07 16:05:20 +02:00
|
|
|
if (! $this->isValidFilterTarget($column)) {
|
|
|
|
throw new QueryException(
|
2014-10-21 17:22:16 +02:00
|
|
|
mt('monitoring', 'The sort column "%s" is not allowed in "%s".'),
|
2014-10-07 16:05:20 +02:00
|
|
|
$column,
|
|
|
|
get_class($this)
|
|
|
|
);
|
2013-10-20 16:08:01 +02:00
|
|
|
}
|
2015-05-21 12:01:58 +02:00
|
|
|
$this->query->order($column, $direction !== null ? $direction : $order);
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|
2014-10-07 16:05:20 +02:00
|
|
|
$this->isSorted = true;
|
2013-10-15 19:56:33 +02:00
|
|
|
return $this;
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|
|
|
|
|
2013-10-14 13:25:25 +02:00
|
|
|
/**
|
|
|
|
* Retrieve default sorting rules for particular columns. These involve sort order and potential additional to sort
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2013-10-20 16:08:01 +02:00
|
|
|
public function getSortRules()
|
|
|
|
{
|
2014-10-07 16:05:20 +02:00
|
|
|
return array();
|
2013-10-20 16:08:01 +02:00
|
|
|
}
|
2013-10-14 13:25:25 +02:00
|
|
|
|
2014-05-07 10:19:00 +02:00
|
|
|
/**
|
|
|
|
* Sort result set either by the given column (and direction) or the sort defaults
|
|
|
|
*
|
|
|
|
* @param string $column
|
|
|
|
* @param string $direction
|
|
|
|
*
|
2014-10-07 16:09:19 +02:00
|
|
|
* @return $this
|
2014-05-07 10:19:00 +02:00
|
|
|
*/
|
|
|
|
public function order($column = null, $direction = null)
|
|
|
|
{
|
2014-06-17 14:46:41 +02:00
|
|
|
return $this->sort($column, $direction);
|
2014-05-07 10:19:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether an order is set
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
2015-06-26 15:13:46 +02:00
|
|
|
public function hasOrder()
|
2014-05-07 10:19:00 +02:00
|
|
|
{
|
2015-06-26 15:13:46 +02:00
|
|
|
return $this->query->hasOrder();
|
2014-05-07 10:19:00 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the order if any
|
|
|
|
*
|
|
|
|
* @return array|null
|
|
|
|
*/
|
|
|
|
public function getOrder()
|
|
|
|
{
|
|
|
|
return $this->query->getOrder();
|
|
|
|
}
|
|
|
|
|
2013-10-14 13:25:25 +02:00
|
|
|
public function getMappedField($field)
|
|
|
|
{
|
|
|
|
return $this->query->getMappedField($field);
|
|
|
|
}
|
|
|
|
|
2013-09-24 15:26:10 +02:00
|
|
|
/**
|
|
|
|
* Return the query which was created in the constructor
|
|
|
|
*
|
2014-10-07 16:09:19 +02:00
|
|
|
* @return \Icinga\Data\SimpleQuery
|
2013-09-24 15:26:10 +02:00
|
|
|
*/
|
|
|
|
public function getQuery()
|
|
|
|
{
|
2014-10-06 11:32:15 +02:00
|
|
|
if (! $this->isSorted) {
|
|
|
|
$this->order();
|
|
|
|
}
|
2013-09-24 15:26:10 +02:00
|
|
|
return $this->query;
|
|
|
|
}
|
2013-10-14 13:25:25 +02:00
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
public function applyFilter(Filter $filter)
|
2013-10-15 19:56:33 +02:00
|
|
|
{
|
2014-10-06 11:32:15 +02:00
|
|
|
$this->validateFilterColumns($filter);
|
|
|
|
|
2014-06-06 09:05:21 +02:00
|
|
|
return $this->addFilter($filter);
|
2013-10-15 19:56:33 +02:00
|
|
|
}
|
|
|
|
|
2014-10-06 11:32:15 +02:00
|
|
|
/**
|
|
|
|
* Validates recursive the Filter columns against the isValidFilterTarget() method
|
|
|
|
*
|
|
|
|
* @param Filter $filter
|
|
|
|
*
|
|
|
|
* @throws \Icinga\Data\Filter\FilterException
|
|
|
|
*/
|
|
|
|
public function validateFilterColumns(Filter $filter)
|
|
|
|
{
|
|
|
|
if ($filter instanceof FilterMatch) {
|
|
|
|
if (! $this->isValidFilterTarget($filter->getColumn())) {
|
|
|
|
throw new QueryException(
|
2014-10-21 17:22:16 +02:00
|
|
|
mt('monitoring', 'The filter column "%s" is not allowed here.'),
|
2014-10-06 11:32:15 +02:00
|
|
|
$filter->getColumn()
|
|
|
|
);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (method_exists($filter, 'filters')) {
|
|
|
|
foreach ($filter->filters() as $filter) {
|
|
|
|
$this->validateFilterColumns($filter);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2013-10-15 19:56:33 +02:00
|
|
|
public function clearFilter()
|
|
|
|
{
|
|
|
|
$this->query->clearFilter();
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-01-27 14:52:13 +01:00
|
|
|
/**
|
|
|
|
* @deprecated(EL): Only use DataView::applyFilter() for applying filter because all other functions are missing
|
|
|
|
* column validation. Filter::matchAny() for the IdoQuery (or the DbQuery or the SimpleQuery I didn't have a look)
|
|
|
|
* is required for the filter to work properly.
|
|
|
|
*/
|
2014-06-06 09:05:21 +02:00
|
|
|
public function setFilter(Filter $filter)
|
|
|
|
{
|
|
|
|
$this->query->setFilter($filter);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
2015-05-19 16:37:39 +02:00
|
|
|
/**
|
|
|
|
* Get the view's search columns
|
|
|
|
*
|
|
|
|
* @return string[]
|
|
|
|
*/
|
|
|
|
public function getSearchColumns()
|
|
|
|
{
|
|
|
|
return array();
|
|
|
|
}
|
|
|
|
|
2015-01-27 14:52:13 +01:00
|
|
|
/**
|
|
|
|
* @deprecated(EL): Only use DataView::applyFilter() for applying filter because all other functions are missing
|
|
|
|
* column validation.
|
|
|
|
*/
|
2014-06-06 09:05:21 +02:00
|
|
|
public function addFilter(Filter $filter)
|
2013-10-14 13:25:25 +02:00
|
|
|
{
|
2014-06-06 09:05:21 +02:00
|
|
|
$this->query->addFilter(clone($filter));
|
|
|
|
$this->filter = $filter; // TODO: Hmmmm.... and?
|
2013-10-15 19:56:33 +02:00
|
|
|
return $this;
|
2013-10-14 13:25:25 +02:00
|
|
|
}
|
2014-05-06 18:34:01 +02:00
|
|
|
|
2014-09-19 15:42:13 +02:00
|
|
|
/**
|
|
|
|
* Count result set
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function count()
|
|
|
|
{
|
2015-05-15 14:23:40 +02:00
|
|
|
return $this->query->count();
|
|
|
|
}
|
|
|
|
|
2015-07-31 13:51:39 +02:00
|
|
|
/**
|
|
|
|
* Set whether the query should peek ahead for more results
|
|
|
|
*
|
|
|
|
* Enabling this causes the current query limit to be increased by one. The potential extra row being yielded will
|
|
|
|
* be removed from the result set. Note that this only applies when fetching multiple results of limited queries.
|
|
|
|
*
|
|
|
|
* @return $this
|
|
|
|
*/
|
|
|
|
public function peekAhead($state = true)
|
|
|
|
{
|
|
|
|
return $this->query->peekAhead($state);
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Return whether the query did not yield all available results
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasMore()
|
|
|
|
{
|
|
|
|
return $this->query->hasMore();
|
|
|
|
}
|
|
|
|
|
2015-08-03 14:49:33 +02:00
|
|
|
/**
|
|
|
|
* Return whether this query will or has yielded any result
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasResult()
|
|
|
|
{
|
|
|
|
return $this->query->hasResult();
|
|
|
|
}
|
|
|
|
|
2015-05-15 14:23:40 +02:00
|
|
|
/**
|
|
|
|
* Set a limit count and offset
|
|
|
|
*
|
|
|
|
* @param int $count Number of rows to return
|
|
|
|
* @param int $offset Start returning after this many rows
|
|
|
|
*
|
|
|
|
* @return self
|
|
|
|
*/
|
|
|
|
public function limit($count = null, $offset = null)
|
|
|
|
{
|
|
|
|
$this->query->limit($count, $offset);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether a limit is set
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasLimit()
|
|
|
|
{
|
|
|
|
return $this->query->hasLimit();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the limit if any
|
|
|
|
*
|
|
|
|
* @return int|null
|
|
|
|
*/
|
|
|
|
public function getLimit()
|
|
|
|
{
|
|
|
|
return $this->query->getLimit();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Whether an offset is set
|
|
|
|
*
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasOffset()
|
|
|
|
{
|
|
|
|
return $this->query->hasOffset();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Get the offset if any
|
|
|
|
*
|
|
|
|
* @return int|null
|
|
|
|
*/
|
|
|
|
public function getOffset()
|
|
|
|
{
|
2015-05-19 12:22:20 +02:00
|
|
|
return $this->query->getOffset();
|
2015-05-15 14:23:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Retrieve an array containing all rows of the result set
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function fetchAll()
|
|
|
|
{
|
|
|
|
return $this->getQuery()->fetchAll();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch the first row of the result set
|
|
|
|
*
|
|
|
|
* @return mixed
|
|
|
|
*/
|
|
|
|
public function fetchRow()
|
|
|
|
{
|
|
|
|
return $this->getQuery()->fetchRow();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
2015-05-19 09:48:20 +02:00
|
|
|
* Fetch the first column of all rows of the result set as an array
|
2015-05-15 14:23:40 +02:00
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
2015-05-19 09:48:20 +02:00
|
|
|
public function fetchColumn()
|
2015-05-15 14:23:40 +02:00
|
|
|
{
|
2015-05-19 09:48:20 +02:00
|
|
|
return $this->getQuery()->fetchColumn();
|
2015-05-15 14:23:40 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch the first column of the first row of the result set
|
|
|
|
*
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function fetchOne()
|
|
|
|
{
|
|
|
|
return $this->getQuery()->fetchOne();
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Fetch all rows of the result set as an array of key-value pairs
|
|
|
|
*
|
|
|
|
* The first column is the key, the second column is the value.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function fetchPairs()
|
|
|
|
{
|
|
|
|
return $this->getQuery()->fetchPairs();
|
2014-09-19 15:42:13 +02:00
|
|
|
}
|
2013-09-24 15:26:10 +02:00
|
|
|
}
|