Skip to main content

MCP server for YouTube — search videos, get transcripts, read comments and more

Project description

mcp-server-youtube

A Rust MCP server for YouTube. Search videos, read channels, browse playlists, fetch comments, and get transcripts — all from your AI assistant.

Why this one?

  • Full YouTube Data API v3 coverage — videos, channels, playlists, comments, categories, trending, search with all filters and sorting options
  • Working transcripts — uses rustypipe (InnerTube API) for reliable subtitle/caption extraction, including auto-generated captions. No API key quota consumed for transcripts
  • Single binary, zero runtime dependencies — written in Rust, starts instantly
  • Typed filter enums — search filters (duration, definition, license, etc.) are exposed as typed enums in the JSON schema, so AI models know exactly which values are valid without guessing

Tools

Videos

Tool Description
videos_getVideo Get video details (snippet, statistics, content details)
videos_searchVideos Search videos with filters for duration, definition, date range, region, captions, license, category, and more. Supports sorting by relevance, date, rating, or view count
videos_getCategories List video categories for a region
videos_getTrending Get trending/most popular videos for a region, optionally filtered by category

Channels

Tool Description
channels_getChannel Get channel info and statistics by channel ID
channels_getByHandle Look up a channel by its handle (e.g. @shura_stone)
channels_search Search for channels by name
channels_listVideos List videos from a channel (by date) with pagination

Playlists

Tool Description
playlists_getPlaylist Get playlist info
playlists_getPlaylistItems List videos in a playlist with pagination

Comments

Tool Description
comments_getComments Get comment threads on a video with pagination

Transcripts & Captions

Tool Description
transcripts_getTranscript Get video transcript/subtitles. Works with both auto-generated and manual captions. Returns plain text by default; set include_timestamps for per-segment timing. Uses rustypipe (InnerTube API) — no API key quota consumed
transcripts_getBatch Fetch transcripts for multiple videos in one call with concurrent fetching. No API key quota consumed
transcripts_listLanguages List available subtitle/caption languages for a video

Setup

Get a YouTube API Key

  1. Go to Google Cloud Console
  2. Create a project (or select an existing one)
  3. Enable the YouTube Data API v3
  4. Create an API key under Credentials

Configuration

Environment Variable CLI Flag Default Description
YOUTUBE_API_KEY --youtube-api-key required YouTube Data API v3 key
YOUTUBE_TRANSCRIPT_LANG --transcript-lang en Default transcript language
MCP_TRANSPORT --transport stdio Transport: stdio or streamable-http
HOST --host 127.0.0.1 HTTP bind address
PORT --port 3000 HTTP port
YOUTUBE_TRANSCRIPT_CONCURRENCY --transcript-concurrency 50 Max concurrent transcript fetches for batch operations

The API key is stored as a SecretString and never appears in logs or debug output.

Usage

Claude Desktop / Claude Code

With uvx:

{
  "mcpServers": {
    "youtube": {
      "command": "uvx",
      "args": ["mcp-server-youtube"],
      "env": {
        "YOUTUBE_API_KEY": "YOUR_API_KEY"
      }
    }
  }
}

With rvx:

{
  "mcpServers": {
    "youtube": {
      "command": "rvx",
      "args": ["mcp-server-youtube"],
      "env": {
        "YOUTUBE_API_KEY": "YOUR_API_KEY"
      }
    }
  }
}
Other installation methods

With Nix:

nix run github:vaporif/mcp-server-youtube

With cargo:

cargo install mcp-server-youtube

From releases:

Download a prebuilt binary from GitHub Releases.

HTTP Transport

YOUTUBE_API_KEY=your_key mcp-server-youtube --transport streamable-http --port 3000

The server listens on http://127.0.0.1:3000/mcp.

Debugging

Enable debug logging to see tool invocations:

RUST_LOG=debug mcp-server-youtube

Development

# Enter dev shell (requires Nix)
nix develop

