| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161 |
- <?php
- namespace Elasticsearch\Helper\Iterators;
- use Iterator;
- /**
- * Class SearchHitIterator
- *
- * @category Elasticsearch
- * @package Elasticsearch\Helper\Iterators
- * @author Arturo Mejia <arturo.mejia@kreatetechnology.com>
- * @license http://www.apache.org/licenses/LICENSE-2.0 Apache2
- * @link http://elastic.co
- * @see Iterator
- */
- class SearchHitIterator implements Iterator, \Countable
- {
- /**
- * @var SearchResponseIterator
- */
- private $search_responses;
- /**
- * @var int
- */
- protected $current_key;
- /**
- * @var int
- */
- protected $current_hit_index;
- /**
- * @var array|null
- */
- protected $current_hit_data;
- /**
- * @var int
- */
- protected $count;
- /**
- * Constructor
- *
- * @param SearchResponseIterator $search_responses
- */
- public function __construct(SearchResponseIterator $search_responses)
- {
- $this->search_responses = $search_responses;
- }
- /**
- * Rewinds the internal SearchResponseIterator and itself
- *
- * @return void
- * @see Iterator::rewind()
- */
- public function rewind()
- {
- $this->current_key = 0;
- $this->search_responses->rewind();
- // The first page may be empty. In that case, the next page is fetched.
- $current_page = $this->search_responses->current();
- if ($this->search_responses->valid() && empty($current_page['hits']['hits'])) {
- $this->search_responses->next();
- }
- $this->count = 0;
- if (isset($current_page['hits']) && isset($current_page['hits']['total'])) {
- $this->count = $current_page['hits']['total'];
- }
- $this->readPageData();
- }
- /**
- * Advances pointer of the current hit to the next one in the current page. If there
- * isn't a next hit in the current page, then it advances the current page and moves the
- * pointer to the first hit in the page.
- *
- * @return void
- * @see Iterator::next()
- */
- public function next()
- {
- $this->current_key++;
- $this->current_hit_index++;
- $current_page = $this->search_responses->current();
- if (isset($current_page['hits']['hits'][$this->current_hit_index])) {
- $this->current_hit_data = $current_page['hits']['hits'][$this->current_hit_index];
- } else {
- $this->search_responses->next();
- $this->readPageData();
- }
- }
- /**
- * Returns a boolean indicating whether or not the current pointer has valid data
- *
- * @return bool
- * @see Iterator::valid()
- */
- public function valid()
- {
- return is_array($this->current_hit_data);
- }
- /**
- * Returns the current hit
- *
- * @return array
- * @see Iterator::current()
- */
- public function current()
- {
- return $this->current_hit_data;
- }
- /**
- * Returns the current hit index. The hit index spans all pages.
- *
- * @return int
- * @see Iterator::key()
- */
- public function key()
- {
- return $this->current_hit_index;
- }
- /**
- * Advances the internal SearchResponseIterator and resets the current_hit_index to 0
- *
- * @internal
- */
- private function readPageData()
- {
- if ($this->search_responses->valid()) {
- $current_page = $this->search_responses->current();
- $this->current_hit_index = 0;
- $this->current_hit_data = $current_page['hits']['hits'][$this->current_hit_index];
- } else {
- $this->current_hit_data = null;
- }
- }
- /**
- * {@inheritDoc}
- */
- public function count()
- {
- if ($this->count === null) {
- $this->rewind();
- }
- return $this->count;
- }
- }
|