An intuitive web interface for searching and requesting book downloads, designed to work seamlessly with Calibre-Web-Automated. This project streamlines the process of downloading books and preparing them for integration into your Calibre library.
- π User-friendly web interface for book search and download
- π Automated download to your specified ingest folder
- π Seamless integration with Calibre-Web-Automated
- π Support for multiple book formats (epub, mobi, azw3, fb2, djvu, cbz, cbr)
- π‘οΈ Cloudflare bypass capability for reliable downloads
- π³ Docker-based deployment for quick setup
- Docker
- Docker Compose
- A running instance of Calibre-Web-Automated (recommended)
-
Get the docker-compose.yml:
curl -O https://raw.githubusercontent.com/calibrain/calibre-web-automated-book-downloader/refs/heads/main/docker-compose.yml
-
Start the service:
docker compose up -d
-
Access the web interface at
http://localhost:8084
| Variable | Description | Default Value |
|---|---|---|
FLASK_PORT |
Web interface port | 8084 |
FLASK_HOST |
Web interface binding | 0.0.0.0 |
DEBUG |
Debug mode toggle | false |
INGEST_DIR |
Book download directory | /cwa-book-ingest |
TZ |
Container timezone | UTC |
UID |
Runtime user ID | 1000 |
GID |
Runtime group ID | 100 |
CWA_DB_PATH |
Calibre-Web's database | None |
ENABLE_LOGGING |
Enable log file | true |
LOG_LEVEL |
Log level to use | info |
If you wish to enable authentication, you must set CWA_DB_PATH to point to Calibre-Web's app.db, in order to match the username and password.
If logging is enabld, log folder default location is /var/log/cwa-book-downloader
Available log levels: DEBUG, INFO, WARNING, ERROR, CRITICAL. Higher levels show fewer messages.
Note that if using TOR, the TZ will be calculated automatically based on IP.
| Variable | Description | Default Value |
|---|---|---|
MAX_RETRY |
Maximum retry attempts | 3 |
DEFAULT_SLEEP |
Retry delay (seconds) | 5 |
MAIN_LOOP_SLEEP_TIME |
Processing loop delay (seconds) | 5 |
SUPPORTED_FORMATS |
Supported book formats | epub,mobi,azw3,fb2,djvu,cbz,cbr |
BOOK_LANGUAGE |
Preferred language for books | en |
AA_DONATOR_KEY |
Optional Donator key for Anna's Archive fast download API | `` |
USE_BOOK_TITLE |
Use book title as filename instead of ID | false |
PRIORITIZE_WELIB |
When downloading, download from WELIB first instead of AA | false |
ALLOW_USE_WELIB |
Allow usage of welib for downloading books if found there | true |
If you change BOOK_LANGUAGE, you can add multiple comma separated languages, such as en,fr,ru etc.
| Variable | Description | Default Value |
|---|---|---|
AA_BASE_URL |
Base URL of Annas-Archive (could be changed for a proxy) | https://annas-archive.org |
USE_CF_BYPASS |
Disable CF bypass and use alternative links instead | true |
If you are a donator on AA, you can use your Key in AA_DONATOR_KEY to speed up downloads and bypass the wait times.
If disabling the cloudflare bypass, you will be using alternative download hosts, such as libgen or z-lib, but they usually have a delay before getting the more recent books and their collection is not as big as aa's. But this setting should work for the majority of books.
| Variable | Description | Default Value |
|---|---|---|
AA_ADDITIONAL_URLS |
Proxy URLs for AA (, separated) | `` |
HTTP_PROXY |
HTTP proxy URL | `` |
HTTPS_PROXY |
HTTPS proxy URL | `` |
CUSTOM_DNS |
Custom DNS IP | `` |
USE_DOH |
Use DNS over HTTPS | false |
For proxy configuration, you can specify URLs in the following format:
# Basic proxy
HTTP_PROXY=http://proxy.example.com:8080
HTTPS_PROXY=http://proxy.example.com:8080
# Proxy with authentication
HTTP_PROXY=http://username:[email protected]:8080
HTTPS_PROXY=http://username:[email protected]:8080The CUSTOM_DNS setting supports two formats:
-
Custom DNS Servers: A comma-separated list of DNS server IP addresses
- Example:
127.0.0.53,127.0.1.53(useful for PiHole) - Supports both IPv4 and IPv6 addresses in the same string
- Example:
-
Preset DNS Providers: Use one of these predefined options:
google- Google DNSquad9- Quad9 DNScloudflare- Cloudflare DNSopendns- OpenDNS
For users experiencing ISP-level website blocks (such as Virgin Media in the UK), using alternative DNS providers like Cloudflare may help bypass these restrictions
If a CUSTOM_DNS is specified from the preset providers, you can also set a USE_DOH=true to force using DNS over HTTPS,
which might also help in certain network situations. Note that only google, quad9, cloudflare and opendns are
supported for now, and any other value in CUSTOM_DNS will make the USE_DOH flag ignored.
Try something like this :
CUSTOM_DNS=cloudflare
USE_DOH=true| Variable | Description | Default Value |
|---|---|---|
CUSTOM_SCRIPT |
Path to an executable script that tuns after each download | `` |
If CUSTOM_SCRIPT is set, it will be executed after each successful download but before the file is moved to the ingest directory. This allows for custom processing like format conversion or validation.
The script is called with the full path of the downloaded file as its argument. Important notes:
- The script must preserve the original filename for proper processing
- The file can be modified or even deleted if needed
- The file will be moved to
/cwa-book-ingestafter the script execution (if not deleted)
You can specify these configuration in this format :
environment:
- CUSTOM_SCRIPT=/scripts/process-book.sh
volumes:
- local/scripts/custom_script.sh:/scripts/process-book.sh
volumes:
- /your/local/path:/cwa-book-ingest
- /cwa/config/path/app.db:/auth/app.db:roNote - If your library volume is on a cifs share, you will get a "database locked" error until you add nobrl to your mount line in your fstab file. e.g. //192.168.1.1/Books /media/books cifs credentials=.smbcredentials,uid=1000,gid=1000,iocharset=utf8,nobrl - See crocodilestick/Calibre-Web-Automated#64 (comment)
Mount should align with your Calibre-Web-Automated ingest folder.
This application also offers a variant that routes all its traffic through the Tor network. This can be useful for enhanced privacy or bypassing network restrictions.
To use the Tor variant:
- Get the Tor-specific docker-compose file:
curl -O https://raw.githubusercontent.com/calibrain/calibre-web-automated-book-downloader/refs/heads/main/docker-compose.tor.yml
- Start the service using this file:
docker compose -f docker-compose.tor.yml up -d
Important Considerations for Tor:
- Capabilities: This variant requires the
NET_ADMINandNET_RAWDocker capabilities to configureiptablesfor transparent Tor proxying. - Timezone: When running in Tor mode, the container will attempt to determine the timezone based on the Tor exit node's IP address and set it automatically. This will override the
TZenvironment variable if it is set. - Network Settings: Custom DNS, DoH, and HTTP(S) proxy settings (
CUSTOM_DNS,USE_DOH,HTTP_PROXY,HTTPS_PROXY) are ignored when using the Tor variant, as all traffic goes through Tor.
This variant allows the application to use an external service to bypass Cloudflare protection, instead of relying on the built-in bypasser. This is useful if you already have a dedicated Cloudflare resolver (such as FlareSolverr or compatible services like ByParr) running elsewhere.
- When enabled, all requests that require Cloudflare bypass are sent to your external resolver service.
- The application communicates with the resolver using its API.
- This approach can improve reliability and performance, especially if your external resolver is optimized or shared across multiple applications.
| Variable | Description | Default Value |
|---|---|---|
EXT_BYPASSER_URL |
The full URL of your external resolver (required) | |
EXT_BYPASSER_PATH |
API path for the resolver (usually /v1) |
/v1 |
EXT_BYPASSER_TIMEOUT |
Timeout for page loading (in milliseconds) | 60000 |
This feature follows the same configuration of the built-in Cloudflare bypasser, so you should turn on the USE_CF_BYPASS configuration to enable it.
- Get the extbp-specific docker-compose file:
curl -O https://raw.githubusercontent.com/calibrain/calibre-web-automated-book-downloader/refs/heads/main/docker-compose.extbp.yml
- Start the service using this file:
docker compose -f docker-compose.extbp.yml up -d
This feature is designed to work with any resolver that implements the FlareSolverr API schema, including ByParr and similar projects.
- Centralizes Cloudflare bypass logic for easier maintenance.
- Can leverage more powerful or distributed resolver infrastructure.
- Reduces load on the main application container.
The application consists of a single service:
- calibre-web-automated-bookdownloader: Main application providing web interface and download functionality
Built-in health checks monitor:
- Web interface availability
- Download service status
- Cloudflare bypass service connection
Checks run every 30 seconds with a 30-second timeout and 3 retries. You can enable by adding this to your compose :
HEALTHCHECK --interval=30s --timeout=30s --start-period=5s --retries=3 \
CMD pyrequests http://localhost:8084/request/api/status || exit 1
Logs are available in:
- Container:
/var/logs/cwa-book-downloader.log - Docker logs: Access via
docker logs
Contributions are welcome! Feel free to submit a Pull Request.
This project is licensed under the MIT License - see the LICENSE file for details.
While this tool can access various sources including those that might contain copyrighted material (e.g., Anna's Archive), it is designed for legitimate use only. Users are responsible for:
- Ensuring they have the right to download requested materials
- Respecting copyright laws and intellectual property rights
- Using the tool in compliance with their local regulations
Please note that the current version:
- Does not check for existing files in the download directory
- Does not verify if books already exist in your Calibre database
- Exercise caution when requesting multiple books to avoid duplicates
For issues or questions, please file an issue on the GitHub repository.



