Skip to main content

MCP server for Plex media discovery, search, and library management

Project description

mcp-plex

MCP server for Plex Media Server, focused on media discovery, search, and library management. 13 granular tools designed for use with Claude and other LLM agents.

Prerequisites

Setup

1. Get Your Plex Token

The easiest way to find your Plex token:

  1. Sign in to Plex Web App
  2. Browse to any media item and click Get Info (or ... > Get Info)
  3. Click View XML in the bottom-left
  4. In the URL bar, find the X-Plex-Token= parameter -- that's your token

Alternatively, check the Plex support article for other methods.

2. Install

cd mcp-plex
uv sync

3. Configure Environment Variables

Set these before running the server:

export PLEX_SERVER_URL="http://your-plex-server:32400"
export PLEX_TOKEN="your_plex_token"

4. Test the Connection

uv run mcp-plex-server

The server connects to your Plex server on startup and verifies the token. If the connection fails, check that your server URL and token are correct.

Claude Desktop / Claude Code Configuration

Add to your MCP server config. If installed from PyPI:

{
  "mcpServers": {
    "plex": {
      "command": "uvx",
      "args": ["mcp-plex-server"],
      "env": {
        "PLEX_SERVER_URL": "http://your-plex-server:32400",
        "PLEX_TOKEN": "your_plex_token"
      }
    }
  }
}

Or if running from a local clone:

{
  "mcpServers": {
    "plex": {
      "command": "uv",
      "args": ["--directory", "/path/to/mcp-plex", "run", "mcp-plex-server"],
      "env": {
        "PLEX_SERVER_URL": "http://your-plex-server:32400",
        "PLEX_TOKEN": "your_plex_token"
      }
    }
  }
}

Tools

Discovery

Tool Parameters Description
search_media query, media_type="", limit=20 Search across all libraries. Optional type filter: "movie", "show", "episode", "artist", "album", "track".
get_recently_added limit=20, library_name="" Recently added media, optionally filtered to a library.
get_on_deck limit=10 Continue watching / next episode list.

Library Browsing

Tool Parameters Description
get_libraries (none) List all library sections with types and item counts.
get_library_contents library_name, sort="titleSort", limit=50 Browse a library. Sort by title, date added, year, or rating.
get_media_details rating_key Full details for one item: summary, genres, cast, directors, ratings.
get_library_stats library_name="" Item counts and stats for one or all libraries.

Shows

Tool Parameters Description
get_seasons rating_key List seasons for a TV show.
get_episodes rating_key, season_number=0 List episodes (all or by season).

Collections & Playlists

Tool Parameters Description
get_collections library_name List collections in a library.
get_playlists (none) List all playlists on the server.
get_playlist_items rating_key Get items in a playlist.

Management

Tool Parameters Description
scan_library library_name Trigger a background library scan.

Development

uv run mcp-plex-server              # Run the server
uv run ruff check src/       # Lint
uv run ruff format src/      # Format
uv run pyright src/          # Type check

Pre-commit Hooks

This project uses lefthook for pre-commit checks. Install with brew install lefthook (or see other install methods), then:

lefthook install

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

mcp_plex_server-0.1.4.tar.gz (7.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

mcp_plex_server-0.1.4-py3-none-any.whl (10.0 kB view details)

Uploaded Python 3

File details

Details for the file mcp_plex_server-0.1.4.tar.gz.

File metadata

  • Download URL: mcp_plex_server-0.1.4.tar.gz
  • Upload date:
  • Size: 7.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for mcp_plex_server-0.1.4.tar.gz
Algorithm Hash digest
SHA256 e9f58e313e63f665d4574f2b2a73405aca5e72f71f66cddeafc62c46e11ba6fa
MD5 4deca3ac9ef44604f37dd2696db7948d
BLAKE2b-256 86db3a142fcb2bba8f1f898881b681bc46c4fdc96332c2a200e0f735e8ba7e1b

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_plex_server-0.1.4.tar.gz:

Publisher: release.yml on obrien-matthew/mcp-plex

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file mcp_plex_server-0.1.4-py3-none-any.whl.

File metadata

File hashes

Hashes for mcp_plex_server-0.1.4-py3-none-any.whl
Algorithm Hash digest
SHA256 37e3cfbce7b8ba92eb703b8588a89365e7bb8b9e0f9eaa9272eed9e01f0ee30f
MD5 8de163c320812a4c2a03965fa67d8028
BLAKE2b-256 272e9d81e74efc62bc883875b4c51a76361b260d1c5239714b7b46e867c9c2d0

See more details on using hashes here.

Provenance

The following attestation bundles were made for mcp_plex_server-0.1.4-py3-none-any.whl:

Publisher: release.yml on obrien-matthew/mcp-plex

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page