group
This predicate allows building nested conditions. Groups can contain nested groups. Everything in a Query Builder query is implicitly in a root group, which can have p.or
and p.not
parameters as well.
The following is an example for matching either one of two properties against a value:
group.p.or=true
group.1_property=jcr:title
group.1_property.value=My Page
group.2_property=navTitle
group.2_property.value=My Page
Conceptually, it is (1_property
OR 2_property)
.
The following is an example for nested groups:
fulltext=Management
group.p.or=true
group.1_group.path=/content/wknd/ch/de
group.1_group.type=cq:Page
group.2_group.path=/content/dam/wknd
group.2_group.type=dam:Asset
Searches for the term Management within pages in /content/wknd/ch/de
or in assets in /content/dam/wknd
.
Conceptually, it is fulltext AND ( (path AND type) OR (path AND type) )
. Such OR joins need good indexes for performance reasons.
Properties
p.or
- if set totrue
, only one predicate in the group must match. Defaults tofalse
, meaning all must matchp.not
- if set totrue
, it negates the group (defaults tofalse
)<predicate>
- adds nested predicatesN_<predicate>
- adds multiple nested predicates of the same time, like1_property, 2_property, ...
orderby
This predicate allows sorting the results. If ordering by multiple properties is required, this predicate must be added multiple times using the number prefix, such as 1_orderby=first
, 2_oderby=second
.
Properties
orderby
- either JCR property name indicated by a leading @, for example,@jcr:lastModified
or@jcr:content/jcr:title
, or another predicate in the query, for example,2_property
, on which to sortsort
- sort direction, eitherdesc
for descending orasc
for ascending (default)case
- if set toignore
, it makes sorting case insensitive, meaninga
comes beforeB
; if empty or left out, sorting is case-sensitive, meaningB
comes beforea
Predicates
boolproperty
This predicate matches on JCR boolean properties. Only accepts the values true
and false
. If the value is false
, it matches if the property has the value false
, or if it does not exist at all. This predicate is useful for checking for boolean flags that are only set when enabled.
The inherited operation
parameter has no meaning.
This predicate supports facet extraction and provides buckets for each true
or false
value, but only for existing properties.
Properties
boolproperty
- relative path to property, for example,myFeatureEnabled
orjcr:content/myFeatureEnabled
value
- value to check property for,true
orfalse
contentfragment
This predicate restricts the result to content fragments.
- It does not support filtering.
- It does not support facet extraction.
Properties
contentfragment
- It can be used with any value to check for content fragments.
dateComparison
This predicate compares two JCR date properties with each other. Can test if they are equal, unequal, greater than or greater-than-or-equal.
A filtering-only predicate and cannot use a search index.
Properties
-
property1
- path to first date property -
property2
- path to second date property -
operation
=
for exact match (default)!=
for inequality comparison>
forproperty1
greater thanproperty2
>=
forproperty1
greater than or equal toproperty2
daterange
This predicate matches JCR date properties against a date/time interval. Uses the ISO8601
format for dates and times (YYYY-MM-DDTHH:mm:ss.SSSZ
) and allows also partial representations, like YYYY-MM-DD
. Alternatively, the timestamp can be provided as POSIX time.
You can look for anything between two timestamps, anything newer or older than a given date, and also chose between inclusive and open intervals.
It supports facet extraction and provides buckets today
, this week
, this month
, last 3 months
, this year
, last year
, and earlier than last year
.
It does not support filtering.
Properties
property
- relative path to aDATE
property, for example,jcr:lastModified
lowerBound
- lower date bound to check property for, for example,2014-10-01
lowerOperation
->
(newer) or>=
(at or newer), applies to thelowerBound
. The default is>
upperBound
- upper bound to check property for, for example,2014-10-01T12:15:00
upperOperation
-<
(older) or<=
(at or older), applies to theupperBound
. The default is<
timeZone
- ID of timezone to use when it is not given as an ISO-8601 date string. The default is the default timezone of the system.
excludepaths
This predicate excludes nodes from the result where their path matches a regular expression.
A filtering-only predicate and cannot use a search index.
It does not support facet extraction.
Properties
excludepaths
- regular expression matched against result paths, excluding matching ones from the result.
fulltext
Searches for terms in the fulltext index.
It does not support filtering.
It does not support facet extraction.
Properties
fulltext
- the fulltext search termsrelPath
- the relative path to search in the property or subnode. This property is optional.
hasPermission
This predicate restricts the result to items where the current session has the specified JCR privileges.
A filtering-only predicate and cannot use a search index. It does not support facet extraction.
Properties
hasPermission
- all comma-separated JCR privileges that the current user session must have for the node in question. For example,jcr:write
,jcr:modifyAccessControl
language
This predicate finds AEM pages in a specific language. It looks at both the page language property and the page path which often includes the language or locale in a top-level site structure.
A filtering-only predicate and cannot use a search index.
It supports facet extraction and provides buckets for each unique language code.
Properties
language
- ISO language code, for example,de
mainasset
This predicate checks if a node is a DAM main asset and not a sub asset. It is basically every node not inside a sub assets node. It does not check for the dam:Asset
node type. To use this predicate, set mainasset=true
or mainasset=false
. There are no further properties.
A filtering-only predicate and cannot use a search index.
It supports facet extraction and provides two buckets for main and sub assets.
Properties
mainasset
- boolean,true
for main assets,false
for sub assets
memberOf
This predicate finds items that are member of a specific sling resource collection.
A filtering-only predicate and cannot use a search index.
It does not support facet extraction.
Properties
memberOf
- path of Sling resource collection
nodename
This predicate matches on JCR node names.
It supports facet extraction and provides buckets for each unique node name (filename).
Properties
nodename
- node name pattern that allows wildcards:*
= any or no char,?
= any char,[abc]
= only chars in brackets
notexpired
This predicate matches items by checking if a JCR date property is greater or equal than the current server time. It can be used to check on an expiresAt
value and limits results to only those values that have not yet expired (notexpired=true
), or that have expired already (notexpired=false
).
It does not support filtering.
It supports facet extraction in the same way as the daterange
predicate.
Properties
notexpired
- boolean,true
for not yet expired (date in the future or equal),false
for expired (date in the past) (required)property
- relative path to theDATE
property to check (required)
path
This predicate searches within a given path.
It does not support facet extraction.
Properties
path
- Defines the path pattern.- Depending on the
exact
property, either the entire subtree matches (like appending//*
in xpath, but note that it does not include the base path), or only an exact path is matched, which can include wildcards (*
).- Defaults to
true
.
- Defaults to
- Depending on the
exact
- ifexact
istrue
, the exact path must match, but it can contain simple wildcards (*
), that match names, but not/
; if it isfalse
(default) all descendants are included (optional).flat
- searches only the direct children (like appending/*
in xpath) (only used ifexact
is not true, optional).self
- searches the subtree but includes the base node given as path (no wildcards).- Important Note: An issue has been identified with
self
property in the current implementation of query builder and using it in queries may not produce correct search results. Changing the current implementation ofself
property is also not feasible because it might break the existing applications that rely on it. Due to this functionality,self
property is now deprecated; it is advised to avoid using it.
- Important Note: An issue has been identified with
property
This predicate matches on JCR properties and their values.
It supports facet extraction and provides buckets for each unique property value in the results.
Properties
-
property
- relative path to property, for example,jcr:title
. -
value
- value to check property for; follows the JCR property type to string conversions. -
N_value
- use1_value
,2_value
, … to check for multiple values (combined withOR
by default, withAND
ifand=true
). -
and
- set totrue
for combining multiple values (N_value
) withAND
-
operation
-
equals
for exact match (default). -
unequals
for inequality comparison. -
like
for using thejcr:like
xpath function (optional). -
not
for no match (for example,not(@prop)
in xpath, value param is ignored). -
exists
for existence check.true
the property must exist.false
is the same asnot
and is the default.
-
-
depth
- number of wildcard levels underneath which the property/relative path can exist (for example,property=size depth=2
checksnode/size
,node/*/size
, andnode/*/*/size
).
rangeproperty
This predicate matches a JCR property against an interval. It applies to properties with linear types such as LONG
, DOUBLE
, and DECIMAL
. For DATE
, see the daterange
predicate that has optimized date format input.
You can define a lower bound, an upper bound, or both. The operation (for example, lesser than, or lesser than or equal to) can also be specified for lower and upper bound individually.
It does not support facet extraction.
Properties
property
- relative path to propertylowerBound
- lower bound to check propertylowerOperation
->
(default) or>=
, applies to thelowerValue
upperBound
- upper bound to check propertyupperOperation
-<
(default) or<=
, applies to thelowerValue
decimal
-true
if the checked property is of type Decimal
relativedaterange
This predicate matches JCR DATE
properties against a date/time interval using time offsets relative to the current server time. You can specify lowerBound
and upperBound
using either a millisecond value or the Bugzilla syntax 1s 2m 3h 4d 5w 6M 7y
(one second, two minutes, three hours, four days, five weeks, six months, seven years). Prefix with -
to indicate a negative offset before the current time. If you only specify lowerBound
or upperBound
, the other one defaults to 0
, representing the current time.
For example:
upperBound=1h
(and nolowerBound
) selects anything in the next hourlowerBound=-1d
(and noupperBound
) selects anything in the last 24 hourslowerBound=-6M
andupperBound=-3M
selects anything in the last 3 to six monthslowerBound=-1500
andupperBound=5500
selects anything between 1500 milliseconds old and 5500 milliseconds in the futurelowerBound=1d
andupperBound=2d
selects anything the day after tomorrow
It does not take leap years into consideration and all months are 30 days.
It does not support filtering.
It supports facet extraction in the same way as the daterange
predicate.
Properties
upperBound
- upper date bound in milliseconds or1s 2m 3h 4d 5w 6M 7y
(one second, two minutes, three hours, four days, five weeks, six months, seven years) relative to current server time, use-
for negative offsetlowerBound
- lower date bound in milliseconds or1s 2m 3h 4d 5w 6M 7y
(one second, two minutes, three hours, four days, five weeks, six months, seven years) relative to current server time, use-
for negative offset
savedquery
This predicate includes all predicates of a persisted Query Builder query into the current query as a sub group predicate.
It does not run an extra query but extends the current query.
Queries can be persisted programmatically using QueryBuilder#storeQuery()
. The format can be either a multi-line String
property or an nt:file
node that contains the query as a text file in Java™ properties format.
It does not support facet extraction for the predicates of the saved query.
Properties
savedquery
- path to the saved query (String
property ornt:file
node)
similar
This predicate is a similarity search using JCR XPath’s rep:similar()
.
It does not support filtering and does not support facet extraction.
Properties
similar
- absolute path to the node for which to find similar nodeslocal
- a relative path to a descendant node or.
for the current node (optional, default is.
)
tag
This predicate searches for content tagged with one or more tags, by specifying tag title paths.
It supports facet extraction and provides buckets for each unique tag, using their current tag title path.
Properties
tag
- tag title path to look for, for example,properties:orientation/landscape
N_value
- use1_value
,2_value
, … to check for multiple tags (combined withOR
by default, withAND
ifand=true
)property
- property (or relative path to property) to look at (defaultcq:tags
)
tagid
This predicate searches for content tagged with one or more tags, by specifying tag IDs.
It supports facet extraction and provides buckets for each unique tag, using their current tag ID.
Properties
tagid
- tag ID to look for, for example,properties:orientation/landscape
N_value
- use1_value
,2_value
, … to check for multiple tag IDs (combined withOR
by default, withAND
ifand=true
)property
- property (or relative path to property) to look at (defaultcq:tags
)
tagsearch
This predicate searches for content tagged with one or more tags, by specifying keywords. It searches first for tags containing these keywords in their titles, then restricts the result to only items tagged with these keywords.
It does not support facet extraction.
Properties
tagsearch
- keyword to search for in tag titlesproperty
- property (or relative path to property) to consider (defaultcq:tags
)lang
- to search in a certain localized tag title only (for example,de
)all
- boolean value to search entire tag fulltext, that is, all titles, descriptions, and so on (takes precedence overlang
)
type
This predicate restricts results to a specific JCR node type, both primary node types or mixin
types. It also finds sub types of that node type. Repository search indexes must cover the node types for efficient execution.
It supports facet extraction and provides buckets for each unique type in the results.
Properties
type
- node type ormixin
name to search for, for example,cq:Page