Unofficial Google Photos Python library
Project description
gPhotoSpy
Interact with Google Photos in Python
NOTE: Updated to Google API 2.0.0; please update this package to the new version.
Sorry for breaking some compatibility here, but Google has had some small changes under the hood, which require this update (See Issue#12).
Installation
You can use Pypi distribution (recommended method):
pip install gphotospy
Otherwise clone this repo and use the modules in gphotospy directly (not recommended).
Usage examples
This library is unofficial; most of the API is covered, however no proper test coverage has been implemented so far.
Please refer to Google's authorization guide (recommended), or see the below "Set up authorization" for a quick review on how to get Google's API keys and authorization (save it in a gphoto_oauth.json
file).
from gphotospy import authorize
from gphotospy.album import Album
# Select secrets file (got through Google's API console)
CLIENT_SECRET_FILE = "gphoto_oauth.json" # Here your secret's file. See below.
# Get authorization and return a service object
service = authorize.init(CLIENT_SECRET_FILE)
# Init the album manager
album_manager = Album(service)
# Create a new album
new_album = album_manager.create('test album')
# Get the album id and share it
id_album = new_album.get("id")
album_manager.share(id_album)
Examples
Check the examples folder for more examples of use.
Tutorials
Check the wiki for tutorials
API Coverage
- OAuth authorization
- Google server upload
- Simple uploader
- Resumable uploader
- Albums
- addEnrichment
- batchAddMediaItems
- batchRemoveMediaItems
- create
- get
- list
- share
- unshare
- MediaItems
- batchCreate
- batchGet
- get
- list
- search
- SharedAlbums
- get
- join
- leave
- list
Test Coverage
Not yet implemented. The tests have been done "live" on my account. I'm planning to set up mock tests for this suite, just for regression purposes.
Documentation
- Docstrings
- Examples
- [-] Tutorials (See the wiki)
- API docs (must be improved though)
Near future plans
These are the next steps:
- Finish Documentation
- Mock tests
- Resumable Uploads
- Objects representations
- Media
- Album
- ...
Accepting ideas, so don't be shy and put them forth!
Set up authorization
Browse through Google's authorization guide
Quick recap:
Go to Google Cloud Console.
Set up a new project, then on the menu select: Api & Services
> Library
.
In the library, search for "photos", select Photo Library API
and click on the ENABLE
button.
On the API & Services, Photo Library API
select Credentials
, and select the +CREDENTIALS
and select in the dropdown OAuth client ID
. Select the type of app to be created (for desktop application select "other") and give it a name. If you are an occasional user, you should before this thing select the authorization display (OAuth Consent Screen
), and make it public (if you are not a g-Suite user $$$. THe interface prompts you already to do so, if never done before).
After this, coming back to the main interface, select in the row of the OAuth 2.0 Client ID just created the download button (rightmost one). Download the .json
file in the root of the project, and give it a meaningful name (because it must be used afterwards). Remember to keep all these secret files far from git pushes, so if you are committing your porject to a repository, add the downloaded file to the .gitignore.
Once run the authentication it should open a browser to authenticate. If you are creating a project for non commercial use you need not apply for review, but you have to allow it, because Google show a big message of warining. Clicking on advanced, it shows the button to allow the authorization, even though the app is not reviewed by Google (useful for tests and personal use projects). A .token file will keep the authorization for further use
Contributing
Please give me some heads up if you are working on an interesting feature to add to gphotospy before a PR (well, even afterwards it's ok).
- Fork it (https://github.com/davidedelpapa/gphotospy/fork)
- Create your feature branch (
git checkout -b feature/fooBar
) - Commit your changes (
git commit -am 'Add some fooBar'
) - Push to the branch (
git push origin feature/fooBar
) - Create a new Pull Request
License
MIT, see the LICENSE file.
Changelog
- V. 0.1.2: Added media item object representation
- V. 0.1.1: Added documentation
- V. 0.1.0: Fisrt usable version
About me
Too shy to talk about it (not true). This project though has been a relief during COVID lockdown.
Project details
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file gphotospy-0.2.0.tar.gz
.
File metadata
- Download URL: gphotospy-0.2.0.tar.gz
- Upload date:
- Size: 17.9 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | ac2854ab310b03a602ac7f0e35c991b55963cbca5883be13dfa58490e80d8a39 |
|
MD5 | bc9e4bd130b8601059f7739a0ee1f244 |
|
BLAKE2b-256 | 7326f19c6cf4d7294075f16cf2c5e774ce172972081be02926526cf8db3cce53 |
File details
Details for the file gphotospy-0.2.0-py3-none-any.whl
.
File metadata
- Download URL: gphotospy-0.2.0-py3-none-any.whl
- Upload date:
- Size: 19.2 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.4.1 importlib_metadata/3.7.3 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.60.0 CPython/3.9.2
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | c1e46f9d97efd9aa9de70a881422e68f775a0df358c8f0345cffdafbf7237b3f |
|
MD5 | 6a3bfeed9198dc167d3324153586f5b6 |
|
BLAKE2b-256 | 644fbd809c92cbfa33d70f0aed4fbabd628864ece3cf78c4310ac002f9392356 |