/photobox-downloader

NodeJS app to download all photos from Photobox website

Primary LanguageJavaScriptMIT LicenseMIT

Photobox Downloader

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...)

Installation & Usage

npm install -g photobox-downloader

mkdir albums

pbdl

Once you run the pbdl application it will ask you for 4 items of information:

  1. The domain that your photos are on (www.photobox.ie, www.photobox.co.uk, etc...)
  2. The Authentication cookie value (see below for more detailed instructions)
  3. The directory where to store the files (this directory must exist already!)
  4. If you want to skip existing files (useful for resuming interrupted downloads)
  5. List of albums you want to download separated by , (leave blank for all albums)

How to get authentication cookie value?

Option 1: Using your browser

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).

Option 2: Using cURL

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: photobox-downloader' \
 -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}'

Screen shot of app in action

A special debug mode can be accessed by passing "-d" parameter at the command line (e.g. "pbdl -d") to see extensive logging

Example API Usage

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!)');
        }
      }
    );
  }
});

Screenshot

Screen shot of app in action

API

login(options, callback)

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...
    }
  }
);

downloadAll(options, callback)

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 progress
  • outputDir : "/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!)');
    }
  }
);

getAlbumList()

Returns a list of albums (include naming, relative link/path and the number of photos in that album.

Example

var albums = photoBox.getAlbumList();

downloadAlbum(options, callback)

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 downloaded
  • outputDir : "/some/folder/path" - The path to where you want the photos downloaded to. Each album will be downloaded into its own folder
  • showProgress : 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');
    }
  }
);

downloadPhoto(options, callback)

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 download
  • outputDir : "/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');
    }
  }
);

License

MIT licensed.

Disclaimer

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.