Photobox Downloader is a NodeJS module and CLI tool to make interacting with and downloading of albums/photos easy. Photobox is a popular photo printing website, while possible to download each photo one-by-one, there is no way to download an entire album at once. This project addresses that need.
While the app was developed against www.photobox.ie it should work against any of the other sister sites (www.photobox.co.uk, www.photobox.fr, www.photobox.de, etc...)
npm install -g photobox-downloader
mkdir albums
pbdl
Once you run the pbdl
application it will ask you for 4 items of information:
- The domain that your photos are on (www.photobox.ie, www.photobox.co.uk, etc...)
- The Authentication cookie value (see below for more detailed instructions)
- The directory where to store the files (this directory must exist already!)
- If you want to skip existing files (useful for resuming interrupted downloads)
When you log into your account on Photobox, Photobox sets an authentication cookie, if you know how to view cookies,
look for the pbx_www_photobox_xx
(xx depends on where you are logging into) cookie, otherwise you can just log into
your Photobox account, open the Developer Toolbar (press F12), goto the "Application" tab (Chrome), expand the
"Cookies" drop down. Click on the base domain (e.g. https://www.photobox.ie), copy the value of the cookie
called "pbx_www_photobox_ie" (the last part, "_ie", will change depending on your domain).
Alternatively, you can use cURL to get it (username and password have to url encoded). Change the URL if needed.
export EMAIL="yourmemail%40gmail.com" # url encoded email address
export PASS="password"
curl 'https://www.photobox.ie/' -H 'User-Agent: ' \
-H 'Content-Type: application/x-www-form-urlencoded' \
-H 'Accept: text/html,*/*;q=0.8' \
-H 'Cache-Control: max-age=0' --cookie-jar - \
--data 'global_action=login&email=$EMAIL&password=$PASS&auto_sign_in=on&login=Sign+in' \
--compressed | grep "pbx_www_photobox" | awk '{print "Authentication cookie: " $NF}'
A special debug mode can be accessed by passing "-d" parameter at the command line (e.g. "pbdl -d") to see extensive logging
You can also use photobox-downloader module inside your own projects to programmatically download photos.
var photoBox = require('photobox-downloader')(logger); // logger could be Winston logger or just: console
var config = {
"baseDomain" : "www.photobox.ie",
// change "authCookieValue" value to your own authentication cookie value, see "login" section below for more info
"authCookieValue" : "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx"
};
// Login and download all photos from every album
photoBox.login(config, function (err) {
if (err) {
console.log('ERROR! Something went wrong logging in, check your authCookieValue!');
console.log(err);
} else {
console.log('Logged into Photobox!');
photoBox.downloadAll(
{
showProgress : true,
outputDir : __dirname + '/out'
},
function (err) {
if (err) {
console.log(err);
} else {
console.log('Done! All photos downloaded (that was easy!)');
}
}
);
}
});
Attempt to get the contents of the albums page. You need to pass the authentication cookie value and the domain you wish to interact with.
Arguments
options
- An object that must contain 2 key/value pairs:
baseDomain
- photoboxDomain - The domain that you want to interact with. Example: "www.photobox.ie".authCookieValue
- "xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx" - The value of the "pbx_www_photobox_xx" cookie.
callback
- Function that is called once login operation is complete. If unsuccessful, the first parameter will be
not null. If successful, can now perform any additional operations.
Example
photoBox.login(
{
baseDomain : 'www.photobox.ie',
authCookieValue : 'xxxxxxxxxxxxxxxxxxxxxxxxxxxxxxxx'
},
function (err) {
if (err) {
console.log('ERROR! Something went wrong logging in!');
console.log(err);
} else {
console.log('Logged into Photobox!');
// Now run any additional command...
}
}
);
Downloads every photo in every album. A folder (with the name of the album) is created, all photos in that album will be downloaded to that album.
Arguments
options
- An object that must contain 2 key/value pairs:
showProgress
: true/false - Boolean - Whether to show a status bar of download progressoutputDir
: "/some/folder/path" - String - The path to where you want the photos downloaded to. Each album will be downloaded into its own folder
callback
- Function that is called once all photos have been downloaded (or if an error is thrown)
Example
photoBox.downloadAll(
{
showProgress : true,
outputDir : __dirname + '/out'
},
function callback (err) {
if (err) {
console.log(err);
} else {
console.log('Finished, all photos in every album have now been downloaded (that was easy!)');
}
}
);
Returns a list of albums (include naming, relative link/path and the number of photos in that album.
Example
var albums = photoBox.getAlbumList();
Downloads all the photos from one specific album. A folder with the name of the album will be created in the desired directory and all the photos will be downloaded into that folder.
Arguments
options
- An object that must contain 3 key/value pairs:
album
: albumObject - The album object (including name, link and count) that is to be downloadedoutputDir
: "/some/folder/path" - The path to where you want the photos downloaded to. Each album will be downloaded into its own foldershowProgress
: true/false - Show a fancy progress bar to show download progress
callback
- Function that is called once all photos have been downloaded (or if an error is thrown)
Example
var albums = photoBox.getAlbumList();
photoBox.downloadAlbum(
{
album : albums[0], // download first album
outputDir : __dirname + '/out',
showProgress : true
},
function (err) {
if (err) {
console.log('ERROR! Something went wrong downloading album!');
console.log(err);
} else {
console.log('Album has been downloaded to the outputDir');
}
}
);
Download a specific photo. If you know the ID of a photo you can download it directly.
Arguments
options
- An object that must contain 2 key/value pairs:
id
: "xxxxxxxx" - The id of the photo to downloadoutputDir
: "/some/folder/path" - The path to where you want the photo downloaded to.
Example
photoBox.downloadAlbum(
{
id : "xxxxxxxx", // The id of the photo to download
outputDir : __dirname + '/out'
}, function (err) {
if (err) {
console.log('ERROR! Something went wrong downloading photo!');
console.log(err);
} else {
console.log('Photo has been downloaded to the outputDir');
}
}
);
MIT licensed.
Photobox is trademark of PhotoBox Limited, its use in this project is under fair use. The author is not connected with Photobox and this project is not an endorsement of them or their services.