icingaweb2/library/Icinga/Protocol/File/Reader.php

224 lines
5.0 KiB
PHP
Raw Normal View History

2014-03-19 16:57:11 +01:00
<?php
2014-04-02 12:18:47 +02:00
// {{{ICINGA_LICENSE_HEADER}}}
// {{{ICINGA_LICENSE_HEADER}}}
2014-03-19 16:57:11 +01:00
namespace Icinga\Protocol\File;
use FilterIterator;
use Iterator;
use Zend_Config;
use Icinga\Protocol\File\FileReaderException;
use Icinga\Util\File;
2014-03-19 16:57:11 +01:00
2014-04-02 13:23:18 +02:00
/**
* Read file line by line
*/
class Reader extends FilterIterator
2014-03-19 16:57:11 +01:00
{
2014-04-02 13:23:18 +02:00
/**
* A PCRE string with the fields to extract from the file's lines as named subpatterns
2014-04-02 13:23:18 +02:00
*
* @var string
*/
protected $fields;
2014-03-19 16:57:11 +01:00
2014-04-02 13:23:18 +02:00
/**
* An associative array of the current line's fields ($field => $value)
2014-04-02 13:23:18 +02:00
*
* @var array
2014-04-02 13:23:18 +02:00
*/
protected $currentData;
2014-03-19 16:57:11 +01:00
2014-04-02 13:23:18 +02:00
/**
* Create a new reader
2014-04-01 16:29:09 +02:00
*
* @param Zend_Config $config
2014-04-01 16:29:09 +02:00
*
* @throws FileReaderException If a required $config directive (filename or fields) is missing
2014-04-01 16:29:09 +02:00
*/
public function __construct(Zend_Config $config)
2014-03-19 16:57:11 +01:00
{
foreach (array('filename', 'fields') as $key) {
if (! isset($config->{$key})) {
throw new FileReaderException('The directive `' . $key . '\' is required');
}
2014-03-19 16:57:11 +01:00
}
$this->fields = $config->fields;
$f = new File($config->filename);
$f->setFlags(
File::DROP_NEW_LINE |
File::READ_AHEAD |
File::SKIP_EMPTY
);
parent::__construct($f);
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Return the current data
2014-04-01 16:29:09 +02:00
*
* @return array
2014-04-01 16:29:09 +02:00
*/
public function current()
2014-03-19 16:57:11 +01:00
{
return $this->currentData;
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Accept lines matching the given PCRE pattern
2014-04-01 16:29:09 +02:00
*
* @return bool
*
* @throws FileReaderException If PHP failed parsing the PCRE pattern
2014-04-01 16:29:09 +02:00
*/
public function accept()
2014-03-19 16:57:11 +01:00
{
$data = array();
$matched = @preg_match(
$this->fields,
$this->getInnerIterator()->current(),
$data
);
if ($matched === false) {
throw new FileReaderException('Failed parsing regular expression!');
} else if ($matched === 1) {
foreach ($data as $key) {
if (is_int($key)) {
unset($data[$key]);
}
2014-03-19 16:57:11 +01:00
}
$this->currentData = $data;
return true;
2014-03-19 16:57:11 +01:00
}
return false;
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Instantiate a Query object
2014-04-01 16:29:09 +02:00
*
* @return Query
2014-04-01 16:29:09 +02:00
*/
public function select()
2014-03-19 16:57:11 +01:00
{
return new Query($this);
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Return the number of available valid lines.
2014-04-01 16:29:09 +02:00
*
* @return int
2014-04-01 16:29:09 +02:00
*/
public function count()
2014-03-19 16:57:11 +01:00
{
return iterator_count($this);
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Fetch result as an array of objects
2014-04-01 16:29:09 +02:00
*
* @param Query $query
2014-04-01 16:29:09 +02:00
*
* @return array
2014-04-01 16:29:09 +02:00
*/
public function fetchAll(Query $query)
2014-03-19 16:57:11 +01:00
{
$all = array();
foreach ($this->fetchPairs($query) as $index => $value) {
$all[$index] = (object) $value;
2014-03-19 16:57:11 +01:00
}
return $all;
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Fetch result as a key/value pair array
2014-04-01 16:29:09 +02:00
*
* @param Query $query
2014-04-01 16:29:09 +02:00
*
* @return array
2014-04-01 16:29:09 +02:00
*/
public function fetchPairs(Query $query)
2014-03-19 16:57:11 +01:00
{
$skipLines = $query->getOffset();
$readLines = $query->getLimit();
if ($skipLines === null) {
$skipLines = 0;
2014-03-19 16:57:11 +01:00
}
$lines = array();
if ($query->sortDesc()) {
$count = $this->count($query);
if ($count <= $skipLines) {
return $lines;
} else if ($count < ($skipLines + $readLines)) {
$readLines = $count - $skipLines;
$skipLines = 0;
} else {
$skipLines = $count - ($skipLines + $readLines);
2014-03-19 16:57:11 +01:00
}
}
foreach ($this as $index => $line) {
if ($index >= $skipLines) {
if ($index >= $skipLines + $readLines) {
break;
}
$lines[] = $line;
2014-03-19 16:57:11 +01:00
}
}
if ($query->sortDesc()) {
$lines = array_reverse($lines);
}
2014-03-19 16:57:11 +01:00
return $lines;
}
2014-04-17 17:59:27 +02:00
/**
* Fetch first result row
*
* @param Query $query
*
* @return object
2014-04-17 17:59:27 +02:00
*/
public function fetchRow(Query $query)
2014-04-17 17:59:27 +02:00
{
$all = $this->fetchAll($query);
if (isset($all[0])) {
return $all[0];
2014-04-17 17:59:27 +02:00
}
return null;
2014-04-17 17:59:27 +02:00
}
2014-04-01 16:29:09 +02:00
/**
* Fetch first result column
*
* @param Query $query
*
* @return array
2014-04-01 16:29:09 +02:00
*/
public function fetchColumn(Query $query)
2014-03-19 16:57:11 +01:00
{
$column = array();
foreach ($this->fetchPairs($query) as $pair) {
foreach ($pair as $value) {
$column[] = $value;
break;
2014-03-19 16:57:11 +01:00
}
}
return $column;
2014-03-19 16:57:11 +01:00
}
2014-04-01 16:29:09 +02:00
/**
* Fetch first column value from first result row
2014-04-01 16:29:09 +02:00
*
* @param Query $query
2014-04-01 16:29:09 +02:00
*
* @return mixed
2014-04-01 16:29:09 +02:00
*/
public function fetchOne(Query $query)
{
$pairs = $this->fetchPairs($query);
if (isset($pairs[0])) {
foreach ($pairs[0] as $value) {
return $value;
2014-03-19 16:57:11 +01:00
}
}
return null;
2014-03-19 16:57:11 +01:00
}
2014-04-17 17:59:27 +02:00
}