2013-06-07 11:44:37 +02:00
|
|
|
<?php
|
|
|
|
|
2013-08-20 23:21:36 +02:00
|
|
|
namespace Icinga\Data\DataArray;
|
2013-06-07 11:44:37 +02:00
|
|
|
|
2013-10-15 19:56:33 +02:00
|
|
|
use Icinga\Data\BaseQuery;
|
2013-08-20 23:21:36 +02:00
|
|
|
|
2013-10-15 19:56:33 +02:00
|
|
|
class Query extends BaseQuery
|
2013-06-07 11:44:37 +02:00
|
|
|
{
|
|
|
|
/**
|
|
|
|
* Remember the last count
|
|
|
|
*/
|
|
|
|
protected $count;
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Remember the last result without applied limits
|
|
|
|
*/
|
|
|
|
protected $result;
|
|
|
|
|
|
|
|
public function getCount()
|
|
|
|
{
|
|
|
|
return $this->count;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function hasResult()
|
|
|
|
{
|
|
|
|
return $this->result !== null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getFullResult()
|
|
|
|
{
|
|
|
|
return $this->result;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function getLimitedResult()
|
|
|
|
{
|
|
|
|
if ($this->hasLimit()) {
|
|
|
|
if ($this->hasOffset()) {
|
|
|
|
$offset = $this->getOffset();
|
|
|
|
} else {
|
|
|
|
$offset = 0;
|
|
|
|
}
|
|
|
|
return array_slice($this->result, $offset, $this->getLimit());
|
|
|
|
} else {
|
|
|
|
return $this->result;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
public function setResult($result)
|
|
|
|
{
|
|
|
|
$this->result = $result;
|
|
|
|
$this->count = count($result);
|
|
|
|
return $this;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* ArrayDatasource will apply this function to sort the array
|
|
|
|
*
|
|
|
|
* @param mixed $a Left side comparsion value
|
|
|
|
* @param mixed $b Right side comparsion value
|
|
|
|
* @param int $col_num Current position in order_columns array
|
|
|
|
*
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function compare(& $a, & $b, $col_num = 0)
|
|
|
|
{
|
2013-10-15 19:56:33 +02:00
|
|
|
$orderColumns = $this->getOrderColumns();
|
|
|
|
if (! array_key_exists($col_num, $orderColumns)) {
|
2013-06-07 11:44:37 +02:00
|
|
|
return 0;
|
|
|
|
}
|
2013-10-15 19:56:33 +02:00
|
|
|
|
|
|
|
$col = $orderColumns[$col_num][0];
|
|
|
|
$dir = $orderColumns[$col_num][1];
|
2013-06-07 11:44:37 +02:00
|
|
|
|
|
|
|
//$res = strnatcmp(strtolower($a->$col), strtolower($b->$col));
|
|
|
|
$res = strcmp(strtolower($a->$col), strtolower($b->$col));
|
|
|
|
if ($res === 0) {
|
2013-10-15 19:56:33 +02:00
|
|
|
if (array_key_exists(++$col_num, $orderColumns)) {
|
2013-06-07 11:44:37 +02:00
|
|
|
return $this->compare($a, $b, $col_num);
|
|
|
|
} else {
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
if ($dir === self::SORT_ASC) {
|
|
|
|
return $res;
|
|
|
|
} else {
|
|
|
|
return $res * -1;
|
|
|
|
}
|
|
|
|
}
|
2013-10-15 19:56:33 +02:00
|
|
|
|
|
|
|
public function parseFilterExpression($expression, $parameters = null)
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
|
|
|
|
|
|
|
public function applyFilter()
|
|
|
|
{
|
|
|
|
return null;
|
|
|
|
}
|
2013-06-07 11:44:37 +02:00
|
|
|
}
|