Cover image
Try Now
2025-03-14

Un serveur de protocole de contrôle multimédia pour l'intégration YouTube

3 years

Works with Finder

1

Github Watches

0

Github Forks

0

Github Stars

YouTube MCP Server

A Media Control Protocol (MCP) server for YouTube integration that allows you to control YouTube playback across multiple devices.

Features

  • Play, pause, and control YouTube videos from any device
  • Synchronize playback across multiple clients
  • Search YouTube videos directly from the interface
  • Control volume and playback position
  • Real-time updates using WebSockets
  • Simple and intuitive user interface

Installation

  1. Clone this repository:

    git clone https://github.com/Tisik79/youtube-mcp-server.git
    cd youtube-mcp-server
    
  2. Install dependencies:

    npm install
    
  3. Create a .env file based on the .env.example template:

    cp .env.example .env
    
  4. Edit the .env file and add your YouTube API key:

    YOUTUBE_API_KEY=your_youtube_api_key_here
    

    You can obtain a YouTube API key from the Google Cloud Console:

    • Create a new project
    • Enable the YouTube Data API v3
    • Create API credentials (API Key)

Usage

  1. Start the server:

    npm start
    
  2. For development with automatic restart:

    npm run dev
    
  3. Open your browser and navigate to:

    http://localhost:3000
    

How it Works

The YouTube MCP Server provides a central control point for YouTube playback across multiple devices. It uses:

  • Express.js for the HTTP server and API endpoints
  • Socket.io for real-time communication between clients
  • YouTube Data API for searching videos and fetching video information
  • YouTube IFrame API for controlling video playback

When a client connects to the server:

  1. They can search for videos using the search function
  2. Play videos on their device
  3. Control playback (play, pause, seek, volume)
  4. All commands are broadcasted to other connected clients
  5. Clients can sync with the current playback state

API Endpoints

  • GET /api/video/:videoId - Get video information
  • GET /api/search?q=query - Search for YouTube videos
  • GET /api/clients - Get a list of connected clients

WebSocket Events

Client to Server

  • play - Play a video
  • pause - Pause the current video
  • stop - Stop playback
  • seek - Seek to a specific position
  • volume - Change volume
  • mute - Mute/unmute audio
  • updateTimestamp - Update the current playback position

Server to Client

  • playerStateUpdate - Broadcast player state updates to all clients

Project Structure

youtube-mcp-server/
├── public/               # Client-side files
│   ├── index.html        # Main HTML file
│   ├── app.js            # Client-side JavaScript
│   └── styles.css        # CSS styles
├── server.js             # Main server file
├── package.json          # Dependencies and scripts
└── .env                  # Environment variables (create from .env.example)

Requirements

  • Node.js (v14 or higher)
  • npm (v6 or higher)
  • A YouTube Data API key

Customization

You can customize the server by:

  1. Modifying the UI in the public directory
  2. Adding additional API endpoints in server.js
  3. Extending the Socket.io event handlers for more functionality

Troubleshooting

Common issues:

  • API Key Error: Ensure your YouTube API key is correctly set in the .env file
  • Connection Issues: Make sure your firewall allows connections on the specified port
  • Video Playback Issues: Some videos may have embedding disabled by the owner

License

This project is licensed under the MIT License - see the LICENSE file for details.

相关推荐

  • NiKole Maxwell
  • I craft unique cereal names, stories, and ridiculously cute Cereal Baby images.

  • Joshua Armstrong
  • Confidential guide on numerology and astrology, based of GG33 Public information

  • https://suefel.com
  • Latest advice and best practices for custom GPT development.

  • Emmet Halm
  • Converts Figma frames into front-end code for various mobile frameworks.

  • Khalid kalib
  • Write professional emails

  • Elijah Ng Shi Yi
  • Advanced software engineer GPT that excels through nailing the basics.

  • ANGEL LEON
  • A world class elite tech co-founder entrepreneur, expert in software development, entrepreneurship, marketing, coaching style leadership and aligned with ambition for excellence, global market penetration and worldy perspectives.

  • INFOLAB OPERATIONS 2
  • A medical specialist offering assistance grounded in clinical guidelines. Disclaimer: This is intended for research and is NOT safe for clinical use!

  • Yasir Eryilmaz
  • AI scriptwriting assistant for short, engaging video content.

  • J. DE HARO OLLE
  • Especialista en juegos de palabras en varios idiomas.

  • apappascs
  • Découvrez la collection la plus complète et la plus à jour de serveurs MCP sur le marché. Ce référentiel sert de centre centralisé, offrant un vaste catalogue de serveurs MCP open-source et propriétaires, avec des fonctionnalités, des liens de documentation et des contributeurs.

  • ShrimpingIt
  • Manipulation basée sur Micropython I2C de l'exposition GPIO de la série MCP, dérivée d'Adafruit_MCP230XX

  • OffchainLabs
  • Aller la mise en œuvre de la preuve de la participation Ethereum

  • huahuayu
  • Une passerelle API unifiée pour intégrer plusieurs API d'explorateur de blockchain de type étherscan avec la prise en charge du protocole de contexte modèle (MCP) pour les assistants d'IA.

  • deemkeen
  • Contrôlez votre MBOT2 avec un combo d'alimentation: MQTT + MCP + LLM

  • zhaoyunxing92
  • 本项目是一个钉钉 MCP (Protocole de connecteur de message) 服务 , 提供了与钉钉企业应用交互的 API 接口。项目基于 Go 语言开发 , 支持员工信息查询和消息发送等功能。

  • pontusab
  • La communauté du curseur et de la planche à voile, recherchez des règles et des MCP

    Reviews

    4 (1)
    Avatar
    user_ANHhMVNT
    2025-04-16

    I've been using the youtube-mcp-server by Tisik79 and I'm impressed by its seamless integration with YouTube. The server handles requests efficiently and the setup was straightforward. The documentation provided was clear and the community support is excellent. It really streamlines YouTube-related tasks for MCP applications! Highly recommended.