# Build
cargo build

# Test
cargo test

# Lint
cargo clippy --workspace -- -D warnings

# Format
cargo fmt --all

License

GPL-3.0-or-later

Project details


Download files

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

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distributions

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

mcp_server_youtube-0.1.2-py3-none-win_amd64.whl (7.2 MB view details)

Uploaded Python 3Windows x86-64

mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_x86_64.whl (8.8 MB view details)

Uploaded Python 3musllinux: musl 1.2+ x86-64

mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_aarch64.whl (8.4 MB view details)

Uploaded Python 3musllinux: musl 1.2+ ARM64

mcp_server_youtube-0.1.2-py3-none-macosx_11_0_arm64.whl (8.0 MB view details)

Uploaded Python 3macOS 11.0+ ARM64

mcp_server_youtube-0.1.2-py3-none-macosx_10_12_x86_64.whl (8.3 MB view details)

Uploaded Python 3macOS 10.12+ x86-64

File details

Details for the file mcp_server_youtube-0.1.2-py3-none-win_amd64.whl.

File metadata

File hashes

Hashes for mcp_server_youtube-0.1.2-py3-none-win_amd64.whl
Algorithm Hash digest
SHA256 1dd2f23e8f6cf3cd6b90e303e1ec6011f24d161eab93f1ce1b81d67d970ded01
MD5 6e5d979429bc0cd721f0191da9bab2c8
BLAKE2b-256 29b88d474787eed15ff754f7e22e18a2ac13c981c8725a96d5668334db56469d

See more details on using hashes here.

File details

Details for the file mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_x86_64.whl.

File metadata

File hashes

Hashes for mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_x86_64.whl
Algorithm Hash digest
SHA256 eb76d84d31549ef7c248415e3fa06996d8225e2d4c878ffab10c662d58e1bfd6
MD5 a2e1235126a729d3582977a117ffcb35
BLAKE2b-256 e39e2a0a2fc0f8214483329b14771756070c985bbe171ce07bca4f127aedbad9

See more details on using hashes here.

File details

Details for the file mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_aarch64.whl.

File metadata

File hashes

Hashes for mcp_server_youtube-0.1.2-py3-none-musllinux_1_2_aarch64.whl
Algorithm Hash digest
SHA256 31c9e250392673bfbce3cb87fab387c015d453e3f71b42f659b8a08bcf60f3d8
MD5 97ed4eb87cd1fc6718dca9f955a0f81d
BLAKE2b-256 d1e8139c7f567e87a5965f1fd6e2eb12153940e213817af05d97763554eee4ec

See more details on using hashes here.

File details

Details for the file mcp_server_youtube-0.1.2-py3-none-macosx_11_0_arm64.whl.

File metadata

File hashes

Hashes for mcp_server_youtube-0.1.2-py3-none-macosx_11_0_arm64.whl
Algorithm Hash digest
SHA256 83b7b11c1a8607ffa780ea7c2ec3a729bb3e85055e69878967a99bd4dc8d8e04
MD5 1748124d255aae7e16bb2dc8f020ebba
BLAKE2b-256 e079b8f43bcb09691972f92c8d05a06a8812557a92c74b7b97c08910b36ef8ba

See more details on using hashes here.

File details

Details for the file mcp_server_youtube-0.1.2-py3-none-macosx_10_12_x86_64.whl.

File metadata

File hashes

Hashes for mcp_server_youtube-0.1.2-py3-none-macosx_10_12_x86_64.whl
Algorithm Hash digest
SHA256 cc5d490acef8ef3174f90152c58b30d89d6b1ecada5e0e57f8d0c8274d8f8f8d
MD5 ec588c45b5926bbbbd41109561b6739c
BLAKE2b-256 ba99b7e6264d5da904920cdcd80be1e4749c82e6d2a08e94456a489a037d6a8a

See more details on using hashes here.

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