Quasarr connects JDownloader with Radarr, Sonarr and LazyLibrarian. It also decrypts links protected by CAPTCHAs.
Project description
Quasarr connects JDownloader with Radarr, Sonarr and LazyLibrarian. It also decrypts links protected by CAPTCHAs.
Quasarr pretends to be both Newznab Indexer and SABnzbd client. Therefore, do not try to use it with real usenet
indexers. It simply does not know what NZB files are.
Quasarr includes a solution to quickly and easily decrypt protected links. Active monthly Sponsors get access to SponsorsHelper to do so automatically. Alternatively, follow the link from the console output (or discord notification) to solve CAPTCHAs manually. Quasarr will confidently handle the rest. Some CAPTCHA types require Tampermonkey to be installed in your browser.
Instructions
- Set up and run FlareSolverr 3
- Set up and run JDownloader 2
- Configure the integrations below
Finding your Quasarr URL and API Key
Both values are shown in the console output under API Information, or in the Quasarr web UI.
FlareSolverr
Provide your FlareSolverr URL during setup. Include the version path:
http://192.168.1.1:8191/v1
Quasarr
⚠️ Quasarr requires at least one valid hostname to start. It does not provide or endorse any specific sources, but community-maintained lists are available:
🔗 quasarr-hostnames.pages.dev — third-party guide for finding hostnames
📋 Alternatively, browse community suggestions via pastebin search (login required).
JDownloader
⚠️ If using Docker: JDownloader's download path must be available to Radarr/Sonarr/LazyLibrarian with identical internal and external path mappings! Matching only the external path is not sufficient.
- Start and connect JDownloader to My JDownloader
- Provide your My JDownloader credentials during Quasarr setup
Fresh install recommended
Consider setting up a fresh JDownloader instance. Quasarr will modify JDownloader's settings to enable Radarr/Sonarr/LazyLibrarian integration.
Radarr / Sonarr
⚠️ Sonarr users: Set all shows (including anime) to the Standard series type. Quasarr cannot find releases for shows set to Anime/Absolute.
Add Quasarr as both a Newznab Indexer and SABnzbd Download Client using your Quasarr URL and API Key.
Show download status in Radarr/Sonarr
Activity → Queue → Options → Enable Release Title
Restrict results to a specific mirror
Append the mirror name to your Newznab URL:
/api/dropbox/
Only releases with dropbox in a link will be returned. If the mirror isn't available, the release will fail.
LazyLibrarian
⚠️ Experimental feature — Report issues when a hostname returns results on its website but not in LazyLibrarian.
Setup instructions
SABnzbd+ Downloader
| Setting | Value |
|---|---|
| URL/Port | Your Quasarr host and port |
| API Key | Your Quasarr API Key |
| Category | docs |
Newznab Provider
| Setting | Value |
|---|---|
| URL | Your Quasarr URL |
| API | Your Quasarr API Key |
Fix Import & Processing
Importing:
- Enable
OpenLibrary api for book/author information - Set Primary Information Source to
OpenLibrary - Add to Import languages:
, Unknown(German users:, de, ger, de-DE)
Processing → Folders:
- Add your Quasarr download path (typically
/downloads/Quasarr/)
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'='' \
-e 'TZ'='Europe/Berlin' \
ghcr.io/rix1337/quasarr:latest
INTERNAL_ADDRESSis required so Radarr/Sonarr/LazyLibrarian 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.TZis optional, wrong timezone can cause HTTPS/SSL issues
Manual setup
Use this only in case you can't run the docker image.
pip install quasarr
- 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. Most feature requests can be satisfied by:
- Existing settings in Radarr/Sonarr/LazyLibrarian
- Existing settings in JDownloader
- Existing tools from the *arr ecosystem that integrate directly with Radarr/Sonarr/LazyLibrarian
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.
- A short guide to set up required dev services is found in /docker/dev-setup.md
- 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.
SponsorsHelper
SponsorsHelper is a Docker image that solves CAPTCHAs and decrypts links for Quasarr.
Image access is limited to active monthly GitHub sponsors.
🔑 GitHub Token Setup
- Start your sponsorship first.
- Open GitHub Classic Token Settings
- Name it (e.g.,
SponsorsHelper) and choose unlimited expiration - Enable these scopes:
read:packagesread:userread:org
- Click Generate token and copy it for the next steps
🐋 Docker Login
⚠️ Before logging in, the image will not download.
echo "GITHUB_TOKEN" | docker login ghcr.io -u USERNAME --password-stdin
USERNAME→ your GitHub usernameGITHUB_TOKEN→ the token you just created
▶️ Run SponsorsHelper
⚠️ Without a valid GitHub token linked to an active sponsorship, the image will not run.
docker run -d \
--name='SponsorsHelper' \
-e 'QUASARR_URL'='http://192.168.0.1:8080' \
-e 'DEATHBYCAPTCHA_TOKEN'='2FMum5zuDBxMmbXDIsADnllEFl73bomydIpzo7...' \
-e 'GITHUB_TOKEN'='ghp_123.....456789' \
-e 'FLARESOLVERR_URL'='http://10.10.0.1:8191/v1' \
-e 'NX_USER'='your_nx_username' \
-e 'NX_PASS'='your_nx_password' \
-e 'JUNKIES_USER'='your_junkies_username' \
-e 'JUNKIES_PASS'='your_junkies_password' \
-e 'JUNKIES_HOSTER'='your_desired_hoster' \
ghcr.io/rix1337-sponsors/docker/helper:latest
QUASARR_URL→ Local URL of QuasarrDEATHBYCAPTCHA_TOKEN→ DeathByCaptcha account tokenGITHUB_TOKEN→ Classic GitHub PAT with the scopes listed aboveFLARESOLVERR_URL→ Local URL of FlareSolverr - required!NX_USER/NX_PASS→ NX account credentialsJUNKIES_USER/JUNKIES_PASS→ Junkies account credentialsJUNKIES_HOSTER→ Preferred hoster for Junkies links
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.27.0.tar.gz.
File metadata
- Download URL: quasarr-1.27.0.tar.gz
- Upload date:
- Size: 623.3 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
9b83c59b7eb34ddc22625230a0e585f7aa74c90cd70eeeb9a1a58824cc948c88
|
|
| MD5 |
2fec8ab35261c70f58dd8f17e4582d7d
|
|
| BLAKE2b-256 |
846f0f874521a78541bb35e02ee7bbe5b31163af8c46f12477e0d85a3dd90b71
|
File details
Details for the file quasarr-1.27.0-py3-none-manylinux2014_aarch64.whl.
File metadata
- Download URL: quasarr-1.27.0-py3-none-manylinux2014_aarch64.whl
- Upload date:
- Size: 667.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
8fcd29ae7b6d689ceab5f81f04709002674cc3269915319e2a57247b7636c433
|
|
| MD5 |
3659086879585fd5775e0490e6d7d6c4
|
|
| BLAKE2b-256 |
fb5dde709e51adc1ff4ec1ae878d75fd650cd88ae00e81957a57f5980dcfaea3
|
File details
Details for the file quasarr-1.27.0-py3-none-any.whl.
File metadata
- Download URL: quasarr-1.27.0-py3-none-any.whl
- Upload date:
- Size: 667.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/6.2.0 CPython/3.12.3
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
2aa4696dd7ea5e3cf5b8ea987cfda387972a0d32e38e2270f7871e5c82a22526
|
|
| MD5 |
b42c3c1d232d836db734ecefd102ad6e
|
|
| BLAKE2b-256 |
75ee9c17b3092f481e13f11091189f089953b909b697bbcfc0f4b51994dfcd4e
|