Get task
GET
/v1/tasks/{taskId}Get a task together with resolved project, sprint, release, assignee, dependencies, dependents, linked threads, and comments.
How to call this endpoint
Every ACP API request uses bearer authentication. The examples here show the actual request path, auth header, and body shape that the platform expects.
Path, query, and header parameters
These parameters control which ACP object the endpoint acts on and how the request is processed.
Path parameters
| Name | Location | Type | Required | Description |
|---|---|---|---|---|
| taskId | path | string | Yes | Task ID |
Query parameters
None.
Body schema
This endpoint does not require a request body.
None.
What the API returns
Each response code below includes the documented payload shape for the ACP API.
200Task detailsapplication/json
| Field | Type | Required | Description |
|---|---|---|---|
| task | object | No | — |
| task.id | string | No | Unique identifier. |
| task.userId | string | No | User ID. |
| task.projectId | string | No | Project ID. |
| task.releaseId | string | No | — |
| task.title | string | No | Display title. |
| task.description | string | No | Human-readable description. |
| task.status | backlog | todo | in_progress | blocked | done | No | Current lifecycle status. |
| task.priority | low | medium | high | urgent | No | — |
| task.sprintId | string | No | — |
| task.assigneeAgentId | string | No | — |
| task.dependencyIds | string[] | No | — |
| task.linkedThreadIds | string[] | No | — |
| task.lastStartedThreadId | string | No | — |
| task.scheduledStartAt | string | No | — |
| task.scheduledEndAt | string | No | — |
| task.dueAt | string | No | — |
| task.completedAt | string | No | ISO 8601 timestamp. |
| task.sortOrder | number | No | — |
| task.metadata | object | No | Free-form metadata object. |
| task.createdAt | string | No | ISO 8601 timestamp. |
| task.updatedAt | string | No | ISO 8601 timestamp. |
| details | object | No | — |
| details.project | object | No | — |
| details.project.id | string | No | Unique identifier. |
| details.project.name | string | No | Human-readable name. |
| details.project.description | string | No | Human-readable description. |
| details.project.type | local | cloud | synced | No | — |
| details.project.primarySource | string | No | — |
| details.project.sources | object[] | No | — |
| details.project.createdAt | string | No | ISO 8601 timestamp. |
| details.project.updatedAt | string | No | ISO 8601 timestamp. |
| details.release | object | No | — |
| details.release.object | string | No | — |
| details.release.id | string | No | Unique identifier. |
| details.release.userId | string | No | User ID. |
| details.release.projectId | string | No | Project ID. |
| details.release.name | string | No | Human-readable name. |
| details.release.description | string | No | Human-readable description. |
| details.release.startAt | string | No | — |
| details.release.endAt | string | No | — |
| details.release.sortOrder | number | No | — |
| details.release.status | planned | active | completed | No | Current lifecycle status. |
| details.release.metadata | object | No | Free-form metadata object. |
| details.release.taskCount | integer | No | — |
| details.release.openTaskCount | integer | No | — |
| details.release.taskIds | string[] | No | — |
| details.release.createdAt | string | No | ISO 8601 timestamp. |
| details.release.updatedAt | string | No | ISO 8601 timestamp. |
| details.sprint | object | No | — |
| details.sprint.id | string | No | Unique identifier. |
| details.sprint.userId | string | No | User ID. |
| details.sprint.projectId | string | No | Project ID. |
| details.sprint.name | string | No | Human-readable name. |
| details.sprint.goal | string | No | — |
| details.sprint.status | planned | active | completed | No | Current lifecycle status. |
| details.sprint.startAt | string | No | — |
| details.sprint.endAt | string | No | — |
| details.sprint.sortOrder | number | No | — |
| details.sprint.metadata | object | No | Free-form metadata object. |
| details.sprint.createdAt | string | No | ISO 8601 timestamp. |
| details.sprint.updatedAt | string | No | ISO 8601 timestamp. |
| details.assignee | object | No | — |
| details.assignee.id | string | No | Unique identifier. |
| details.assignee.userId | string | No | User ID. |
| details.assignee.projectId | string | No | Project ID. |
| details.assignee.name | string | No | Human-readable name. |
| details.assignee.description | string | No | Human-readable description. |
| details.assignee.model | string | No | Model identifier for the agent. Built-in managed models: - `claude-opus-4-6` - `claude-sonnet-4-5` - `claude-haiku-4-5` - `gemini-3-flash` - `gemini-3-1-pro` Team and Enterprise workspaces can also use connected external models in the form `external:{providerType}:{urlEncodedModelId}`. Use `GET /agents/models` to discover the exact managed and external model IDs available in the current workspace. |
| details.assignee.instructions | string | No | — |
| details.assignee.binary | Claude Code CLI | No | Execution binary used for the agent runtime. |
| details.assignee.reasoningEffort | minimal | low | medium | high | No | Reasoning intensity used by the execution runtime. |
| details.assignee.enabledSkills | string[] | No | Skill IDs enabled for this agent, for example `deep_research` or custom installed skills. |
| details.assignee.deepResearchModel | gemini-3-flash-preview | gemini-3-pro-preview | No | Optional model override used by the deep research skill when enabled. |
| details.assignee.isDefault | boolean | No | — |
| details.assignee.isSystem | boolean | No | — |
| details.assignee.isActive | boolean | No | — |
| details.assignee.metadata | object | No | Free-form metadata object. |
| details.assignee.createdAt | string | No | ISO 8601 timestamp. |
| details.assignee.updatedAt | string | No | ISO 8601 timestamp. |
| details.assignee.lastRunAt | string | No | — |
| details.dependencies | object[] | No | — |
| details.dependencies[].id | string | No | Unique identifier. |
| details.dependencies[].userId | string | No | User ID. |
| details.dependencies[].projectId | string | No | Project ID. |
| details.dependencies[].releaseId | string | No | — |
| details.dependencies[].title | string | No | Display title. |
| details.dependencies[].description | string | No | Human-readable description. |
| details.dependencies[].status | backlog | todo | in_progress | blocked | done | No | Current lifecycle status. |
| details.dependencies[].priority | low | medium | high | urgent | No | — |
| details.dependencies[].sprintId | string | No | — |
| details.dependencies[].assigneeAgentId | string | No | — |
| details.dependencies[].dependencyIds | string[] | No | — |
| details.dependencies[].linkedThreadIds | string[] | No | — |
| details.dependencies[].lastStartedThreadId | string | No | — |
| details.dependencies[].scheduledStartAt | string | No | — |
| details.dependencies[].scheduledEndAt | string | No | — |
| details.dependencies[].dueAt | string | No | — |
| details.dependencies[].completedAt | string | No | ISO 8601 timestamp. |
| details.dependencies[].sortOrder | number | No | — |
| details.dependencies[].metadata | object | No | Free-form metadata object. |
| details.dependencies[].createdAt | string | No | ISO 8601 timestamp. |
| details.dependencies[].updatedAt | string | No | ISO 8601 timestamp. |
| details.dependents | object[] | No | — |
| details.dependents[].id | string | No | Unique identifier. |
| details.dependents[].userId | string | No | User ID. |
| details.dependents[].projectId | string | No | Project ID. |
| details.dependents[].releaseId | string | No | — |
| details.dependents[].title | string | No | Display title. |
| details.dependents[].description | string | No | Human-readable description. |
| details.dependents[].status | backlog | todo | in_progress | blocked | done | No | Current lifecycle status. |
| details.dependents[].priority | low | medium | high | urgent | No | — |
| details.dependents[].sprintId | string | No | — |
| details.dependents[].assigneeAgentId | string | No | — |
| details.dependents[].dependencyIds | string[] | No | — |
| details.dependents[].linkedThreadIds | string[] | No | — |
| details.dependents[].lastStartedThreadId | string | No | — |
| details.dependents[].scheduledStartAt | string | No | — |
| details.dependents[].scheduledEndAt | string | No | — |
| details.dependents[].dueAt | string | No | — |
| details.dependents[].completedAt | string | No | ISO 8601 timestamp. |
| details.dependents[].sortOrder | number | No | — |
| details.dependents[].metadata | object | No | Free-form metadata object. |
| details.dependents[].createdAt | string | No | ISO 8601 timestamp. |
| details.dependents[].updatedAt | string | No | ISO 8601 timestamp. |
| details.linkedThreads | object[] | No | — |
| details.linkedThreads[].id | string | No | Unique identifier. |
| details.linkedThreads[].projectId | string | No | Project ID. |
| details.linkedThreads[].environmentId | string | No | Computer ID. |
| details.linkedThreads[].agentId | string | No | Agent ID. |
| details.linkedThreads[].title | string | No | Display title. |
| details.linkedThreads[].task | string | No | — |
| details.linkedThreads[].appId | string | No | — |
| details.linkedThreads[].status | active | running | completed | failed | cancelled | No | Current lifecycle status. |
| details.linkedThreads[].messageCount | integer | No | — |
| details.linkedThreads[].lastMessageAt | string | No | — |
| details.linkedThreads[].lastMessagePreview | string | No | — |
| details.linkedThreads[].inputTokens | integer | No | — |
| details.linkedThreads[].outputTokens | integer | No | — |
| details.linkedThreads[].totalCost | number | No | — |
| details.linkedThreads[].environmentMinutes | number | No | — |
| details.linkedThreads[].metadata | object | No | Free-form metadata object. |
| details.linkedThreads[].teamExecution | object | No | — |
| details.linkedThreads[].teamExecution.mode | team | No | — |
| details.linkedThreads[].teamExecution.teamAgentId | string | No | — |
| details.linkedThreads[].teamExecution.teamAgentName | string | No | — |
| details.linkedThreads[].teamExecution.orchestrator | object | No | — |
| details.linkedThreads[].teamExecution.orchestrator.agentId | string | No | Agent ID. |
| details.linkedThreads[].teamExecution.orchestrator.agentName | string | No | — |
| details.linkedThreads[].teamExecution.orchestrator.claudeAgentName | string | No | — |
| details.linkedThreads[].teamExecution.subagents | object[] | No | — |
| details.linkedThreads[].teamExecution.subagents[].agentId | string | No | Agent ID. |
| details.linkedThreads[].teamExecution.subagents[].agentName | string | No | — |
| details.linkedThreads[].teamExecution.subagents[].claudeAgentName | string | No | — |
| details.linkedThreads[].subagentActivity | object[] | No | — |
| details.linkedThreads[].subagentActivity[].agentId | string | No | Agent ID. |
| details.linkedThreads[].subagentActivity[].agentName | string | No | — |
| details.linkedThreads[].subagentActivity[].claudeAgentName | string | No | — |
| details.linkedThreads[].subagentActivity[].eventCount | integer | No | — |
| details.linkedThreads[].subagentActivity[].lastActiveAt | string | No | — |
| details.linkedThreads[].subagentActivity[].teamAgentId | string | No | — |
| details.linkedThreads[].subagentActivity[].teamAgentName | string | No | — |
| details.linkedThreads[].environmentName | string | No | — |
| details.linkedThreads[].agentName | string | No | — |
| details.linkedThreads[].createdAt | string | No | ISO 8601 timestamp. |
| details.linkedThreads[].updatedAt | string | No | ISO 8601 timestamp. |
| details.lastStartedThread | object | No | — |
| details.lastStartedThread.id | string | No | Unique identifier. |
| details.lastStartedThread.projectId | string | No | Project ID. |
| details.lastStartedThread.environmentId | string | No | Computer ID. |
| details.lastStartedThread.agentId | string | No | Agent ID. |
| details.lastStartedThread.title | string | No | Display title. |
| details.lastStartedThread.task | string | No | — |
| details.lastStartedThread.appId | string | No | — |
| details.lastStartedThread.status | active | running | completed | failed | cancelled | No | Current lifecycle status. |
| details.lastStartedThread.messageCount | integer | No | — |
| details.lastStartedThread.lastMessageAt | string | No | — |
| details.lastStartedThread.lastMessagePreview | string | No | — |
| details.lastStartedThread.inputTokens | integer | No | — |
| details.lastStartedThread.outputTokens | integer | No | — |
| details.lastStartedThread.totalCost | number | No | — |
| details.lastStartedThread.environmentMinutes | number | No | — |
| details.lastStartedThread.metadata | object | No | Free-form metadata object. |
| details.lastStartedThread.teamExecution | object | No | — |
| details.lastStartedThread.teamExecution.mode | team | No | — |
| details.lastStartedThread.teamExecution.teamAgentId | string | No | — |
| details.lastStartedThread.teamExecution.teamAgentName | string | No | — |
| details.lastStartedThread.teamExecution.orchestrator | object | No | — |
| details.lastStartedThread.teamExecution.orchestrator.agentId | string | No | Agent ID. |
| details.lastStartedThread.teamExecution.orchestrator.agentName | string | No | — |
| details.lastStartedThread.teamExecution.orchestrator.claudeAgentName | string | No | — |
| details.lastStartedThread.teamExecution.subagents | object[] | No | — |
| details.lastStartedThread.teamExecution.subagents[].agentId | string | No | Agent ID. |
| details.lastStartedThread.teamExecution.subagents[].agentName | string | No | — |
| details.lastStartedThread.teamExecution.subagents[].claudeAgentName | string | No | — |
| details.lastStartedThread.subagentActivity | object[] | No | — |
| details.lastStartedThread.subagentActivity[].agentId | string | No | Agent ID. |
| details.lastStartedThread.subagentActivity[].agentName | string | No | — |
| details.lastStartedThread.subagentActivity[].claudeAgentName | string | No | — |
| details.lastStartedThread.subagentActivity[].eventCount | integer | No | — |
| details.lastStartedThread.subagentActivity[].lastActiveAt | string | No | — |
| details.lastStartedThread.subagentActivity[].teamAgentId | string | No | — |
| details.lastStartedThread.subagentActivity[].teamAgentName | string | No | — |
| details.lastStartedThread.environmentName | string | No | — |
| details.lastStartedThread.agentName | string | No | — |
| details.lastStartedThread.createdAt | string | No | ISO 8601 timestamp. |
| details.lastStartedThread.updatedAt | string | No | ISO 8601 timestamp. |
| details.blockedByDependencyIds | string[] | No | — |
| details.readyToStart | boolean | No | — |
| comments | object[] | No | — |
| comments[].object | string | No | — |
| comments[].id | string | No | Unique identifier. |
| comments[].userId | string | No | User ID. |
| comments[].projectId | string | No | Project ID. |
| comments[].taskId | string | No | — |
| comments[].task | object | No | — |
| comments[].task.object | string | No | — |
| comments[].task.id | string | No | Unique identifier. |
| comments[].task.projectId | string | No | Project ID. |
| comments[].task.releaseId | string | No | — |
| comments[].task.title | string | No | Display title. |
| comments[].task.status | backlog | todo | in_progress | blocked | done | No | Current lifecycle status. |
| comments[].task.priority | low | medium | high | urgent | No | — |
| comments[].task.sprintId | string | No | — |
| comments[].task.assigneeAgentId | string | No | — |
| comments[].body | string | No | — |
| comments[].authorType | user | agent | system | No | — |
| comments[].authorAgentId | string | No | — |
| comments[].authorName | string | No | — |
| comments[].sourceThreadId | string | No | — |
| comments[].threadId | string | No | Thread ID. |
| comments[].metadata | object | No | Free-form metadata object. |
| comments[].createdAt | string | No | ISO 8601 timestamp. |
| comments[].updatedAt | string | No | ISO 8601 timestamp. |