Merge pull request #2988 from aynsix/PHRAS-2497-port-41-search-when-mix-data

PHRAS-2497 Port TO 4.1 - Search issue when query mix data from Public and Private field
This commit is contained in:
Nicolas Maillat
2019-04-24 18:44:26 +02:00
committed by GitHub
8 changed files with 50 additions and 20 deletions

View File

@@ -43,7 +43,7 @@ class QuotedTextNode extends Node
$private_fields = $context->getPrivateFields(); $private_fields = $context->getPrivateFields();
$private_fields = ValueChecker::filterByValueCompatibility($private_fields, $this->text); $private_fields = ValueChecker::filterByValueCompatibility($private_fields, $this->text);
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $query_builder) as $private_field_query) { foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $unrestricted_fields, $query_builder) as $private_field_query) {
$query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query); $query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query);
} }

View File

@@ -61,7 +61,7 @@ class RawNode extends Node
$private_fields = $context->getPrivateFields(); $private_fields = $context->getPrivateFields();
$private_fields = ValueChecker::filterByValueCompatibility($private_fields, $this->text); $private_fields = ValueChecker::filterByValueCompatibility($private_fields, $this->text);
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $query_builder) as $private_field_query) { foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $unrestricted_fields, $query_builder) as $private_field_query) {
$query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query); $query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query);
} }

View File

@@ -19,9 +19,11 @@ class TermNode extends AbstractTermNode
return $query; return $query;
}; };
$query = $query_builder($context->getUnrestrictedFields()); $unrestricted_fields = $context->getUnrestrictedFields();
$private_fields = $context->getPrivateFields(); $private_fields = $context->getPrivateFields();
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $query_builder) as $concept_query) { $query = $query_builder($unrestricted_fields);
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $unrestricted_fields, $query_builder) as $concept_query) {
$query = QueryHelper::applyBooleanClause($query, 'should', $concept_query); $query = QueryHelper::applyBooleanClause($query, 'should', $concept_query);
} }

View File

@@ -66,12 +66,11 @@ class TextNode extends AbstractTermNode implements ContextAbleInterface
return $query; return $query;
}; };
// Unrestricted fields $unrestricted_fields = $context->getUnrestrictedFields();
$query = $query_builder($context->getUnrestrictedFields());
// Private fields
$private_fields = $context->getPrivateFields(); $private_fields = $context->getPrivateFields();
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $query_builder) as $private_field_query) {
$query = $query_builder($unrestricted_fields);
foreach (QueryHelper::wrapPrivateFieldQueries($private_fields, $unrestricted_fields, $query_builder) as $private_field_query) {
$query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query); $query = QueryHelper::applyBooleanClause($query, 'should', $private_field_query);
} }

View File

