Requires Google Cloud Console setup to enable YouTube Data API v3 and generate API credentials for accessing YouTube services.
Enables interaction with YouTube content including retrieving video details, transcripts, and statistics; searching videos; managing channels and playlists; and accessing timestamped captions across multiple languages through the YouTube Data API v3.
YouTube MCP Server Enhanced
Enhanced fork of with fixes and improvements.
A Model Context Protocol (MCP) server implementation for YouTube, enabling AI language models to interact with YouTube content through a standardized interface.
What's Enhanced
All video responses include direct YouTube URLs (
urlandvideoIdfields)Shared utilities architecture (single source of truth)
Lazy initialization for better performance
90% code deduplication
Better error handling
Works reliably with Claude Code CLI on Windows
Features
Video Information
Get video details (title, description, duration, etc.) with direct URLs
List channel videos with direct URLs
Get video statistics (views, likes, comments)
Search videos across YouTube with direct URLs
NEW: Enhanced video responses include
urlandvideoIdfields for easy integration
Transcript Management
Retrieve video transcripts
Support for multiple languages
Get timestamped captions
Search within transcripts
Direct Resources & Prompts
Resources:
youtube://transcript/{videoId}: Access transcripts directly via resource URIsyoutube://info: Server information and usage documentation (Smithery discoverable)
Prompts:
summarize-video: Automated workflow to get and summarize video contentanalyze-channel: Comprehensive analysis of a channel's content strategy
Annotations: All tools include capability hints (read-only, idempotent) for better LLM performance
Channel Management
Get channel details
List channel playlists
Get channel statistics
Search within channel content
Playlist Management
List playlist items
Get playlist details
Search within playlists
Get playlist video transcripts
Installation
Local Installation (Recommended)
Clone this repository:
Add to your Claude Desktop or Claude Code configuration:
Claude Desktop (%APPDATA%\Claude\claude_desktop_config.json on Windows):
Claude Code CLI (~/.claude.json):
Configuration
Set the following environment variables:
YOUTUBE_API_KEY: Your YouTube Data API key (required)YOUTUBE_TRANSCRIPT_LANG: Default language for transcripts (optional, defaults to 'en')
YouTube API Setup
Go to Google Cloud Console
Create a new project or select an existing one
Enable the YouTube Data API v3
Create API credentials (API key)
Copy the API key for configuration
Examples
Managing Videos
Managing Channels
Managing Playlists
Enhanced Response Structure
Video Objects with URLs
All video-related responses now include enhanced fields for easier integration:
Example Enhanced Response
Benefits
Easy URL Access: No need to manually construct URLs
Consistent Structure: Both search and individual video responses include URLs
Backward Compatible: All existing YouTube API data is preserved
Type Safe: Full TypeScript support available
Development
Architecture
This project uses a dual-architecture service-based design with the following features:
Shared Utilities: Single source of truth for all MCP server configuration (
src/server-utils.ts)Modern McpServer: Updated from deprecated
Serverclass to the newMcpServerDynamic Version Management: Version automatically read from
package.jsonType-Safe Tool Registration: Uses
zodschemas for input validationES Modules: Full ES module support with proper
.jsextensionsEnhanced Video Responses: All video operations include
urlandvideoIdfieldsLazy Initialization: YouTube API client initialized only when needed
Code Deduplication: Eliminated 90% code duplication through shared utilities (407 → 285 lines)
Project Structure
Key Features
Smithery Optimized: Achieved 90%+ Smithery quality score with comprehensive resources, prompts, and configuration
Shared Utilities Architecture: Eliminated 90% code duplication with single source of truth
Enhanced Video Responses: All video objects include direct YouTube URLs
Flexible Configuration: Optional config via Smithery UI or environment variables
Type-Safe Development: Full TypeScript support with
zodvalidationModern MCP Tools: Uses
registerToolinstead of manual request handlersComprehensive Resources: Discoverable resources and prompts for better LLM integration
Error Handling: Comprehensive error handling with descriptive messages
Contributing
See CONTRIBUTING.md for information about contributing to this repository.
License
This project is licensed under the MIT License - see the LICENSE file for details.
This server cannot be installed