gearbox-torrent
v0.17.1
Published
A modern web UI for Transmission built to handle 300,000+ torrents.
Downloads
27
Readme
Gearbox
Gearbox is a modern web UI for Transmission, designed to efficiently manage over 300,000 torrents across several torrent clients.
Features
- 🤗 Federated operation: Offers a unified UI across multiple backends.
- 🐎 Super-fast: UI interactions are instantaneous.
- 🧠 Low memory usage: Uses 30% less memory compared to the standard Transmission web UI (at 7,000 torrents).
- 🔁 Transfer: Move torrents between clients.
Why Gearbox?
Torrent clients typically have a limit on the number of torrents they can handle. The conventional solution upon reaching this limit is to launch additional instances. This workaround might suffice for managing two or three instances, but it becomes cumbersome with more. Gearbox was developed to provide a singular interface for controlling multiple instances seamlessly. It also has a great UI. Our goal was to incorporate Deluge-like filters and introduce a superior search functionality unmatched by any other.
Gearbox is Transmission RPC compatible. Any software that can communicate with Transmission can also communicate with Gearbox.
Installation
NPM
npm add -g gearbox-torrent
gearbox
Docker
Note: after running it once to create the config.mjs
file, you will have to change ip
to 0.0.0.0
. The default does not allow access outside local machine.
docker run -p 2112:2112 -it -e GEARBOX_PATH=/config -v $PWD:/config ghcr.io/mikabytes/gearbox:latest
Source
git clone https://github.com/mikabytes/gearbox.git
cd gearbox
npm start
For active development, you may run pnpm watch
for a setup where server restarts automatically on file changes. It also enables live reloading in the browser.
Frequently Asked Questions
Please check our FAQ
Configuration
By default, Gearbox automatically searches for a config.mjs
file within the current directory. Should it fail to locate one, Gearbox will proceed to generate a new config.mjs
file automatically. Additionally, users have the option to direct Gearbox to a specific folder for the config.mjs
file by setting the GEARBOX_PATH
environment variable.
Example config.mjs
:
export default {
clients: [
{ id: `torr1`, host: "192.168.0.1", port: 9091, type: "transmission" },
{ id: `torr2`, host: "127.0.0.1", port: 9091, type: "transmission" },
{
id: `torr3`,
host: "10.0.107.1",
port: 80,
user: "admin",
password: "supersecret",
type: "transmission",
maxCount: 5000,
torrentDir: "/config/torrents",
},
],
addTorrentStrategy: "least-count", // or "round-robin", "first-found",
ip: "127.0.0.1",
port: 2112,
logLevel: "warn",
}
Clients
A list of Transmission torrent clients to connect to.
Here is your list converted into a markdown table:
| Field | Description |
| ----------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
| id | An identifier for the client. You can pick any name you want, but it must be unique and at least one character. |
| host | Specifies the address of a Transmission daemon with Web-UI enabled. This can be a local or remote IP address or a DNS name. |
| port | Designates the port for a Transmission daemon with Web-UI enabled, typically 9091. |
| user / password | Authentication that you want to use with Transmission. Optional |
| type | The type of torrent client. Defaults to transmission
. Currently, only transmission
is supported. |
| maxCount | A client is qualified to accept new torrents only if it has less than this number of existing torrents. Useful not to overload any individual client. Discarded if omitted or negative. |
| torrentDir | The directory where the client stores its .torrent files. For transmission, this is the torrents
folder inside of your Transmission configuration folder. |
addTorrentStrategy
The configuration for adding new torrents. Deciding which client gets the new torrent is decided here. Client maxCount
is respected. If no client was found that matches configuration, an error will be thrown.
strategy: The strategy for adding new torrents. Defaults to least-count
.
| Strategy | Description |
| :------------ | :------------------------------------------------------------------- |
| least-count
| Add it to the client that has the least number of torrents. |
| round-robin
| Spread new torrents evenly across all clients. |
| first-found
| Add it to the first client available client (in order of backends
) |
ip / port
This specifies the IP and port on which the Gearbox server will listen. Defaults to 127.0.0.1
and 2112
respectively.
If you want to be able to access Gearbox from outside the local machine, you should set ip
to 0.0.0.0
.
logLevel
The logging level. Defaults to warn
, can be any of error
, warn
, or debug
.
Usage
Filters & Search
- Freetext in search bar to filter based on name, file path, or file extension.
- Click on a filter in the sidebar to choose it.
- Click on it again to remove it.
- Shift-click to to pick the inverse of a filter. For example, if you shift-click on "Everything's fine", all torrents that are not fine will be shown.
Advanced usage: Any field sent from Transmission can be used in the search bar. For example, if you want to list all torrents that haven't downloaded anything, you could type percentDone:0
. You also have the option to create a "OR"
filter by putting arguments in parenthesis. Example: clientId:(trans1 trans2)
will show you any torrents from backends trans1
OR trans2
.
Sorting
You may sort by clicking on the header of a column. Click on a column twice to sort in the other direction.
Performance
Gearbox was tested for memory use at 7,000 torrents, showing 90MB of memory use where Transmission Web Interface used 314MB.
It was also stress-tested at 370,000 torrents on an average PC. While it took a good moment to start, and used 1.7GB of memory, it was still very fast after that. The real limit is not known, it may be in the millions depending on hardware.
Keyboard shortcuts
| Key | Action |
| :--------------------------- | :-------------------------------------------------- |
| x
, -
, DEL
, Backspace
| Delete |
| Space
| If all selected are paused, then resume, else pause |
| Ctrl+A
| Select all |
| Ctrl+L
| Change location |
Protocol
Gearbox implements the Transmission RPC protocol. Anywhere you can use Transmission RPC, you can use Gearbox, including *Arrs, autodl-irssi, etc.
There are a few differences. When adding torrents you can specify which torrent client should receive the new torrent using the non-standard clientId
field. If this field is omitted, the addTorrentStrategy
together with maxCount
will be used to pick a client.
When using session-get
, a reasonable hard-coded default is returned. session-set
is not supported.
Transfer: Moving torrents between clients
Gearbox supports transferring torrents between clients, with some limitations:
torrentDir
must be set on the client transfering from.- The
torrentDir
must be accessible by Gearbox.
For setups where Gearbox and the torrent clients run on the same machine, compatibility issues are unlikely. However, if they operate on separate machines, ensure that you mount the remote filesystem. Additionally, maintain consistent paths across all systems. For instance, if Transmission uses /config/torrents
, Gearbox should also also access these files on /config/torrents
.
Roadmap
Currently Gearbox does a good job to give you insight into where your torrents are and what they're doing. You can also delete them by right-clicking on them. There are many more features planned, check out the Issues tab!
Contributing
Want to help? You can do so by suggesting features or reporting bugs (in the Issues tab), or by submitting a pull request.
Tests
Source code should have tests whenever you're doing something that is not UI related, especially if it's complex to wrap your head around. Don't add tests for UI interactions, as these tend to become more troublesome than they help out.
Dependencies
Strive to keep the codebase slim by not including unnecessary dependencies. If something can be achieved just as easily natively as with some third-party package, then it should be done natively. Some examples of these are Axios and jQuery.