Trakt MCP Server

Trakt MCP Server

A comprehensive MCP server with 36 tools for tracking TV shows and movies, managing watchlists, and syncing ratings with Trakt.tv. It enables users to search extensive databases, check into current viewings, and receive personalized recommendations through natural language commands.

Category
Visit Server

README

████████╗██████╗  █████╗ ██╗  ██╗████████╗
╚══██╔══╝██╔══██╗██╔══██╗██║ ██╔╝╚══██╔══╝
   ██║   ██████╔╝███████║█████╔╝    ██║
   ██║   ██╔══██╗██╔══██║██╔═██╗    ██║
   ██║   ██║  ██║██║  ██║██║  ██╗   ██║
   ╚═╝   ╚═╝  ╚═╝╚═╝  ╚═╝╚═╝  ╚═╝  ╚═╝

<div align="center">

TypeScript Node.js MCP npm License

A Trakt MCP server with 36 tools for TV show and movie tracking, sync, ratings, watchlists, and checkins.

FeaturesQuick StartInstallationToolsDevelopment

</div>


Features

  • 🔍 Search movies, shows, episodes, and people across Trakt's database
  • 🎬 Movies — details, trending, popular, related, ratings, and cast
  • 📺 Shows & Episodes — full show info, seasons, episode details, cast
  • 👤 People — actor/director profiles and filmographies
  • 📅 Calendar — your personalised upcoming episodes and movies
  • 🕐 History — view, add, and remove watch history entries
  • Ratings — get, add, and remove ratings for movies, shows, and episodes
  • 📋 Watchlist — full CRUD on your movie/show watchlist
  • Checkin — check into what you're watching right now
  • 🤖 Recommendations — personalised movie and show suggestions

Quick Start

1. Create a Trakt API app

Go to trakt.tv/oauth/applications/new and create a new app. You only need to fill in the name — leave the redirect URI as urn:ietf:wg:oauth:2.0:oob. Copy your Client ID and Client Secret.

2. Run setup

npx @kud/mcp-trakt setup

This launches the device OAuth flow: paste your Client ID and Secret when prompted, visit the URL shown, enter the code, and your credentials are saved to ~/.config/trakt.json. You never touch them again.

3. Add to your MCP client

No credentials needed in the config — the server reads them from ~/.config/trakt.json automatically.

