Google Photos client based on reverse engineered mobile API.
- Unlimited uploads in original quality (can be disabled).
- Use as a CLI tool or Python library.
- Skips files already present in your account.
- Upload individual files or entire directories, with optional recursive scanning.
- Album creation based on directory structure or custom album name.
- Real-time progress tracking.
- Configurable threads for faster uploads (default: 1).
Run the command:
pip install https://github.com/xob0t/google_photos_mobile_client/archive/refs/heads/main.zip --force-reinstall
Note
If auth_data is omitted, GP_AUTH_DATA
env variable will be used
from gpmc import Client
path = "/path/to/media_file.jpg" # file or dir path
auth_data = "androidId=216e583113f43c75&app=com.google.android.app..."
client = Client(auth_data=auth_data)
output = client.upload(target=path, show_progress=True)
print(output)
# {"/absolute/path/to/media_file.jpg": "google_photos_media_key"}
gpmc "/path/to/media_file.jpg" --progress --auth-data "androidId=216e583113f43c75&app=com.google.android.app..."
usage: gpmc [-h] [--auth_data AUTH_DATA] [--album ALBUM] [--proxy PROXY] [--progress] [--recursive] [--threads THREADS] [--force-upload] [--delete-from-host] [--use-quota] [--saver] [--timeout TIMEOUT]
[--log-level {DEBUG,INFO,WARNING,ERROR,CRITICAL}] [--filter FILTER] [--exclude] [--regex] [--ignore-case] [--match-path]
path
Google Photos mobile client.
positional arguments:
path Path to the file or directory to upload.
options:
-h, --help show this help message and exit
--auth_data AUTH_DATA
Google auth data for authentication. If not provided, `GP_AUTH_DATA` env variable will be used.
--album ALBUM Add uploaded media to an album with given name. If set to 'AUTO', albums will be created based on the immediate parent directory of each file.
Example for using 'AUTO':
When uploading '/foo':
'/foo/image1.jpg' goes to 'foo'
'/foo/bar/image2.jpg' goes to 'bar'
'/foo/bar/foo/image3.jpg' goes to 'foo' (distinct from the first 'foo' album)
--proxy PROXY Proxy to use. Format: `protocol://username:password@host:port`
--progress Display upload progress.
--recursive Scan the directory recursively.
--threads THREADS Number of threads to run uploads with. Defaults to 1.
--force-upload Upload files regardless of their presence in Google Photos (determined by hash).
--delete-from-host Delete uploaded files from source path.
--use-quota Uploaded files will count against your Google Photos storage quota.
--saver Upload files in storage saver quality.
--timeout TIMEOUT Requests timeout, seconds. Defaults to 60.
--log-level {DEBUG,INFO,WARNING,ERROR,CRITICAL}
Set the logging level (default: INFO)
File Filter Options:
--filter FILTER Filter expression.
--exclude Exclude files matching the filter.
--regex Use regex for filtering.
--ignore-case Perform case-insensitive matching.
--match-path Check for matches in the path, not just the filename.
You only need to do this once.
-
Install Google Photos ReVanced on your device.
- Install GmsCore https://github.com/ReVanced/GmsCore/releases
- Install patched apk https://github.com/j-hc/revanced-magisk-module/releases or patch it yourself
-
Connect the device to your PC via ADB.
-
Open the terminal on your PC and execute
Windows
adb logcat | FINDSTR "auth%2Fphotos.native"
Linux/Mac
adb logcat | grep "auth%2Fphotos.native"
-
If you are already using ReVanced - remove Google Account from GmsCore.
-
Open Google Photos ReVanced on your device and log into your account.
-
One or more identical GmsCore logs should appear in the terminal.
-
Copy text from
androidId=
to the end of the line from any log. -
That's it! 🎉
Click to expand
-
Get a rooted android device or an emulator. Recommended Android versions 9-13
-
Connect the device to your PC via ADB.
-
Install HTTP Toolkit
-
In HTTP Toolkit, select Intercept -
Android Device via ADB
. Filter traffic withcontains(https://www.googleapis.com/auth/photos.native)
Or if you have an older version of Google Photos, try
contains(www.googleapis.com%2Fauth%2Fplus.photos.readwrite)
-
Open Google Photos app and login with your account.
-
Now you've got yourself your auth_data! 🎉
- No Auth Request Intercepted
- Log out of your Google account.
- Log in again.
- Try
Android App via Frida
interception method in HTTP Toolkit.
- Web api python client: https://github.com/xob0t/google_photos_web_client
- Disguise any file as media for GP to accept and store it: https://github.com/xob0t/gp-file-hide
- Manage library with bulk operations: https://github.com/xob0t/Google-Photos-Toolkit