mirror of
https://github.com/StuffAnThings/qbit_manage.git
synced 2025-10-27 14:37:32 +08:00
This tool will help manage tedious tasks in qBittorrent and automate them. Tag, categorize, remove Orphaned data, remove unregistered torrents and much much more.
|
|
||
|---|---|---|
| .github | ||
| config | ||
| modules | ||
| .dockerignore | ||
| .gitignore | ||
| Dockerfile | ||
| LICENSE | ||
| qbit_manage.py | ||
| qbm_logo.png | ||
| README.md | ||
| requirements.txt | ||
| VERSION | ||
qBit Management
This is a program used to manage your qBittorrent instance such as:
- Tag torrents based on tracker URL and set seed goals/limit upload speed by tag (only tag torrents that have no tags)
- Update categories based on save directory
- Remove unregistered torrents (delete data & torrent if it is not being cross-seeded, otherwise it will just remove the torrent)
- Automatically add cross-seed torrents in paused state. *Note: cross-seed now allows for torrent injections directly to qBit, making this feature obsolete.*
- Recheck paused torrents sorted by lowest size and resume if completed
- Remove orphaned files from your root directory that are not referenced by qBittorrent
- Tag any torrents that have no hard links and allows optional cleanup to delete these torrents and contents based on maximum ratio and/or time seeded
- RecycleBin function to move files into a RecycleBin folder instead of deleting the data directly when deleting a torrent
- Built-in scheduler to run the script every x minutes. (Can use
--runcommand to run without the scheduler)
Installation
Check out the wiki for installation help
Usage
To run the script in an interactive terminal run:
- copy the
config.yml.samplefile toconfig.yml - add your qBittorrent host, user and pass. If you are not using a username and password you can remove the
userandpasslines. - add your
cross_seedandroot_dir. If you're running cross-seed in a docker container you must fill outremote_diras well. - Add your categories and save path to match with what is being used in your qBittorrent instance. I suggest using the full path when defining
save_path - Add the
tagdefinition based on tracker URL (optional add seed goals/limit upload speed by tag) - Modify the
nohardlinksby specifying your completed movies/series category to match with qBittorrent. Please ensure theroot_dirand/orremote_diris added in thedirectorysection root_dirneeds to be defined in order to use the RecycleBin function. If optionalempty_after_x_daysis not defined then it will never empty the RecycleBin. Setting it to 0 will empty the RecycleBin immediately.- Modify the
orphanedsection to define file patterns not to consider as orphans. Use this to exclude your incomplete torrents directory, or to ignore auto-generated files such as Thumbs.db. - To run the script in an interactive terminal with a list of possible commands run:
python qbit_manage.py -h
Commands
| Shell Command | Docker Environment Variable | Description | Default Value |
|---|---|---|---|
-r or--run |
QBT_RUN | Run without the scheduler. Script will exit after completion. | False |
-sch or --schedule |
QBT_SCHEDULE | Schedule to run every x minutes. (Default set to 30) | 30 |
-c CONFIG or --config-file CONFIG |
QBT_CONFIG | This is used if you want to use a different name for your config.yml. Example: tv.yml |
config.yml |
-lf LOGFILE, or --log-file LOGFILE, |
QBT_LOGFILE | This is used if you want to use a different name for your log file. Example: tv.log |
activity.log |
-cs or --cross-seed |
QBT_CROSS_SEED | Use this after running cross-seed script to add torrents from the cross-seed output folder to qBittorrent | False |
-re or --recheck |
QBT_RECHECK | Recheck paused torrents sorted by lowest size. Resume if Completed. | False |
-cu or --cat-update |
QBT_CAT_UPDATE | Use this if you would like to update your categories. | False |
-tu or --tag-update |
QBT_TAG_UPDATE | Use this if you would like to update your tags and/or set seed goals/limit upload speed by tag. (Only adds tags to untagged torrents) | False |
-ru or --rem-unregistered |
QBT_REM_UNREGISTERED | Use this if you would like to remove unregistered torrents. (It will the delete data & torrent if it is not being cross-seeded, otherwise it will just remove the torrent without deleting data) | False |
-ro or --rem-orphaned |
QBT_REM_ORPHANED | Use this if you would like to remove orphaned files from your root_dir directory that are not referenced by any torrents. It will scan your root_dir directory and compare it with what is in qBittorrent. Any data not referenced in qBittorrent will be moved into /data/torrents/orphaned_data folder for you to review/delete. |
False |
-tnhl or --tag-nohardlinks |
QBT_TAG_NOHARDLINKS | Use this to tag any torrents that do not have any hard links associated with any of the files. This is useful for those that use Sonarr/Radarr that hard links your media files with the torrents for seeding. When files get upgraded they no longer become linked with your media therefore will be tagged with a new tag noHL. You can then safely delete/remove these torrents to free up any extra space that is not being used by your media folder. | False |
-sr or --skip-recycle |
QBT_SKIP_RECYCLE | Use this to skip emptying the Reycle Bin folder (/root_dir/.RecycleBin). |
False |
-dr or --dry-run |
QBT_DRY_RUN | If you would like to see what is gonna happen but not actually move/delete or tag/categorize anything. | False |
-ll or --log-level LOGLEVEL |
QBT_LOG_LEVEL | Change the ouput log level. | INFO |
-d or --divider |
QBT_DIVIDER | Character that divides the sections (Default: '=') | = |
-w or --width |
QBT_WIDTH | Screen Width (Default: 100) | 100 |
Config
To choose the location of the YAML config file
python qbit_manage.py --config-file <path_to_config>
Log
To choose the location of the Log File
python qbit_manage.py --log-file <path_to_log>