{
  "mcpServers": {
    "Trakt": {
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

Installation

Run npx @kud/mcp-trakt setup first — this saves your credentials to ~/.config/trakt.json so no tokens are needed in any config file.

<details> <summary><strong>Claude Code CLI</strong></summary>

claude mcp add trakt npx -- -y @kud/mcp-trakt@latest

</details>

<details> <summary><strong>Claude Desktop — macOS</strong></summary>

Edit ~/Library/Application Support/Claude/claude_desktop_config.json:

{
  "mcpServers": {
    "Trakt": {
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

Restart Claude Desktop after saving.

</details>

<details> <summary><strong>Claude Desktop — Windows</strong></summary>

Edit %APPDATA%\Claude\claude_desktop_config.json:

{
  "mcpServers": {
    "Trakt": {
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

</details>

<details> <summary><strong>Cursor</strong></summary>

Add to .cursor/mcp.json in your project root:

{
  "mcpServers": {
    "Trakt": {
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

</details>

<details> <summary><strong>Windsurf</strong></summary>

Edit ~/.codeium/windsurf/mcp_config.json:

{
  "mcpServers": {
    "Trakt": {
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

</details>

<details> <summary><strong>VSCode</strong></summary>

Add to .vscode/mcp.json:

{
  "servers": {
    "Trakt": {
      "type": "stdio",
      "command": "npx",
      "args": ["-y", "@kud/mcp-trakt@latest"]
    }
  }
}

</details>


Available Tools

Search

Tool Description
search Search for movies, shows, episodes, people, or lists

Movies

Tool Description
get_movie Get detailed information about a movie
get_trending_movies Movies currently being watched across Trakt
get_popular_movies Most popular movies on Trakt
get_movie_ratings Community rating distribution for a movie
get_movie_related Movies related to a given movie
get_movie_people Cast and crew for a movie

Shows

Tool Description
get_show Get detailed information about a TV show
get_trending_shows Shows currently being watched across Trakt
get_popular_shows Most popular TV shows on Trakt
get_show_ratings Community rating distribution for a show
get_show_seasons All seasons, optionally with full episode details
get_show_people Cast and crew for a show

Episodes

Tool Description
get_season_episodes All episodes in a specific season
get_episode Full details for a specific episode

People

Tool Description
get_person Actor or director profile
get_person_credits Movie or show credits for a person

Calendar

Tool Description
get_my_show_calendar My upcoming episodes (personalised)
get_my_movie_calendar My upcoming movies (personalised)
get_all_show_calendar All shows premiering and airing across Trakt

History

Tool Description
get_history Watch history for the authenticated user
add_to_history Mark movies or episodes as watched
remove_from_history Remove entries from watch history

Ratings

Tool Description
get_ratings Ratings given by the authenticated user
add_rating Rate movies, shows, seasons, or episodes (1–10)
remove_rating Remove ratings from items

Watchlist

Tool Description
get_watchlist View the authenticated user's watchlist
add_to_watchlist Add movies, shows, or episodes
remove_from_watchlist Remove items from the watchlist

Checkin

Tool Description
checkin Check in to a movie or episode you're watching now
delete_checkin Cancel the current active checkin

Recommendations

Tool Description
get_movie_recommendations Personalised movie recommendations
get_show_recommendations Personalised TV show recommendations

User

Tool Description
get_user_profile Profile info for any user (or yourself)
get_user_stats Watch statistics for a user
get_user_watching What a user is currently watching

Total: 36 Tools


Example Conversations

"What movies are trending on Trakt right now?"

"Search for Breaking Bad and give me its full details."

"What episodes of Severance do I have coming up this week?"

"Mark that I just watched Dune: Part Two — give it a 9."

"Add The Penguin to my watchlist."

"Check me in to S02E01 of The Bear."

"What have I watched this month?"

"Give me 10 personalised movie recommendations."

"Who plays the lead in Succession and what else have they been in?"

"What are my all-time watch stats?"


Development

Project Structure

mcp-trakt/
├── src/
│   └── index.ts       # Full server — all 36 tools
├── dist/              # Compiled output (git-ignored)
├── setup.js           # OAuth device flow setup script
├── package.json
└── tsconfig.json

Scripts

Script Purpose
npm run setup Run OAuth device flow and save credentials
npm run build Compile TypeScript to dist/
npm run build:watch Watch mode compilation
npm run dev Run directly with tsx (no build needed)
npm run inspect Open MCP Inspector against built output
npm run inspect:dev Open MCP Inspector with live tsx
npm run typecheck Type-check without emitting
npm run clean Remove dist/

Dev Workflow

# Run without building
npm run dev

# Inspect all tools interactively in the browser
npm run inspect:dev

Authentication

Trakt uses OAuth 2.0. The npm run setup script handles the full device flow — you never manage tokens manually.

How it works

  1. Run npm run setup
  2. Enter your Client ID and Client Secret from trakt.tv/oauth/applications
  3. Visit the URL shown (e.g. https://trakt.tv/activate), enter the displayed code
  4. Tokens are saved to ~/.config/trakt.json — the server reads them automatically on every start

To refresh an expired token, just run npm run setup again.

Test your credentials

curl -s https://api.trakt.tv/users/me \
  -H "trakt-api-version: 2" \
  -H "trakt-api-key: YOUR_CLIENT_ID" \
  -H "Authorization: Bearer YOUR_ACCESS_TOKEN" | jq .username

Troubleshooting

Server not showing in Claude Desktop

  • Check JSON syntax in claude_desktop_config.json
  • Verify the path to dist/index.js is absolute and the file exists
  • Run npm run build if dist/ is missing

401 / auth errors

  • Access tokens expire after 3 months — regenerate via the OAuth device flow
  • Make sure TRAKT_CLIENT_ID matches the app your access token was issued for
  • Check logs: Claude Desktop → Help → Show Logs

No data returned for personal endpoints (history, watchlist, etc.)

  • These require a valid TRAKT_ACCESS_TOKEN — public/read-only client_id alone is not enough
  • Make sure the token was granted the correct scopes during the OAuth flow

Security Best Practices

  • Never commit ~/.config/trakt.json or any file containing tokens to source control
  • ~/.config/trakt.json is user-scoped and never read by MCP client configs
  • Rotate your access token if it is accidentally exposed — run npm run setup again
  • Trakt access tokens expire after 90 days — re-run npm run setup to refresh
  • Treat your access token like a password: full account access with history/checkin write rights

Tech Stack

Runtime Node.js ≥ 20
Language TypeScript 5.x
Target ES2023
Protocol Model Context Protocol (MCP) SDK 1.x
HTTP Client Native fetch
Module System ESM ("type": "module")

Contributing

Issues and PRs welcome at github.com/kud/mcp-trakt.

License

MIT © kud

Acknowledgments

Built on the Model Context Protocol SDK by Anthropic. API provided by Trakt.

Support

Open an issue at github.com/kud/mcp-trakt/issues.


<div align="center">

Made with ❤️ for TV and movie fans

⭐ Star this repo if it's useful • ↑ Back to top

</div>

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