Skip to main content

Torrent Search MCP Server

Project description

Torrent Search MCP Server & API

uv Python PyPI Actions status License: MIT Ask DeepWiki

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

Torrent Search MCP server

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, YggTorrent and La Cale.
  • 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 across all available sources
    • Get magnet link or torrent file for a specific torrent by id

Setup

Prerequisites

  • An active YggTorrent account with username and password (Optional).
  • An active La Cale account with passkey (Optional).
  • Python 3.10+ (required for PyPI install).
  • uv (for local development)
  • Chromium and its required dependencies
  • Docker and Docker Compose (for Docker setup)

Configuration (Optional)

This application requires credentials if you want to interact with YggTorrent or La Cale.

  1. YggTorrent: Username and password from your account.
  2. La Cale: Find your passkey on the La Cale website at https://la-cale.space/profile.
  3. Set Environment Variables: The application reads configuration from environment variables. The recommended way to set them is by creating a .env file in your project's root directory. The application will load it automatically. See .env.example for all available options.

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
playwright install --with-deps chromium # If previous command fails
  1. Create a .env file in the directory where you'll run the application and add your credentials (optional):
YGG_USERNAME=your_username_here
YGG_PASSWORD=your_password_here
LA_CALE_PASSKEY=your_passkey_here
  1. Run the MCP server (default: stdio):
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 --locked
uvx playwright install --with-deps chromium
  1. Create your configuration file by copying the example and add your credentials (optional):
cp .env.example .env
  1. Run the MCP server (default: stdio):
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: 8000):
docker compose up --build -d
  1. Access container logs:
docker logs torrent-search-mcp -f

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

# With Python
python -m torrent_search --mode fastapi
# With uv
uv run -m torrent_search --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"}.
  • /torrent/search: Search for torrents (POST request with query and optional max_items parameters).
  • /torrent/{torrent_id}: Get magnet link or torrent file for a specific torrent by id.
  • /docs: Interactive API documentation (Swagger UI).
  • /redoc: Alternative API documentation (ReDoc).

Environment variables (like YGG_USERNAME, YGG_PASSWORD, LA_CALE_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 across all available sources (ThePirateBay, Nyaa, YggTorrent, La Cale).
  • get_torrent: Get the magnet link or torrent file for a specific torrent by id.

Available resources:

  • data://torrent_sources: Get the list of available torrent sources.

Example with Windsurf

Configuration:

{
  "mcpServers": {
    ...
    # with stdio (only requires uv)
    "torrent-search-mcp": {
      "command": "uvx",
      "args": [ "torrent-search-mcp" ],
      "env": {
        "YGG_LOCAL_API": "http://localhost:3456", # YggTorrent instance URL
        "LA_CALE_PASSKEY": "your_passkey_here" # La Cale passkey
      } # optional
    },
    # with sse transport (requires installation)
    "torrent-search-mcp": {
      "serverUrl": "http://127.0.0.1:8000/sse"
    },
    # with streamable-http transport (requires installation)
    "torrent-search-mcp": {
      "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.

Project details


Download files

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

Source Distribution

Built Distribution

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

File details

Details for the file iflow_mcp_philogicae_torrent_search_mcp-2.0.3.tar.gz.

File metadata

  • Download URL: iflow_mcp_philogicae_torrent_search_mcp-2.0.3.tar.gz
  • Upload date:
  • Size: 12.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_philogicae_torrent_search_mcp-2.0.3.tar.gz
Algorithm Hash digest
SHA256 1b9011f293b4433494bf0a76f0e0cbc7730b4b5341ed45dc8e4393d069e55c80
MD5 7299b5ba18b39ad344ababf7594e8ab5
BLAKE2b-256 b77bdaf5129d7b5dcf87ac5fc78ce10f315e98f4ae399278f29faa03da6c838d

See more details on using hashes here.

File details

Details for the file iflow_mcp_philogicae_torrent_search_mcp-2.0.3-py3-none-any.whl.

File metadata

  • Download URL: iflow_mcp_philogicae_torrent_search_mcp-2.0.3-py3-none-any.whl
  • Upload date:
  • Size: 16.9 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.9.26 {"installer":{"name":"uv","version":"0.9.26","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Debian GNU/Linux","version":"13","id":"trixie","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":null}

File hashes

Hashes for iflow_mcp_philogicae_torrent_search_mcp-2.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 62714ed9aaca13244f6fd966fd2521777eb73b4598a57806bad3297a63522cf6
MD5 92b5f0cfaf98b4a217fe1b9b96b3672e
BLAKE2b-256 e11619461a1cc6ca22901dad4aabcb30fe31bfe8125019fb7d3ee652f3bce935

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