Simple script to download purchases from humble bundle account.
By default, script download multiple files at once, starting with the biggest files. Script will only download files specified by platform parameter. Platform parameter is based on platform selection in HB Library.
Script only download files once even if it was purchased in multiple bundles. It will be saved in the oldest bundle/purchase folder.
To not download files multiple times, hash of file is computed and compared with one provided by HB, so if HB will update files it will overwrite existing one.
By default, file are saved in following folder structure:
platform/date of purchase bundle name/item name
This structure helps with importing e-books into calibre, so each e-book will be in separate folder with multiple available formats.
Python in version 3.x or higher, accessible in command line
Script require few additional non-standard packages. Install them with
pip install python-slugify ruamel.yaml requests loguru --userFor Windows systems script require removing 260 path name limit, otherwise download of some files will fail or script will try to redownload files with long file names.
Make config.yaml file based on example_config.yaml and provide
_simpleauth_sess cookie from browser between apostrophes.
Providing switches for download_limit and purchase_limit ignore default values from config.yaml file.
usage: hb_downloader.py [-h] [-l X] [-n Y] [-s] [-w] [-m] platform [platform ...]
Download files from Humble Bundle, based on selected platform
positional arguments:
platform platform to download, valid platforms are: ['android', 'audio', 'ebook', 'linux', 'mac', 'windows', 'video',
'other', 'nogames', 'all']
options:
-h, --help show this help message and exit
-l, --download_limit X
Download X files in parallel
-n, --purchase_limit Y
Download only from Y newest purchases, 0 for all --default
-s, --smallest_first Download smallest files first
-w, --keep_wrong_size
Download files with wrong size and keep them
-m, --keep_wrong_md5sum
keep files with wrong md5sum themYou can specify multiple platforms to download, for example to download all audio albums, and all e-book files:
python hb_downloader.py audio ebookTo download all files from HB account use:
python hb_downloader.py allTo download all files, but not games:
python hb_downloader.py nogames
By default, script download multiple files at once, starting with the biggest files. You can limit maximum parallel downloads by specifying download-limit, to download 6 audio files at once use:
python hb_downloader.py -l 6 audio
To download only files from the latest purchase use purchase-limit option, for example to download only e-books from last 5 bundles use:
python hb_downloader.py -n 5 ebook
Above example will skip files if they were in previous bundles purchased, so it recommended use is to update downloaded collection by newest purchased bundles not downloaded before. If purchase-limit option is omitted all previously downloaded files will have their hash recomputed which will slow down overall process of downloading.
Added flags to keep files with wrong reported sizes and hashes. Humble no longer provide md5sum on their websites, when downloading, so i stopped nagging them that sums and/or sizes are incorrect. So to keep downloading all books I added such flag. There are some files with wrong size, but correct hash, but most of them will have both wrong. So you probably want to use both flags.
In 2020-11-01 ability to download trove games was added.
By default script don't try to download trove games, it can be enable in config file or by using --trove switch. Trove games are inside windows/linux/mac folder in 2010-11-24 trove directory. If reported md5sum for trove games is identical to games from other purchase, then it will be put in corresponding purchase folder and not trove directory.
Script don't have ability to download only trove games
Trove support was dropped on 2022-02-15, because Humble Bundle no longer provide it.
On 2022-08-08 created podman/docker image for easy use.
To download image use:
podman pull ghcr.io/tokariew/hb_downloader:latestBasic run looks like:
podman run -it --rm -v .:/srv:z hb_downloader:latest allAbove command at first run will create config.yaml file and fail, edit
the file by providing session_cookie and run it again. Don't edit
download_folder unless you properly change container volume. Files
will be downloaded into current folder. You can change it by changing
volume location for example:
podman run -it --rm -v ~/Downloads/hb:/srv:z hb_downloader:latest all