Full template for python web projects with Docker, GitHub Actions, PyPI, and more.
Project description
Quasarr connects JDownloader with Radarr and Sonarr. It also decrypts links protected by CAPTCHAs.
Quasarr poses as a Newznab Indexer and a SABnzbd client. It will thus never work in parallel with a real NZB indexer and download client set up. Torrents are unaffected. To still use NZB indexers, you must set fixed download clients in the advanced indexer settings for Radarr/Sonarr.
Quasarr includes a solution to quickly and easily decrypt protected links. Active Sponsors get access to SponsorsHelper to do so automatically. Alternatively, follow the link from the console output (or discord notification) to solve the CAPTCHA manually. Quasarr will confidently handle the rest.
Instructions
- Set up at least one hostname for Quasarr to use
- Chose your own or use the
HOSTNAMESvariable to provide a list of hostnames. - This project will not condone nor provide you with hostnames. Search Google, Pastebin, etc. for suggestions.
- Always redact hostnames when creating issues in this repo.
- Quasarr will become available once at least one suitable hostname is set.
- Chose your own or use the
- Provide your My-JDownloader-Credentials
- Consider setting up a fresh JDownloader before you begin.
- JDownloader must be running and available to Quasarr.
- Quasarr will modify the settings of JDownloader so downloads can be properly handled by Radarr/Sonarr.
- If using docker, make extra sure that JDownloader's download path is available to Radarr/Sonarr with the exact same internal and external path mapping. Just matching the external path is not enough.
- Set up Quasarr as
Newznab IndexerandSABnzbd Download Clientin Radarr/Sonarr- Use the
URLfrom theAPI Informationsection of the console output (or copy it from the Quasarr web UI) - Use the
API Keyfrom theAPI Informationsection of the console output (or copy it from the Quasarr web UI) - Leave all other settings by default.
- If you prefer to only get releases for a specific mirror, add the mirror name to the
API path in the advanced indexer settings.
- Example:
/api/dropbox/results will only return releases wheredropboxis explicitly mentioned in a link. - This means that if a mirror is not available at a hostname, the release is ignored or the download will fail. So use this option with caution.
- Example:
- Use the
- To see download status information
- Open
Activity→Queue→Optionsin Radarr/Sonarr - Enable
Release Title
- Open
Docker
It is highly recommended to run the latest docker image with all optional variables set.
docker run -d \
--name="Quasarr" \
-p port:8080 \
-v /path/to/config/:/config:rw \
-e 'INTERNAL_ADDRESS'='http://192.168.0.1:8080' \
-e 'EXTERNAL_ADDRESS'='https://foo.bar/' \
-e 'DISCORD'='https://discord.com/api/webhooks/1234567890/ABCDEFGHIJKLMN' \
-e 'HOSTNAMES'='https://pastebin.com/raw/eX4Mpl3'
-e 'SILENT'='True' \
-e 'DEBUG'='' \
ghcr.io/rix1337/quasarr:latest
INTERNAL_ADDRESSis required so Radarr/Sonarr can reach Quasarr. Must include port!EXTERNAL_ADDRESSis optional and helpful if using a reverse proxy. Always protect external access with basic auth!DISCORDis optional and must be a valid Discord webhook URL.HOSTNAMESis optional and allows skipping the manual hostname step during setup.- Must be a publicly available
HTTPorHTTPslink - Must be a raw
.ini/ text file (not HTML or JSON) - Must contain at least one valid Hostname per line
ab = xyz
- Must be a publicly available
SILENTis optional and silences all discord notifications except for error messages from SponsorsHelper ifTrue.DEBUGis optional and enables debug logging ifTrue.
Manual setup
Use this only in case you can't run the docker image.
pip install
- Requires Python 3.12 or later
--port=8080
--discord=https://discord.com/api/webhooks/1234567890/ABCDEFGHIJKLMN
--external_address=https://foo.bar/
--hostnames=https://pastebin.com/raw/eX4Mpl3
--discordseeDISCORDdocker variable--external_addressseeEXTERNAL_ADDRESSdocker variable--hostnamesseeHOSTNAMESdocker variable
Philosophy
Complexity is the killer of small projects like this one. It must be fought at all cost!
We will not waste precious time on features that will slow future development cycles down. It is by choice, that you will not find settings or filtering options in Quasarr.
Most feature requests can be satisfied by:
- Existing settings in Radarr/Sonarr
- Existing settings in JDownloader
- Existing tools from the *arr ecosystem that integrate directly with Radarr/Sonarr
If you want to edit the hostname selection after the initial setup, you can do so by editing or deleting Quasarr.ini.
Roadmap
- Assume there are zero known issues unless you find one or more open issues in this repository.
- Still having an issue? Provide a detailed report here!
- There are no hostname integrations in active development unless you see an open pull request here.
- Pull requests are welcome. Especially for popular hostnames.
- Always reach out on Discord before starting work on a new feature to prevent waste of time.
- Please follow the existing code style and project structure.
- Anti-bot measures must be circumvented fully by Quasarr. Thus you will need to provide a working solution for new CAPTCHA types by integrating it in the Quasarr Web UI.
- Please provide proof of functionality (screenshots/examples) when submitting your pull request.
Development Setup for Pull Requests
To test your changes before submitting a pull request:
Run Quasarr with the --internal_address parameter:
python Quasarr.py --internal_address=http://<host-ip>:<port>
Replace <host-ip> and <port> with the scheme, IP, and port of your host machine.
The --internal_address parameter is mandatory.
Start the required services using the dev-services-compose.yml file:
CONFIG_VOLUMES=/path/to/config docker-compose -f docker/dev-services-compose.yml up
Replace /path/to/config with your desired configuration location.
The CONFIG_VOLUMES environment variable is mandatory.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distributions
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file quasarr-1.5.1.tar.gz.
File metadata
- Download URL: quasarr-1.5.1.tar.gz
- Upload date:
- Size: 121.1 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
10af8549b138e888c25cf960d937512e7bd82283528e6720ff33c5ea8989f40f
|
|
| MD5 |
e12d9ceffc89e41078eff2d24892364b
|
|
| BLAKE2b-256 |
d349666ca8f8f88db15368a37483d594292d9de3b06fe7dbf9bd417e7b368367
|
File details
Details for the file quasarr-1.5.1-py3-none-manylinux2014_aarch64.whl.
File metadata
- Download URL: quasarr-1.5.1-py3-none-manylinux2014_aarch64.whl
- Upload date:
- Size: 139.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2dc6516ed6ef81ddee62c064c3c67f50dc2c46a9c79de8fa911a345cbce24985
|
|
| MD5 |
f7a6aabf8ddee877de3cbee7498d32f8
|
|
| BLAKE2b-256 |
c69508408db508b612b6546e844b7da690e0e79bff4843cf7102fa9ec64dbcef
|
File details
Details for the file quasarr-1.5.1-py3-none-any.whl.
File metadata
- Download URL: quasarr-1.5.1-py3-none-any.whl
- Upload date:
- Size: 139.5 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.1.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
d84f39a30f05dbe51d965f716c4de74c3b66c0003167b75c72841bea36a3e2b3
|
|
| MD5 |
0001ace3b334d797231611a1a64a5fc8
|
|
| BLAKE2b-256 |
e5ca56fef3f699b0ed47b9392c9c45001e2860d6351ed6472571991f843d5e1d
|