FR Torrent MCP Server
Project description
FR Torrent MCP Server & Wrapper
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.
Quickstart
Table of Contents
- Features
- Setup
- Prerequisites
- Configuration
- Installation
- Install from PyPI (Recommended)
- For Local Development
- For Docker
- Usage
- As Python Wrapper
- As MCP Server
- As FastAPI Server
- Via MCP Clients
- Example with Windsurf
- Contributing
- Changelog
- License
Features
- API aggregator for multiple French torrent providers:
- YggTorrent:
Support via local bridge UwUDev/ygegeDEPRECATED - La Cale: Native support (requires apikey).
- YggTorrent:
- 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
- Passkey (for LaCale). Find your apikey on https://la-cale.space/profile
Active account (for YggTorrent)DEPRECATED.- Python 3.10+ (required for PyPI install).
uv(for local development)- Docker and Docker Compose (for Docker setup)
Configuration
The application requires configuration for the supported providers.
- Set Environment Variables: The application reads configuration from environment variables. The recommended way is by creating a
.envfile in your project's root directory.
# LaCale Configuration
#LA_CALE_DOMAIN=la-cale.space
# Create your apikey on https://la-cale.space/settings/api-keys
LA_CALE_API_KEY=
# Target folder for torrent files (Default: ./torrents).
#FOLDER_TORRENT_FILES=/path/to/target/folder
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.
- Install the package from PyPI:
pip install fr-torrent-search-mcp
- Create a
.envfile 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
- 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:
- Clone the repository:
git clone https://github.com/philogicae/fr-torrent-search-mcp.git
cd fr-torrent-search-mcp
- Install dependencies using
uv:
uv sync --locked
- Create your configuration file by copying the example and add your apikey:
cp .env.example .env
- 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).
- Clone the repository (if you haven't already):
git clone https://github.com/philogicae/fr-torrent-search-mcp.git
cd fr-torrent-search-mcp
- Create your configuration file by copying the example and add your apikey:
cp .env.example .env
- Build and run the container using Docker Compose (default port: 8000):
docker compose up --build -d
- 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
Release history Release notifications | RSS feed
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file fr_torrent_search_mcp-1.2.1.tar.gz.
File metadata
- Download URL: fr_torrent_search_mcp-1.2.1.tar.gz
- Upload date:
- Size: 14.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
63ab4fb7e2d6779a394bd937e2cf627a832d31a568c81e662f851adc47262ba7
|
|
| MD5 |
2a111c32bc9ba437921fb7fefdff9c69
|
|
| BLAKE2b-256 |
253b39b7a3172a5ba41166254df4e98b487d1e2a29c65ec9abbadf52ca3b83a4
|
Provenance
The following attestation bundles were made for fr_torrent_search_mcp-1.2.1.tar.gz:
Publisher:
python-package-ci.yml on philogicae/fr-torrent-search-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fr_torrent_search_mcp-1.2.1.tar.gz -
Subject digest:
63ab4fb7e2d6779a394bd937e2cf627a832d31a568c81e662f851adc47262ba7 - Sigstore transparency entry: 1030421313
- Sigstore integration time:
-
Permalink:
philogicae/fr-torrent-search-mcp@b3dd92bae8b69a2f942991fc7fe378750754ae2c -
Branch / Tag:
refs/tags/1.2.1 - Owner: https://github.com/philogicae
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-package-ci.yml@b3dd92bae8b69a2f942991fc7fe378750754ae2c -
Trigger Event:
push
-
Statement type:
File details
Details for the file fr_torrent_search_mcp-1.2.1-py3-none-any.whl.
File metadata
- Download URL: fr_torrent_search_mcp-1.2.1-py3-none-any.whl
- Upload date:
- Size: 19.9 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/6.1.0 CPython/3.13.7
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
f238458f7ac3816c4b0b697e3c14c28e4a796663b03d0d14f3f8f7a7dc7df202
|
|
| MD5 |
670ed63a4af1fed6008e81392d1ff3b7
|
|
| BLAKE2b-256 |
a3cf7b0925875516f18a8a2daf5bb2022cc5eb9cadbe5adbc39658f28f61ef60
|
Provenance
The following attestation bundles were made for fr_torrent_search_mcp-1.2.1-py3-none-any.whl:
Publisher:
python-package-ci.yml on philogicae/fr-torrent-search-mcp
-
Statement:
-
Statement type:
https://in-toto.io/Statement/v1 -
Predicate type:
https://docs.pypi.org/attestations/publish/v1 -
Subject name:
fr_torrent_search_mcp-1.2.1-py3-none-any.whl -
Subject digest:
f238458f7ac3816c4b0b697e3c14c28e4a796663b03d0d14f3f8f7a7dc7df202 - Sigstore transparency entry: 1030421392
- Sigstore integration time:
-
Permalink:
philogicae/fr-torrent-search-mcp@b3dd92bae8b69a2f942991fc7fe378750754ae2c -
Branch / Tag:
refs/tags/1.2.1 - Owner: https://github.com/philogicae
-
Access:
private
-
Token Issuer:
https://token.actions.githubusercontent.com -
Runner Environment:
github-hosted -
Publication workflow:
python-package-ci.yml@b3dd92bae8b69a2f942991fc7fe378750754ae2c -
Trigger Event:
push
-
Statement type: