2016-12-09 11:47:28 +01:00
|
|
|
<?php
|
2017-07-06 23:48:47 +02:00
|
|
|
namespace Codappix\SearchCore\Domain\Model;
|
2016-12-09 11:47:28 +01:00
|
|
|
|
|
|
|
/*
|
2016-12-09 13:19:35 +01:00
|
|
|
* Copyright (C) 2016 Daniel Siepmann <coding@daniel-siepmann.de>
|
2016-12-09 11:47:28 +01:00
|
|
|
*
|
|
|
|
* This program is free software; you can redistribute it and/or
|
|
|
|
* modify it under the terms of the GNU General Public License
|
|
|
|
* as published by the Free Software Foundation; either version 2
|
|
|
|
* of the License, or (at your option) any later version.
|
|
|
|
*
|
|
|
|
* This program is distributed in the hope that it will be useful,
|
|
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
* GNU General Public License for more details.
|
|
|
|
*
|
|
|
|
* You should have received a copy of the GNU General Public License
|
|
|
|
* along with this program; if not, write to the Free Software
|
|
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
|
|
|
|
* 02110-1301, USA.
|
|
|
|
*/
|
|
|
|
|
2017-07-06 23:48:47 +02:00
|
|
|
use Codappix\SearchCore\Connection\FacetRequestInterface;
|
|
|
|
use Codappix\SearchCore\Connection\SearchRequestInterface;
|
2016-12-09 11:47:28 +01:00
|
|
|
|
|
|
|
/**
|
2016-12-09 13:19:35 +01:00
|
|
|
* Represents a search request used to process an actual search.
|
2016-12-09 11:47:28 +01:00
|
|
|
*/
|
2016-12-09 13:19:35 +01:00
|
|
|
class SearchRequest implements SearchRequestInterface
|
2016-12-09 11:47:28 +01:00
|
|
|
{
|
2016-12-09 13:19:35 +01:00
|
|
|
/**
|
|
|
|
* The search string provided by the user, the actual term to search for.
|
|
|
|
*
|
|
|
|
* @var string
|
|
|
|
*/
|
2017-06-06 12:32:27 +02:00
|
|
|
protected $query = '';
|
|
|
|
|
2017-07-18 10:44:39 +02:00
|
|
|
/**
|
|
|
|
* @var int
|
|
|
|
*/
|
|
|
|
protected $size = 10;
|
|
|
|
|
2017-06-06 12:32:27 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $filter = [];
|
2016-12-09 13:19:35 +01:00
|
|
|
|
2017-07-06 12:03:52 +02:00
|
|
|
/**
|
|
|
|
* @var array
|
|
|
|
*/
|
|
|
|
protected $facets = [];
|
|
|
|
|
2016-12-09 13:19:35 +01:00
|
|
|
/**
|
|
|
|
* @param string $query
|
|
|
|
*/
|
|
|
|
public function __construct($query)
|
|
|
|
{
|
2017-06-08 08:38:14 +02:00
|
|
|
$this->query = (string) $query;
|
2016-12-09 13:19:35 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getQuery()
|
2016-12-09 11:47:28 +01:00
|
|
|
{
|
2016-12-09 13:19:35 +01:00
|
|
|
return $this->query;
|
2016-12-09 11:47:28 +01:00
|
|
|
}
|
|
|
|
|
2016-12-09 13:19:35 +01:00
|
|
|
/**
|
|
|
|
* @return string
|
|
|
|
*/
|
|
|
|
public function getSearchTerm()
|
2016-12-09 11:47:28 +01:00
|
|
|
{
|
2016-12-15 09:17:58 +01:00
|
|
|
return $this->query;
|
2016-12-09 11:47:28 +01:00
|
|
|
}
|
2017-06-06 12:32:27 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @param array $filter
|
|
|
|
*/
|
|
|
|
public function setFilter(array $filter)
|
|
|
|
{
|
2017-07-06 12:03:52 +02:00
|
|
|
$this->filter = array_filter(array_map('strval', $filter));
|
2017-06-06 12:32:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return bool
|
|
|
|
*/
|
|
|
|
public function hasFilter()
|
|
|
|
{
|
2017-06-06 15:33:06 +02:00
|
|
|
return count($this->filter) > 0;
|
2017-06-06 12:32:27 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getFilter()
|
|
|
|
{
|
|
|
|
return $this->filter;
|
|
|
|
}
|
2017-07-06 12:03:52 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Add a facet to gather in this search request.
|
|
|
|
*
|
|
|
|
* @param FacetRequestInterface $facet
|
|
|
|
*/
|
|
|
|
public function addFacet(FacetRequestInterface $facet)
|
|
|
|
{
|
|
|
|
$this->facets[$facet->getIdentifier()] = $facet;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Returns all configured facets to fetch in this search request.
|
|
|
|
*
|
|
|
|
* @return array
|
|
|
|
*/
|
|
|
|
public function getFacets()
|
|
|
|
{
|
|
|
|
return $this->facets;
|
|
|
|
}
|
2017-07-18 10:44:39 +02:00
|
|
|
|
|
|
|
/**
|
|
|
|
* @return int
|
|
|
|
*/
|
|
|
|
public function getSize()
|
|
|
|
{
|
|
|
|
return $this->size;
|
|
|
|
}
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @param int $size
|
|
|
|
*/
|
|
|
|
public function setSize($size)
|
|
|
|
{
|
|
|
|
$this->size = (int) $size;
|
|
|
|
}
|
2016-12-09 11:47:28 +01:00
|
|
|
}
|