Direct Client Injection
If you use rTorrent, Transmission, Deluge, or qBittorrent, cross-seed
can inject the torrents it finds directly into your torrent client. This feature is extremely
robust and can be leveraged manually or through automation external to cross-seed
.
If you are having issues with injection errors, and it reverting to save, please check our FAQ
There is a potential problem with duplication of imports using either an Arr On Download/Upgrade, Deluge/qBittorrent on complete execution,
or search/rss/announce trigger, which causes race conditions and bad categorizing/labeling when you use inject with cross-seed
.
Injecting to qBittorrent/Deluge and using an Arr can result in new cross-seeds being added with the Arr import
category, causing them to get stuck in your Arr's import queue. The workaround is to enable the duplicateCategories
option, which will append your category with .cross-seed
and if using qBittorrent either...
- use the same pre/post import categories in your Arr OR
- your Arr's pre/post import categories have the same save path in qBittorrent.
cross-seed
requires access to the directory where your client's .torrent files are stored.
Client | Torrent/Session Folder |
---|---|
qBittorrent | BT_Backup |
Deluge | state |
Transmission | torrents |
rTorrent | session dir from .rtorrent.rc |
Manual or Scheduled Injection
In v6, cross-seed
has the ability to add .torrent files for injection directly. You can either opt to wait for the hourly cadence, or
alternatively run the cross-seed inject
command to attempt injection for .torrent files in
your outputDir
. You can alternatively use cross-seed inject --inject-dir /path/to/folder
to specify
another directory.
For torrent files being injected manually, if using flatLinking: false
will require a
[mediatype][tracker]
prefix (where tracker is the name corresponding to that tracker's linkDir
folder) in order to inject within your
existing folder structure.
To achieve optimal injection behavior, adding the prefix [mediatype][tracker-name]
as you would normally see it in
outputDir
when saving the torrent file is recommended.
Current "mediatypes" support are episode
, pack
, movie
, anime
, video
, audio
, book
, and unknown
.
This is the same format in which cross-seed
normally saves .torrent files. If you do not specify both of these parameters,
cross-seed
will link the torrents into the UnknownTracker
directory for you, and will require your intervention to sort them
if you wish to do so.
Using this command or utilizing the injection hourly cadence will perform minimal filtering on injection attempts. This means there is the
possibility of slightly increased chance of false-positives with .torrent files you add for injection. All torrent files saved by cross-seed
for retrying have already been filtered for matching.
If the .torrent files follow the naming format above, they will be elligible for cleanup if they fall into one of these categories:
- The torrent is in client and complete (successful injection or already exists)
- The torrent has no matches (source torrent/data was likely removed)
- The torrent matches your blocklist
Stalled torrents (either the cross seeded torrent or it's source) will require your intervention before cross-seed
will remove the .torrent file.
You will need to remove these torrents from your client or remove the .torrent file from outputDir manually if you wish to keep them.
You can find more information about this feature in the v6 migration guide
.
rTorrent
setup
cross-seed
will inject torrents into rTorrent with a cross-seed
label.
- Edit your config file:
- Set your
action
option toinject
. - Set your
rtorrentRpcUrl
option. It should look like anhttp
url that looks likehttp://user:pass@localhost:8080/rutorrent/RPC2
(if you have ruTorrent installed). See the reference for more details.
- Set your
- Start or restart
cross-seed
. The logs at startup will tell you ifcross-seed
was able to connect to rTorrent.
In order for cross-seed
to prove to rTorrent that a torrent is completed,
it must check the modification timestamps of all the torrent's files.
Make sure that your cross-seed
container has read access to the data
directories of your torrents, mapped to the same path as rTorrent.
qBittorrent
setup
Injection will work best if you use the Original
content layout in qBittorrent options.
- Edit your config file:
- Set your
action
option toinject
. - Set your
qbittorrentUrl
option. It should look like anhttp
url that looks likehttp://user:pass@localhost:8080/
See the reference for more details.
- Set your
- Start or restart
cross-seed
. The logs at startup will tell you ifcross-seed
was able to connect to qBittorrent.
Transmission
setup
- Edit your config file:
- Set your
action
option toinject
. - Set your
transmissionRpcUrl
option. It should look like anhttp
url that looks likehttp://user:pass@localhost:9091/transmission/rpc
- Set your
- Start or restart
cross-seed
. The logs at startup will tell you ifcross-seed
was able to connect to Transmission.
Deluge
setup
- Edit your config file:
- Set your
action
option toinject
. - Set your
delugeRpcUrl
option. It should look like anhttp
url that looks likehttp://:pass@localhost:8112/json
(the colon beforepass
is intentional)
- Set your
- Start or restart
cross-seed
. The logs at startup will tell you ifcross-seed
was able to connect to Deluge.