exatorrent

self-hostable torrent client


ScreenshotsReleasesFeatures Installation UsageDocker Build License


## Introduction exatorrent is [BitTorrent](https://www.bittorrent.org/) Client written in [Go](https://go.dev/). It can be run locally or be hosted in Remote Server with good resources to use that Server as [SeedBox](https://en.wikipedia.org/wiki/Seedbox). It is Single Completely Statically Linked Binary with Zero External Dependencies . exatorrent is simple yet feature-rich . It is lightweight and light on resources. It comes with Beautiful Responsive Web Client written in Svelte and Typescript , but thanks to documented [WebSocket](https://datatracker.ietf.org/doc/html/rfc6455) [API](docs/API.md) of exatorrent , you can also write your own client if you want to. exatorrent can operate in Optional Multi-User Mode administrated by admin user/s but it can successfully be used by Single-User as well. Torrented Files are stored in local disk of device where it's run, which are then retrievable or streamable via HTTP.

exatorrent web client

More Screenshots →


## Installation exatorrent can be installed in 3 ways. * **Releases:** You can download binary for your OS from [Releases](https://github.com/varbhat/exatorrent/releases/latest) . Mark it as executable and run it . Refer [Usage](docs/usage.md) . ```bash wget https://github.com/varbhat/exatorrent/releases/latest/download/exatorrent-linux-amd64 chmod u+x ./exatorrent-linux-amd64 ./exatorrent-linux-amd64 ``` * **Docker:** exatorrent can also be run inside Docker ( or Podman ). See [Docker Docs](docs/docker.md) . ```bash docker pull ghcr.io/varbhat/exatorrent:latest docker run -p 5000:5000 -p 42069:42069 -v /path/to/directory:/exa/exadir ghcr.io/varbhat/exatorrent:latest ``` * **Build:** exatorrent is open source and can be built from sources . See [Build Docs](docs/build.md) . ```bash make web && make app ``` Note that **Username** and **Password** of Default User created on first run are `adminuser` and `adminpassword` respectively. You can change Password later but Username of Account can't be changed after creation. Refer [Usage](docs/usage.md#-admin) . [Github Actions](https://github.com/features/actions) is used to build and publish [Releases](https://github.com/varbhat/exatorrent/releases/latest) and [Docker/Podman Images](https://ghcr.io/varbhat/exatorrent) of exatorrent . If you want to deploy `exatorrent` on server , please also refer [Deploy Docs](docs/deploy.md) . ## Features * Single Executable File with No Dependencies * Small in Size * Cross Platform * Download (or Build ) Single Executable Binary and run . That's it * Open and Stream Torrents in your Browser * Add Torrents by Magnet or by Infohash or Torrent File * Individual File Control (Start, Stop or Delete ) * Stop , Remove or Delete Torrent * Persistent between Sessions * Stop Torrent once SeedRatio is reached (Optional) * Powered by [anacrolix/torrent](https://github.com/anacrolix/torrent) * Download/Upload [Rate limiter](https://github.com/varbhat/exatorrent/blob/main/docs/usage.md#rate-limiter) (Optional) * Apply [Blocklist](docs/usage.md#blocklist) (Optional) * [Configurable](docs/config.md) via Config File but works fine with Zero Configuration * Share Files by Unlocking Torrent or Lock Torrent (protect by Auth) to prevent External Access * Retrieve or Stream Files via HTTP * Multi-Users with Authentication * Auto Add Trackers to Torrent from TrackerList URL * Auto Fetch Torrent Metainfo from Online/Local Metainfo Cache * Download Directory as Zip or as Tarball * Stream directly on Browser or [VLC](https://www.videolan.org/vlc/) or [mpv](https://mpv.io/) or other Media Players * [Documented API](docs/API.md) * Uses Sqlite3 (embedded database with no setup and no configuration) by Default for [Database](docs/database.md) but PostgreSQL can be used instead too

Read More →

## Help Communication about the project is primarily through [Discussions](https://github.com/varbhat/exatorrent/discussions) and the [Issues](https://github.com/varbhat/exatorrent/issues). ## Contribute You are welcome to contribute . Please Read the [contributing docs](docs/CONTRIBUTING.md) first. ## Sponsor If you like this Project , please consider this as an opportunity to sponsor / donate to this project . This would help me maintain this project and also work on other Open Source Projects . Use [Liberapay](https://liberapay.com/varbhat) , [Paypal](https://www.paypal.me/varbhat) , [Ko-fi](https://ko-fi.com/varbhat) or [UPI](https://en.wikipedia.org/wiki/Unified_Payments_Interface) (VPA: `mailvarbhat@okhdfcbank`) to Sponsor / Donate to this Project . ## License [GPL-v3](LICENSE)