popstas / transmission-cli
Transmission client for automate weburg.net downloads
Requires
- php: >=7.0
- influxdb/influxdb-php: ^1.0.0
- martial/transmission-api: ^2.0.0
- stecman/symfony-console-completion: ^0.7.0
- symfony/console: ^3.4.0
- symfony/yaml: ^3.4.0
Requires (Dev)
README
transmission-cli is console php application for automate torrent download/upload from weburg.net
Blog post: http://blog.popstas.ru/blog/2016/01/17/torrent-transmission-client-for-weburg/
Based on:
Features
- send metrics to InfluxDB, torrent monitoring trends with Grafana
- download popular (rating, comment and votes based) movies from http://weburg.net
- download tracked series from http://weburg.net
- delete not popular uploads from transmission
- working with multiple transmission instances
- command line autocompletion
- add torrents with GET request
Graphics
- hourly upload stats by torrent and summary upload
- list all hosts that sends metrics to InfluxDB
Available commands:
help
- Displays help for a commandlist
- List commandstorrent-list [--name='series*1080'] [--age='>1 <3 =2'] [--sort=1] [--limit=10]
,tl
- List, filter and sort torrentstorrent-add file|url [file2] [fileX]
,ta
- Safe add torrentstorrent-remove 1 [2] [3]
,tr
- Remove one or more torrents by torrent idtorrent-remove-duplicates
,trd
- Remove duplicates obsolete torrentsstats-get [--name='name'] [--age='>1 <3 =2'] [profit='>0'] [--days=7] [--sort=1] [--limit=10] [--rm]
,sg
- Get metrics from InfluxDBstats-send
,ss
- Send metrics to InfluxDBweburg-download [--limit 1]
,wd
- Download popular torrents and tracked series from weburg.netweburg-download --popular [--movies-url=url]
- Download only popularweburg-download --series
- Download only seriesweburg-download --query
- Download first resultweburg-download [movie url or id]
- Download movie without popularity checkweburg-download [series url or id] [--days=1]
- Download series for last x daysweburg-series-add
,wsa
- Add series to monitoring listweburg-info
,wi
- Test internal weburg parser
Global command options
--config
- set path to config file--dry-run
- don't change any data-v|vv|vvv
- more verbose output--transmission-host
- set transmission host--transmission-port
- set transmission port--transmission-user
- set transmission user--transmission-password
- set transmission password
HTTP server for add torrents
node scripts/server-torrent-add.js
Then you can add torrents via open urls like http://localhost:10293/?url=http%3A%2F%2Fbt.weburg.net%2Fgettorrent.php%3Fsecuritykey%3D70c3fcb98000761e78ea2b9c8bedd69e%26user_id%3D151954%26info_hash%3D9f67aa271026be1ca2d7c6b4a88f9417455d64f5
You can also add userscript to your browser, scripts/weburg-torrent-add.user.js
Install
PHAR automatic (Recommended)
latest_phar=$(curl -s https://api.github.com/repos/popstas/transmission-cli/releases/latest | grep 'browser_' | cut -d\" -f4)
wget -O /usr/local/bin/transmission-cli "$latest_phar"
chmod +x /usr/local/bin/transmission-cli
PHAR manually
Download latest transmission-cli.phar here, make it executable and put it to bin directory.
Composer global
composer global require popstas/transmission-cli
If you cannot execute transmission-cli
after that, probably you should add ~/.config/composer/vendor/bin to your PATH environment variable
as described here.
Composer from source:
git clone https://github.com/popstas/transmission-cli
cd transmission-cli
composer install
ln -s "$PWD"/bin/transmission-cli /usr/local/bin/transmission-cli
Configure
Default config placement: ~/.transmission-cli.yml
. It creates on first run.
You can change some parameters here.
Also, you can pass config to command: transmission-cli --config /path/to/config.yml
Commands weburg-download
, weburg-series-add
, interacts only with weburg.net and not requests to Transmission or InfluxDb.
You can use download-filename-whitelist
and download-filename-blacklist
lists for filter torrents before download.
About torrent duplicates
By default, transmission-cli
prevents send stats to InfluxDB when you have torrents with same names in your Transmission,
because it make stats about these torrents wrong. If it not matters for you, you can use allow-duplicates
option in config.
When allow-duplicates: true
defined in config, transmission-cli will allow to stats-send with duplicates
and don't ask to remove duplicates after torrent-add
command.
Transmission
If you want to make commands torrent-*
working, you should enable remote access in Transmission
and add host, port, username, password if it not defaults.
By default, transmission-cli request to Transmission on localhost:9091 without user and password. You can change it in ~/.transmission-cli.yml
.
You can override default config: --transmission-host
, --transmission-port
, --transmission-user
, --transmission-password
Also, maybe you want to automatically download movies, not only torrent files. To do that, enable autodownload in Transmission
and point to same directory in --dest=
option.
InfluxDB and Grafana
You need to install it for drawing torrent graphics.
InfluxDB
Simplest way to install InfluxDB - Docker:
docker run --name influxdb -d --restart=always \
-v /Users/popstas/lib/influxdb:/data \
-p 8083:8083 -p 8086:8086 \
influxdb
And if you don't want to see detailed stats about your torrents, you may not install InfluxDB, commands stats-*
will not working.
Grafana
- Run Grafana with Docker
docker run --name grafana -d \
-v /Users/popstas/lib/grafana:/var/lib/grafana \
-p 3000:3000 \
-e "GF_SECURITY_ADMIN_USER=admin" \
-e "GF_SECURITY_ADMIN_PASSWORD=secret" \
grafana/grafana
- Add InfluxDB as data source "influxdb" to Grafana, choose database "transmission".
- Import dashboard - grafana-torrents.json
If you don't want to see graphs, Grafana not necessary.
autocompletion for bash/zsh:
source <(transmission-cli _completion --generate-hook)
Cron
Then, add to cron tasks like this:
PATH="/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin:~/.config/composer/vendor/bin"
59 * * * * transmission-cli torrent-remove-duplicates --yes --transmission-host=localhost
59 * * * * transmission-cli torrent-remove-duplicates --yes --transmission-host=wrtnsq
0 * * * * transmission-cli stats-send --transmission-host=localhost
0 * * * * transmission-cli stats-send --transmission-host=wrtnsq
1 2 * * * transmission-cli weburg-download --yes --download-torrents-dir=/Volumes/media/_planeta/_torrents
Don't forget add to cron PATH your ~/.config/composer/vendor/bin if you installed transmission-cli with composer global
!
Usage
See commands --help
.
Contributing
See CONTRIBUTING.md.