| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107 |
- <?php
- namespace Elastica\Index;
- use Elastica\Index as BaseIndex;
- /**
- * Elastica index stats object.
- *
- * @author Nicolas Ruflin <spam@ruflin.com>
- *
- * @see https://www.elastic.co/guide/en/elasticsearch/reference/current/indices-stats.html
- */
- class Stats
- {
- /**
- * Response.
- *
- * @var \Elastica\Response Response object
- */
- protected $_response;
- /**
- * Stats info.
- *
- * @var array Stats info
- */
- protected $_data = [];
- /**
- * Index.
- *
- * @var \Elastica\Index Index object
- */
- protected $_index;
- /**
- * Construct.
- *
- * @param \Elastica\Index $index Index object
- */
- public function __construct(BaseIndex $index)
- {
- $this->_index = $index;
- $this->refresh();
- }
- /**
- * Returns the raw stats info.
- *
- * @return array Stats info
- */
- public function getData()
- {
- return $this->_data;
- }
- /**
- * Returns the entry in the data array based on the params.
- * Various params possible.
- *
- * @return mixed Data array entry or null if not found
- */
- public function get()
- {
- $data = $this->getData();
- foreach (func_get_args() as $arg) {
- if (isset($data[$arg])) {
- $data = $data[$arg];
- } else {
- return;
- }
- }
- return $data;
- }
- /**
- * Returns the index object.
- *
- * @return \Elastica\Index Index object
- */
- public function getIndex()
- {
- return $this->_index;
- }
- /**
- * Returns response object.
- *
- * @return \Elastica\Response Response object
- */
- public function getResponse()
- {
- return $this->_response;
- }
- /**
- * Reloads all status data of this object.
- */
- public function refresh()
- {
- $this->_response = $this->getIndex()->requestEndpoint(new \Elasticsearch\Endpoints\Indices\Stats());
- $this->_data = $this->getResponse()->getData();
- }
- }
|