Skip to main content

FR Torrent MCP Server

Project description

FR Torrent MCP Server & Wrapper

uv Python PyPI Actions status License: MIT Ask DeepWiki

This repository provides a Python wrapper for the FR Torrent websites and an MCP (Model Context Protocol) server to interact with them programmatically. This allows for easy integration of FR Torrent functionalities into other applications or services.

FR Torrent Server MCP server

Quickstart

How to use it with MCP Clients

Run it with Docker to bypass common DNS issues

Table of Contents

Features

  • API aggregator for multiple French torrent providers:
    • YggTorrent (now ygg.gratis): Support via local bridge UwUDev/ygege Fork
    • La Cale: Native support (requires apikey).
  • 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 providers
    • Get torrent
      • Get magnet link
      • Download torrent file

Setup

Prerequisites

  • Python 3.10+ (required for PyPI install).
  • uv (for local development)
  • Docker and Docker Compose (for Docker setup)
  • Passkey for LaCale (Optional). Create your apikey on https://la-cale.space/settings/api-keys

Configuration (Optional)

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

  1. La Cale: Find your API key on the La Cale website.
  2. 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 fr-torrent-search-mcp
  1. Create a .env file in the directory where you'll run the application and add your configuration:
LA_CALE_API_KEY=your_la_cale_passkey
#FOLDER_TORRENT_FILES=/path/to/target/folder
  1. Run the MCP server (default: stdio):
python -m fr_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/fr-torrent-search-mcp.git
cd fr-torrent-search-mcp
  1. Install dependencies using uv:
uv sync --locked
  1. Create your configuration file by copying the example and add your apikey:
cp .env.example .env
  1. Run the MCP server (default: stdio):
uv run -m fr_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/fr-torrent-search-mcp.git
cd fr-torrent-search-mcp
  1. Create your configuration file by copying the example and add your apikey:
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 fr-torrent-search-mcp -f

Usage

As Python Wrapper

from fr_torrent_search import fr_torrent_api

results = fr_torrent_api.search_torrents('...', max_items=10)
for torrent in results:
    print(f"{torrent.filename} | {torrent.size} | {torrent.seeders} SE | {torrent.leechers} LE | {torrent.downloads} DL | {torrent.date}")

As MCP Server

from fr_torrent_search import fr_torrent_mcp

fr_torrent_mcp.run(transport="sse")

As FastAPI Server

This project also includes a FastAPI server as an alternative way to interact with the FR Torrent 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:

# With Python
python -m fr_torrent_search --mode fastapi
# With uv
uv run -m fr_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:

  • GET /: Health check endpoint. Returns {"status": "ok"}.
  • POST /torrent/search: Search for torrents (params: query, max_items).
  • GET /torrent/{torrent_id}: Get torrent (returns magnet link or .torrent file).
  • GET /torrent/{torrent_id}/magnet: Get magnet link for a torrent.
  • GET /torrent/{torrent_id}/file: Download .torrent file.
  • GET /docs: Interactive API documentation (Swagger UI).
  • GET /redoc: Alternative API documentation (ReDoc).

Environment variables are configured the same way as for the MCP server.

Via MCP Clients

Usable with any MCP-compatible client. Available tools:

  • search_torrents: Search for torrents.
  • get_torrent: Get torrent data (magnet or file).
  • get_magnet_link: Get the magnet link for a torrent.
  • download_torrent_file: Download the .torrent file for a torrent.

Example with Windsurf

Configuration:

{
  "mcpServers": {
    ...
    # with sse transport (requires installation)
    "fr-torrent-search-mcp": {
      "serverUrl": "http://127.0.0.1:8000/sse"
    }
    # with streamable-http transport (requires installation)
    "fr-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

fr_torrent_search_mcp-1.3.1.tar.gz (15.1 kB view details)

Uploaded Source

Built Distribution

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

fr_torrent_search_mcp-1.3.1-py3-none-any.whl (21.8 kB view details)

Uploaded Python 3

File details

Details for the file fr_torrent_search_mcp-1.3.1.tar.gz.

File metadata

  • Download URL: fr_torrent_search_mcp-1.3.1.tar.gz
  • Upload date:
  • Size: 15.1 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for fr_torrent_search_mcp-1.3.1.tar.gz
Algorithm Hash digest
SHA256 91815df04ad4f7e31f969739396976c6d3f755ee381090192bdaec79b7621a51
MD5 3667fac46ccc60d56eabe85d826b1d74
BLAKE2b-256 6d9c05c1b5b246c898ec5f52aa3b48a664b355200dc4461e09de0ed0f273d65c

See more details on using hashes here.

Provenance

The following attestation bundles were made for fr_torrent_search_mcp-1.3.1.tar.gz:

Publisher: python-package-ci.yml on philogicae/fr-torrent-search-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file fr_torrent_search_mcp-1.3.1-py3-none-any.whl.

File metadata

File hashes

Hashes for fr_torrent_search_mcp-1.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 d511ef48515e3ed8c7e65c124d98dac48555b455b55a20cad9a74fddde8e6283
MD5 f920818111ff2fdcb1b9c4f494dceb3a
BLAKE2b-256 2f67ba61b42d3b7a6bfd358c30630da85ee3c776772ab091205b931777543439

See more details on using hashes here.

Provenance

The following attestation bundles were made for fr_torrent_search_mcp-1.3.1-py3-none-any.whl:

Publisher: python-package-ci.yml on philogicae/fr-torrent-search-mcp

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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