A script to stream torrents using BTFS
Project description
btstrm - BitTorrent Streaming Program
btstrm
is a Python program that allows you to stream torrents directly from the command line. It provides a seamless streaming experience by leveraging the power of BitTorrent and integrating with popular media players.
Features
- Stream torrents directly without waiting for the entire download to complete
- Search for torrents using multiple indexers through
Jackett
integration - Fetch movie titles and posters from The Movie Database (TMDB)
- Interactive selection of torrents and movie titles using
fzf
- Automatic detection and use of available media players (
omxplayer
,mpv
,vlc
) - Option to keep downloaded files after streaming
- Integration with
impd
for condensing videos for language learning - Real-time display of download progress and peer information
- Support for multiple languages and configurable settings
- Automatically subtitle searching using great
osd
program
Prerequisites
Before using btstrm
, ensure that you have the following dependencies installed:
- Python 3.x
- Player of your choice:
mpv
,vlc
oromxplayer
(for RPi) btfs
(BitTorrent Filesystem)fzf
(fuzzy finder)Jackett
(optional, but highly recommended for torrent search integration)impd
(optional, for language immersion enthusiasts)chafa
(for displaying movie posters)- osd (optional, for subtitle downloading)
- Required Python packages:
requests
,tqdm
,colorama
,beautifulsoup4
,unidecode
At ArchLinux you can find all these programs in repos or AUR.
Installation via PyPi
pipx install btstrm
Manual installation
-
Clone the repository or download the
btstrm.py
file. -
Install the required Python packages:
pip install requests tqdm colorama beautifulsoup4 unidecode
-
Install btfs, fzf, and Jackett by following their respective installation instructions.
-
Configure Jackett and obtain the API key.
-
Create a configuration file named
btstrm.conf
in the~/.config
directory with the following content:[DEFAULT] LANG = es-ES JACKETT_API_KEY = your_jackett_api_key JACKETT_URL = http://127.0.0.1:9117
Replace
your_jackett_api_key
with your actual Jackett API key and adjust theJACKETT_URL
if necessary.You can omit this step because
btstrm
creates configuration file automatically.
Usage
To use btstrm
, run the following command:
python btstrm.py [options] [URI]
Options:
-p PLAYER
,--player PLAYER
: Specify the media player to use for streaming (default: auto-detect)-k
,--keep
: Keep the downloaded files after streaming (default: delete files)-i
,--impd
: Add the downloaded files to impd playlist (default: disabled)-s [MOVIE_NAME]
,--subtitles [MOVIE_NAME]
: Search opensubtitles for subs with optional name title-t TITLE
,--title TITLE
: Search for alternative movie titles and select using fzf
URI:
- Video/audio content name, magnet link or torrent file
Examples:
python btstrm.py -p mpv -k magnet:?xt=urn:btih:example
python btstrm.py -t "Movie Title"
python btstrm.py "Big Buck Bunny"
Configuration
The btstrm.conf
file allows you to customize the following settings:
LANG
: Set the language code for TMDB searches (default: es-ES)JACKETT_API_KEY
: Set your Jackett API keyJACKETT_URL
: Set the URL of your Jackett server (default: http://127.0.0.1:9117)
Contributing
Contributions to btstrm
are welcome! If you find any bugs, have feature requests, or want to contribute improvements, please open an issue or submit a pull request on the GitHub repository.
Acknowledgements
btstrm
was inspired by the need for a simple and efficient way to stream torrents from the command line. It wouldn't have been possible without the following projects and some codebase from developers:
- btfs: https://github.com/johang/btfs
- fzf: https://github.com/junegunn/fzf
- Jackett: https://github.com/Jackett/Jackett
- The Movie Database: https://www.themoviedb.org/
Disclaimer
Please note that streaming copyrighted content without permission is illegal in many jurisdictions. The authors of btstrm
do not condone or encourage the illegal use of this software. Use it responsibly and respect the rights of content creators.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file btstrm-0.1.7.tar.gz
.
File metadata
- Download URL: btstrm-0.1.7.tar.gz
- Upload date:
- Size: 23.8 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d8c424cc05b5dbf7d9d29e2d72530b879725b6050d1a409d875e8e7922755ded |
|
MD5 | 6853bcf2a35d73e5dabe2d369498b90a |
|
BLAKE2b-256 | a8fb9d3c52794de789d863bb2b1a6f9046339201c7dbcf5604913d3d4250417a |
File details
Details for the file btstrm-0.1.7-py3-none-any.whl
.
File metadata
- Download URL: btstrm-0.1.7-py3-none-any.whl
- Upload date:
- Size: 22.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: twine/5.0.0 CPython/3.12.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | d0e3803706897f6cf5f8707b18a51c968beb9320890ca5873cac1a6dff929c06 |
|
MD5 | f9969c0df909c91b7a8abf382991e9e6 |
|
BLAKE2b-256 | cb42c9b4f5f54b1cb3065941722566e6c8295939d9afb7c055eaa89f522b6dfd |