Skip to main content
Glama

YggTorrent MCP Server

README.md7.67 kB
# YggTorrent MCP Server & Wrapper [![uv](https://img.shields.io/endpoint?url=https://raw.githubusercontent.com/astral-sh/uv/main/assets/badge/v0.json)](https://docs.astral.sh/uv/getting-started/installation/) [![Python](https://img.shields.io/badge/python-3.10%2B-blue)](https://www.python.org/downloads/) [![PyPI](https://badge.fury.io/py/ygg-torrent-mcp.svg?cache-control=no-cache)](https://badge.fury.io/py/ygg-torrent-mcp) [![Actions status](https://github.com/philogicae/ygg-torrent-mcp/actions/workflows/python-package-ci.yml/badge.svg?cache-control=no-cache)](https://github.com/philogicae/ygg-torrent-mcp/actions) [![License: MIT](https://img.shields.io/badge/License-MIT-yellow.svg)](https://opensource.org/licenses/MIT) [![Ask DeepWiki](https://deepwiki.com/badge.svg)](https://deepwiki.com/philogicae/ygg-torrent-mcp) This repository provides a Python wrapper for the YggTorrent website and an MCP (Model Context Protocol) server to interact with it programmatically. This allows for easy integration of YggTorrent functionalities into other applications or services. <a href="https://glama.ai/mcp/servers/@philogicae/ygg-torrent-mcp"> <img width="380" height="200" src="https://glama.ai/mcp/servers/@philogicae/ygg-torrent-mcp/badge?cache-control=no-cache" alt="YggTorrent Server MCP server" /> </a> ## Quickstart > [How to use it with MCP Clients](#via-mcp-clients) > [Run it with Docker to bypass common DNS issues](#for-docker) ## Table of Contents - [Features](#features) - [Setup](#setup) - [Prerequisites](#prerequisites) - [Configuration](#configuration) - [Installation](#installation) - [Install from PyPI (Recommended)](#install-from-pypi-recommended) - [For Local Development](#for-local-development) - [For Docker](#for-docker) - [Usage](#usage) - [As Python Wrapper](#as-python-wrapper) - [As MCP Server](#as-mcp-server) - [As FastAPI Server](#as-fastapi-server) - [Via MCP Clients](#via-mcp-clients) - [Example with Windsurf](#example-with-windsurf) - [Contributing](#contributing) - [Changelog](#changelog) - [License](#license) ## Features - API wrapper for [YggAPI](https://yggapi.eu/), an unofficial API for YggTorrent - **Your Ygg passkey is injected locally into the torrent file/magnet link, ensuring it's not exposed externally** - MCP server interface for standardized communication (stdio, sse, streamable-http) - FastAPI server interface for alternative HTTP access (e.g., for direct API calls or testing) - Tools: - Search for torrents on YggTorrent - Get details for a specific torrent - Retrieve magnet links - Retrieve torrent files - Retrieve torrent categories ## Setup ### Prerequisites - An active YggTorrent account and passkey. - Python 3.10+ (required for PyPI install). - [`uv`](https://github.com/astral-sh/uv) (for local development) - Docker and Docker Compose (for Docker setup) ### Configuration This application requires your YggTorrent passkey to interact with the API. 1. **Find your Passkey**: On the YggTorrent website, navigate to `Mon compte` -> `PASSKEY` field. 2. **Set Environment Variable**: The application reads the passkey from the `YGG_PASSKEY` environment variable. The recommended way to set this is by creating a `.env` file in your project's root directory. The application will load it automatically. ### Installation Choose one of the following installation methods. #### Install from PyPI (Recommended) This method is best for using the package as a library or running the server without modifying the code. 1. Install the package from PyPI: ```bash pip install ygg-torrent-mcp ``` 2. Create a `.env` file in the directory where you'll run the application and add your passkey: ```env YGG_PASSKEY=your_passkey_here ``` 3. Run the MCP server (default: stdio): ```bash python -m ygg_torrent ``` #### For Local Development This method is for contributors who want to modify the source code. Using [`uv`](https://github.com/astral-sh/uv): 1. Clone the repository: ```bash git clone https://github.com/philogicae/ygg-torrent-mcp.git cd ygg-torrent-mcp ``` 2. Install dependencies using `uv`: ```bash uv sync --locked ``` 3. Create your configuration file by copying the example and add your passkey: ```bash cp .env.example .env ``` 4. Run the MCP server (default: stdio): ```bash uv run -m ygg_torrent ``` #### For Docker This method uses Docker to run the server in a container. compose.yaml is configured to bypass DNS issues (using [quad9](https://quad9.net/) DNS). 1. Clone the repository (if you haven't already): ```bash git clone https://github.com/philogicae/ygg-torrent-mcp.git cd ygg-torrent-mcp ``` 2. Create your configuration file by copying the example and add your passkey: ```bash cp .env.example .env ``` 3. Build and run the container using Docker Compose (default port: 8000): ```bash docker compose up --build -d ``` 4. Access container logs: ```bash docker logs ygg-torrent-mcp -f ``` ## Usage ### As Python Wrapper ```python from ygg_torrent import ygg_api results = ygg_api.search_torrents('...') for torrent in results: print(f"{torrent.filename} | {torrent.size} | {torrent.seeders} SE | {torrent.leechers} LE | {torrent.downloads} DL | {torrent.date}") ``` ### As MCP Server ```python from ygg_torrent import ygg_mcp ygg_mcp.run(transport="sse") ``` ### As FastAPI Server This project also includes a FastAPI server as an alternative way to interact with the YggTorrent functionalities via a standard HTTP API. This can be useful for direct API calls, integration with other web services, or for testing purposes. **Running the FastAPI Server:** ```bash # With Python python -m ygg_torrent --mode fastapi # With uv uv run -m ygg_torrent --mode fastapi ``` - `--host <host>`: Default: `0.0.0.0`. - `--port <port>`: Default: `8000`. - `--reload`: Enables auto-reloading when code changes (useful for development). - `--workers <workers>`: Default: `1`. The FastAPI server will then be accessible at `http://<host>:<port>` **Available Endpoints:** The FastAPI server exposes similar functionalities to the MCP server. Key endpoints include: - `/`: A simple health check endpoint. Returns `{"status": "ok"}`. - `/docs`: Interactive API documentation (Swagger UI). - `/redoc`: Alternative API documentation (ReDoc). Environment variables (like `YGG_PASSKEY`) are configured the same way as for the MCP server (via an `.env` file in the project root). ### Via MCP Clients Usable with any MCP-compatible client. Available tools: - `search_torrents`: Search for torrents. - `get_torrent_details`: Get details of a specific torrent. - `get_magnet_link`: Get the magnet link for a torrent. - `download_torrent_file`: Download the .torrent file for a torrent. #### Example with Windsurf Configuration: ```json { "mcpServers": { ... # with stdio (only requires uv installed) "ygg-torrent-mcp": { "command": "uvx", "args": ["ygg-torrent-mcp"], "env": { "YGG_PASSKEY": "your_passkey_here" } } # with sse transport (requires installation) "ygg-torrent-mcp": { "serverUrl": "http://127.0.0.1:8000/sse" } # with streamable-http transport (requires installation) "ygg-torrent-mcp": { "serverUrl": "http://127.0.0.1:8000/mcp" # not yet supported by every client } ... } } ``` ## Changelog See [CHANGELOG.md](CHANGELOG.md) for a history of changes to this project. ## Contributing Contributions are welcome! Please open an issue or submit a pull request. ## License This project is licensed under the MIT License - see the [LICENSE](LICENSE) file for details.

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/philogicae/ygg-torrent-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server