ElevenLabs
Provides tools for text-to-speech, sound effects, music generation, voice cloning, speech-to-speech, transcription, and voice isolation using ElevenLabs' AI audio models.
Click on "Install Server".
Wait a few minutes for the server to deploy. Once ready, it will show a "Started" state.
In the chat, type
@followed by the MCP server name and your instructions, e.g., "@ElevenLabsgenerate a sound effect of thunder rumbling in the distance"
That's it! The server will respond to your query, and you can continue using it as needed.
Here is a step-by-step guide with screenshots.
ElevenLabs MCP Server
MCP server that brings ElevenLabs to Claude Code — text-to-speech, sound effects, music generation, voice cloning, speech-to-speech, transcription, and voice isolation. 8 tools for industry-leading AI audio. Supports Multilingual v2, v3, Turbo, Flash, and Scribe models.
Quick Start
Step 1: Get Your API Key
Go to elevenlabs.io
Create an account or sign in
Click your profile icon → API Keys
Generate and copy the key (you'll need it in Step 3)
Step 2: Install Prerequisites
Node.js 18+ - Download here
Claude Code CLI - Installation guide
Step 3: Install the MCP Server
3.1 Clone the repository
git clone https://github.com/wynandw87/claude-code-elevenlabs-mcp.git
cd claude-code-elevenlabs-mcp3.2 Install dependencies
macOS / Linux / Windows:
npm installNote: Dependencies are installed and the server is built automatically in one step.
3.3 Register with Claude Code
Choose your install scope:
Scope | Flag | Who can use it |
User (recommended) |
| You, in any project |
Project |
| Anyone who clones this repo |
Local |
| Only in current directory |
Replace YOUR_API_KEY with your actual ElevenLabs API key, and use the full path to dist/index.js.
Tip: To get the full path, run this from the cloned directory:
macOS/Linux:
echo "$(pwd)/dist/index.js"Windows:
echo %cd%\dist\index.js
macOS / Linux:
claude mcp add -s user ElevenLabs -e ELEVENLABS_API_KEY=YOUR_API_KEY -- node /full/path/to/dist/index.jsWindows (CMD):
claude mcp add -s user ElevenLabs -e "ELEVENLABS_API_KEY=YOUR_API_KEY" -- node "C:\full\path\to\dist\index.js"Windows (PowerShell):
claude mcp add -s user ElevenLabs -e "ELEVENLABS_API_KEY=YOUR_API_KEY" '--' node "C:\full\path\to\dist\index.js"Alternative: Use Setup Scripts
The setup scripts handle dependency installation, building, and registration automatically.
macOS / Linux:
chmod +x setup.sh
./setup.sh YOUR_API_KEYWindows (PowerShell):
.\setup.ps1 -ApiKey YOUR_API_KEYOr use the npm helper (if API key is set in environment):
export ELEVENLABS_API_KEY=YOUR_API_KEY
npm run install:claudeStep 4: Restart Claude Code
Close and reopen Claude Code for the changes to take effect.
Step 5: Verify Installation
claude mcp listYou should see ElevenLabs listed with a Connected status.
Related MCP server: ElevenLabs MCP Server
Features
Speech Generation
Text-to-Speech (
text_to_speech) - Convert text to natural speech with voice/emotion controls and 29+ languagesSpeech-to-Speech (
speech_to_speech) - Transform audio to use a different voice while preserving emotion and cadence
Sound & Music
Sound Effects (
sound_effects) - Generate sound effects from text descriptionsMusic Generation (
generate_music) - Generate studio-grade music from text descriptions
Voice Management
List Voices (
list_voices) - Browse and search available voices with filteringClone Voice (
clone_voice) - Create instant voice clones from audio samples
Audio Processing
Transcription (
transcribe) - Speech-to-text with speaker diarization (90+ languages)Voice Isolation (
voice_isolation) - Isolate vocals from background noise
Usage
Once installed, use trigger phrases to invoke ElevenLabs:
Trigger | Tool | Example |
| Text-to-Speech | "elevenlabs speak: Hello, welcome to the demo" |
| Sound Effects | "elevenlabs sfx: thunder rumbling in the distance" |
| Generate Music | "elevenlabs music: lo-fi hip hop with soft piano" |
| List Voices | "elevenlabs list voices matching female" |
| Clone Voice | "elevenlabs clone voice from recording.wav" |
| Speech-to-Speech | "elevenlabs voice change audio.mp3 to Adam" |
| Transcribe | "elevenlabs transcribe meeting.mp3" |
| Voice Isolation | "elevenlabs isolate vocals from noisy-recording.mp3" |
Or ask naturally:
"Use ElevenLabs to convert this text to speech with the Rachel voice"
"Generate a sound effect of a spaceship engine starting up"
"Create some lo-fi background music with ElevenLabs"
"Show me the available ElevenLabs voices"
"Clone a voice from my recording.wav file"
"ElevenLabs transcribe this audio file"
"Clean up the background noise in this recording with ElevenLabs"
Tool Reference
text_to_speech
Convert text to natural speech. ElevenLabs' flagship feature with industry-leading quality.
Parameters:
text(string, required) - The text to convert to speechvoice(string, optional) - Voice name (e.g., "Rachel", "Adam") or voice ID (default:Rachel)model(string, optional) - TTS model (default:eleven_multilingual_v2)stability(number, optional) - Voice stability 0.0-1.0 (lower = more expressive)similarity_boost(number, optional) - Voice clarity 0.0-1.0 (higher = closer to original)style(number, optional) - Style exaggeration 0.0-1.0speed(number, optional) - Speech speed 0.25-4.0 (default: 1.0)output_format(string, optional) - Audio format (default:mp3_44100_128)save_path(string, optional) - File path to save the audio
sound_effects
Generate sound effects from text descriptions.
Parameters:
text(string, required) - Description of the sound effect (e.g., "wooden door creaking open slowly")duration_seconds(number, optional) - Duration 0.5-30 seconds (auto-determined if omitted)prompt_influence(number, optional) - How closely to follow the prompt 0.0-1.0 (default: 0.3)save_path(string, optional) - File path to save the audio
generate_music
Generate studio-grade music from text descriptions.
Parameters:
text(string, required) - Description of the music (e.g., "epic orchestral score for a movie trailer")duration_seconds(number, optional) - Duration 0.5-30 seconds (auto-determined if omitted)save_path(string, optional) - File path to save the audio
list_voices
Browse and search available ElevenLabs voices.
Parameters:
search(string, optional) - Search query to filter voices by name, description, or labelscategory(string, optional) -"premade","cloned","generated","professional"page_size(integer, optional) - Number of voices to return (default: 20, max: 100)
clone_voice
Create an instant voice clone from audio samples. Requires 1-2 minutes of clear audio.
Parameters:
name(string, required) - Name for the cloned voicefiles(string[], required) - Array of absolute paths to audio filesdescription(string, optional) - Description of the voiceremove_background_noise(boolean, optional) - Apply audio isolation to samples before cloning
speech_to_speech
Transform audio to use a different voice while preserving emotion and cadence.
Parameters:
audio_path(string, required) - Absolute path to the source audio filevoice(string, required) - Target voice name or IDmodel(string, optional) - STS model (default:eleven_english_sts_v2)stability(number, optional) - Voice stability 0.0-1.0similarity_boost(number, optional) - Voice clarity 0.0-1.0remove_background_noise(boolean, optional) - Remove background noise from sourcesave_path(string, optional) - File path to save the audio
transcribe
Transcribe audio to text with optional speaker diarization. Supports 90+ languages.
Parameters:
audio_path(string, required) - Absolute path to the audio filemodel(string, optional) -"scribe_v2"(default, 90+ languages),"scribe_v1"language_code(string, optional) - ISO 639-1 language code (e.g., "en", "es", "fr")diarize(boolean, optional) - Identify which speaker is talkingnum_speakers(integer, optional) - Expected number of speakers (up to 32)
voice_isolation
Isolate vocals from background noise in audio files.
Parameters:
audio_path(string, required) - Absolute path to the audio file to processsave_path(string, optional) - File path to save the isolated audio
Supported Models
Text-to-Speech Models
Model | Languages | Latency | Best For |
| 29 | Balanced | Default — general use, voiceovers |
| 70+ | ~500ms | Latest quality, dramatic delivery |
| 32 | ~250ms | Fast, balanced quality |
| 32 | ~75ms | Ultra-fast, real-time apps |
Speech-to-Speech Models
Model | Best For |
| Default — English voice conversion |
Transcription Models
Model | Languages | Best For |
| 90+ | Default — high accuracy with diarization |
| Multiple | Previous generation |
Sound Effects / Music Models
Model | Best For |
| Sound effect generation |
| Music generation |
Configuration
Environment Variables
Variable | Required | Default | Description |
| Yes | — | ElevenLabs API key |
| No |
| Default voice name for TTS |
| No |
| API timeout in ms |
| No |
| Directory for auto-saved audio |
How It Works
This MCP server uses the official @elevenlabs/elevenlabs-js SDK to communicate with ElevenLabs models. It connects to Claude Code via stdio transport.
Voice name resolution: You can use voice names (e.g., "Rachel", "Adam") instead of voice IDs. The server resolves names automatically via a cached voice lookup.
Tools provided:
Tool | API Endpoint | Default Model |
| Text-to-Speech |
|
| Text-to-Sound-Effects |
|
| Text-to-Sound-Effects |
|
| Voices Search | — |
| Instant Voice Cloning | — |
| Speech-to-Speech |
|
| Speech-to-Text |
|
| Audio Isolation | — |
Troubleshooting
Fix API Key
If you entered the wrong API key, remove and reinstall:
claude mcp remove ElevenLabsThen reinstall using the command from Step 3.3 above (use the same scope you originally installed with).
MCP Server Not Showing Up
Check if the server is installed:
claude mcp listIf not listed, follow Step 3 to install it.
Server Won't Start
Verify your API key is valid at elevenlabs.io → Profile → API Keys
Check Node.js version (needs 18+):
node --versionEnsure the server was built — if
dist/index.jsis missing, runnpm installagain
Connection Errors
Check that
dist/index.jsexists — if not, runnpm installVerify the path is absolute in your
claude mcp addcommandRestart Claude Code after any configuration changes
Timeout Errors
Audio generation can be slower than text — the default timeout is 120 seconds
Increase
ELEVENLABS_TIMEOUTenvironment variable for slow connections
View Current Configuration
claude mcp listContributing
Pull requests welcome! Please keep it simple and beginner-friendly.
License
MIT
Made for the Claude Code community
Maintenance
Resources
Unclaimed servers have limited discoverability.
Looking for Admin?
If you are the server author, to access and configure the admin panel.
Latest Blog Posts
MCP directory API
We provide all the information about MCP servers via our MCP API.
curl -X GET 'https://glama.ai/api/mcp/v1/servers/wynandw87/claude-code-elevenlabs-mcp'
If you have feedback or need assistance with the MCP directory API, please join our Discord server