<?php

use rmartignoni\ElasticSearch;
require __DIR__ . '/../vendor/autoload.php';
$hosts = ['10.0.0.10:9200'];
$index = 'products';
$type = 'product';
$elasticSearch = new ElasticSearch\ElasticSearch($hosts, $index, $type);
/*
 * SELECT id, product_name, price, updated_at FROM products WHERE product_name LIKE 'car%' AND category = 3 LIMIT 20 OFFSET 0
 */
$query = new ElasticSearch\Query();
$query->wildcard('product_name', 'car*');
$filter = new ElasticSearch\Filter();
$filter->where('category', 3);
// You should always use the take method before paging
$elasticSearch->select('id, product_name, price, updated_at')->setQuery($query)->setFilter($filter)->take(20)->page(0)->get();
 /**
  * @param Filter $filter
  *
  * @return $this
  */
 public function setPostFilter(Filter $filter)
 {
     $this->postFilter = $filter->getFilters();
     return $this;
 }