Despite the confusing name, this connects Claude to the ElevenLabs Conversational AI API, not TwelveLabs video platform. You get agent management (list, configure, update prompts and LLM settings), knowledge base operations (add docs from text or URL, read full extracted content, delete), conversation history with full transcripts and data collection analysis, and voice browsing. It exposes capabilities the official ElevenLabs MCP doesn't cover, like reading agent webhooks, updating temperature settings, and pulling complete system prompts. Reach for this when you need Claude to inspect or modify your ElevenLabs voice agents programmatically rather than through their dashboard.
This project is not affiliated with TwelveLabs (the video understanding platform). It is an MCP server for the ElevenLabs Conversational AI API — voice agents, knowledge bases, conversations, and TTS. The name "TwelveLabs" is the project codename only.
An enhanced MCP (Model Context Protocol) server that gives Claude direct access to the ElevenLabs Conversational AI API -- including capabilities the official ElevenLabs MCP connector doesn't expose.
ELEVENLABS_API_KEY=your-key npx twelvelabs-mcp-server
git clone https://github.com/micro-JAY/twelvelabs-mcp-server.git
cd twelvelabs-mcp-server
npm install --include=dev
npm run build
Edit ~/Library/Application Support/Claude/claude_desktop_config.json:
{
"mcpServers": {
"twelvelabs": {
"command": "node",
"args": ["/path/to/twelvelabs-mcp-server/dist/index.js"],
"env": {
"ELEVENLABS_API_KEY": "your-api-key-here"
}
}
}
}
Then restart Claude Desktop. You should see "twelvelabs" in the available tools panel.
In any Claude conversation:
"List my agents" "Get the full config for agent_1001kjbh14xce5kbreh55ydf4rae" "Show me the last 10 conversations for that agent" "Get the transcript and analysis for conversation_xyz"
| Tool | What it does |
|---|---|
twelvelabs_list_agents | List all agents in your account |
twelvelabs_get_agent | Full config: LLM model, voice, KB docs, webhook, prompt preview |
twelvelabs_get_agent_prompt | Full untruncated system prompt text |
twelvelabs_update_agent_prompt | Replace system prompt and/or first message |
twelvelabs_update_agent_settings | Change temperature, voice, TTS settings, language |
twelvelabs_list_agent_conversations | Recent conversations for one agent |
twelvelabs_get_agent_webhook | Current webhook URL |
twelvelabs_set_agent_webhook | Set or remove webhook URL |
| Tool | What it does |
|---|---|
twelvelabs_list_kb_docs | All KB docs with size and creation date |
twelvelabs_get_kb_doc | Full extracted text content of a doc |
twelvelabs_add_kb_text | Add a plain text document |
twelvelabs_add_kb_url | Add a web page by URL |
twelvelabs_delete_kb_doc | Permanently delete a doc |
| Tool | What it does |
|---|---|
twelvelabs_list_conversations | Recent conversations (optionally filtered by agent) |
twelvelabs_get_conversation | Full transcript + data_collection + evaluation_criteria |
| Tool | What it does |
|---|---|
twelvelabs_list_voices | Browse available voices with IDs and labels |
npm run dev # watch mode with tsx -- auto-reloads on file changes
npm run build # compile to dist/
git checkout -b feat/my-feature)git commit -m 'feat: add my feature')git push origin feat/my-feature)MIT -- see LICENSE for details.
All tools share a single Axios client instance (src/client.ts) initialised from
ELEVENLABS_API_KEY at startup. Tool implementations live in src/tools/ -- one
file per domain -- and are registered onto the McpServer in src/index.ts. The
server communicates over stdio transport (stdin/stdout), which is why all debug
logging uses console.error (stderr), not console.log.
ELEVENLABS_API_KEY*secretYour ElevenLabs API key
io.github.socialapishub/social-media-api
io.github.xpaysh/social-media
com.thenextgennexus/youtube-media-mcp-server
io.github.ludmila-omlopes/youtube-video-analyzer
csoai-org/social-media-ai-mcp
com.ezbizservices/social-media