MCP Spotify AI Assistant

MCP Spotify AI Assistant

Enables Claude to control Spotify features including playback control, playlist management, search, and accessing user's listening history and preferences through the Spotify API.

Category
Visit Server

README

<div align="center" style="display: flex; align-items: center; justify-content: center; gap: 10px;"> <img src="https://upload.wikimedia.org/wikipedia/commons/8/84/Spotify_icon.svg" width="30" height="30"> <h1>MCP Spotify AI Assistant</h1> </div>

A Model Context Protocol (MCP) server that enables Claude to control Spotify features.

<details> <summary>Contents</summary>

Example Interactions

  • "Can you add the top 5 Coldplay songs to my playlist vibes"
  • "What are my most listened to songs this past month"
  • "Can you shuffle play my top songs"

Tools

Read Operations

  1. searchSpotify

    • Description: Search for tracks, albums, artists, or playlists on Spotify
    • Parameters:
      • query (string): The search term
      • type (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)
  2. getTopItems

    • Description: Get the current user's top artists or tracks based on calculated affinity
    • Parameters:
      • type (string): The type of entity to return. Valid values: artists or tracks
      • time_range (string, optional): Over what time frame the affinities are computed. Long_term ~1 year of data, medium_term is last 6 months, short_term is last 4 weeks
      • limit (number, optional): The maximum number of items to return. Default: 20, minimum: 1, maximum: 50
    • Returns: List of matching items with name, ids, and additional details
    • Example: getTopItems("artists", "short_term", 5)
  3. getMyPlaylists

    • Description: Get a list of the playlists owned or followed by the current Spotify user
    • Parameters:
      • limit (number, optional): The maximum number of items to return. Default: 20, minimum: 1, maximum: 50
    • Returns: List of matching playlists with name, ids, and additional details
    • Example: getMyPlaylists(25)
  4. getPlaylistItems

    • Description: Get full details of the items of a playlist owned by a Spotify user
    • Parameters:
      • playlist_id (string): The Spotify ID of the playlist
      • fields (string, optional): A comma-separated list of the fields to return
      • limit (number, optional): The maximum number of items to return. Default: 20, minimum: 1, maximum: 50
    • Returns: List of matching playlist items with name, ids, and additional details
    • Example: getPlaylistItems("123")
  5. getCurrentUserProfile

    • Description: Get detailed profile information about the current user
    • Parameters: None
    • Returns: Users' display name, id, email, and number of followers
    • Example: getCurrentUserProfile()
  6. getCurrentlyPlaying

    • Description: Get full details of the items of a playlist owned by a Spotify user
    • Parameters: None
    • Returns: Returns the currently playing item's name and accompanying details
    • Example: getCurrentlyPlaying()
  7. getRecentlyPlayedTracks

    • Description: Get full details of the items of a playlist owned by a Spotify user
    • Parameters:
      • limit (number, optional): The maximum number of items to return. Default: 20, minimum: 1, maximum: 50
    • Returns: List recently played tracks' names and additional information
    • Example: getRecentlyPlayedTracks(20)
  8. getUserQueue

    • Description: Get the list of objects that make up the user's queue
    • Parameters: None
    • Returns: The items' names and additional information in the queue
    • Example: getUserQueue()

