Torrent Search MCP Server

Torrent Search MCP Server

A Python MCP server that allows programmatic interaction to find torrents programmatically on ThePirateBay, Nyaa and YggTorrent.

Category
访问服务器

Tools

search_torrents

Search for torrents on sources [thepiratebay.org, nyaa.si, yggtorrent].

get_ygg_torrent_details

Get details about a specific torrent coming from YGG Torrent source only.

get_ygg_magnet_link

Get the magnet link for a specific torrent coming from YGG Torrent source only.

README

Torrent Search MCP Server & API

PyPI version License: MIT Ask DeepWiki

This repository provides a Python API and an MCP (Model Context Protocol) server to find torrents programmatically on ThePirateBay, Nyaa and YggTorrent. It allows for easy integration into other applications or services.

<a href="https://glama.ai/mcp/servers/@philogicae/torrent-search-mcp"> <img width="380" height="200" src="https://glama.ai/mcp/servers/@philogicae/torrent-search-mcp/badge" alt="Torrent Search MCP server" /> </a>

Quickstart

How to use it with MCP Clients

Run it with Docker to bypass common DNS issues

Table of Contents

Features

  • API wrapper for ThePirateBay, Nyaa and 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 ThePirateBay, Nyaa and YggTorrent
    • Get details for a specific YGG torrent
    • Retrieve YGG magnet links

Setup

Prerequisites

  • An active YggTorrent account and passkey (Optional).
  • Python 3.10+ (required for PyPI install).
  • uv (for local development)
  • Docker and Docker Compose (for Docker setup)

Configuration (Optional)

This application requires your YggTorrent passkey to interact with the API.

  1. Find your Passkey: On the YggTorrent website, navigate to Mon compte -> Mes paramètres. Your passkey is part of the tracker URL, which looks like http://tracker.p2p-world.net:8080/{YOUR_PASSKEY}/announce.

  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:
pip install torrent-search-mcp
crawl4ai-setup # For crawl4ai/playwright
# If it fails, try:
uvx playwright install --with-deps chromium
  1. Create a .env file in the directory where you'll run the application and add your passkey (optional):
YGG_PASSKEY=your_passkey_here
  1. Run the MCP server (default port: 8000):
python -m torrent_search

For Local Development

This method is for contributors who want to modify the source code. Using uv:

  1. Clone the repository:
git clone https://github.com/philogicae/torrent-search-mcp.git
cd torrent-search-mcp
  1. Install dependencies using uv:
uv sync
crawl4ai-setup # For crawl4ai/playwright
# If it fails, try:
uvx playwright install --with-deps chromium
  1. Create your configuration file by copying the example and add your passkey (optional):
cp .env.example .env
  1. Run the MCP server (default port: 8000):
uv run -m torrent_search

For Docker

This method uses Docker to run the server in a container.

compose.yaml is configured to bypass DNS issues (using quad9 DNS).

  1. Clone the repository (if you haven't already):
git clone https://github.com/philogicae/torrent-search-mcp.git
cd torrent-search-mcp
  1. Create your configuration file by copying the example and add your passkey (optional):
cp .env.example .env
  1. Build and run the container using Docker Compose (default port: 8765):
docker-compose -f docker/compose.yaml up --build [-d]

Usage

As Python Wrapper

from torrent_search import torrent_search_api

results = torrent_search_api.search_torrents('...')
for torrent in results:
    print(f"{torrent.filename} | {torrent.size} | {torrent.seeders} SE | {torrent.leechers} LE | {torrent.date} | {torrent.source}")

As MCP Server

from torrent_search import torrent_search_mcp

torrent_search_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:

# Dev
python -m torrent_search --fastapi
# Prod
uvicorn torrent_search.fastapi_server:app
  • --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.

Example with Windsurf

Configuration:

{
  "mcpServers": {
    ...
    # with stdio + sudo (only requires uv and playwright installed)
    # Install playwright first:
    # uvx playwright install --with-deps chromium
    "mcp-torrent-search": {
      "command": "uvx",
      "args": ["torrent-search-mcp"],
      "env": { "YGG_PASSKEY": "your_passkey_here" } # optional
    },
    # with stdio + no-sudo (only requires uv)
    "mcp-torrent-search": {
      "command": "sh",
      "args": [
        "-c",
        "uvx playwright install --with-deps chromium && uvx torrent_search"
      ],
      "env": { "YGG_PASSKEY": "your_passkey_here" } # optional
    },
    # with sse transport (requires installation)
    "mcp-torrent-search": {
      "serverUrl": "http://127.0.0.1:8000/sse"
    }
    # with streamable-http transport (requires installation)
    "mcp-torrent-search": {
      "serverUrl": "http://127.0.0.1:8000/mcp" # not yet supported by every client
    }
    ...
  }
}

Changelog

See 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 file for details.

推荐服务器

Baidu Map

Baidu Map

百度地图核心API现已全面兼容MCP协议,是国内首家兼容MCP协议的地图服务商。

官方
精选
JavaScript
Playwright MCP Server

Playwright MCP Server

一个模型上下文协议服务器,它使大型语言模型能够通过结构化的可访问性快照与网页进行交互,而无需视觉模型或屏幕截图。

官方
精选
TypeScript
Magic Component Platform (MCP)

Magic Component Platform (MCP)

一个由人工智能驱动的工具,可以从自然语言描述生成现代化的用户界面组件,并与流行的集成开发环境(IDE)集成,从而简化用户界面开发流程。

官方
精选
本地
TypeScript
Audiense Insights MCP Server

Audiense Insights MCP Server

通过模型上下文协议启用与 Audiense Insights 账户的交互,从而促进营销洞察和受众数据的提取和分析,包括人口统计信息、行为和影响者互动。

官方
精选
本地
TypeScript
VeyraX

VeyraX

一个单一的 MCP 工具,连接你所有喜爱的工具:Gmail、日历以及其他 40 多个工具。

官方
精选
本地
graphlit-mcp-server

graphlit-mcp-server

模型上下文协议 (MCP) 服务器实现了 MCP 客户端与 Graphlit 服务之间的集成。 除了网络爬取之外,还可以将任何内容(从 Slack 到 Gmail 再到播客订阅源)导入到 Graphlit 项目中,然后从 MCP 客户端检索相关内容。

官方
精选
TypeScript
Kagi MCP Server

Kagi MCP Server

一个 MCP 服务器,集成了 Kagi 搜索功能和 Claude AI,使 Claude 能够在回答需要最新信息的问题时执行实时网络搜索。

官方
精选
Python
e2b-mcp-server

e2b-mcp-server

使用 MCP 通过 e2b 运行代码。

官方
精选
Neon MCP Server

Neon MCP Server

用于与 Neon 管理 API 和数据库交互的 MCP 服务器

官方
精选
Exa MCP Server

Exa MCP Server

模型上下文协议(MCP)服务器允许像 Claude 这样的 AI 助手使用 Exa AI 搜索 API 进行网络搜索。这种设置允许 AI 模型以安全和受控的方式获取实时的网络信息。

官方
精选