MCP

Generate Speech from Text with ElevenLabs

ElevenLabs MCP Server integrates with the ElevenLabs text-to-speech API, enabling voice generation from text and script management.

Works with elevenlabs
⚠️ This tool looks unmaintained — no upstream commits in 12+ months.

21
Spark score
out of 100
Updated Jan 2025
Version 1.0.0
Models

Add to Favorites

Why it matters

Integrate ElevenLabs text-to-speech capabilities into your applications. Generate high-quality audio from scripts or simple text, manage multiple voices, and store voiceover history.

Outcomes

What it gets done

01

Generate audio from plain text.

02

Create audio from multi-voice scripts.

03

Manage and retrieve voiceover history.

04

List available voices for generation.

Install

Add it to your toolbox

Run in your project directory:

curl -fsSL https://spark.entire.vc/get/vb-elevenlabs | bash

Capabilities

Tools your agent gets

generate_audio_simple

Generate audio from plain text using default voice settings

generate_audio_script

Generate audio from a structured script with multiple voices and actors

delete_job

Delete a job by its ID

get_audio_file

Get an audio file by its ID

list_voices

List all available voices

get_voiceover_history

Get voiceover job history, optionally filtered by job ID

Overview

ElevenLabs MCP Server

What it does

This Model Context Protocol (MCP) server integrates with the ElevenLabs text-to-speech API, enabling clients to generate audio from text. It supports managing multiple voices and script parts, with a persistent history stored in an SQLite database. A sample SvelteKit MCP Client is provided for managing voice generation tasks.

How it connects

Use this server when you need to programmatically generate speech from text using ElevenLabs' voice capabilities. It's ideal for applications requiring text-to-speech for narration, character voices, or audio content creation. Do not use this server if your application does not require ElevenLabs' specific voice synthesis features.

Source README

ElevenLabs MCP Server

smithery badge

A Model Context Protocol (MCP) server that integrates with ElevenLabs text-to-speech API, featuring both a server component and a sample web-based MCP Client (SvelteKit) for managing voice generation tasks.

ElevenLabs Server MCP server

Features

  • Generate audio from text using ElevenLabs API
  • Support for multiple voices and script parts
  • SQLite database for persistent history storage
  • Sample SvelteKit MCP Client for:
    • Simple text-to-speech conversion
    • Multi-part script management
    • Voice history tracking and playback
    • Audio file downloads

Installation

Installing via Smithery

To install ElevenLabs MCP Server for Claude Desktop automatically via Smithery:

npx -y @smithery/cli install elevenlabs-mcp-server --client claude

Using uvx (recommended)

When using uvx, no specific installation is needed.

Add the following configuration to your MCP settings file (e.g., cline_mcp_settings.json for Claude Desktop):

{
  "mcpServers": {
    "elevenlabs": {
      "command": "uvx",
      "args": ["elevenlabs-mcp-server"],
      "env": {
        "ELEVENLABS_API_KEY": "your-api-key",
        "ELEVENLABS_VOICE_ID": "your-voice-id",
        "ELEVENLABS_MODEL_ID": "eleven_flash_v2",
        "ELEVENLABS_STABILITY": "0.5",
        "ELEVENLABS_SIMILARITY_BOOST": "0.75",
        "ELEVENLABS_STYLE": "0.1",
        "ELEVENLABS_OUTPUT_DIR": "output"
      }
    }
  }
}

Development Installation

  1. Clone this repository
  2. Install dependencies:
    uv venv
    
  3. Copy .env.example to .env and fill in your ElevenLabs credentials
{
  "mcpServers": {
    "elevenlabs": {
      "command": "uv",
      "args": [
        "--directory",
        "path/to/elevenlabs-mcp-server",
        "run",
        "elevenlabs-mcp-server"
      ],
      "env": {
        "ELEVENLABS_API_KEY": "your-api-key",
        "ELEVENLABS_VOICE_ID": "your-voice-id",
        "ELEVENLABS_MODEL_ID": "eleven_flash_v2",
        "ELEVENLABS_STABILITY": "0.5",
        "ELEVENLABS_SIMILARITY_BOOST": "0.75",
        "ELEVENLABS_STYLE": "0.1",
        "ELEVENLABS_OUTPUT_DIR": "output"
      }
    }
  }
}

Using the Sample SvelteKit MCP Client

  1. Navigate to the web UI directory:
    cd clients/web-ui
    
  2. Install dependencies:
    pnpm install
    
  3. Copy .env.example to .env and configure as needed
  4. Run the web UI:
    pnpm dev
    
  5. Open http://localhost:5174 in your browser

Available Tools

  • generate_audio_simple: Generate audio from plain text using default voice settings
  • generate_audio_script: Generate audio from a structured script with multiple voices and actors
  • delete_job: Delete a job by its ID
  • get_audio_file: Get the audio file by its ID
  • list_voices: List all available voices
  • get_voiceover_history: Get voiceover job history. Optionally specify a job ID for a specific job.

Available Resources

  • voiceover://history/{job_id}: Get the audio file by its ID
  • voiceover://voices: List all available voices

Discussion

Questions & comments · 0

Sign In Sign in to leave a comment.