Skip to main content
POST
/
api
/
v1
/
workspaces
/
{workspace_id}
/
agents
Create Agent
curl --request POST \
  --url https://api.usetuner.ai/api/v1/workspaces/{workspace_id}/agents/ \
  --header 'Authorization: Bearer <token>' \
  --header 'Content-Type: application/json' \
  --data '
{
  "agent_name": "<string>",
  "provider_name": "<string>",
  "api_key": "<string>",
  "agent_id": "<string>",
  "summary": "<string>",
  "agent_lang": "<string>",
  "call_direction": "inbound",
  "prompt": "<string>",
  "workflow": {}
}
'
{
  "id": 123,
  "integration_id": 123,
  "name": "<string>",
  "call_direction": "<string>",
  "remote_identifier": "<string>",
  "created_at": "2023-11-07T05:31:56Z",
  "updated_at": "2023-11-07T05:31:56Z",
  "description": "<string>",
  "lang": "<string>",
  "prompt": "<string>",
  "workflow": {},
  "integration_name": "<string>",
  "deleted_at": "2023-11-07T05:31:56Z",
  "created_by": 123,
  "updated_by": 123,
  "integration": {
    "id": 123,
    "uuid": "3c90c3cc-0d44-4b50-8888-8dd25736052a",
    "workspace_id": 123,
    "provider_id": 123,
    "created_at": "2023-11-07T05:31:56Z",
    "updated_at": "2023-11-07T05:31:56Z",
    "api_key": "<string>",
    "deleted_at": "2023-11-07T05:31:56Z",
    "created_by": 123,
    "updated_by": 123,
    "provider": {
      "id": 123,
      "name": "<string>"
    }
  }
}

Authorizations

Authorization
string
header
required

Use Tuner API key (tr_api_...) or user session token. Find your API key in Workspace Settings > API Keys.

Path Parameters

workspace_id
integer
required

Body

application/json

Request schema for agent creation.

agent_name
string
required

Display name for the agent (e.g., 'Support Bot', 'Sales Agent').

Required string length: 1 - 200
provider_name
string
required

Voice provider this agent is connected to (e.g., 'retell', 'vapi'). Must match a provider name supported by Tuner.

Required string length: 1 - 200
api_key
string
required

API key for authenticating with your voice provider. Find this in your provider's account settings.

Required string length: 1 - 500
agent_id
string
required

Your voice provider's unique identifier for this agent. Find this in your provider's agent configuration.

Required string length: 1 - 36
summary
string | null

Brief description of what this agent does (e.g., 'Handles billing inquiries').

agent_lang
string | null

BCP 47 language tag for the agent's primary language (e.g., 'en', 'es', 'fr'). Defaults to workspace language if omitted.

Maximum string length: 10
call_direction
string
default:inbound

Whether this agent handles 'inbound' (customer-initiated) or 'outbound' (agent-initiated) calls. Defaults to 'inbound'.

Pattern: ^(inbound|outbound)$
prompt
string | null

System prompt or instructions given to the agent.

workflow
Workflow · object

Agent workflow configuration as a JSON object (must be JSON-serializable).

Response

Successful Response

Agent schema for API responses with nested relationships.

id
integer
required

Tuner's internal numeric ID for this agent.

integration_id
integer
required

ID of the voice provider integration this agent uses.

name
string
required

Display name of the agent.

call_direction
string
required

'inbound' for customer-initiated calls, 'outbound' for agent-initiated calls.

remote_identifier
string
required

Your voice provider's unique identifier for this agent.

created_at
string<date-time>
required

ISO 8601 timestamp when the agent was created.

updated_at
string<date-time>
required

ISO 8601 timestamp when the agent was last updated.

description
string | null

Brief description of what this agent does.

lang
string | null

BCP 47 language tag for the agent's primary language (e.g., 'en', 'es').

prompt
string | null

System prompt or instructions given to the agent.

workflow
Workflow · object

Agent workflow configuration. Must be valid JSON.

integration_name
string | null

Name of the voice provider for this agent's integration.

deleted_at
string<date-time> | null

Timestamp when the agent was deleted. Null if the agent is active.

created_by
integer | null

ID of the user who created this agent.

updated_by
integer | null

ID of the user who last updated this agent.

integration
IntegrationWithProvider · object

Integration schema with nested provider object.