Files
Phraseanet/lib/Alchemy/Phrasea/SearchEngine/Elastic/AST/TextNode.php
Mathieu Darse a31442368b Fix number field search
Search with non numeric content will not hit number field (it breaks elasticsearch and is useless anyway)

- Rename QueryHelper::buildPrivateFieldQueries() to wrapPrivateFieldQuery().
    - Signature changed too, the third parameter is dropped an QueryContext is replaced by an array of Field.
    - Query builder closure is now passed an array of Field, not of index field names.
- Remove Field::toConceptPathIndexFieldArray() because method name was beyond understanding (and also because it wasn't needed anymore)
- Various AST node types have changed due to previous API changes
2015-07-23 17:39:11 +02:00

80 lines
2.6 KiB
PHP

<?php
namespace Alchemy\Phrasea\SearchEngine\Elastic\AST;
use Alchemy\Phrasea\SearchEngine\Elastic\Search\QueryContext;
use Alchemy\Phrasea\SearchEngine\Elastic\Search\QueryHelper;
use Alchemy\Phrasea\SearchEngine\Elastic\Search\TextQueryHelper;
use Alchemy\Phrasea\SearchEngine\Elastic\Thesaurus\Term;
class TextNode extends AbstractTermNode implements ContextAbleInterface
{
/**
* Merge two text nodes by concatenating their content.
*
* /!\ Text contexts are lost in the process
*
* @param TextNode $a First node
* @param TextNode $b The other one
* @return TextNode Merged text node
*/
public static function merge(TextNode $a, TextNode $b)
{
return new self(sprintf('%s%s', $a->getValue(), $b->getValue()));
}
/**
* Creates a new text node with the same content and the provided context.
*
* /!\ The original node context will not be preserved (ie. not merged).
*
* @param Context $context Context to add on the new node
* @return TextNode A text node with a context
*/
public function withContext(Context $context)
{
return new self($this->getValue(), $context);
}
public function buildQuery(QueryContext $context)
{
$query_builder = function (array $fields) use ($context) {
$index_fields = [];
foreach ($fields as $field) {
foreach ($context->localizeField($field) as $index_fields[]);
}
if (!$index_fields) {
return null;
}
return [
'multi_match' => [
'fields' => $index_fields,
'query' => $this->text,
'operator' => 'and',
]
];
};
$query = $query_builder($context->getUnrestrictedFields());
$private_fields = $context->getPrivateFields();
$private_fields = TextQueryHelper::filterCompatibleFields($private_fields, $this->text);
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $query_builder) as $private_field_query) {
$query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query);
}
$concept_query = $this->buildConceptQuery($context);
if ($concept_query !== null) {
$query = QueryHelper::applyBooleanClause($query, 'should', $this->buildConceptQuery($context));
}
return $query;
}
public function __toString()
{
return sprintf('<text:%s>', Term::dump($this));
}
}