Provides tools for controlling TeamSpeak servers, including sending messages to channels, managing users, creating and modifying channels with permissions, configuring talk power settings, and managing virtual server settings.
TeamSpeak MCP
A Model Context Protocol (MCP) server for controlling TeamSpeak from AI models like Claude.
Requirements
- Python 3.10-3.12
- Docker (optional, for containerized deployment)
- TeamSpeak 3 Server with ServerQuery enabled
Features
- 🎯 Connect to TeamSpeak servers
- 💬 Send messages to channels, private messages, and pokes (alert notifications)
- 📋 List connected users and detailed client information
- 🔧 Advanced channel management (create, delete, update properties, permissions)
- 🔇 AFK/Silent channel setup with talk power presets
- 🎵 Voice control (mute, unmute, kick, ban)
- 🛡️ Fine-grained permission management per channel
- 🖥️ Virtual server configuration (name, description, limits, welcome messages)
- 👥 User permission management (server groups, individual permissions)
- 📊 Comprehensive server and channel diagnostics
- ⚙️ 39 powerful tools for complete TeamSpeak automation
🎯 Integration Methods Overview
TeamSpeak MCP offers multiple integration methods to fit your setup and preferences:
📦 Method 1: PyPI Package (Recommended for most users)
- ✅ Easiest setup - One command installation
- ✅ Automatic updates via standard package managers
- ✅ Standard MCP pattern - Compatible with Claude Desktop examples
- ✅ No Docker required - Pure Python implementation
🐳 Method 2: Pre-built Docker Images (Recommended for containers)
- ✅ No dependencies - Everything included
- ✅ Version consistency - Immutable deployments
- ✅ Easy scaling - Works with orchestration
- ✅ Cross-platform - Works anywhere Docker runs
💡 Note: We use
-e
flags in args instead of the"env": {}
field because Claude Desktop's environment variable handling can be unreliable. The args method ensures consistent variable passing.
🐍 Method 3: Local Python Installation (For developers)
- ✅ Full control - Access to source code
- ✅ Customizable - Modify for specific needs
- ✅ Development - Contribute to the project
- ⚠️ More setup - Requires Python environment management
🏗️ Method 4: Local Docker Build (For customization)
- ✅ Custom builds - Modify Dockerfile as needed
- ✅ Offline capability - No external dependencies
- ✅ Version control - Pin to specific commits
- ⚠️ Build time - Requires local Docker build
🎯 Which Method Should You Choose?
Use Case | Recommended Method | Why |
---|---|---|
First time user | PyPI Package (uvx ) | Easiest setup, standard MCP pattern |
Production deployment | Pre-built Docker | Reliable, versioned, no dependencies |
CI/CD environments | Pre-built Docker | Consistent, fast deployment |
Development/Contributing | Local Python | Full access to source code |
Custom modifications | Local Docker Build | Controlled build process |
Corporate environments | Local Docker Build | No external dependencies |
💡 Quick Start Examples
Fastest (PyPI):
Most Reliable (Docker):
Most Flexible (Local):
🚀 Quick Start
Automatic installation script
Connection test
With Docker
🔑 TeamSpeak Server Setup
Before using TeamSpeak MCP, you need to configure your TeamSpeak server credentials:
📋 Required Information
Parameter | Description | Example |
---|---|---|
TEAMSPEAK_HOST | Your server IP or domain | ts.example.com or 192.168.1.100 |
TEAMSPEAK_PORT | ServerQuery port (default: 10011) | 10011 |
TEAMSPEAK_USER | ServerQuery username | mcp_user |
TEAMSPEAK_PASSWORD | ServerQuery password | secure_password123 |
TEAMSPEAK_SERVER_ID | Virtual server ID (usually 1) | 1 |
🔧 How to Get Your Credentials
Step 1: Enable ServerQuery
On your TeamSpeak server, ensure ServerQuery is enabled:
- Check
ts3server.ini
:query_port=10011
- Default enabled on most installations
Step 2: Get Admin Access
- First installation: Check server logs for admin token:
token=AAAA...
- Existing server: Use your admin credentials
Step 3: Create MCP User
Connect to ServerQuery and create a dedicated user:
Step 4: Test Connection
💡 Quick Configuration Examples
For PyPI installation:
For Docker installation:
⚠️ Security Note: Create a dedicated ServerQuery user with minimal permissions. Never use your admin account for automated tools.
Usage
Once configured, you can use these commands with Claude:
Basic Commands
- "Connect to TeamSpeak server"
- "Send message 'Hello everyone!' to general channel"
- "Send private message 'Can you join me?' to user 5"
- "Poke user 12 with message 'Urgent: Please check the announcement!'"
- "List connected users"
- "Create temporary channel called 'Meeting'"
- "Move user John to private channel"
- "Show me server info"
🆕 Advanced Commands
- "Make channel 5 silent so nobody can talk" → Uses
set_channel_talk_power
with preset "silent" - "Set up a moderated welcome channel" → Uses
set_channel_talk_power
with preset "moderated" - "Update channel 3 to set max clients to 10 and add password 'secret'" → Uses
update_channel
- "Show me detailed information about channel 7" → Uses
channel_info
- "Get comprehensive details about client 12" → Uses
client_info_detailed
- "List all permissions for channel 4" → Uses
manage_channel_permissions
with action "list" - "Add talk power permission to channel 6" → Uses
manage_channel_permissions
with action "add" - "Change server name to 'My Gaming Server' and set max clients to 100" → Uses
update_server_settings
- "Set welcome message to 'Welcome to our server!'" → Uses
update_server_settings
- "Add user 15 to admin group 6" → Uses
manage_user_permissions
with action "add_group" - "Remove user 8 from moderator group" → Uses
manage_user_permissions
with action "remove_group" - "Show all server groups for user 12" → Uses
manage_user_permissions
with action "list_groups" - "Give user 20 the 'b_client_kick' permission with value 75" → Uses
manage_user_permissions
with action "add_permission" - "Diagnose my current permissions and connection" → Uses
diagnose_permissions
- "Check why I can't list clients" → Uses
diagnose_permissions
🎯 Available Tools (39 total)
Core Tools (12 total)
connect_to_server
: Connect to TeamSpeak serversend_channel_message
: Send message to a channelsend_private_message
: Send private messagepoke_client
: Send poke (alert notification) to a user - more attention-grabbing than private messagelist_clients
: List connected clientslist_channels
: List channelscreate_channel
: Create new channeldelete_channel
: Delete channelmove_client
: Move client to another channelkick_client
: Kick clientban_client
: Ban clientserver_info
: Get server information
🆕 Advanced Management Tools (8 total)
update_channel
: Update channel properties (name, description, password, talk power, limits, etc.)set_channel_talk_power
: Quick setup for AFK/silent/moderated channels with presetschannel_info
: Get detailed channel information (permissions, codec, type, etc.)manage_channel_permissions
: Fine-grained permission control (add/remove/list)client_info_detailed
: Comprehensive client details (platform, version, status, etc.)update_server_settings
: Update virtual server settings (name, welcome message, max clients, password, host message, default groups)manage_user_permissions
: Complete user permission management (add/remove server groups, set individual permissions, list assignments)diagnose_permissions
: Diagnose current connection permissions and troubleshoot issues
🆕 Server Groups Management (4 total)
list_server_groups
: List all server groups availableassign_client_to_group
: Add or remove clients from server groupscreate_server_group
: Create new server groups with custom settingsmanage_server_group_permissions
: Manage permissions for server groups
🆕 Moderation & Bans (3 total)
list_bans
: List all active ban rules on the servermanage_ban_rules
: Create, delete or manage ban rules (IP, name, UID-based)list_complaints
: List complaints against users
🆕 Search & Discovery (2 total)
search_clients
: Search for clients by name pattern or unique identifierfind_channels
: Search for channels by name pattern
🆕 Privilege Tokens (2 total)
list_privilege_tokens
: List all privilege keys/tokens availablecreate_privilege_token
: Create new privilege tokens for server/channel access
🆕 File Management (3 total)
list_files
: List files in a channel's file repositoryget_file_info
: Get detailed information about specific filesmanage_file_permissions
: List and manage active file transfers
🆕 Logs & Monitoring (3 total)
view_server_logs
: View recent entries from the server logadd_log_entry
: Add custom entries to the server logget_connection_info
: Get detailed connection information
🆕 Snapshots & Backup (2 total)
create_server_snapshot
: Create snapshots of server configurationdeploy_server_snapshot
: Deploy/restore server configuration from snapshots
🔧 Development
Local testing
Docker build
🔒 Security
- 🔑 Never commit credentials in code
- 🛡️ Use ServerQuery accounts with limited privileges
- 🌐 Configure firewall to restrict ServerQuery port access
- 🔄 Change ServerQuery passwords regularly
🚀 Automatized Release Workflow (For Maintainers)
This project uses fully automated releases via GitHub Actions. No manual PyPI uploads needed!
How it works:
- One Command Release:
- Automatic Process:
- ✅ Bumps version in
pyproject.toml
- ✅ Creates git commit and tag
- ✅ Pushes to GitHub
- ✅ GitHub Actions triggers automatically:
- 🔨 Builds Python package
- 🧪 Tests on TestPyPI first
- 📦 Publishes to PyPI
- 🐳 Builds and publishes Docker images
- 📝 Creates GitHub release with changelog
- ✅ Bumps version in
- Setup (One-time):
Result:
- PyPI:
uvx install teamspeak-mcp
gets the new version - Docker:
ghcr.io/marlburrow/teamspeak-mcp:v1.0.4
available - GitHub: Automatic release with changelog
- No manual work needed! 🎉
📦 Release Process
This project uses automated GitHub Actions for building and publishing Docker images:
- Tag a release:
make release-patch
(orrelease-minor
/release-major
) - Automatic build: GitHub Actions builds and pushes multi-arch images
- Available everywhere: PyPI, GitHub Container Registry, and GitHub Releases
🆘 Troubleshooting
Common Issues
- "Connection refused"
- Check that ServerQuery is enabled on your server
- Verify port (default: 10011)
- "Authentication failed"
- Check your ServerQuery credentials
- Ensure user has proper permissions
- "Virtual server not found"
- Check virtual server ID with
serverlist
- Check virtual server ID with
- "Python version error"
- Ensure you're using Python 3.10-3.12
- The MCP library requires Python 3.10+
- "Docker environment variables not working"
- Use
-e
flags in args instead of the"env": {}
field for better compatibility - Ensure environment variables are passed correctly in Docker args
- Check that all required variables are provided: TEAMSPEAK_HOST, TEAMSPEAK_USER, TEAMSPEAK_PASSWORD
- Use
Logs
📝 License
MIT
This server cannot be installed
remote-capable server
The server can be hosted and run remotely because it primarily relies on remote services or has no dependency on the local environment.
A Model Context Protocol server that enables AI models like Claude to control TeamSpeak servers, allowing users to manage channels, send messages, configure permissions, and perform server administration through natural language commands.
Related MCP Servers
- -securityFlicense-qualityA Model Context Protocol server that allows Claude to make API requests on your behalf, providing tools for testing various APIs including HTTP requests and OpenAI integrations without sharing your API keys in the chat.Last updated -Python
- -securityFlicense-qualityA Model Context Protocol server that enables AI assistants like Claude to perform Python development tasks through file operations, code analysis, project management, and safe code execution.Last updated -1Python
- -securityAlicense-qualityA Model Context Protocol server that integrates high-quality text-to-speech capabilities with Claude Desktop and other MCP-compatible clients, supporting multiple voice options and audio formats.Last updated -TypeScriptMIT License
- -securityFlicense-qualityA Model Context Protocol server that extends AI capabilities by providing file system access and management functionalities to Claude or other AI assistants.Last updated -3TypeScript