marcelmarais/spotify-mcp-server
If you are the rightful owner of spotify-mcp-server and would like to certify it and/or have it hosted online, please leave a comment on the right or send an email to dayong@mcphub.com.
A lightweight Model Context Protocol (MCP) server that enables AI assistants like Cursor & Claude to control Spotify playback and manage playlists.
Spotify MCP Server
A lightweight Model Context Protocol (MCP) server that enables AI assistants like Cursor & Claude to control Spotify playback and manage playlists.
Contents
Example Interactions
- "Play Elvis's first song"
- "Create a Taylor Swift / Slipknot fusion playlist"
- "Copy all the techno tracks from my workout playlist to my work playlist"
- "Turn the volume down a bit"
Tools
Read Operations
-
searchSpotify
- Description: Search for tracks, albums, artists, or playlists on Spotify
- Parameters:
query(string): The search termtype(string): Type of item to search for (track, album, artist, playlist)limit(number, optional): Maximum number of results to return (10-50)
- Returns: List of matching items with their IDs, names, and additional details
- Example:
searchSpotify("bohemian rhapsody", "track", 20)
-
getNowPlaying
- Description: Get information about the currently playing track on Spotify, including device and volume info
- Parameters: None
- Returns: Object containing track name, artist, album, playback progress, duration, playback state, device info, volume, and shuffle/repeat status
- Example:
getNowPlaying()
-
getMyPlaylists
- Description: Get a list of the current user's playlists on Spotify
- Parameters:
limit(number, optional): Maximum number of playlists to return (default: 20)offset(number, optional): Index of the first playlist to return (default: 0)
- Returns: Array of playlists with their IDs, names, track counts, and public status
- Example:
getMyPlaylists(10, 0)
-
getPlaylistTracks
- Description: Get a list of tracks in a specific Spotify playlist
- Parameters:
playlistId(string): The Spotify ID of the playlistlimit(number, optional): Maximum number of tracks to return (default: 100)offset(number, optional): Index of the first track to return (default: 0)
- Returns: Array of tracks with their IDs, names, artists, album, duration, and added date
- Example:
getPlaylistTracks("37i9dQZEVXcJZyENOWUFo7")
-
getRecentlyPlayed
- Description: Retrieves a list of recently played tracks from Spotify.
- Parameters:
limit(number, optional): A number specifying the maximum number of tracks to return.
- Returns: If tracks are found it returns a formatted list of recently played tracks else a message stating: "You don't have any recently played tracks on Spotify".
- Example:
getRecentlyPlayed({ limit: 10 })
-
getUsersSavedTracks
- Description: Get a list of tracks saved in the user's "Liked Songs" library
- Parameters:
limit(number, optional): Maximum number of tracks to return (1-50, default: 50)offset(number, optional): Offset for pagination (0-based index, default: 0)
- Returns: Formatted list of saved tracks with track names, artists, duration, track IDs, and when they were added to Liked Songs. Shows pagination info (e.g., "1-20 of 150").
- Example:
getUsersSavedTracks({ limit: 20, offset: 0 })
-
getQueue
- Description: Get the currently playing track and upcoming items in the Spotify queue
- Parameters:
limit(number, optional): Maximum number of upcoming items to show (1-50, default: 10)
- Returns: Currently playing track and list of upcoming tracks in the queue
- Example:
getQueue({ limit: 20 })
-
getAvailableDevices
- Description: Get information about the user's available Spotify Connect devices
- Parameters: None
- Returns: List of available devices with name, type, active status, volume, and device ID
- Example:
getAvailableDevices()
Play / Create Operations
-
playMusic
- Description: Start playing a track, album, artist, or playlist on Spotify
- Parameters:
uri(string, optional): Spotify URI of the item to play (overrides type and id)type(string, optional): Type of item to play (track, album, artist, playlist)id(string, optional): Spotify ID of the item to playdeviceId(string, optional): ID of the device to play on
- Returns: Success status
- Example:
playMusic({ uri: "spotify:track:6rqhFgbbKwnb9MLmUQDhG6" }) - Alternative:
playMusic({ type: "track", id: "6rqhFgbbKwnb9MLmUQDhG6" })
-
pausePlayback
- Description: Pause the currently playing track on Spotify
- Parameters:
deviceId(string, optional): ID of the device to pause
- Returns: Success status
- Example:
pausePlayback()
-
resumePlayback
- Description: Resume Spotify playback on the active device
- Parameters:
deviceId(string, optional): ID of the device to resume playback on
- Returns: Success status
- Example:
resumePlayback()
-
skipToNext
- Description: Skip to the next track in the current playback queue
- Parameters:
deviceId(string, optional): ID of the device
- Returns: Success status
- Example:
skipToNext()
-
skipToPrevious
- Description: Skip to the previous track in the current playback queue
- Parameters:
deviceId(string, optional): ID of the device
- Returns: Success status
- Example:
skipToPrevious()
-
createPlaylist
- Description: Create a new playlist on Spotify
- Parameters:
name(string): Name for the new playlistdescription(string, optional): Description for the playlistpublic(boolean, optional): Whether the playlist should be public (default: false)
- Returns: Object with the new playlist's ID and URL
- Example:
createPlaylist({ name: "Workout Mix", description: "Songs to get pumped up", public: false })
-
addTracksToPlaylist
- Description: Add tracks to an existing Spotify playlist
- Parameters:
playlistId(string): ID of the playlisttrackUris(array): Array of track URIs or IDs to addposition(number, optional): Position to insert tracks
- Returns: Success status and snapshot ID
- Example:
addTracksToPlaylist({ playlistId: "3cEYpjA9oz9GiPac4AsH4n", trackUris: ["spotify:track:4iV5W9uYEdYUVa79Axb7Rh"] })
-
addToQueue
- Description: Adds a track, album, artist or playlist to the current playback queue
- Parameters:
uri(string, optional): Spotify URI of the item to add to queue (overrides type and id)type(string, optional): Type of item to queue (track, album, artist, playlist)id(string, optional): Spotify ID of the item to queuedeviceId(string, optional): ID of the device to queue on
- Returns: Success status
- Example:
addToQueue({ uri: "spotify:track:6rqhFgbbKwnb9MLmUQDhG6" }) - Alternative:
addToQueue({ type: "track", id: "6rqhFgbbKwnb9MLmUQDhG6" })
-
setVolume
- Description: Set the playback volume to a specific percentage (requires Spotify Premium)
- Parameters:
volumePercent(number): The volume to set (0-100)deviceId(string, optional): ID of the device to set volume on
- Returns: Success status with the new volume level
- Example:
setVolume({ volumePercent: 50 })
-
adjustVolume
- Description: Adjust the playback volume up or down by a relative amount (requires Spotify Premium)
- Parameters:
adjustment(number): The amount to adjust volume by (-100 to 100). Positive values increase volume, negative values decrease it.deviceId(string, optional): ID of the device to adjust volume on
- Returns: Success status showing the volume change (e.g., "Volume increased from 50% to 60%")
- Example:
adjustVolume({ adjustment: 10 })(increase by 10%) - Example:
adjustVolume({ adjustment: -20 })(decrease by 20%)
Album Operations
-
getAlbums
- Description: Get detailed information about one or more albums by their Spotify IDs
- Parameters:
albumIds(string|array): A single album ID or array of album IDs (max 20)
- Returns: Album details including name, artists, release date, type, total tracks, and ID. For single album returns detailed view, for multiple albums returns summary list.
- Example:
getAlbums("4aawyAB9vmqN3uQ7FjRGTy")orgetAlbums(["4aawyAB9vmqN3uQ7FjRGTy", "1DFixLWuPkv3KT3TnV35m3"])
-
getAlbumTracks
- Description: Get tracks from a specific album with pagination support
- Parameters:
albumId(string): The Spotify ID of the albumlimit(number, optional): Maximum number of tracks to return (1-50)offset(number, optional): Offset for pagination (0-based index)
- Returns: List of tracks from the album with track names, artists, duration, and IDs. Shows pagination info.
- Example:
getAlbumTracks("4aawyAB9vmqN3uQ7FjRGTy", 10, 0)
-
saveOrRemoveAlbumForUser
- Description: Save or remove albums from the user's "Your Music" library
- Parameters:
albumIds(array): Array of Spotify album IDs (max 20)action(string): Action to perform: "save" or "remove"
- Returns: Success status with confirmation message
- Example:
saveOrRemoveAlbumForUser(["4aawyAB9vmqN3uQ7FjRGTy"], "save")
-
checkUsersSavedAlbums
- Description: Check if albums are saved in the user's "Your Music" library
- Parameters:
albumIds(array): Array of Spotify album IDs to check (max 20)
- Returns: Status of each album (saved or not saved)
- Example:
checkUsersSavedAlbums(["4aawyAB9vmqN3uQ7FjRGTy", "1DFixLWuPkv3KT3TnV35m3"])
Setup
Prerequisites
- Node.js v16+
- A Spotify Premium account
- A registered Spotify Developer application
Installation
git clone https://github.com/marcelmarais/spotify-mcp-server.git
cd spotify-mcp-server
npm install
npm run build
Creating a Spotify Developer Application
- Go to the Spotify Developer Dashboard
- Log in with your Spotify account
- Click the "Create an App" button
- Fill in the app name and description
- Accept the Terms of Service and click "Create"
- In your new app's dashboard, you'll see your Client ID
- Click "Show Client Secret" to reveal your Client Secret
- Click "Edit Settings" and add a Redirect URI (e.g.,
http://127.0.0.1:8888/callback) - Save your changes
Spotify API Configuration
Create a spotify-config.json file in the project root (you can copy and modify the provided example):
# Copy the example config file
cp spotify-config.example.json spotify-config.json
Then edit the file with your credentials:
{
"clientId": "your-client-id",
"clientSecret": "your-client-secret",
"redirectUri": "http://127.0.0.1:8888/callback"
}
Authentication Process
The Spotify API uses OAuth 2.0 for authentication. Follow these steps to authenticate your application:
- Run the authentication script:
npm run auth
-
The script will generate an authorization URL. Open this URL in your web browser.
-
You'll be prompted to log in to Spotify and authorize your application.
-
After authorization, Spotify will redirect you to your specified redirect URI with a code parameter in the URL.
-
The authentication script will automatically exchange this code for access and refresh tokens.
-
These tokens will be saved to your
spotify-config.jsonfile, which will now look something like:
{
"clientId": "your-client-id",
"clientSecret": "your-client-secret",
"redirectUri": "http://localhost:8888/callback",
"accessToken": "BQAi9Pn...kKQ",
"refreshToken": "AQDQcj...7w",
"expiresAt": 1677889354671
}
- The server will automatically refresh the access token when needed, using the refresh token.
Integrating with Claude Desktop, Cursor, and VsCode Via Cline model extension
To use your MCP server with Claude Desktop, add it to your Claude configuration:
{
"mcpServers": {
"spotify": {
"command": "node",
"args": ["spotify-mcp-server/build/index.js"]
}
}
}
For Cursor, go to the MCP tab in Cursor Settings (command + shift + J). Add a server with this command:
node path/to/spotify-mcp-server/build/index.js
To set up your MCP correctly with Cline ensure you have the following file configuration set cline_mcp_settings.json:
{
"mcpServers": {
"spotify": {
"command": "node",
"args": ["~/../spotify-mcp-server/build/index.js"],
"autoApprove": ["getListeningHistory", "getNowPlaying"]
}
}
}
You can add additional tools to the auto approval array to run the tools without intervention.