Vulpes Spotify
Interact with Spotify to search for and play tracks using an AI assistant.
Vuples Spotify MCP Server
A Model Context Protocol (MCP) server that enables AI assistants like Claude to interact with Spotify, allowing them to search for and play tracks.
Features
- Search for tracks by artist, title, or any query
- Play tracks directly on your active Spotify device
- Get information about your currently playing track
- Find available Spotify playback devices
- Combined search-and-play functionality
- List user's Spotify playlists
- View tracks within playlists
- Play playlists (with optional shuffle mode)
- Find and play playlists by name
Requirements
- Node.js (v16+)
- Spotify Developer Account
- Spotify Premium account (for playback functionality)
- An MCP-compatible client (e.g., Claude Desktop)
Installation
Installing via Smithery
To install Vulpes Spotify Server for Claude Desktop automatically via Smithery:
npx -y @smithery/cli install @ejfox/vulpes-spotify-mcp --client claude
Manual Installation
-
Clone this repository:
git clone https://github.com/yourusername/spotify-mcp.git cd spotify-mcp -
Install dependencies:
npm install -
Create a
.envfile with your Spotify API credentials:SPOTIFY_CLIENT_ID=your_client_id SPOTIFY_CLIENT_SECRET=your_client_secret SPOTIFY_REDIRECT_URI=http://localhost:8888 # Optional: For playback control SPOTIFY_REFRESH_TOKEN=your_refresh_tokenYou can get your Client ID and Secret from the Spotify Developer Dashboard.
-
Generate a refresh token (required for playback control):
There are two ways to get a refresh token:
Option 1: Use the built-in script
npm run get-tokenThis will start a local server and provide instructions in the terminal.
Option 2: Use the simple script (if option 1 doesn't work)
node src/simple-auth.jsThis will give you a URL to open in your browser. After authorizing, you'll be redirected to a URL. Copy that URL back to the terminal, and it will show you a curl command to get the refresh token.
Required scopes (already included in the scripts):
user-read-playback-stateuser-modify-playback-stateuser-read-currently-playingplaylist-read-privateplaylist-read-collaborative
-
Add the refresh token to your
.envfile:SPOTIFY_REFRESH_TOKEN=your_refresh_token -
Build the project:
npm run build
Usage with Claude Desktop
-
First, ensure Spotify is open and playing on your device
-
Add this server to your Claude Desktop configuration:
Edit your
claude_desktop_config.jsonfile (typically in~/Library/Application Support/Claude/on macOS or%APPDATA%\\Claude\\on Windows):{ "mcpServers": { "spotify": { "command": "node", "args": ["/absolute/path/to/vulpes-spotify-mcp/dist/index.js"], "env": { "SPOTIFY_CLIENT_ID": "your_client_id", "SPOTIFY_CLIENT_SECRET": "your_client_secret", "SPOTIFY_REDIRECT_URI": "http://localhost:8888", "SPOTIFY_REFRESH_TOKEN": "your_refresh_token" } } } }Make sure to replace
/absolute/path/to/vulpes-spotify-mcpwith the actual path to your project. -
Restart Claude Desktop
-
You should now see the Spotify tools available when you click on the hammer icon in Claude Desktop
Available Tools
- spotify-search: Search for tracks by query
- spotify-play: Play a specific track by ID or URI
- spotify-currently-playing: Get information about the currently playing track
- spotify-devices: List available Spotify playback devices
- spotify-search-and-play: Search for a track and automatically play the top result
- spotify-playlists: Get a list of the user's Spotify playlists
- spotify-playlist-tracks: Get tracks from a specific playlist
- spotify-play-playlist: Play a specific playlist (with optional shuffle)
- spotify-find-playlist: Find a playlist by name and play it (recommended for AI use)
Troubleshooting
- "No active device found": Make sure Spotify is open and playing on at least one of your devices
- "Missing permissions": Your refresh token may not have the required scopes
- "Not premium": Playback control requires a Spotify Premium account
- "Issues with refresh token": If your token expires, generate a new one using the steps in the installation section
Important Notes
- Always ensure Spotify is open on at least one device before using playback controls
- The refresh token in your
.envfile and Claude Desktop config must match - After making changes to your configuration, restart Claude Desktop
License
MIT
İlgili Sunucular
MCP Doppler Server
Securely access secrets from Doppler's secret management platform using a Doppler API token.
Daraja MCP
Integrate AI applications with Safaricom's Daraja API for seamless interaction with M-Pesa services.
New Relic
Query New Relic logs using NRQL queries.
Waldur MCP server
Integrates Waldur instances with Claude Desktop using the Model Context Protocol (MCP).
Vast Storage MCP Server
An MCP (Model Context Protocol) server that enables LLMs to interact with VAST Data storage APIs. This server exposes VAST Data management endpoints as tools for comprehensive storage infrastructure management and automation.
CData SAP Ariba Source
An MCP server for SAP Ariba Source, powered by CData. Requires the external CData JDBC Driver for SAP Ariba Source.
API-MARKET MCP Server
Exposes API-Market's endpoints as MCP resources, requiring an API key for access.
BICScan
Provides risk scoring and asset information for blockchain addresses, domains, and dApps using the BICScan API.
Spotify
Control Spotify playback and manage your liked songs using LLMs.
Kubernetes
Interact with Kubernetes clusters using natural language to manage and query resources.