Install
openclaw skills install setlist-mcpLook up concert setlists and live-music history via setlist.fm. Use when the user asks what songs an artist played at a show, their tour setlists, what was performed at a venue or on a date, or wants to find concerts by artist, venue, city, or year. Triggers on phrases like "what did Radiohead play at...", "Phish setlist for...", "shows at Red Rocks", "what songs were played on this tour", or any request about concert setlists, gigs, tours, or live performances. Requires setlist-mcp installed and the setlist server registered (see Setup below).
openclaw skills install setlist-mcpMCP server for setlist.fm — search concert setlists, artists, venues, and tours via natural language. Read-only (setlist.fm has no write API).
Add to .mcp.json in your project or ~/.claude/mcp.json:
{
"mcpServers": {
"setlist": {
"command": "npx",
"args": ["-y", "setlist-mcp"],
"env": {
"SETLIST_API_KEY": "your-api-key-here"
}
}
}
}
git clone https://github.com/chrischall/setlist-mcp
cd setlist-mcp
npm install && npm run build
Then add to .mcp.json:
{
"mcpServers": {
"setlist": {
"command": "node",
"args": ["/path/to/setlist-mcp/dist/index.js"],
"env": {
"SETLIST_API_KEY": "your-api-key-here"
}
}
}
}
Or use a .env file in the project directory with SETLIST_API_KEY=<value>.
Apply for a free API key (non-commercial use) at setlist.fm/settings/api — you'll need a setlist.fm account. The key is sent as the x-api-key header on every request.
Optional: set SETLIST_ACCEPT_LANGUAGE (one of en, es, fr, de, pt, tr, it, pl) to localize city/country names.
All tools are read-only and prefixed setlist_.
setlist_search_artists — find artists by artistName or artistMbid; returns each artist's MusicBrainz ID (mbid).setlist_get_artist — get an artist by mbid.setlist_get_artist_setlists — an artist's setlists (most recent first), by mbid, paginated via p.setlist_search_setlists — search by any mix of artist, venue, city, country, tour, date (ISO yyyy-MM-dd), or year.setlist_get_setlist — a setlist (with full song list) by setlistId.setlist_get_setlist_version — a specific historical version by versionId.setlist_search_venues — find venues by name and/or location.setlist_get_venue — get a venue by venueId.setlist_get_venue_setlists — setlists performed at a venue, paginated via p.setlist_search_cities — find cities by name/location; returns each city's geoId.setlist_get_city — get a city by geoId.setlist_search_countries — list all supported countries and their codes.setlist_get_user — a user's public profile by userId.setlist_get_user_attended — concerts a user marked as attended.setlist_get_user_edited — setlists a user has created or edited.setlist_healthcheck — verify the API key works and the API is reachable.setlist_search_artists (Radiohead → mbid) → setlist_get_artist_setlists (latest) → setlist_get_setlist for the song list.setlist_search_venues (Red Rocks → venueId) → setlist_search_setlists with venueId + year: 2023.setlist_search_setlists with artistName: "Phish", date: "2023-08-07".setlist.fm's API terms bind anyone using this data. When you present setlist.fm results to a user:
url — show it as a real, clickable link to setlist.fm (e.g. "Source: The Beatles setlist on setlist.fm"). The terms require a followable link — never a nofollow. If a particular result has no url, link to https://www.setlist.fm instead.SETLIST_API_KEY and never appears in results.sets.set[]; each set may have an encore number (1 = first encore) and a name (e.g. an acoustic set or a full album).song may carry: tape: true (a pre-recorded intro/outro — not actually performed live), cover (the original artist when it's a cover), with (a guest performer), and info (a note like "acoustic" or "first time live"). Surface these when relevant rather than dropping them.songCount / setCount / hasSongs. A page can exist with no songs logged (hasSongs: false) — skip those without a second get_setlist call.artistName + date can return shows in multiple cities. Add cityName/cityId or venueName/venueId to pin the right one (e.g. TSO on a date plays both Charlotte and Orlando).setlist_search_setlists with venueName (or venueId) + date and no artist.search_* tools return the mbid / setlistId / venueId / geoId you feed into the get_* tools.yyyy-MM-dd — both the date/lastUpdated inputs and every eventDate in the output. (The server translates to/from setlist.fm's native dd-MM-yyyy internally.)p (1-based) to page through large result sets.