From telnyx
Imports Retell AI agents into Telnyx AI Assistants, preserving instructions, voice settings, tools, and call analysis. Supports single/multi-prompt configs and all SDK languages.
npx claudepluginhub team-telnyx/ai --plugin telnyxThis skill uses the workspace's default tool permissions.
Migrate your Retell AI agents to Telnyx in minutes. The import API pulls agent configurations directly from Retell using your API key and recreates them as Telnyx AI Assistants. Both single-prompt and multi-prompt Retell agents are supported.
Imports Retell AI agents into Telnyx AI Assistants, preserving instructions, voice settings, tools, and call analysis. Supports single/multi-prompt configs and all SDK languages.
Imports ElevenLabs conversational AI agents into Telnyx, preserving instructions, greetings, voice settings, tools, and call analysis. Guides API key setup and usage via curl or Python SDK.
Provides Retell AI SDK deep dive for voice agent and phone call migration with TypeScript examples, error handling, and resources. For telephony automation projects.
Share bugs, ideas, or general feedback.
Migrate your Retell AI agents to Telnyx in minutes. The import API pulls agent configurations directly from Retell using your API key and recreates them as Telnyx AI Assistants. Both single-prompt and multi-prompt Retell agents are supported.
Interaction model: Collect the user's Telnyx API key and Retell API key, store the Retell key as a Telnyx integration secret, run the import, then verify. Do NOT skip the secret-creation step — the import endpoint requires a secret reference, not a raw key.
| Component | Imported? | Notes |
|---|---|---|
| Instructions | Yes | Imported as-is (both single and multi-prompt) |
| Greeting / first message | Yes | Maps to assistant greeting |
| Voice configuration | Yes | Voice provider and voice ID preserved |
| Dynamic variables | Yes | Default values carried over |
| Tools (hangup, transfer, webhook) | Yes | Tool definitions and configurations |
| MCP Server integrations | Yes | Server URLs and tool mappings |
| Call analysis / insights | Yes | Mapped to insight_settings |
| Data retention preferences | Yes | Mapped to privacy_settings |
| Knowledge base | No | Must be manually added post-import |
| Secrets (API keys in tools) | Partial | Placeholder secrets created — you must re-enter values in the Telnyx portal |
Before importing, store your Retell API key as an integration secret in Telnyx. Note the secret reference name (e.g., retell_api_key) — you'll use it in the import call.
You can create integration secrets via the Telnyx Portal under Integration Secrets, or via the API.
Import every agent from your Retell account:
curl \
-X POST \
-H "Authorization: Bearer $TELNYX_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"provider": "retell",
"api_key_ref": "retell_api_key"
}' \
"https://api.telnyx.com/v2/ai/assistants/import"
import os
from telnyx import Telnyx
client = Telnyx(api_key=os.environ.get("TELNYX_API_KEY"))
assistants = client.ai.assistants.imports(
provider="retell",
api_key_ref="retell_api_key",
)
for assistant in assistants.data:
print(f"Imported: {assistant.name} (ID: {assistant.id})")
import Telnyx from 'telnyx';
const client = new Telnyx();
const assistants = await client.ai.assistants.imports({
provider: 'retell',
api_key_ref: 'retell_api_key',
});
for (const assistant of assistants.data) {
console.log(`Imported: ${assistant.name} (ID: ${assistant.id})`);
}
assistants, err := client.AI.Assistants.Imports(context.TODO(), telnyx.AIAssistantImportsParams{
Provider: telnyx.AIAssistantImportsParamsProviderRetell,
APIKeyRef: "retell_api_key",
})
if err != nil {
panic(err.Error())
}
for _, a := range assistants.Data {
fmt.Printf("Imported: %s (ID: %s)\n", a.Name, a.ID)
}
import com.telnyx.sdk.models.ai.assistants.AssistantImportsParams;
import com.telnyx.sdk.models.ai.assistants.AssistantsList;
AssistantImportsParams params = AssistantImportsParams.builder()
.provider(AssistantImportsParams.Provider.RETELL)
.apiKeyRef("retell_api_key")
.build();
AssistantsList assistants = client.ai().assistants().imports(params);
assistants.getData().forEach(a ->
System.out.printf("Imported: %s (ID: %s)%n", a.getName(), a.getId()));
assistants = client.ai.assistants.imports(
provider: :retell,
api_key_ref: "retell_api_key"
)
assistants.data.each do |a|
puts "Imported: #{a.name} (ID: #{a.id})"
end
To import only certain agents, pass their Retell agent IDs in import_ids:
curl \
-X POST \
-H "Authorization: Bearer $TELNYX_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"provider": "retell",
"api_key_ref": "retell_api_key",
"import_ids": ["retell-agent-id-1", "retell-agent-id-2"]
}' \
"https://api.telnyx.com/v2/ai/assistants/import"
assistants = client.ai.assistants.imports(
provider="retell",
api_key_ref="retell_api_key",
import_ids=["retell-agent-id-1", "retell-agent-id-2"],
)
const assistants = await client.ai.assistants.imports({
provider: 'retell',
api_key_ref: 'retell_api_key',
import_ids: ['retell-agent-id-1', 'retell-agent-id-2'],
});
List your Telnyx assistants to confirm the import succeeded:
curl -H "Authorization: Bearer $TELNYX_API_KEY" \
"https://api.telnyx.com/v2/ai/assistants"
assistants = client.ai.assistants.list()
for a in assistants.data:
print(f"{a.name} — {a.id} — imported: {a.import_metadata}")
const assistants = await client.ai.assistants.list();
for (const a of assistants.data) {
console.log(`${a.name} — ${a.id} — imported:`, a.import_metadata);
}
After importing, complete these manual steps:
Running the import again for the same Retell agents will overwrite the existing Telnyx copies with the latest configuration from Retell. This is useful for syncing changes during a gradual migration.
| Field | Type | Required | Description |
|---|---|---|---|
provider | string | Yes | Must be "retell" |
api_key_ref | string | Yes | Name of the Telnyx integration secret containing your Retell API key |
import_ids | array[string] | No | Specific Retell agent IDs to import. Omit to import all. |
Endpoint: POST https://api.telnyx.com/v2/ai/assistants/import
Full API docs: https://developers.telnyx.com/api-reference/assistants/import-assistants-from-external-provider