Write Operations

  1. startPlayback

    • Description: Start a new playback on the active device
    • Parameters:
      • device_id (string, optional): The ID of the device this command is targeting
      • context_uri (number, optional): Spotify URI of the context to play. Valid contexts are albums, artists, and playlists
      • type (number, optional): The type to play. Valid types are track, album, artist, or playlist
      • id (number, optional): The Spotify ID of the item to play
    • Returns: Playback started
    • Example: startPlayback()
  2. resumePlayback

    • Description: Resume playback on the active device
    • Parameters:
      • device_id (string, optional): The ID of the device this command is targeting
    • Returns: Playback resumed
    • Example: resumePlayback()
  3. pausePlayback

    • Description: Pause playback on the active device
    • Parameters:
      • device_id (string, optional): The ID of the device this command is targeting
    • Returns: Playback paused
    • Example: pausePlayback()
  4. addQueue

    • Description: Add an item to be played next in the playback queue
    • Parameters:
      • uri (string): The URI of the item to add to the queue. Must be a track or an episode URI
      • device_id (string, optional): The ID of the device this command is targeting
    • Returns: Added to Queue
    • Example: addQueue("123uri")
  5. togglePlaybackShuffle

    • Description: Toggle shuffle on or off for the user's playback
    • Parameters:
      • state (boolean): True: Shuffle the user's playback. False: Do not shuffle the user's playback
      • device_id (string, optional): The ID of the device this command is targeting
    • Returns: Shuffle changed
    • Example: togglePlaybackShuffle(true)
  6. createPlaylist

    • Description: Create a playlist for a Spotify user
    • Parameters:
      • device_id (string): The user's Spotify user ID
      • name (string): The name for your new playlist
      • public (boolean, optional): The playlist's public/private status
      • description (string, optional): The playlist's description
    • Returns: New playlist created
    • Example: createPlaylist("user123", "new playlist", true, "This is a new playlist")
  7. addItemsToPlaylist

    • Description: Adds one or more items to a user's playlist
    • Parameters:
      • playlist_id (string): The Spotify ID of the playlist
      • uris (string, optional): A comma-separated list of Spotify URIs to add, can be track or episode URIs
      • types (boolean, optional): A comma-separated list of types in the same order as ids
      • ids (string, optional): A comma-separated list of ids in the same order as types
    • Returns: Items added to playlist
    • Example: createPlaylist("playlist123")
  8. changePlaylistDetails

    • Description: Change a playlist's name and public/private state
    • Parameters:
      • playlist_id (string): The Spotify ID of the playlist
      • name (string, optional): The new name for the playlist
      • public (boolean, optional): The playlist's new public/private status
      • description (string, optional): Value for playlist description
    • Returns: Playlist details changed
    • Example: changePlaylistDetails("playlist123", "new new playlist")

Setup

Prerequisites

  • Node.js v16+
  • A Spotify Premium account
  • A registered Spotify Developer application

Installation

git clone https://github.com/iankan04/MCP-Spotify.git
cd mcp-spotify
npm install
npm run build

Creating a Spotify Developer Application

  1. Go to the Spotify Developer Dashboard
  2. Log in with your Spotify account
  3. Click the "Create an App" button
  4. Fill in the app name and description
  5. Accept the Terms of Service and click "Create"
  6. In your new app's dashboard, you'll see your Client ID
  7. Click "Show Client Secret" to reveal your Client Secret
  8. Click "Edit Settings" and add a Redirect URI (e.g., http://localhost:8000/callback)
  9. Save your changes

Spotify API Configuration

Create a .env.local file in the project root (you can copy and modify the provided example):

SPOTIFY_CLIENT_ID='Your client_id'
SPOTIFY_CLIENT_SECRET='Your client_secret'
SPOTIFY_REDIRECT_URI='Your redirect_uri (i.e. http://127.0.0.1:8000/callback'

Make sure your redirect_uri follows the newest Spotify Developer Settings.

Authentication Process

The Spotify API uses OAuth 2.0 for authentication. Follow these steps to authenticate your application:

  1. Open two terminal screens. In one, run
redis-server

In the other, run

npm run auth
  1. The script will generate an authorization URL. Open this URL in your web browser.

  2. You'll be prompted to log in to Spotify and authorize your application.

  3. After authorization, Spotify will redirect you to your specified redirect URI with a code parameter in the URL.

  4. The authentication script will automatically exchange this code for access and refresh tokens.

  5. These tokens will be saved to the Redis database and automatically refreshed when called

Integrating with Claude Desktop

To use your MCP server with Claude Desktop, add it to your Claude configuration:

{
  "mcpServers": {
    "spotify": {
      "command": "node",
      "args": ["MCP-Spotify/build/index.js"]
    }
  }
}

If Claude is running, restart the application, and you should see "spotify" as a new tool

Recommended Servers

playwright-mcp

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.

Official
Featured
TypeScript
Magic Component Platform (MCP)

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.

Official
Featured
Local
TypeScript
Audiense Insights MCP Server

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.

Official
Featured
Local
TypeScript
VeyraX MCP

VeyraX MCP

Single MCP tool to connect all your favorite tools: Gmail, Calendar and 40 more.

Official
Featured
Local
graphlit-mcp-server

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.

Official
Featured
TypeScript
Kagi MCP Server

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.

Official
Featured
Python
E2B

E2B

Using MCP to run code via e2b.

Official
Featured
Neon Database

Neon Database

MCP server for interacting with Neon Management API and databases

Official
Featured
Exa Search

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.

Official
Featured
Qdrant Server

Qdrant Server

This repository is an example of how to create a MCP server for Qdrant, a vector search engine.

Official
Featured