Skip to main content

Use many service accounts as a unified google storage, with mounting to filesystem, and parallel uploads/downloads.

Project description

SA Drive (Service Account Drive)

Note: As of April 15 2025, New service accounts will not have 15GiB of Google Drive Storage, hence this repository is specifically targeted at those users who have service accounts generated before April 15 2025, and wish to combine their storage into a unified place.

Note to old users (who used GUI version): This repository was previously aimed at the GUI version, see gui-deprecated, which was maintained by another author. Now the live workings are supported by the cli. Which is much more powerful than the GUI, it shows progress, has support to mount the sa-drive with gclone onto local filesystem, and most importantly, supports large file upload ( > 14.7 GiB). [BONUS: The CLI is implemented in a statically typed way using type hints.]

Why is it needed ?

Now Team Drives or shared drives (whichever you may prefer) are have a restriction of ~100GiB. So, to circumvent that, using Google's own services, this project aims to give a displayable + managable look to the drive storage of service accounts.

How it works ?

Each service account has a 15GiB of drive storage. If you have a 100 service accounts [i.e. use only 1 google cloud project], then you have roughly 1.46 TiB of storage

When you upload files using the cli, the program automatically detects a service account with enough storage to upload the file, and uploads it to that service account's google drive.

Hence in this way you can exceed the 15GiB storage of your personal drive.

Features:

  • Mount the drive as a local filesystem.
  • Simultaneous uploads.
  • Simultaneous downloads (using gclone).
  • Split large files (>14.7 GiB).
  • Progress bars, ETA etc.
  • Fuzzy Search.

Deployment

  1. Do pip install sadrive
  2. Make a folder named config_dir or whatever at your choice of location.
  3. Make sure that config dir has a folder with the name accounts, which contains the json representation of service accounts. Also it should have a config.json file with the following content:
    {
    "parent_id": "1at0dM_hN2GFVn8ANGOlFwvo5ZcJy38XC", // ID of google drive fodler in your personal account where you want the sa-drive to be hosted.
    "path_to_gclone.exe":"C:\\Users\\HEMAN\\Desktop\\\\gclone-l3v11\\gclone.exe" // Path to gclone.exe. Downlaod from: https://github.com/l3v11/gclone
    }
    
    The config_dir should look like this:
  4. Run the command sadrive config set-dir absolute/path/to/config_dir.
  5. Now you are done. Just use any of the commands.
  6. Visit https://sadrive.readthedocs.io/en/latest/. For detailed documentation, and examples.

Images and Examples

  1. sadrive alt text
  2. sadrive config set-dir <path> alt text
  3. sadrive rename newname file/folderid alt text
  4. sadrive navigate [optional_folderid] alt text
  5. sadrive share file/folderid alt text
  6. sadrive mount [This gives a read only filesystem, you can directly view/open files from this] alt text alt text
  7. sadrive delete file/folderid alt text
  8. sadrive newfolder name [optional_destination_id] alt text
  9. sadrive upload path/to/upload destination_folder_id If destination folder id is not provided then it will upload to the parent directory set in config.json. alt text
  10. sadrive download folder_id path/to/destination [--transfers int]. transfers represents the maximum number of parallel downloads you want. alt text

Limitations

None as of now.

Best Case Scenario

Each Gmail account can create 12 projects. i.e. 12*100 service accounts. Hence you can effectively get 15*12*100 = 18000 GiB of storage, or roughly 17TiB per gmail account.

Got questions ?

Read FAQs.

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

sadrive-2.0.2.tar.gz (40.2 kB view details)

Uploaded Source

Built Distribution

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

sadrive-2.0.2-py3-none-any.whl (42.5 kB view details)

Uploaded Python 3

File details

Details for the file sadrive-2.0.2.tar.gz.

File metadata

  • Download URL: sadrive-2.0.2.tar.gz
  • Upload date:
  • Size: 40.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.4

File hashes

Hashes for sadrive-2.0.2.tar.gz
Algorithm Hash digest
SHA256 c7e191c6423c3b165e46894a87b25476cb1465ac1ea71ff52efcf8702fec8951
MD5 7b7c5d126f37fb181461aa7259918bb4
BLAKE2b-256 23d0bbdd117777e78638a9223662eb76326c2bed54a2e58088f033db33e36307

See more details on using hashes here.

File details

Details for the file sadrive-2.0.2-py3-none-any.whl.

File metadata

  • Download URL: sadrive-2.0.2-py3-none-any.whl
  • Upload date:
  • Size: 42.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.4

File hashes

Hashes for sadrive-2.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 fca431b966163b617f500d25573e8c74c0300cb8caf78e6500202db419658e7d
MD5 699a239ae5456a3406e09cc6a8fc8209
BLAKE2b-256 293ea107d24d6306c1d5c586639c53f5ae9ee13c58b80c493b371aea21e48f66

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