Tasks
Create Task
Create and execute a task using an AI agent. Supports both standard chat and Claude agent modes.
POST
This endpoint creates a new agent task. Optionally provide a GitHub repository for the agent to work on.
Claude Agent (
Standard Chat (
Returns an SSE stream (
Standard chat models (
Authentication
All requests require a BLACKBOX API key passed as a Bearer token. To get your API key:- Go to app.blackbox.ai/agent-api and click Get an API Key (requires a Pro subscription)
- Once provisioning completes, you will be redirected to your Dashboard
- From the Dashboard, create an API key to use with all Agent API requests
sk-xxxxxxxxxxxxxxxxxxxxxx
GitHub Connection Required
For GitHub-related tasks: Before creating tasks that work with repositories, you must connect your GitHub account via the API. Call
POST /api/v1/git/config with your GitHub personal access token (ghp_…) — the agent uses this token to access and modify your repositories. See Connect GitHub for details.Headers
API Key of the form
Bearer <api_key>.Example: Bearer sk_b41b647ffbfed27f616560Must be set to
application/json.Request Body
The task description or instruction for the agent. One of
message or prompt is required.Examples:"Write a Python script to parse CSV files""Add unit tests for the authentication module""Refactor the payment service to use async/await"
Alias for
message. One of message or prompt is required.Routing mode for the request.
"claude"— Run a Claude agent task (default). ReturnstaskIdandrunId."standard"— Standard chat completion. Returns an SSE stream with headersx-chat-idandx-message-id.
Model to use for the agent. The id also selects the agent runtime — Anthropic/Claude ids run the Claude Agent SDK; OpenAI/Codex ids (e.g.
blackboxai/openai/gpt-5.3-codex) run the Codex SDK. See Models.Example: "blackboxai/anthropic/claude-sonnet-4.6"Explicit agent-runtime override —
"claude" or "codex". When set, it overrides the runtime that would be inferred from model (e.g. agent: "codex" to run a non-OpenAI model on the Codex runtime). Omit to auto-select from the model id (default: "claude"). See Agent Runtimes for the full selection rule, the shared event stream, and side-by-side examples.Custom system prompt for the agent.
GitHub repository URL for the agent to clone and work on.Example:
"https://github.com/org/repo.git"Branch to check out in the repository. Defaults to the repo’s default branch.Example:
"main", "develop", "feature/new-api"Whether to run dependency installation (e.g.
npm install) before executing the task.Maximum execution time in seconds.Range:
30 – 600. Default: 300.UUID of an existing chat to continue. If omitted, a new chat is created.
Visibility of the created chat.
"private"— Only you can see it (default)"public"— Publicly accessible
Response
Claude Agent (type: "claude")
Unique identifier for the task (same as
runId).Unique identifier for this agent run. Use this to poll status, stream logs, or continue the task.
ID of the assistant message being generated in the chat.
UUID of the chat thread this task belongs to.
Number of agents spawned. Always
1.Standard Chat (type: "standard")
Returns an SSE stream (text/event-stream) with response headers:
x-chat-id— the chat UUIDx-message-id— the user message UUID
Available Models
The default model isblackboxai/anthropic/claude-sonnet-4.6. Pass any of the following in the model field:
Claude Agent models (type: "claude" — default):
| Model | ID |
|---|---|
| Claude Sonnet 4.6 (default) | blackboxai/anthropic/claude-sonnet-4.6 |
| Claude Sonnet 4.5 | blackboxai/anthropic/claude-sonnet-4.5 |
| Claude Opus 4.6 | blackboxai/anthropic/claude-opus-4.6 |
| Claude Opus 4.7 | blackboxai/anthropic/claude-opus-4.7 |
| MiniMax M2.5 | blackboxai/minimax/minimax-m2.5 |
type: "standard"):
| Model | ID |
|---|---|
| Mistral Small (default) | mistral/mistral-small |
| MiniMax M2.5 | minimax/minimax-m2.5 |
| Kimi K2.5 | moonshotai/kimi-k2.5 |
| Grok 4.1 Fast | xai/grok-4.1-fast-non-reasoning |
Error Codes
| Status Code | Error | Description |
|---|---|---|
| 200 | Success | Task created successfully |
| 400 | Bad Request | Missing message/prompt, invalid JSON, or validation error |
| 401 | Unauthorized | Invalid or missing API key |
| 403 | Forbidden | Pro subscription required, or no Blackbox API key configured |
| 404 | Not Found | GitHub token not found |
| 500 | Internal Server Error | Failed to spawn agent or database error |