Skip to main content
Glama
igorgarbuz

Spotify MCP Node Server

by igorgarbuz

addTracksToPlaylist

Add multiple songs to a Spotify playlist using track IDs. Specify playlist ID and position for insertion.

Instructions

Add tracks to a Spotify playlist

Input Schema

TableJSON Schema
NameRequiredDescriptionDefault
playlistIdYesThe Spotify ID of the playlist
trackIdsYesArray of Spotify track IDs to add
positionNoPosition to insert the tracks (0-based index)

Implementation Reference

  • The handler function that adds tracks to a Spotify playlist by converting track IDs to URIs and calling the Spotify API's addItemsToPlaylist method.
      handler: async (args, extra: SpotifyHandlerExtra) => {
        const { playlistId, trackIds, position } = args;
    
        if (trackIds.length === 0) {
          return {
            content: [
              {
                type: 'text',
                text: 'Error: No track IDs provided',
              },
            ],
          };
        }
    
        try {
          const trackUris = trackIds.map((id) => `spotify:track:${id}`);
    
          await handleSpotifyRequest(async (spotifyApi) => {
            await spotifyApi.playlists.addItemsToPlaylist(
              playlistId,
              trackUris,
              position,
            );
          });
    
          return {
            content: [
              {
                type: 'text',
                text: `Successfully added ${trackIds.length} track${
                  trackIds.length === 1 ? '' : 's'
                } to playlist (ID: ${playlistId})`,
              },
            ],
          };
        } catch (error) {
          return {
            content: [
              {
                type: 'text',
                text: `Error adding tracks to playlist: ${
                  error instanceof Error ? error.message : String(error)
                }`,
              },
            ],
          };
        }
      },
    };
  • Zod schema defining the input parameters: playlistId (string), trackIds (array of strings), position (optional nonnegative number).
    schema: {
      playlistId: z.string().describe('The Spotify ID of the playlist'),
      trackIds: z.array(z.string()).describe('Array of Spotify track IDs to add'),
      position: z
        .number()
        .nonnegative()
        .optional()
        .describe('Position to insert the tracks (0-based index)'),
    },
  • src/write.ts:238-243 (registration)
    Exports the addTracksToPlaylist tool as part of the writeTools array.
    export const writeTools = [
      addToQueue,
      addTracksToPlaylist,
      createPlaylist,
      removeTracksFromPlaylist,
    ];
  • src/index.ts:12-14 (registration)
    Registers all tools from playTools, readTools, and writeTools (including addTracksToPlaylist) with the MCP server.
    [...playTools, ...readTools, ...writeTools].forEach((tool) => {
      server.tool(tool.name, tool.description, tool.schema, tool.handler);
    });
  • Uses the handleSpotifyRequest helper (imported from utils.ts) to perform the API call securely.
    await handleSpotifyRequest(async (spotifyApi) => {
      await spotifyApi.playlists.addItemsToPlaylist(
        playlistId,
        trackUris,
        position,
      );
    });

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/igorgarbuz/spotify-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server