Skip to main content

A tool to shard photos across multiple Google Photo accounts

Project description

Sharded-Google-Photos

Description

Running out of space in your Google Photos account? Wish you can upload your photos to multiple Google Accounts? Now you can! With this Python library, you can upload your photos to multiple Google Photo Accounts and then share those albums to your main Google Photos account. That way, you get to see all of your photos on one main Google Photos account.

Getting Started

It works like this:

  1. Let's say you have three Google Accounts. Follow this doc to create your own OAuth2 Google Client ID to interact with Google Photos and Google Drive.

  2. Install libmagic

  3. Install the package by running pip install sharded-google-photos.

  4. Import the following code in your main.py app:

    from sharded_google_photos.backup.gphotos_backup import GPhotosBackup
    from sharded_google_photos.shared.gphotos_client import GPhotosClient
    
    clients = [
        GPhotosClient(name="bob@gmail.com", creds_file = "credentials-1.json", client_secret="client_secret.json"),
        GPhotosClient(name="alice@gmail.com", creds_file = "credentials-2.json", client_secret="client_secret.json"),
        GPhotosClient(name="jerry@gmail.com", creds_file = "credentials-3.json", client_secret="client_secret.json"),
    ]
    for client in clients:
        client.authenticate()
    
    backup_client = GPhotosBackup(clients)
    

    Run this script.

    The first time this is run, it will ask for you to log in via OAuth. Copy-paste the links to your browser and follow the instructions from there. It will save the credentials (i.e, access_token and refresh_token) in the respected creds_file (i.e, credentials-1.json, credentials-2.json, and credentials-3.json).

    The next time the script is run, it will take the credentials from the creds_file. If it needs to be reauthenticated, it will ask you to log in via OAuth.

  5. To upload four photos from two folders, run the following:

    new_album_uris = backup_client.backup(
        [
            { "modifier": "+", "path": "./Archives/Photos/2022/Trip to California/1.jpg" },
            { "modifier": "+", "path": "./Archives/Photos/2022/Trip to California/2.jpg" },
            { "modifier": "+", "path": "./Archives/Photos/2022/Trip to Toronto/3.jpg" },
            { "modifier": "+", "path": "./Archives/Photos/2022/Trip to Toronto/4.jpg" },
        ]
    )
    print(new_album_uris)
    

    What will happen is that it will:

    1. A shared read-only album Archives/Photos/2022/Trip to California will be made in some Google Photos account with the most amount of space available.

    2. A shared read-only album Archives/Photos/2022/Trip to Toronto will be made in some Google Photos account with the second most amount of space available.

    3. Photos 1.jpg, and 2.jpg will be in the Archives/Photos/2022/Trip to California album.

    4. Photos 3.jpg, and 4.jpg will be in the Archives/Photos/2022/Trip to Toronto album.

    5. The url to those new albums will be in new_album_uris that you can share to.

  6. To update a file in a folder, run the following:

    backup_client.backup(
        [
            { "modifier": "-", "path": "./Archives/Photos/2022/Trip to California/1.jpg" },
            { "modifier": "+", "path": "./Archives/Photos/2022/Trip to California/1.jpg" },
        ]
    )
    
  7. To delete a file in a folder, run the following:

    backup_client.backup(
        [
            {
                "modifier": "-", "path": "./Archives/Photos/2022/Trip to California/1.jpg",
            }
        ]
    )
    

    Note: it is not possible for the Google Photos API to actually delete a photo from Google Photos. Instead, you can clean your Google Photo accounts by putting all album-less photos into a "Trash" album by running the following script:

    from sharded_google_photos.cleanup.gphotos_cleaner import GPhotosCleaner
    
    for client in clients:
        cleaner = GPhotosCleaner(client)
        cleaner.cleanup()
    

    After running that script, it will put all of the albumless photos into an album called "Trash", and you can log into Google Photos and delete those photos from your account manually.

Getting Started to Contribute

  1. Ensure Python3, Pip, and Poetry are installed on your machine

  2. Install dependencies by running:

    poetry install
    
  3. To lint your code, run:

    poetry run flake8 && poetry run black .
    
  4. To run tests and code coverage, run:

    poetry run coverage run -m pytest && poetry run coverage report -m
    
  5. To publish your app:

    1. First, set your PyPI api token to Poetry

      poetry config pypi-token.pypi <YOUR_API_TOKEN>
      
    2. Then, build the app by running:

      poetry build
      
    3. Finally, publish the app by running:

      poetry publish
      

Usage

Please note that this project is used for educational purposes and is not intended to be used commercially. We are not liable for any damages/changes done by this project.

Credits

Emilio Kartono, who made the entire project.

License

This project is protected under the GNU licence. Please refer to the LICENSE.txt for more information.

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

sharded_google_photos-0.2.4.tar.gz (30.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sharded_google_photos-0.2.4-py3-none-any.whl (36.6 kB view details)

Uploaded Python 3

File details

Details for the file sharded_google_photos-0.2.4.tar.gz.

File metadata

  • Download URL: sharded_google_photos-0.2.4.tar.gz
  • Upload date:
  • Size: 30.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.8.3 CPython/3.12.4 Darwin/23.6.0

File hashes

Hashes for sharded_google_photos-0.2.4.tar.gz
Algorithm Hash digest
SHA256 da0a7547c1f4f452c50f6521e29779fcab077239b93ea5aaf19acfff60ba2b2f
MD5 e405c0895da89b10a4e8ff847a80d4f4
BLAKE2b-256 1ee5de9dc520a9208addfebde8d66786ee15433f41f51fc04ec9c00523e9f45f

See more details on using hashes here.

File details

Details for the file sharded_google_photos-0.2.4-py3-none-any.whl.

File metadata

File hashes

Hashes for sharded_google_photos-0.2.4-py3-none-any.whl
Algorithm Hash digest
SHA256 1bf9cf82672ca65eef2459caacd16cf8f957ece2bf3d2325cb27e092f0c263d6
MD5 34aee4bb5ad0887b20fbbf27bebc6b91
BLAKE2b-256 bcbde971f365a767774bd1b0fd316aec4e2a4552ba32931497ade1cbc999a615

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page