Filter: Query pipeline feature
Filter: Query pipeline feature
A query pipeline statement expressing the filter
query pipeline feature adds one or more query expressions to the advanced (aq
), constant (cq
), disjunction (dq
), large (lq
), or basic (q
) part of the query expression before the query is sent to the index.
Leading practice
Typically, a statement expressing the In general, you should ensure that this is the case by associating such a statement, and/or the pipeline it’s defined in, to a global condition. Moreover, when basing a Example
Condition
Statement
|
Note
In the Coveo Administration Console, you can manage statements expressing the |
The following diagram shows the process of a query being sent to the Search API and the order of execution of query pipeline features.
Filters, by themselves, don’t prevent the exposure of filtered content.
We strongly advise against creating a source whose content is accessible to everyone ( In the following cases, sensitive content from a source whose content is accessible to everyone (
You can ensure security by enforcing the search hub at the search token level (see Search token authentication). Moreover, search hubs defined on the client-side that are used as conditions in pipelines don’t safeguard the security of the filtered content. |
Syntax
Use the following query pipeline language (QPL) syntax to define a statement expressing the filter
feature:
filter <queryExpressionPart> <expressions>
<queryExpressionPart>
A string indicating the part of the query expression to which one or more query expressions should be appended. Must be one of:
-
aq
: The advanced part -
cq
: The constant part -
dq
: the disjunction part -
lq
: the large part -
q
: the basic part
Notes
|
<expressions>
A comma-separated list of query expressions (for example, foo`,
using an implicit @bar=="baz"
).
Each of those query expressions will be appended to the current value of the target `<queryExpressionPart>AND
operator (that is, a whitespace character).
The result set of the constant part ( Consequently, you should avoid creating |
Example
You create a global condition with the following QPL definition:
Global condition:
when $searchHub is "Community"
In an empty query pipeline named Testing Filter
, you create three distinct statements, each expressing the filter
feature, with the following QPL definitions:
Statement 1:
filter cq `@language==en`
Statement 2:
filter aq `@source=="Public Content"`
Statement 3:
filter dq `@date=today`
You associate each of those three statements to the global condition you created before.
A user performs a query with the following payload:
{
"aq": "@tags==(\"Query pipeline\", \"Search API\")",
"context": {
"userRole": "Developer"
},
"cq": "@filetype==html",
"pipeline": "Testing Filter",
"q": "filter statement",
"searchHub": "Community"
}
Since this query goes through the Testing Filter
query pipeline and satisfies the condition of each statement in that pipeline, those statements apply.
As a result, the different parts of the query expression are modified as follows:
-
cq
(that is,$constantQuery
) becomes@filetype==html @language==en
. -
aq
(that is,$advancedQuery
) becomes@tags==("Query pipeline", "Search API") @source=="Public Content"
. -
dq
(that is,$disjunctionQuery
) becomes@date=today
. -
q
(that is,$query
) remainsfilter statement
.
The combined query expression (that is, ((q AND aq) OR dq) AND cq
) means that to be included in the result set of this query, an item must mandatorily:
-
Be an HTML file (because of the original
cq
query parameter). -
Be in English (because of Statement 1, which modifies the
cq
expression).
In addition, this item must:
-
Match the
filter statement
basic query expression (because of theq
query parameter). -
Be tagged as being about query pipelines or the Search API (because of the original
aq
query parameter). -
Reside within the source named Public Content (because of Statement 2, which modifies the
aq
expression).OR
-
Have been updated today (because of Statement 3, which modifies the
dq
expression).