If you’re a GoPro Plus user, you’ve probably felt the frustration of trying to download your media in bulk, only to be stopped by the 25-file limit. This arbitrary restriction makes it tedious 😤😡 to migrate your content to other platforms like Google Drive, Dropbox, or your self-hosted NAS (e.g. Synology).
GoPro Plus is an open-source project designed to enable users to interact with the GoPro Plus media library from the command line. This project aims to provide a convenient way to access and manage your GoPro media without the need to use the web interface.
- 🐳 Docker hub: https://hub.docker.com/r/itsankoff/gopro
- 📝 Article: https://thetooth.io/blog/gopro-plus-downloader/
For <AUTH_TOKEN>
and <USER_ID>
check Environment Variables
docker run --name gopro-downloader -e AUTH_TOKEN='<AUTH_TOKEN>' -e USER_ID='<USER_ID>' -v </path/to/download>:/app/download itsankoff/gopro:latest
or
docker run \
--name gopro-downloader
-e AUTH_TOKEN='<AUTH_TOKEN>' \
-e USER_ID='<USER_ID>' \
-v </path/to/download>:/app/download \
itsankoff/gopro:latest
Supported Docker ENV variable options:
-e AUTH_TOKEN=<gopro-auth-token>
- (required) authentication token obtained from GoPro Media Library website. See Environment Variables.-e USER_ID=<gopro-user-id>
- (required) user id obtained from GoPro Media Library website. See Environment Variables.-e ACTION=<list|download>
- (optional) action to execute. The default isdownload
.-e START_PAGE=<number>
- (optional) run the<action>
from specific page (GoPro Media Library API is paginated). The default1
.-e PAGES=<number>
- (optional) run the<action>
over the specified number of pages. Default1000000
which should mean max and will download the all cloud assets.-e PER_PAGE=<number>
- (optional) specify number of items per page. Default15
.-e PROGRESS_MODE=<inline|newline|noline>
- (optional) specify printing mode for download progress. Defaultnoline
.
To set up AUTH_TOKEN
as an environment variable, you'll need to retrieve
your JWT token by logging into your GoPro Plus media library account.
- Open a browser of choice (Firefox/Chrome is prefered, for Safari you need to enable Developer Tools)
- Go to GoPro Plus Media Library (assuming that you are signed out. If you are not, please sing out)
- Open your browser's Developer Tools (Ctrl+Shift+I on most browsers or Cmd+Option+I on Mac).
- Go to the Network Tab on the Developer Tools console.
- In the Filter field enter -
user
- Open the request and find the Cookies tab in the Sub Preview. You need to find the two mandatory cookies:
gp_access_token
- usually starts witheyJhbGc...
. Copy this long sequence of gibberish characters into the env variableAUTH_TOKEN
gp_user_id
- the user ID. Copy this ID into the env variableUSER_ID
For Docker:
docker run -e AUTH_TOKEN=<gopro-auth-token> -e USER_ID=<gopro-user-id> itsankoff/gopro:latest
For Linux/macOS:
export AUTH_TOKEN="<gibberish_string_here>"
export USER_ID="<user-id>`
For Windows Command Prompt:
set AUTH_TOKEN="<gibberish_string_here>"
set USER_ID="<user-id>"
For Windows PowerShell:
$env:AUTH_TOKEN="<gibberish_string_here>"
$env:USER_ID="<user-id>"
Once the AUTH_TOKEN
and USER_ID
is set, you can run the GoPro Plus application without needing to pass the token explicitly.
Remember to replace <gibberish_string_here>
with the actual token you copied from the console.
By following these steps, you should be able to effectively manage your GoPro Plus media directly from your command line using GoPro Plus.
Before you can use GoPro Plus, you need to have the following installed:
python3.10+
pip3
direnv
(optional)docker
(optional)
To run GoPro Plus locally on your machine, follow these steps:
git clone https://github.com/itsankoff/gopro-plus.git
cd gopro-plus
python3 -m venv .venv
pip3 install -r requirements.txt
- (optional)
echo source .venv/bin/activate > .envrc # assuming direnv usage
- (optional)
echo "export AUTH_TOKEN='<gopro-auth-token (see below)>'" >> .envrc # assuming direnv usage
./gopro
- running the help section
-
Makefile
- check for convenient shortcutsbuild
- build a docker containerrelease
- build and release the docker image for multiple platforms.run
- run as local docker containerstop
- stop docker containerlogs
- show docker logs in a follow modeclean
- stop and remove spawned containers
-
Dockerfile
- base configuration for the docker image
- Docker logs
docker logs gopro-downloader