org.camunda.bpm.engine.task.TaskQuery Maven / Gradle / Ivy
/*
* Copyright Camunda Services GmbH and/or licensed to Camunda Services GmbH
* under one or more contributor license agreements. See the NOTICE file
* distributed with this work for additional information regarding copyright
* ownership. Camunda licenses this file to you under the Apache License,
* Version 2.0; you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.camunda.bpm.engine.task;
import java.io.Serializable;
import java.util.Date;
import java.util.List;
import org.camunda.bpm.engine.BadUserRequestException;
import org.camunda.bpm.engine.ProcessEngineConfiguration;
import org.camunda.bpm.engine.ProcessEngineException;
import org.camunda.bpm.engine.query.Query;
import org.camunda.bpm.engine.variable.type.ValueType;
/**
* Allows programmatic querying of {@link Task}s;
*
* @author Joram Barrez
* @author Falko Menge
*/
public interface TaskQuery extends Query{
/**
* Only select tasks with the given task id (in practice, there will be
* maximum one of this kind)
*/
TaskQuery taskId(String taskId);
/** Only select tasks with the given task ids. */
TaskQuery taskIdIn(String... taskIds);
/**
* Only select tasks with the given name.
* The query will match the names of tasks in a case-insensitive way.
*/
TaskQuery taskName(String name);
/**
* Only select tasks with a name not matching the given name/
* The query will match the names of tasks in a case-insensitive way.
*/
TaskQuery taskNameNotEqual(String name);
/**
* Only select tasks with a name matching the parameter.
* The syntax is that of SQL: for example usage: nameLike(%camunda%).
* The query will match the names of tasks in a case-insensitive way.
*/
TaskQuery taskNameLike(String nameLike);
/**
* Only select tasks with a name not matching the parameter.
* The syntax is that of SQL: for example usage: nameNotLike(%camunda%)
* The query will match the names of tasks in a case-insensitive way.
*/
TaskQuery taskNameNotLike(String nameNotLike);
/**
* Only select tasks with the given description.
* The query will match the descriptions of tasks in a case-insensitive way.
*/
TaskQuery taskDescription(String description);
/**
* Only select tasks with a description matching the parameter .
* The syntax is that of SQL: for example usage: descriptionLike(%camunda%)
* The query will match the descriptions of tasks in a case-insensitive way.
*/
TaskQuery taskDescriptionLike(String descriptionLike);
/** Only select tasks with the given priority. */
TaskQuery taskPriority(Integer priority);
/** Only select tasks with the given priority or higher. */
TaskQuery taskMinPriority(Integer minPriority);
/** Only select tasks with the given priority or lower. */
TaskQuery taskMaxPriority(Integer maxPriority);
/** Only select tasks which are assigned to the given user. */
TaskQuery taskAssignee(String assignee);
/**
* Only select tasks which are assigned to the user described by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskAssigneeExpression(String assigneeExpression);
/** Only select tasks which are matching the given user.
* The syntax is that of SQL: for example usage: nameLike(%camunda%)*/
TaskQuery taskAssigneeLike(String assignee);
/**
* Only select tasks which are assigned to the user described by the given expression.
* The syntax is that of SQL: for example usage: taskAssigneeLikeExpression("${'%test%'}")
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskAssigneeLikeExpression(String assigneeLikeExpression);
/** Only select tasks which are assigned to one of the given users. */
TaskQuery taskAssigneeIn(String... assignees);
/** Only select tasks which are not assigned to any of the given users. */
TaskQuery taskAssigneeNotIn(String... assignees);
/** Only select tasks for which the given user is the owner. */
TaskQuery taskOwner(String owner);
/**
* Only select tasks for which the described user by the given expression is the owner.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskOwnerExpression(String ownerExpression);
/** Only select tasks which don't have an assignee. */
TaskQuery taskUnassigned();
/** @see {@link #taskUnassigned} */
@Deprecated
TaskQuery taskUnnassigned();
/** Only select tasks which have an assignee. */
TaskQuery taskAssigned();
/** Only select tasks with the given {@link DelegationState}. */
TaskQuery taskDelegationState(DelegationState delegationState);
/**
* Only select tasks for which the given user or one of his groups is a candidate.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the "and query" instance.
* No exception is thrown when query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the "or query" instance.
*
- When passed user is
null
.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*
*/
TaskQuery taskCandidateUser(String candidateUser);
/**
* Only select tasks for which the described user by the given expression is a candidate.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the query instance.
*
- When passed user is
null
.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskCandidateUserExpression(String candidateUserExpression);
/** Only select tasks for which there exist an {@link IdentityLink} with the given user */
TaskQuery taskInvolvedUser(String involvedUser);
/**
* Only select tasks for which there exist an {@link IdentityLink} with the
* described user by the given expression
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskInvolvedUserExpression(String involvedUserExpression);
/**
* Only select tasks which have a candidate group
*
* @throws ProcessEngineException When method has been executed within "or query".
*/
TaskQuery withCandidateGroups();
/**
* Only select tasks which have no candidate group
*
* @throws ProcessEngineException When method has been executed within "or query".
*/
TaskQuery withoutCandidateGroups();
/**
* Only select tasks which have a candidate user
*
* @throws ProcessEngineException When method has been executed within "or query".
*/
TaskQuery withCandidateUsers();
/**
* Only select tasks which have no candidate user
*
* @throws ProcessEngineException When method has been executed within "or query".
*/
TaskQuery withoutCandidateUsers();
/**
* Only select tasks for which users in the given group are candidates.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateUser(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the "and query" instance.
* No exception is thrown when query is executed and {@link #taskCandidateUser(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the "or query" instance.
* - When passed group is
null
.
*/
TaskQuery taskCandidateGroup(String candidateGroup);
/**
* Only select tasks for which users in the described group by the given expression are candidates.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateUser(String)} or
* {@link #taskCandidateGroupIn(List)} has been executed on the query instance.
*
- When passed group is
null
.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskCandidateGroupExpression(String candidateGroupExpression);
/**
* Only select tasks for which the 'candidateGroup' is one of the given groups.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateUser(String)} has been executed on the "and query" instance.
* No exception is thrown when query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateUser(String)} has been executed on the "or query" instance.
* - When passed group list is empty or
null
.
*/
TaskQuery taskCandidateGroupIn(List candidateGroups);
/**
* Only select tasks for which the 'candidateGroup' is one of the described groups of the given expression.
*
*
* Per default it only selects tasks which are not already assigned
* to a user. To also include assigned task in the result specify
* {@link #includeAssignedTasks()} in your query.
*
*
* @throws ProcessEngineException
* - When query is executed and {@link #taskCandidateGroup(String)} or
* {@link #taskCandidateUser(String)} has been executed on the query instance.
*
- When passed group list is empty or
null
.
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery taskCandidateGroupInExpression(String candidateGroupsExpression);
/**
* Select both assigned and not assigned tasks for candidate user or group queries.
*
* By default {@link #taskCandidateUser(String)}, {@link #taskCandidateGroup(String)}
* and {@link #taskCandidateGroupIn(List)} queries only select not assigned tasks.
*
*
* @throws ProcessEngineException
* When no candidate user or group(s) are specified beforehand
*/
TaskQuery includeAssignedTasks();
/** Only select tasks for the given process instance id. */
TaskQuery processInstanceId(String processInstanceId);
/** Only select tasks for the given process instance ids. */
TaskQuery processInstanceIdIn(String... processInstanceIds);
/** Only select tasks for the given process instance business key */
TaskQuery processInstanceBusinessKey(String processInstanceBusinessKey);
/** Only select tasks for the given process instance business key described by the given expression */
TaskQuery processInstanceBusinessKeyExpression(String processInstanceBusinessKeyExpression);
/**
* Only select tasks for any of the given the given process instance business keys.
*/
TaskQuery processInstanceBusinessKeyIn(String... processInstanceBusinessKeys);
/** Only select tasks matching the given process instance business key.
* The syntax is that of SQL: for example usage: nameLike(%camunda%)*/
TaskQuery processInstanceBusinessKeyLike(String processInstanceBusinessKey);
/** Only select tasks matching the given process instance business key described by the given expression.
* The syntax is that of SQL: for example usage: processInstanceBusinessKeyLikeExpression("${ '%camunda%' }")*/
TaskQuery processInstanceBusinessKeyLikeExpression(String processInstanceBusinessKeyExpression);
/** Only select tasks for the given execution. */
TaskQuery executionId(String executionId);
/** Only select task which have one of the activity instance ids. **/
TaskQuery activityInstanceIdIn(String... activityInstanceIds);
/** Only select tasks that are created on the given date. **/
TaskQuery taskCreatedOn(Date createTime);
/** Only select tasks that are created on the described date by the given expression. **/
TaskQuery taskCreatedOnExpression(String createTimeExpression);
/** Only select tasks that are created before the given date. **/
TaskQuery taskCreatedBefore(Date before);
/** Only select tasks that are created before the described date by the given expression. **/
TaskQuery taskCreatedBeforeExpression(String beforeExpression);
/** Only select tasks that are created after the given date. **/
TaskQuery taskCreatedAfter(Date after);
/** Only select tasks that are created after the described date by the given expression. **/
TaskQuery taskCreatedAfterExpression(String afterExpression);
/** Only select tasks that have no parent (i.e. do not select subtasks). **/
TaskQuery excludeSubtasks();
/**
* Only select tasks with the given taskDefinitionKey.
* The task definition key is the id of the userTask:
* <userTask id="xxx" .../>
**/
TaskQuery taskDefinitionKey(String key);
/**
* Only select tasks with a taskDefinitionKey that match the given parameter.
* The syntax is that of SQL: for example usage: taskDefinitionKeyLike("%camunda%").
* The task definition key is the id of the userTask:
* <userTask id="xxx" .../>
**/
TaskQuery taskDefinitionKeyLike(String keyLike);
/** Only select tasks which have one of the taskDefinitionKeys. **/
TaskQuery taskDefinitionKeyIn(String... taskDefinitionKeys);
/**
* Select the tasks which are sub tasks of the given parent task.
*/
TaskQuery taskParentTaskId(String parentTaskId);
/** Only select tasks for the given case instance id. */
TaskQuery caseInstanceId(String caseInstanceId);
/** Only select tasks for the given case instance business key */
TaskQuery caseInstanceBusinessKey(String caseInstanceBusinessKey);
/** Only select tasks matching the given case instance business key.
* The syntax is that of SQL: for example usage: nameLike(%aBusinessKey%)*/
TaskQuery caseInstanceBusinessKeyLike(String caseInstanceBusinessKeyLike);
/** Only select tasks for the given case execution. */
TaskQuery caseExecutionId(String caseExecutionId);
/**
* Only select tasks which are part of a case instance which has the given
* case definition key.
*/
TaskQuery caseDefinitionKey(String caseDefinitionKey);
/**
* Only select tasks which are part of a case instance which has the given
* case definition id.
*/
TaskQuery caseDefinitionId(String caseDefinitionId);
/**
* Only select tasks which are part of a case instance which has the given
* case definition name.
*/
TaskQuery caseDefinitionName(String caseDefinitionName);
/**
* Only select tasks which are part of a case instance which case definition
* name is like the given parameter.
* The syntax is that of SQL: for example usage: nameLike(%processDefinitionName%)*/
TaskQuery caseDefinitionNameLike(String caseDefinitionNameLike);
/**
* All queries for task-, process- and case-variables will match the variable names in a case-insensitive way.
*/
TaskQuery matchVariableNamesIgnoreCase();
/**
* All queries for task-, process- and case-variables will match the variable values in a case-insensitive way.
*/
TaskQuery matchVariableValuesIgnoreCase();
/**
* Only select tasks which have a local task variable with the given name
* set to the given value.
*/
TaskQuery taskVariableValueEquals(String variableName, Object variableValue);
/**
* Only select tasks which have a local task variable with the given name, but
* with a different value than the passed value.
* Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*/
TaskQuery taskVariableValueNotEquals(String variableName, Object variableValue);
/**
* Only select tasks which have a local task variable with the given name
* matching the given value.
* The syntax is that of SQL: for example usage: valueLike(%value%)
*/
TaskQuery taskVariableValueLike(String variableName, String variableValue);
/**
* Only select tasks which have a local task variable with the given name
* and a value greater than the given one.
*/
TaskQuery taskVariableValueGreaterThan(String variableName, Object variableValue);
/**
* Only select tasks which have a local task variable with the given name
* and a value greater than or equal to the given one.
*/
TaskQuery taskVariableValueGreaterThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which have a local task variable with the given name
* and a value less than the given one.
*/
TaskQuery taskVariableValueLessThan(String variableName, Object variableValue);
/**
* Only select tasks which have a local task variable with the given name
* and a value less than or equal to the given one.
*/
TaskQuery taskVariableValueLessThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which have are part of a process that have a variable
* with the given name set to the given value.
*/
TaskQuery processVariableValueEquals(String variableName, Object variableValue);
/**
* Only select tasks which have a variable with the given name, but
* with a different value than the passed value.
* Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*/
TaskQuery processVariableValueNotEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and matching the given value.
* The syntax is that of SQL: for example usage: valueLike(%value%)*/
TaskQuery processVariableValueLike(String variableName, String variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and not matching the given value.
* The syntax is that of SQL: for example usage: valueNotLike(%value%)*/
TaskQuery processVariableValueNotLike(String variableName, String variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and a value greater than the given one.
*/
TaskQuery processVariableValueGreaterThan(String variableName, Object variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and a value greater than or equal to the given one.
*/
TaskQuery processVariableValueGreaterThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and a value less than the given one.
*/
TaskQuery processVariableValueLessThan(String variableName, Object variableValue);
/**
* Only select tasks which are part of a process that have a variable
* with the given name and a value greater than or equal to the given one.
*/
TaskQuery processVariableValueLessThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a variable
* with the given name set to the given value. The type of variable is determined based
* on the value, using types configured in {@link ProcessEngineConfiguration#getVariableSerializers()}.
*
* Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*
* @param name name of the variable, cannot be null.
*/
TaskQuery caseInstanceVariableValueEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a variable
* with the given name, but with a different value than the passed value. The
* type of variable is determined based on the value, using types configured
* in {@link ProcessEngineConfiguration#getVariableSerializers()}.
*
* Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*
* @param name name of the variable, cannot be null.
*/
TaskQuery caseInstanceVariableValueNotEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a variable value
* like the given value.
*
* This be used on string variables only.
*
* @param name variable name, cannot be null.
*
* @param value variable value. The string can include the
* wildcard character '%' to express like-strategy:
* starts with (string%), ends with (%string) or contains (%string%).
*/
TaskQuery caseInstanceVariableValueLike(String variableName, String variableValue);
/**
* Only select tasks which are part of a case instance that have a variable
* with the given name and a variable value greater than the passed value.
*
* Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*
* @param name variable name, cannot be null.
*/
TaskQuery caseInstanceVariableValueGreaterThan(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a
* variable value greater than or equal to the passed value.
*
* Booleans, Byte-arrays and {@link Serializable} objects (which
* are not primitive type wrappers) are not supported.
*
* @param name variable name, cannot be null.
*/
TaskQuery caseInstanceVariableValueGreaterThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a variable
* value less than the passed value.
*
* Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*
* @param name variable name, cannot be null.
*/
TaskQuery caseInstanceVariableValueLessThan(String variableName, Object variableValue);
/**
* Only select tasks which are part of a case instance that have a variable
* value less than or equal to the passed value.
*
* Booleans, Byte-arrays and {@link Serializable} objects (which are not primitive type wrappers)
* are not supported.
*
* @param name variable name, cannot be null.
*/
TaskQuery caseInstanceVariableValueLessThanOrEquals(String variableName, Object variableValue);
/**
* Only select tasks which are part of a process instance which has the given
* process definition key.
*/
TaskQuery processDefinitionKey(String processDefinitionKey);
/**
* Only select tasks which are part of a process instance which has one of the
* given process definition keys.
*/
TaskQuery processDefinitionKeyIn(String... processDefinitionKeys);
/**
* Only select tasks which are part of a process instance which has the given
* process definition id.
*/
TaskQuery processDefinitionId(String processDefinitionId);
/**
* Only select tasks which are part of a process instance which has the given
* process definition name.
*/
TaskQuery processDefinitionName(String processDefinitionName);
/**
* Only select tasks which are part of a process instance which process definition
* name is like the given parameter.
* The syntax is that of SQL: for example usage: nameLike(%processDefinitionName%)*/
TaskQuery processDefinitionNameLike(String processDefinitionName);
/**
* Only select tasks with the given due date.
*/
TaskQuery dueDate(Date dueDate);
/**
* Only select tasks with the described due date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery dueDateExpression(String dueDateExpression);
/**
* Only select tasks which have a due date before the given date.
*/
TaskQuery dueBefore(Date dueDate);
/**
* Only select tasks which have a due date before the described date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery dueBeforeExpression(String dueDateExpression);
/**
* Only select tasks which have a due date after the given date.
*/
TaskQuery dueAfter(Date dueDate);
/**
* Only select tasks which have a due date after the described date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery dueAfterExpression(String dueDateExpression);
/**
* Only select tasks with the given follow-up date.
*/
TaskQuery followUpDate(Date followUpDate);
/**
* Only select tasks with the described follow-up date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery followUpDateExpression(String followUpDateExpression);
/**
* Only select tasks which have a follow-up date before the given date.
*/
TaskQuery followUpBefore(Date followUpDate);
/**
* Only select tasks which have a follow-up date before the described date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery followUpBeforeExpression(String followUpDateExpression);
/**
* Only select tasks which have no follow-up date or a follow-up date before the given date.
* Serves the typical use case "give me all tasks without follow-up or follow-up date which is already due"
*/
TaskQuery followUpBeforeOrNotExistent(Date followUpDate);
/**
* Only select tasks which have no follow-up date or a follow-up date before the described date by the given expression.
* Serves the typical use case "give me all tasks without follow-up or follow-up date which is already due"
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery followUpBeforeOrNotExistentExpression(String followUpDateExpression);
/**
* Only select tasks which have a follow-up date after the given date.
*/
TaskQuery followUpAfter(Date followUpDate);
/**
* Only select tasks which have a follow-up date after the described date by the given expression.
*
* @throws BadUserRequestException
* - When the query is executed and expressions are disabled for adhoc queries
* (in case the query is executed via {@link #list()}, {@link #listPage(int, int)}, {@link #singleResult()}, or {@link #count()})
* or stored queries (in case the query is stored along with a filter).
* Expression evaluation can be activated by setting the process engine configuration properties
*
enableExpressionsInAdhocQueries
(default false
) and
* enableExpressionsInStoredQueries
(default true
) to true
.
*/
TaskQuery followUpAfterExpression(String followUpDateExpression);
/**
* Only select tasks which are suspended, because its process instance was suspended.
*/
TaskQuery suspended();
/**
* Only select tasks which are active (ie. not suspended)
*/
TaskQuery active();
/**
* If called, the form keys of the fetched tasks are initialized and
* {@link Task#getFormKey()} will return a value (in case the task has a form key).
*
* @throws ProcessEngineException
* When method has been executed within "or query". Method must be executed on the base query.
*
* @return the query itself
*/
TaskQuery initializeFormKeys();
/**
* Only select tasks with one of the given tenant ids.
*
* @throws ProcessEngineException
*
* - When a query is executed and {@link #withoutTenantId()} has been executed on
* the "and query" instance. No exception is thrown when a query is executed
* and {@link #withoutTenantId()} has been executed on the "or query" instance.
*
* - When a
null
tenant id is passed.
*
*/
TaskQuery tenantIdIn(String... tenantIds);
/**
* Only select tasks which have no tenant id.
*
* @throws ProcessEngineException When query is executed and {@link #tenantIdIn(String...)}
* has been executed on the "and query" instance. No exception is thrown when query is
* executed and {@link #tenantIdIn(String...)} has been executed on the "or query" instance.
*/
TaskQuery withoutTenantId();
/**
* Only select tasks which have no due date.
*/
TaskQuery withoutDueDate();
// ordering ////////////////////////////////////////////////////////////
/**
* Order by task id (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskId();
/**
* Order by task name (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskName();
/**
* Order by task name case insensitive (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskNameCaseInsensitive();
/**
* Order by description (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskDescription();
/**
* Order by priority (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskPriority();
/**
* Order by assignee (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskAssignee();
/**
* Order by the time on which the tasks were created (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskCreateTime();
/**
* Order by process instance id (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByProcessInstanceId();
/**
* Order by case instance id (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByCaseInstanceId();
/**
* Order by execution id (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByExecutionId();
/**
* Order by case execution id (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByCaseExecutionId();
/**
* Order by due date (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByDueDate();
/**
* Order by follow-up date (needs to be followed by {@link #asc()} or {@link #desc()}).
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByFollowUpDate();
/**
* Order by a process instance variable value of a certain type. Calling this method multiple times
* specifies secondary, tertiary orderings, etc. The ordering of variables with null
* values is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByProcessVariable(String variableName, ValueType valueType);
/**
* Order by an execution variable value of a certain type. Calling this method multiple times
* specifies secondary, tertiary orderings, etc. The ordering of variables with null
* values is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByExecutionVariable(String variableName, ValueType valueType);
/**
* Order by a task variable value of a certain type. Calling this method multiple times
* specifies secondary, tertiary orderings, etc. The ordering of variables with null
* values is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTaskVariable(String variableName, ValueType valueType);
/**
* Order by a task variable value of a certain type. Calling this method multiple times
* specifies secondary, tertiary orderings, etc. The ordering of variables with null
* values is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByCaseExecutionVariable(String variableName, ValueType valueType);
/**
* Order by a task variable value of a certain type. Calling this method multiple times
* specifies secondary, tertiary orderings, etc. The ordering of variables with null
* values is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByCaseInstanceVariable(String variableName, ValueType valueType);
/**
* Order by tenant id (needs to be followed by {@link #asc()} or {@link #desc()}).
* Note that the ordering of tasks without tenant id is database-specific.
*
* @throws ProcessEngineException When method has been executed within "or query".
* */
TaskQuery orderByTenantId();
/**
* After calling or(), a chain of several filter criteria could follow. Each filter criterion that follows or()
* will be linked together with an OR expression until the OR query is terminated. To terminate the OR query right
* after the last filter criterion was applied, {@link #endOr()} must be invoked.
*
* @return an object of the type {@link TaskQuery} on which an arbitrary amount of filter criteria could be applied.
* The several filter criteria will be linked together by an OR expression.
*
* @throws ProcessEngineException when or() has been invoked directly after or() or after or() and trailing filter
* criteria. To prevent throwing this exception, {@link #endOr()} must be invoked after a chain of filter criteria to
* mark the end of the OR query.
* */
TaskQuery or();
/**
* endOr() terminates an OR query on which an arbitrary amount of filter criteria were applied. To terminate the
* OR query which has been started by invoking {@link #or()}, endOr() must be invoked. Filter criteria which are
* applied after calling endOr() are linked together by an AND expression.
*
* @return an object of the type {@link TaskQuery} on which an arbitrary amount of filter criteria could be applied.
* The filter criteria will be linked together by an AND expression.
*
* @throws ProcessEngineException when endOr() has been invoked before {@link #or()} was invoked. To prevent throwing
* this exception, {@link #or()} must be invoked first.
* */
TaskQuery endOr();
}