soundcloud-mcp-server

soundcloud-mcp-server

An MCP server that gives Claude access to your SoundCloud library, allowing you to manage playlists and tracks through natural language.

Category
Visit Server

README

SoundCloud MCP Server

An MCP (Model Context Protocol) server that gives Claude access to your SoundCloud library. Connect it to Claude Web and manage your playlists and tracks through natural language.

Features

Tool Description
get_my_playlists List all your playlists
get_playlist Get a playlist with its full tracklist
create_playlist Create a new playlist
update_playlist Rename, redescribe, or reorder a playlist
add_tracks_to_playlist Append tracks to an existing playlist
remove_track_from_playlist Remove a track from a playlist
delete_playlist Delete a playlist permanently
search_tracks Search SoundCloud tracks by keyword and genre
get_track Get details for a specific track
get_stream_url Get a direct MP3 stream URL for a track (personal/authorized listening only — see Usage notes)

Prerequisites

  • A SoundCloud developer app — register at soundcloud.com/you/apps
  • A publicly reachable server with HTTPS (required by Claude Web)

Setup

1. Clone and install

git clone https://github.com/marcellkehmstedt/soundcloud-mcp-server
cd soundcloud-mcp-server
npm install
npm run build

2. Configure environment variables

cp .env.example .env
Variable Required Description
PUBLIC_URL Yes Public HTTPS URL of your server, e.g. https://mcp.example.com
SOUNDCLOUD_REDIRECT_URI Yes Must be {PUBLIC_URL}/soundcloud/callback
PORT No Port to listen on (default: 3000)
MCP_DEBUG No Set to true to enable verbose debug logging to stderr
UI_BRAND_COLOR No Accent color of the login UI (hex #rrggbb, default #3b82f6)

3. Run

Directly:

npm start

With Docker Compose:

# Edit PUBLIC_URL and SOUNDCLOUD_REDIRECT_URI in docker-compose.yml first
docker compose up -d

Connect to Claude Web

  1. Open Claude Web → Settings → Integrations → Add integration
  2. Enter your server URL:
    https://your-domain.com/mcp
    
  3. Claude will redirect you to a login form — enter your SoundCloud Client ID and Client Secret from soundcloud.com/you/apps
  4. Authorize the app on SoundCloud
  5. You're connected — Claude can now use your SoundCloud tools

Your SoundCloud credentials are never stored on the server. The access token is issued to Claude directly and used only for API calls.

Endpoints

Endpoint Description
GET /health Health check
POST /mcp MCP Streamable HTTP endpoint (used by Claude)
GET /diagnostic Test your SoundCloud token directly (see below)
GET /.well-known/oauth-authorization-server OAuth metadata (RFC 8414)
GET /.well-known/oauth-protected-resource Resource metadata (RFC 9728)

Diagnostic endpoint

If a tool is not returning results, use this to verify your SoundCloud token works:

curl https://your-domain.com/diagnostic \
  -H "Authorization: Bearer <your-soundcloud-access-token>"

Returns the HTTP status of GET /me and GET /me/playlists so you can tell immediately whether the issue is in the token, the API, or the server.

Debug logging

Enable with MCP_DEBUG=true. Logs go to stderr and cover:

  • MCP session lifecycle (create / close)
  • Every JSON-RPC method call and parameters
  • SoundCloud API requests: method, URL, status, latency, body-read timing
[MCP] new session abc123
[MCP] → tools/call {"name":"get_my_playlists","arguments":{}}
[MCP] session abc123 — POST
[SC] → GET https://api.soundcloud.com/me/playlists (token: 47 chars)
[SC] ← 200 GET https://api.soundcloud.com/me/playlists — 312ms
[SC] reading body (content-length: 18432)
[SC] body parsed

Architecture

Claude Web
    │  OAuth 2.0 (RFC 6749 + PKCE)
    │  MCP Streamable HTTP (2025-03-26)
    ▼
Express server
    ├── /.well-known/*     OAuth discovery (RFC 8414 + RFC 9728)
    ├── /register          Dynamic Client Registration (RFC 7591)
    ├── /oauth/authorize   Login form → SoundCloud OAuth redirect
    ├── /soundcloud/callback  Token exchange
    ├── /oauth/token       Issue / refresh MCP access tokens
    └── /mcp               MCP tools (StreamableHTTPServerTransport)
            │
            ▼
    SoundCloud API (api.soundcloud.com)

Token flow: Claude Web completes a PKCE OAuth flow against this server. The server exchanges Claude's auth code for a SoundCloud access token and passes it straight through as the MCP Bearer token. Each MCP session uses the token to call the SoundCloud API on Claude's behalf.

Usage notes

  • get_stream_url returns the direct MP3 URL that the SoundCloud API exposes for an authorized user. It is intended for personal, authorized listening only. Do not use it to re-host, re-distribute, or publicly broadcast tracks. Each user is responsible for complying with the SoundCloud API Terms of Use.
  • Each deployer registers their own SoundCloud developer app and supplies their own client_id / client_secret via the login form — the server never stores these credentials at rest.

Disclaimer

This is an unofficial integration. This project is not affiliated with, endorsed by, or sponsored by SoundCloud Limited. "SoundCloud" is a trademark of SoundCloud Limited, used here solely in a descriptive sense to refer to the third-party API this software interacts with.

License

This project is licensed under the GNU Affero General Public License v3.0 or later (AGPL-3.0-or-later).

See the LICENSE file for the full license text.

Copyright (C) 2026 Marcell Kehmstedt.

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