Maslosoft Manganel API
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73
<?php
/**
* This software package is licensed under `AGPL, Commercial` license[s].
*
* @package maslosoft/manganel
* @license AGPL, Commercial
*
* @copyright Copyright (c) Peter Maselkowski <pmaselkowski@gmail.com>
* @link https://maslosoft.com/manganel/
*/
namespace Maslosoft\Manganel\Decorators\QueryBuilder;
use Maslosoft\Gazebo\PluginFactory;
use Maslosoft\Manganel\Interfaces\ManganelAwareInterface;
use Maslosoft\Manganel\Interfaces\QueryBuilder\ConditionDecoratorInterface;
use Maslosoft\Manganel\Interfaces\QueryBuilder\QueryStringDecoratorInterface;
use Maslosoft\Manganel\SearchCriteria;
use Maslosoft\Manganel\Traits\ManganelAwareTrait;
use stdClass;
/**
* SearchDecorator
*
* @author Piotr Maselkowski <pmaselkowski at gmail.com>
*/
class SearchDecorator implements ConditionDecoratorInterface,
ManganelAwareInterface
{
use ManganelAwareTrait;
const Ns = __NAMESPACE__;
public function decorate(&$conditions, SearchCriteria $criteria)
{
$q = $criteria->getSearch();
if (empty($q))
{
// Match all documents if query is null
// stdClass is used here to get `{}` in json, as `[]` causes bad
// request exception!
$conditions[] = [
'match_all' => new stdClass()
];
}
else
{
// Use query string matching
$decorators = (new PluginFactory())->instance($this->manganel->decorators, $criteria, [
QueryStringDecoratorInterface::class
]);
$queryStringParams = [];
foreach ($decorators as $decorator)
{
/* @var $decorator QueryStringDecoratorInterface */
$decorator->decorate($queryStringParams, $criteria);
}
$conditions[] = [
'simple_query_string' => $queryStringParams
];
}
}
public function getKind()
{
return self::KindMust;
}
}
API documentation generated by ApiGen