@@ -10,13 +10,13 @@ class QueryHelper
{ {
private function __construct() {} private function __construct() {}
public static function wrapPrivateFieldQueries(array $fields, \Closure $query_builder) public static function wrapPrivateFieldQueries(array $private_fields, array $unrestricted_fields, \Closure $query_builder)
{ {
// We make a boolean clause for each collection set to shrink query size // We make a boolean clause for each collection set to shrink query size
// (instead of a clause for each field, with his collection set) // (instead of a clause for each field, with his collection set)
$fields_map = []; $fields_map = [];
$collections_map = []; $collections_map = [];
foreach ($fields as $field) { foreach ($private_fields as $field) {
$collections = $field->getDependantCollections(); $collections = $field->getDependantCollections();
$hash = self::hashCollections($collections); $hash = self::hashCollections($collections);
$collections_map[$hash] = $collections; $collections_map[$hash] = $collections;
@@ -31,7 +31,7 @@ class QueryHelper
foreach ($fields_map as $hash => $fields) { foreach ($fields_map as $hash => $fields) {
// Right to query on a private field is dependant of document collection // Right to query on a private field is dependant of document collection
// Here we make sure we can only match on allowed collections // Here we make sure we can only match on allowed collections
$query = $query_builder($fields); $query = $query_builder(array_merge($fields, $unrestricted_fields));
if ($query !== null) { if ($query !== null) {
$queries[] = self::restrictQueryToCollections($query, $collections_map[$hash]); $queries[] = self::restrictQueryToCollections($query, $collections_map[$hash]);
} }

View File

@@ -47,7 +47,9 @@ class QuotedTextNodeTest extends \PHPUnit_Framework_TestCase
public function testQueryBuildWithPrivateFields() public function testQueryBuildWithPrivateFields()
{ {
$public_field = new Field('foo', FieldMapping::TYPE_STRING, ['private' => false]); $public_field = new Field('foo', FieldMapping::TYPE_STRING, [
'private' => false
]);
$private_field = new Field('bar', FieldMapping::TYPE_STRING, [ $private_field = new Field('bar', FieldMapping::TYPE_STRING, [
'private' => true, 'private' => true,
'used_by_collections' => [1, 2, 3] 'used_by_collections' => [1, 2, 3]
@@ -75,7 +77,10 @@ class QuotedTextNodeTest extends \PHPUnit_Framework_TestCase
"should": [{ "should": [{
"multi_match": { "multi_match": {
"type": "phrase", "type": "phrase",
"fields": ["foo.fr", "foo.en"], "fields": [
"foo.fr",
"foo.en"
],
"query": "baz", "query": "baz",
"lenient": true "lenient": true
} }
@@ -89,7 +94,12 @@ class QuotedTextNodeTest extends \PHPUnit_Framework_TestCase
"query": { "query": {
"multi_match": { "multi_match": {
"type": "phrase", "type": "phrase",
"fields": ["private_caption.bar.fr", "private_caption.bar.en"], "fields": [
"private_caption.bar.fr",
"private_caption.bar.en",
"foo.fr",
"foo.en"
],
"query": "baz", "query": "baz",
"lenient": true "lenient": true
} }

View File

@@ -126,12 +126,18 @@ class TermNodeTest extends \PHPUnit_Framework_TestCase
"bool": { "bool": {
"should": [{ "should": [{
"multi_match": { "multi_match": {
"fields": ["concept_path.bar"], "fields": [
"concept_path.bar",
"concept_path.foo"
],
"query": "/baz" "query": "/baz"
} }
}, { }, {
"multi_match": { "multi_match": {
"fields": ["concept_path.bar"], "fields": [
"concept_path.bar",
"concept_path.foo"
],
"query": "/qux" "query": "/qux"
} }
}] }]

View File

@@ -109,7 +109,12 @@ class TextNodeTest extends \PHPUnit_Framework_TestCase
}, },
"query": { "query": {
"multi_match": { "multi_match": {
"fields": ["private_caption.bar.fr", "private_caption.bar.en"], "fields": [
"private_caption.bar.fr",
"private_caption.bar.en",
"foo.fr",
"foo.en"
],
"query": "baz", "query": "baz",
"type": "cross_fields", "type": "cross_fields",
"operator": "and", "operator": "and",
@@ -216,7 +221,12 @@ class TextNodeTest extends \PHPUnit_Framework_TestCase
"bool": { "bool": {
"should": [{ "should": [{
"multi_match": { "multi_match": {
"fields": ["private_caption.bar.fr", "private_caption.bar.en"], "fields": [
"private_caption.bar.fr",
"private_caption.bar.en",
"foo.fr",
"foo.en"
],
"query": "baz", "query": "baz",
"type": "cross_fields", "type": "cross_fields",
"operator": "and", "operator": "and",
@@ -224,7 +234,10 @@ class TextNodeTest extends \PHPUnit_Framework_TestCase
} }
}, { }, {
"multi_match": { "multi_match": {
"fields": ["concept_path.bar"], "fields": [
"concept_path.bar",
"concept_path.foo"
],
"query": "/qux" "query": "/qux"
} }
}] }]