Spotify MCP Server
Controls Spotify playback through Claude using the Model Context Protocol. Supports playback control, search, library management, and local favorites.
README
Spotify MCP Server
Control Spotify playback through Claude using the Model Context Protocol (MCP).
Uses PKCE authentication - just install and authorize your Spotify account.
Note: The bundled client ID works for playback control and reading data. For write operations (adding to playlists, saving to library), you'll need to set up your own Spotify app.
Quick Start
1. Install
git clone https://github.com/panuhen/spotify-mcp.git ~/spotify-mcp
cd ~/spotify-mcp
python -m venv .venv
.venv/bin/pip install -e .
2. First Run - Authenticate
Run once to authorize with your Spotify account:
~/spotify-mcp/.venv/bin/spotify-mcp
This opens your browser for Spotify login. After authorizing, the token is cached at ~/.spotify-mcp-token.
3. Add to Claude Code
Add to ~/.mcp.json:
{
"mcpServers": {
"spotify": {
"command": "/home/YOUR_USER/spotify-mcp/.venv/bin/spotify-mcp"
}
}
}
Then enable in ~/.claude/settings.local.json:
{
"enabledMcpjsonServers": ["spotify"]
}
Restart Claude Code and you're ready!
Available Tools
Playback Control
play- Resume or play specific track/album/playlistpause- Pause playbacknext- Skip to next trackprevious- Go to previous trackseek- Seek to position in trackset_volume- Set volume (0-100)shuffle- Toggle shuffle moderepeat- Set repeat mode (off/track/context)
Information
get_current_track- Get currently playing track infoget_playback_state- Get full playback stateget_queue- Get upcoming tracksget_devices- List available devices
Search & Library
search- Search for tracks, albums, artists, playlistsadd_to_queue- Add track to queueget_playlists- List your playlistsget_playlist_tracks- Get tracks from a playlistadd_to_playlist- Add tracks to a playlist (requires own app)save_tracks- Save tracks to your library (requires own app)remove_saved_tracks- Remove tracks from library (requires own app)get_saved_tracks- Get your liked tracks
Local Favorites
No Spotify API permissions needed - stored locally in ~/.spotify-mcp-favorites.json:
favorite_current- Add currently playing track to favoritesget_favorites- List all favorited tracksremove_favorite- Remove a track from favoritesplay_favorites- Play random favorite or queue all favoritesclear_favorites- Clear all favorites
Usage Examples
Once configured, you can ask Claude:
- "What song is currently playing?"
- "Pause the music"
- "Play the next track"
- "Search for 'Bohemian Rhapsody' and add it to the queue"
- "Set the volume to 50%"
- "Turn on shuffle"
- "Show my playlists"
Setup Your Own Spotify App
Required for: add_to_playlist, save_tracks, remove_saved_tracks
The bundled client ID is in Spotify's Development Mode, which restricts write operations. To use all features:
- Create an app at https://developer.spotify.com/dashboard
- In your app settings, add redirect URI:
http://127.0.0.1:8888/callback - Copy your Client ID and add to
~/spotify-mcp/.env:SPOTIPY_CLIENT_ID=your_client_id_here - Delete cached token and re-auth:
rm ~/.spotify-mcp-token - Restart the MCP server
Troubleshooting
"No active device" error
Make sure Spotify is open on at least one device (phone, desktop app, web player).
Authentication issues
Delete ~/.spotify-mcp-token and run spotify-mcp again to re-authenticate.
Token expired
The token auto-refreshes, but if issues persist, delete ~/.spotify-mcp-token and re-auth.
Recommended Servers
playwright-mcp
A Model Context Protocol server that enables LLMs to interact with web pages through structured accessibility snapshots without requiring vision models or screenshots.
Magic Component Platform (MCP)
An AI-powered tool that generates modern UI components from natural language descriptions, integrating with popular IDEs to streamline UI development workflow.
Audiense Insights MCP Server
Enables interaction with Audiense Insights accounts via the Model Context Protocol, facilitating the extraction and analysis of marketing insights and audience data including demographics, behavior, and influencer engagement.
VeyraX MCP
Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.
graphlit-mcp-server
The Model Context Protocol (MCP) Server enables integration between MCP clients and the Graphlit service. Ingest anything from Slack to Gmail to podcast feeds, in addition to web crawling, into a Graphlit project - and then retrieve relevant contents from the MCP client.
Kagi MCP Server
An MCP server that integrates Kagi search capabilities with Claude AI, enabling Claude to perform real-time web searches when answering questions that require up-to-date information.
E2B
Using MCP to run code via e2b.
Neon Database
MCP server for interacting with Neon Management API and databases
Exa Search
A Model Context Protocol (MCP) server lets AI assistants like Claude use the Exa AI Search API for web searches. This setup allows AI models to get real-time web information in a safe and controlled way.
Qdrant Server
This repository is an example of how to create a MCP server for Qdrant, a vector search engine.