mirror of
https://github.com/coder/coder.git
synced 2026-06-03 13:08:25 +00:00
81109e17df
Adds a deprecation warning callout to the top of the main Coder Tasks docs page (`docs/ai-coder/tasks.md`). The message reads: > Beginning June 2026, Coder Tasks will be deprecated. Support for Tasks will be maintained on Coder's ESR release and through Coder v2.36. After v2.36, support for Tasks will only be on our 12-month ESR release for Coder Premium Customers. Uses the existing `> [!WARNING]` admonition pattern already used for deprecations elsewhere in the docs (e.g. `docs/ai-coder/ai-gateway/mcp.md`). Linear: [CODAGT-157](https://linear.app/codercom/issue/CODAGT-157/ensure-docs-are-updated-for-beta) --- _This PR was opened by Coder Agents on @davidfraley's behalf._ --------- Co-authored-by: Matt Vollmer <matthewjvollmer@outlook.com>
172 lines
4.9 KiB
Markdown
172 lines
4.9 KiB
Markdown
# Migrating Task Templates for Coder version 2.28.0
|
|
|
|
> [!WARNING]
|
|
> Starting June 2, 2026, Coder Tasks will move to a 12-month Extended Support Release (ESR) for Premium customers.
|
|
>
|
|
> Tasks will be removed from new Coder releases beginning with v2.37 (September 1, 2026) and will only be available via the ESR during the support period.
|
|
>
|
|
> We recommend transitioning to [Coder Agents](./agents/index.md), the long-term replacement.
|
|
|
|
Prior to Coder version 2.28.0, the definition of a Coder task was different to the above. It required the following to be defined in the template:
|
|
|
|
1. A Coder parameter specifically named `"AI Prompt"`,
|
|
2. A `coder_workspace_app` that runs the `coder/agentapi` binary,
|
|
3. A `coder_ai_task` resource in the template that sets `sidebar_app.id`. This was generally defined in Coder modules specific to AI Tasks.
|
|
|
|
Note that 2 and 3 were generally handled by the `coder/agentapi` Terraform module.
|
|
|
|
> [!IMPORTANT]
|
|
> The pre-2.28.0 definition is no longer supported as of Coder 2.30.0. You must update your Tasks-enabled templates to use the new format described below.
|
|
|
|
You can view an [example migration here](https://github.com/coder/coder/pull/20420). Alternatively, follow the steps below:
|
|
|
|
## Upgrade Steps
|
|
|
|
1. Update the Coder Terraform provider to at least version 2.13.0:
|
|
|
|
```diff
|
|
terraform {
|
|
required_providers {
|
|
coder = {
|
|
source = "coder/coder"
|
|
- version = "x.y.z"
|
|
+ version = ">= 2.13"
|
|
}
|
|
}
|
|
}
|
|
```
|
|
|
|
1. Define a `coder_ai_task` resource and `coder_task` data source in your template:
|
|
|
|
```diff
|
|
+data "coder_task" "me" {}
|
|
+resource "coder_ai_task" "task" {}
|
|
```
|
|
|
|
1. Update the version of the respective AI agent module (e.g. `claude-code`) to at least 4.0.0 and provide the prompt from `data.coder_task.me.prompt` instead of the "AI Prompt" parameter.
|
|
|
|
```diff
|
|
module "claude-code" {
|
|
source = "registry.coder.com/coder/claude-code/coder"
|
|
- version = "4.0.0"
|
|
+ version = "4.0.0"
|
|
...
|
|
- ai_prompt = data.coder_parameter.ai_prompt.value
|
|
+ ai_prompt = data.coder_task.me.prompt
|
|
}
|
|
```
|
|
|
|
1. Add the `coder_ai_task` resource and set `app_id` to the `task_app_id` output of the Claude module.
|
|
|
|
> [!NOTE]
|
|
> Refer to the documentation for the specific module you are using for the exact name of the output.
|
|
|
|
```diff
|
|
resource "coder_ai_task" "task" {
|
|
+ app_id = module.claude-code.task_app_id
|
|
}
|
|
```
|
|
|
|
## Coder Tasks format pre-2.28
|
|
|
|
Below is a minimal illustrative example of a Coder Tasks template pre-2.28.0.
|
|
**Note that this is NOT a full template.**
|
|
|
|
```hcl
|
|
terraform {
|
|
required_providers {
|
|
coder = {
|
|
source = "coder/coder
|
|
}
|
|
}
|
|
}
|
|
|
|
data "coder_workspace" "me" {}
|
|
|
|
resource "coder_agent" "main" { ... }
|
|
|
|
# The prompt is passed in via the specifically named "AI Prompt" parameter.
|
|
data "coder_parameter" "ai_prompt" {
|
|
name = "AI Prompt"
|
|
mutable = true
|
|
}
|
|
|
|
# This coder_app is the interface to the Coder Task.
|
|
# This is assumed to be a running instance of coder/agentapi
|
|
resource "coder_app" "ai_agent" {
|
|
...
|
|
}
|
|
|
|
# Assuming that the below script runs `coder/agentapi` with the prompt
|
|
# defined in ARG_AI_PROMPT
|
|
resource "coder_script" "agentapi" {
|
|
agent_id = coder_agent.main.id
|
|
run_on_start = true
|
|
script = <<EOT
|
|
#!/usr/bin/env bash
|
|
ARG_AI_PROMPT=${data.coder_parameter.ai_prompt.value} \
|
|
/tmp/run_agentapi.sh
|
|
EOT
|
|
...
|
|
}
|
|
|
|
# The coder_ai_task resource associates the task to the app.
|
|
resource "coder_ai_task" "task" {
|
|
sidebar_app {
|
|
id = coder_app.ai_agent.id
|
|
}
|
|
}
|
|
```
|
|
|
|
## Tasks format from 2.28 onwards
|
|
|
|
In v2.28 and above, the following changes were made:
|
|
|
|
- The explicitly named "AI Prompt" parameter is no longer supported. The task prompt is now available in the `coder_ai_task` resource (provider version 2.12 and above) and `coder_task` data source (provider version 2.13 and above).
|
|
- Modules no longer define the `coder_ai_task` resource. These must be defined explicitly in the template.
|
|
- The `sidebar_app` field of the `coder_ai_task` resource is now deprecated. In its place, use `app_id`.
|
|
|
|
Example (**not** a full template):
|
|
|
|
```hcl
|
|
terraform {
|
|
required_providers {
|
|
coder = {
|
|
source = "coder/coder
|
|
version = ">= 2.13.0
|
|
}
|
|
}
|
|
}
|
|
|
|
data "coder_workspace" "me" {}
|
|
|
|
# The prompt is now available in the coder_task data source.
|
|
data "coder_task" "me" {}
|
|
|
|
resource "coder_agent" "main" { ... }
|
|
|
|
# This coder_app is the interface to the Coder Task.
|
|
# This is assumed to be a running instance of coder/agentapi (for instance, started via `coder_script`).
|
|
resource "coder_app" "ai_agent" {
|
|
...
|
|
}
|
|
|
|
# Assuming that the below script runs `coder/agentapi` with the prompt
|
|
# defined in ARG_AI_PROMPT
|
|
resource "coder_script" "agentapi" {
|
|
agent_id = coder_agent.main.id
|
|
run_on_start = true
|
|
script = <<EOT
|
|
#!/usr/bin/env bash
|
|
ARG_AI_PROMPT=${data.coder_task.me.prompt} \
|
|
/tmp/run_agentapi.sh
|
|
EOT
|
|
...
|
|
}
|
|
|
|
# The coder_ai_task resource associates the task to the app.
|
|
resource "coder_ai_task" "task" {
|
|
app_id = coder_app.ai_agent.id
|
|
}
|
|
```
|