Skip to main content

git-annex external special remote for Google Cloud Storage

Project description

This is a git-annex external special remote that supports Google Cloud Storage (GCS).

Features

  • Supports Standard, Durable Reduced Availability, and Nearline storage classes.

  • Accesses Google Cloud Storage via a Google Cloud service account. Does not use the Google Cloud Storage Interoperability API.

  • Should support object sizes up to 5 TB.

License

GNU General Public License, version 3 or later.

Installing

pip install gcsannex

Configuring Google Cloud Storage

  1. Log into the Google Developers Console.

  2. Create a project if you don’t already have one. Remember its project ID.

  3. In the project’s settings, go to APIs & auth > Credentials.

  4. Click “Create new Client ID”, select “Service account”, then click “Create Client ID”.

  5. A credentials file will be downloaded to your computer. You will need this file when configuring gcsannex.

Adding a remote

git annex initremote <remotename> type=external externaltype=gcs encryption={none|shared|pubkey|hybrid} project=<gcs-project-id>

Set the GOOGLE_APPLICATION_CREDENTIALS environment variable to the path to your credentials file. This is only necessary when running initremote; afterward, git-annex will remember your credentials.

Mandatory settings

encryption

See the git-annex encryption documentation.

project

Your project ID from the Google developer console.

Optional settings

bucket

The bucket name, which must be globally unique within GCS. The default name is based on the remote name and UUID.

chunk

Enable chunking.

embedcreds

Set to yes to commit the login credentials to the Git repository so other clones can read them. When using GPG encryption, the default is yes and the credentials are stored encrypted. Otherwise, the default is no; if set to yes, anyone with access to the repo can also access the GCS bucket.

fileprefix

A string, such as mydata/, to be prepended to the name of each object. This allows a bucket to be shared by multiple remotes.

location

The physical location for the data. Can be any of the location strings supported by GCS, such as ASIA, EU, or US. Defaults to US.

public

If yes, newly-uploaded objects are made publicly readable. Defaults to no.

readonly

If set to true when enabling an existing public remote, files can be retrieved without GCS credentials and without gcsannex installed. Requires development version of git-annex.

storageclass

A storage class supported by GCS, such as STANDARD, DURABLE_REDUCED_AVAILABILITY, or NEARLINE. Defaults to STANDARD.

Release notes

Version 0.2

  • Time out stuck requests

  • Retry after more types of errors

  • Permit encrypted public remotes

  • Support showing public URLs in git annex whereis

  • Improve compatibility with git-annex < 5.20141219

  • Properly accept implicit encryption=hybrid

Version 0.1

  • Initial release

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

gcsannex-0.2.tar.gz (21.6 kB view details)

Uploaded Source

Built Distribution

gcsannex-0.2-py2-none-any.whl (10.5 kB view details)

Uploaded Python 2

File details

Details for the file gcsannex-0.2.tar.gz.

File metadata

  • Download URL: gcsannex-0.2.tar.gz
  • Upload date:
  • Size: 21.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No

File hashes

Hashes for gcsannex-0.2.tar.gz
Algorithm Hash digest
SHA256 f684511d17ed779275c2543af54bd9f9fa720045a18aa3e02f895f1784796319
MD5 d60dd802e36e997972e449d699542e1e
BLAKE2b-256 9c475c4486557aef7c34406a8639f188b34309e597a52a52339962a7860c1f5d

See more details on using hashes here.

File details

Details for the file gcsannex-0.2-py2-none-any.whl.

File metadata

File hashes

Hashes for gcsannex-0.2-py2-none-any.whl
Algorithm Hash digest
SHA256 ff0a2c2a4eec4a117182e0170c0427ed7bab5f6139b0e8144f855513f3ecc75f
MD5 a5e33f7a2e4f4d686193d51bfe6a5e34
BLAKE2b-256 3acd3fed7aaca1d268721bf8009ca4ad4a562b78f7611bd7064f672a3f8c5743

See more details on using hashes here.

Supported by

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