Humble Trove Downloader
Quick and dirty script to download all games, for all operating systems, from Humble Trove. You need a Humble Monthly subscription to download these games.
Forked from Slashbunny's excellent initial work; looking at the more "popular" Humble Trove downloaders made me think I'd have to write mine from scratch, until I found this clean but full-featured one. (Honorable mention goes to the one by darktohka -- initially I felt that was a bit too OO for this task, but the more I looked at it the more it grew on me.) Not that more than ten people will end up seeing this anyway, but credit where credit's due. I thought about making a PR for my changes, but they got to be rather expansive and I didn't have the good forethought to fork off features as I made them. Most of the README below also comes from upstream, so while I'll eventually try to update the below as I go, the code is the final authority.
Existing files have their md5 checksums checked versus what the Humble Bundle API reports. If there is a mismatch, you'll be prompted to skip or overwrite the file in question. For unattended options, check the available option flags (-h for help).
Setup
Pre-requisites
Install PHP and Composer. If you are using Linux, these should be available from your distribution's package repositories.
Install Dependencies
After cloning this repository, run composer
in the project's main directory
to install dependencies:
$ composer install
Usage
API Key
See the instructions here on how to get a session key from your browser while logged into the Humble Bundle website. This script will not work without it.
Running the Script
$ ./src/download.php DOWNLOAD_PATH HUMBLE_API_KEY
Example (this is not a real key):
$ ./src/download.php /home/downloads/trove "eyJ1GzZJE0oqwEaunyOYX3yrlkFUxPJq8PFWCgkKOHM00\075|1566665561|JR7m2nO769sO2Je4C2fE"
Excluding OS or Games
You can exclude operating systems with the -o
parameter and games with the -g
parameter. To exclude multiple, specify them in a comma-separated list as follows:
$ ./src/download.php -o mac,linux -g game1,game2,game3 /home/downloads/trove "eyJ1GzZJE0oqwEaunyOYX3yrlkFUxPJq8PFWCgkKOHM00\075|1566665561|JR7m2nO769sO2Je4C2fE"
-o
can be "mac", "linux", and/or "windows". -g
should be the "machine name"
of the games, which are output in square brackets when downloading:
Processing The Flame in the Flood [theflameintheflood_trove]...
In the above example, you should use theflameintheflood_trove
when using the
-g
parameter.
You can also find this "machine name" value on the Humble Trove website. When you click on the game you are planning to exclude, the URL in your browser will change to the following format:
https://www.humblebundle.com/subscription/trove?selected=theflameintheflood_trove
The value of the selected=
parameter in the URL is the same name you should
use when excluding games from download using this tool.
Docker
Slashbunny's docker image is available so you don't need to setup PHP or deal with dependencies:
$ docker run -it \
-v /your/path/to/downloads/folder/:/downloads \
-u $(id -u):$(id -g) \
slashbunny/humble-trove-downloader:latest /downloads "eyJ1GzZJE0oqwEaunyOYX3yrlkFUxPJq8PFWCgkKOHM00\075|1566665561|JR7m2nO769sO2Je4C2fE"
The above will create the Docker instance with the upstream source; you can then attach to your local copy of the container and overwrite that with the download.php from this repo.
Help
Error Message: "Trying to get property 'signed_url' of non-object"
Your API key is wrong. Double check is it correct and quote it the same way in the example under Usage.