- Add new booklore API file formats - Renamed cookie for better login persistence with reverse proxy - Updated fs.py to try hardlink before atomic move from tmp dir - Fix transmission URL parsing - Fix scenario where file processing of huge files starves the healthcheck - Large enhancements to custom scripting, including passing JSON download info, more consistent activation across output types, decoupling from staging behavior, and added full documentation.
4.8 KiB
Directory and Volume Setup
This guide explains how to configure directories and Docker volumes for Shelfmark. It focuses on the difference between the destination folder and your download client paths, and how to make those paths line up inside containers.
Conceptual Overview
DIRECT DOWNLOADS
Shelfmark downloads directly -> destination
TORRENT / USENET
Prowlarr -> Download client saves to <client path>
-> Shelfmark reads from <client path>
-> Shelfmark processes to destination
Key point: For torrent and usenet downloads, Shelfmark must see the same file path that your download client reports. The container path must match in both containers.
Direct Download Setup
Direct downloads do not use an external download client. A simple two-folder setup is enough.
Required volumes:
| Container path | Purpose | Notes |
|---|---|---|
/config |
Settings, database, cover cache | Configurable via CONFIG_DIR |
/books |
Destination folder for completed files | Configurable via INGEST_DIR and Settings -> Downloads -> Destination |
Example docker-compose:
services:
shelfmark:
image: ghcr.io/calibrain/shelfmark:latest
volumes:
- /path/to/config:/config
- /path/to/books:/books
Notes:
- Point
/booksto your library ingest folder (Calibre-Web, Booklore, Audiobookshelf, etc) for automatic import. - If you set Books Output Mode to Booklore (API), books are uploaded via API instead of written to
/books. Audiobooks still use a destination folder. - Ensure
PUID/PGID(or legacyUID/GID) match the owner of the host directories to avoid permission errors.
Torrent / Usenet Setup
For torrents and usenet, your download client reports a path (for example /data/torrents/books/MyBook.epub). Shelfmark must be able to read that exact path inside its own container.
Required volumes:
| Container path | Purpose | Notes |
|---|---|---|
/config |
Settings, database, cover cache | Configurable via CONFIG_DIR |
/books |
Destination folder for processed files | Configurable via INGEST_DIR |
<client path> |
Download client path | Must match the download client container path exactly |
Side-by-side example with qBittorrent:
services:
shelfmark:
volumes:
- /path/to/config:/config
- /path/to/books:/books
- /path/to/downloads:/data/torrents # Must match client
qbittorrent:
volumes:
- /path/to/downloads:/data/torrents # Same container path
Host paths can be anything. The container path (for example /data/torrents) must be identical in both containers.
Remote Path Mappings
If paths cannot match (different machines or a fixed setup), use Remote Path Mappings.
Where to configure:
- Settings -> Advanced -> Remote Path Mappings
Example:
- Client reports
/data/torrents/books/... - Shelfmark can see the same files at
/downloads/books/... - Add a mapping from Remote Path
/data/torrentsto Local Path/downloads
File Processing Options
Transfer Method (Torrent / Usenet Only)
Available methods:
- Copy (default). Works everywhere.
- Hardlink. Preserves seeding without duplicating files.
Hardlink requirements and behavior:
- Source and destination must be on the same filesystem.
- If hardlinking is enabled but not possible, Shelfmark falls back to copying.
- Archive extraction is disabled while hardlinking is enabled.
- Do not use hardlinking if your destination is a library ingest folder.
File Organization
Shelfmark supports three organization modes for the destination:
- None. Keep original filenames from the source.
- Rename Only. Rename files using a template.
- Rename and Organize. Create folders and rename using templates. Do not use with ingest folders.
Configure templates in Settings -> Downloads. Template syntax details are documented separately.
Common Mistakes
- "Download failed - file not found": Path mismatch between Shelfmark and the download client. Ensure container paths match or use Remote Path Mappings.
- "Permission denied":
PUID/PGIDdo not match the host directories. Ensure Shelfmark can read the client path and write to the destination. - "Hardlinks not working" or "Files being copied instead": Source and destination are on different filesystems. Move the destination or accept copy fallback.
- "Downloads work but library does not see them": Destination does not point to the library ingest folder. Check Settings -> Downloads -> Destination.
- CIFS/SMB shares: Use the
nobrlmount option to avoid database lock errors. Example://server/share /mnt/share cifs nobrl,... 0 0
Related Documentation
- Environment Variables Reference:
docs/environment-variables.md - Custom Scripts:
docs/custom-scripts.md - Installation:
docs/installation.md - Troubleshooting:
docs/troubleshooting.md