icingaweb2/library/Icinga/Data/DataArray/Datasource.php

122 lines
2.9 KiB
PHP

<?php
namespace Icinga\Data\DataArray;
use Icinga\Data\DatasourceInterface;
class Datasource implements DatasourceInterface
{
protected $data;
/**
* Constructor, create a new Datasource for the given Array
*
* @param array $array The array you're going to use as a data source
*/
public function __construct(array $array)
{
$this->data = (array) $array;
}
/**
* Instantiate a Query object
*
* @return Query
*/
public function select()
{
return new Query($this);
}
public function fetchColumn(Query $query)
{
$result = array();
foreach ($this->getResult($query) as $row) {
$arr = (array) $row;
$result[] = array_shift($arr);
}
return $result;
}
public function fetchPairs(Query $query)
{
$result = array();
$keys = null;
foreach ($this->getResult($query) as $row) {
if ($keys === null) {
$keys = array_keys((array) $row);
if (count($keys) < 2) {
$keys[1] = $keys[0];
}
}
$result[$row->{$keys[0]}] = $row->{$keys[1]};
}
return $result;
}
public function fetchAll(Query $query)
{
$result = $this->getResult($query);
return $result;
}
public function count(Query $query)
{
$this->createResult($query);
return $query->getCount();
}
protected function createResult(Query $query)
{
if ($query->hasResult()) {
return $this;
}
$result = array();
$filters = $query->listFilters();
$columns = $query->listColumns();
foreach ($this->data as & $row) {
// Skip rows that do not match applied filters
foreach ($filters as $f) {
if ($row->{$f[0]} !== $f[1]) {
continue 2;
}
}
// Get only desired columns if asked so
if (empty($columns)) {
$result[] = $row;
} else {
$c_row = (object) array();
foreach ($columns as $alias => $key) {
if (is_int($alias)) {
$alias = $key;
}
if (isset($row->$key)) {
$c_row->$alias = $row->$key;
} else {
$c_row->$alias = null;
}
}
$result[] = $c_row;
}
}
// Sort the result
if ($query->hasOrder()) {
usort($result, array($query, 'compare'));
}
$query->setResult($result);
return $this;
}
protected function getResult(Query $query)
{
if (! $query->hasResult()) {
$this->createResult($query);
}
return $query->getLimitedResult();
}
}