All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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 date resolved from 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 date resolved from 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 date resolved from the given expression. **/ TaskQuery taskCreatedAfterExpression(String afterExpression); /** Only select tasks that were updated after the given date. **/ TaskQuery taskUpdatedAfter(Date after); /** Only select tasks that were updated after the date resolved from the given expression. **/ TaskQuery taskUpdatedAfterExpression(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 value * not 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 caseInstanceVariableValueNotLike(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 and form references of the fetched tasks are initialized and * {@link Task#getFormKey()} and {@link Task#getCamundaFormRef()} will return a value (in * case the task has is linked to a form). * * @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 the time the task was updated last (needs to be followed by {@link #asc()} or {@link #desc()}). * * @throws ProcessEngineException When method has been executed within "or query". */ TaskQuery orderByLastUpdated(); /** * 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(); }




© 2015 - 2025 Weber Informatics LLC | Privacy Policy