MCP server for ElevenLabs text-to-speech API integration
Project description
ElevenLabs MCP Server
A Model Context Protocol (MCP) server that provides text-to-speech functionality using the ElevenLabs API. This server allows you to convert text to natural-sounding speech with various voices and models.
Features
- Text-to-Speech Conversion: Convert any text to high-quality speech
- Voice Management: List and get detailed information about available voices
- Multiple Models: Support for various ElevenLabs TTS models
- Streaming Support: Real-time audio generation for longer texts
- Flexible Output: Multiple audio formats and custom voice settings
- Automatic File Management: Smart file naming and directory creation
Installation
- Clone this repository:
git clone <repository-url>
cd elevan-labs-mcp
- Install dependencies:
pip install -e .
- Set up your ElevenLabs API key:
export ELEVENLABS_API_KEY="your_api_key_here"
Or create a .env file in the project root:
cp .env.example .env
# Edit .env and add your API key
You can get your API key from ElevenLabs Dashboard.
Usage
Running the Server
python main.py
Or using the installed script:
elevan-labs-mcp
🤖 LLM Integration
MCP Configuration
The mcp.json file provides configuration with clients:
{
"servers": {
"elevenlabs-mcp": {
"type": "stdio",
"command": "uvx",
"args": [
"--directory",
"${workspaceFolder}",
"elevan-labs-mcp"
],
"envFile": "${workspaceFolder}/.env"
}
}
}
Available Tools
1. elevenlabs_text_to_speech
Convert text to speech with extensive customization options.
Parameters:
text(required): The text to convert to speechvoice_id(optional): Voice ID to use (defaults to George voice)model_id(optional): Model to use (defaults to eleven_multilingual_v2)output_format(optional): Audio format (defaults to mp3_44100_128)output_file(optional): Custom output file pathvoice_settings(optional): Custom voice settings (stability, similarity_boost, etc.)
Example:
{
"text": "Hello, this is a test of the ElevenLabs text-to-speech API.",
"voice_id": "JBFqnCBsd6RMkjVDRZzb",
"output_format": "mp3_44100_128"
}
2. elevenlabs_list_voices
Get all available voices from your ElevenLabs account.
Parameters: None
Returns: List of voices with their IDs, names, categories, and settings.
3. elevenlabs_get_voice_info
Get detailed information about a specific voice.
Parameters:
voice_id(required): ID of the voice to query
Returns: Detailed voice information including samples and settings.
4. elevenlabs_stream_text_to_speech
Convert text to speech with streaming for real-time generation.
Parameters:
text(required): The text to convertvoice_id(optional): Voice ID to usemodel_id(optional): Model to useoutput_file(required): Output file path
5. elevenlabs_get_models
Get all available text-to-speech models.
Parameters: None
Returns: List of models with their capabilities and limitations.
Supported Audio Formats
- MP3:
mp3_44100_128,mp3_44100_192,mp3_44100_64 - PCM:
pcm_16000,pcm_22050,pcm_24000,pcm_44100 - WAV:
wav_22050,wav_44100,wav_48000 - μ-law:
ulaw_8000
Voice Settings
You can customize voice generation with these settings:
stability(0-1): Controls consistency between generationssimilarity_boost(0-1): Enhances similarity to the original voicestyle(0-1): Amplifies the style of the original speakeruse_speaker_boost(boolean): Boost similarity to the original speaker
Error Handling
The server includes comprehensive error handling for:
- Missing API keys
- Invalid voice IDs
- API rate limits
- Network issues
- File system errors
Configuration
Environment Variables
ELEVENLABS_API_KEY: Your ElevenLabs API key (required)
Default Settings
- Default Voice: George (
JBFqnCBsd6RMkjVDRZzb) - Default Model:
eleven_multilingual_v2 - Default Format:
mp3_44100_128 - Default Output Directory:
./audio_output
Examples
Basic Text-to-Speech
{
"tool": "elevenlabs_text_to_speech",
"arguments": {
"text": "Welcome to the ElevenLabs MCP server!"
}
}
Custom Voice and Settings
{
"tool": "elevenlabs_text_to_speech",
"arguments": {
"text": "This is a custom voice example.",
"voice_id": "your_voice_id_here",
"voice_settings": {
"stability": 0.75,
"similarity_boost": 0.8,
"style": 0.6
}
}
}
List Available Voices
{
"tool": "elevenlabs_list_voices",
"arguments": {}
}
Development
Project Structure
elevan-labs-mcp/
├── elevan_labs_mcp/
│ ├── __init__.py
│ └── server.py # Main MCP server implementation
├── main.py # Entry point
├── pyproject.toml # Project configuration
├── README.md # This file
└── .gitignore # Git ignore rules
Dependencies
mcp>=1.0.0: Model Context Protocol SDKelevenlabs>=1.0.0: ElevenLabs Python SDKhttpx>=0.25.0: HTTP clientpydantic>=2.0.0: Data validation
Troubleshooting
Common Issues
- Missing API Key: Make sure
ELEVENLABS_API_KEYis set in your environment - Voice Not Found: Use
elevenlabs_list_voicesto see available voices - Rate Limits: ElevenLabs has rate limits based on your subscription tier
- File Permissions: Ensure the output directory is writable
Getting Help
- Check the ElevenLabs API Documentation
- Review the MCP Specification
License
This project is licensed under the MIT License - see the LICENSE file for details.
Contributing
Contributions are welcome! Please feel free to submit a Pull Request.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file elevan_labs_mcp-0.1.1.tar.gz.
File metadata
- Download URL: elevan_labs_mcp-0.1.1.tar.gz
- Upload date:
- Size: 9.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fd33a8a50a1d7697bdfbf2a37b6edcbdcda25fec2e31df7764cb3b31eef2ec72
|
|
| MD5 |
86ddd57831d94e356f24c4f4d3c061a3
|
|
| BLAKE2b-256 |
dde4df5c8408b01355284c4bea482a07a610b71e8b1f68e410556286717b2d1c
|
Provenance
The following attestation bundles were made for elevan_labs_mcp-0.1.1.tar.gz:
Publisher:
publish.yml on mafzaal/elevan-labs-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
elevan_labs_mcp-0.1.1.tar.gz -
Subject digest:
fd33a8a50a1d7697bdfbf2a37b6edcbdcda25fec2e31df7764cb3b31eef2ec72 - Sigstore transparency entry: 254620976
- Sigstore integration time:
-
Permalink:
mafzaal/elevan-labs-mcp@a384dad615439f53773e39897f552474d127f516 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/mafzaal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a384dad615439f53773e39897f552474d127f516 -
Trigger Event:
release
-
Statement type:
File details
Details for the file elevan_labs_mcp-0.1.1-py3-none-any.whl.
File metadata
- Download URL: elevan_labs_mcp-0.1.1-py3-none-any.whl
- Upload date:
- Size: 10.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.12.9
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
fbbd14296d758fa1a96ef283adcda765f563df7292df4dac9666e8802ed58660
|
|
| MD5 |
3f23da608b91eac807d89112432c49b6
|
|
| BLAKE2b-256 |
3ad226854d768c5263ed3e5f6229af25e50e8a0526ad85c72465737dd86fb961
|
Provenance
The following attestation bundles were made for elevan_labs_mcp-0.1.1-py3-none-any.whl:
Publisher:
publish.yml on mafzaal/elevan-labs-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
elevan_labs_mcp-0.1.1-py3-none-any.whl -
Subject digest:
fbbd14296d758fa1a96ef283adcda765f563df7292df4dac9666e8802ed58660 - Sigstore transparency entry: 254620980
- Sigstore integration time:
-
Permalink:
mafzaal/elevan-labs-mcp@a384dad615439f53773e39897f552474d127f516 -
Branch / Tag:
refs/tags/v0.1.1 - Owner: https://github.com/mafzaal
-
Access:
public
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
publish.yml@a384dad615439f53773e39897f552474d127f516 -
Trigger Event:
release
-
Statement type: