# requeue\_tasks

`imerit_ango.sdk.SDK.`

## requeue\_tasks(project\_id, to\_stage\_id, filters, options)

Move tasks from one stage to another within your project, with control over which tasks are requeued and how they are processed.

### Parameters

* **project\_id:** string
  * The unique identifier for the project. You can find the project ID in [the user interface](https://docs.imerit.net/sdk/sdk-documentation/..#project-ids) or retrieve it using the [`list_projects`](https://docs.imerit.net/sdk/sdk-documentation/project-level-sdk-functions/list_projects) function.
* **to\_stage\_id:** string
  * The identifier of the target stage to which the tasks will be requeued. This stage must exist within the specified project.
* **filters:** dict, *default None*
  * Criteria to select which tasks should be requeued. If no filters are provided, all tasks will be requeued.
    * **taskIds:** List\[str]
      * List of task IDs
    * **externalIds:** List\[str]
      * List of external IDs
    * **assetIds:** List\[str]
      * List of asset IDs
    * **batches:** List\[str]
      * List of batch IDs
    * **fromStageIds:** List\[str]
      * List of stage IDs from which tasks should be requeued
* **options:** dict, *default None*
  * Settings that customize how tasks are requeued. Supported options:
    * **removeAnnotations:** bool
      * Remove existing annotations before requeuing.
    * **removeAssignee:** bool
      * Unassign the current assignee from the task.
    * **removeStageHistory:** bool
      * Clear the task’s stage history.

Returns:

* **output:** dict
  * A dictionary containing the result of the operation.
  * Including a `status` field indicating whether the request was successful and a `data` field containing the response payload with updated resources produced by the operation.

{% hint style="warning" %}
The target stage (to\_stage\_id) must already exist within the specified project. If needed, update the workflow using the [update\_workflow\_stages](https://docs.imerit.net/sdk/sdk-documentation/project-level-sdk-functions/update_workflow_stages) function.
{% endhint %}

### Example

Requeue all the tasks to the specified stage from other stages

{% tabs %}
{% tab title="python" %}

```python
import os
from dotenv import load_dotenv
from imerit_ango.sdk import SDK

load_dotenv('variables.env')
api_key = os.getenv('API_KEY')
project_id = os.getenv('PROJECT_ID')

ango_sdk = SDK(api_key)

stage_id = '<YOUR STAGE ID>'
sdk_response = ango_sdk.requeue_tasks(project_id=project_id, to_stage_id=stage_id)
```

{% endtab %}

{% tab title="curl" %}

```bash
curl -X POST "https://imeritapi.ango.ai/v2/project/$PROJECT_ID/requeueTasks" \
  -H "Content-Type: application/json" \
  -H "apikey: $API_KEY" \
  -d '{
    "filters": {},
    "options": {},
    "toStageId": "<YOUR STAGE ID>"
  }'
```

{% endtab %}
{% endtabs %}

Requeue specific tasks only

{% tabs %}
{% tab title="python" %}

```python
import os
from dotenv import load_dotenv
from imerit_ango.sdk import SDK

load_dotenv('variables.env')
api_key = os.getenv('API_KEY')
project_id = os.getenv('PROJECT_ID')

ango_sdk = SDK(api_key)

stage_id = '<YOUR STAGE ID>'
external_id_list = ["<EXTERNAL ID 1>", "<EXTERNAL ID 2>", "<EXTERNAL ID 3>"]

sdk_response = ango_sdk.requeue_tasks(
    project_id=project_id,
    to_stage_id=stage_id,
    filters={"externalIds": external_id_list}
)
```

{% endtab %}

{% tab title="curl" %}

```bash
curl -X POST "https://imeritapi.ango.ai/v2/project/$PROJECT_ID/requeueTasks" \
  -H "Content-Type: application/json" \
  -H "apikey: $API_KEY" \
  -d '{
    "filters": {
      "externalIds": ["<EXTERNAL ID 1>", "<EXTERNAL ID 2>", "<EXTERNAL ID 3>"]
    },
    "options": {},
    "toStageId": "<YOUR STAGE ID>"
  }'
```

{% endtab %}
{% endtabs %}

Requeue tasks with configurable preferences

{% tabs %}
{% tab title="python" %}

```python
import os
from dotenv import load_dotenv
from imerit_ango.sdk import SDK

load_dotenv('variables.env')
api_key = os.getenv('API_KEY')
project_id = os.getenv('PROJECT_ID')

ango_sdk = SDK(api_key)

stage_id = '<YOUR STAGE ID>'

sdk_response = ango_sdk.requeue_tasks(
    project_id=project_id,
    to_stage_id=stage_id,
    options={
        "removeAnnotations":True, 
        "removeAssignee": True, 
        "removeStageHistory": True
    }
)
```

{% endtab %}

{% tab title="curl" %}

```bash
curl -X POST "https://imeritapi.ango.ai/v2/project/$PROJECT_ID/requeueTasks" \
  -H "Content-Type: application/json" \
  -H "apikey: $API_KEY" \
  -d '{
    "filters": {},
    "options": {
      "removeAnnotations": true,
      "removeAssignee": true,
      "removeStageHistory": true
    },
    "toStageId": "<YOUR STAGE ID>"
  }'
```

{% endtab %}
{% endtabs %}

{% hint style="info" %}
See also

[get\_project](https://docs.imerit.net/sdk/sdk-documentation/project-level-sdk-functions/get_project)
{% endhint %}
