Skip to main content

Django storage module implementation for Google Cloud Storage

Project description

https://img.shields.io/pypi/v/django-gcloud-storage.svg https://img.shields.io/pypi/l/django-gcloud-storage.svg https://img.shields.io/pypi/pyversions/django-gcloud-storage.svg https://img.shields.io/pypi/format/django-gcloud-storage.svg

Django storage module implementation for Google Cloud Storage using the google-cloud-storage python module by Google.

Notice: alpha release

Please keep in mind that this version is not yet used in any production application (as far as I know of) and thus is an alpha release, even though fully tested! Any kind of feedback is greatly appreciated.

Installation

Install django-gcloud-storage:

pip install django-gcloud-storage

Create a GCS service account JSON keyfile and a bucket for your application. Check the documentation of Google Cloud Platform for more details:

https://cloud.google.com/iam/docs/creating-managing-service-accounts#creating

https://cloud.google.com/iam/docs/creating-managing-service-account-keys#creating

Update your Django settings and use it like any other Django storage module:

DEFAULT_FILE_STORAGE = 'django_gcloud_storage.DjangoGCloudStorage'

GCS_PROJECT = "django-gcloud-storage"
GCS_BUCKET = "django-gcloud-storage-bucket"
GCS_CREDENTIALS_FILE_PATH = "/path/to/gcs-credentials.json"

Features

  • Fully tested on Python 3.7 - 3.10, PyPy 3.7-7.3.7 and PyPy 3.8-7.3.7 with Django 2.2, 3.2 and 4.0

  • Files are locally downloaded as SpooledTemporaryFile objects to avoid memory abuse

  • Changed files will automatically be reuploaded to GCS when closed

Caveats

  • Files must be fully downloaded to be accessed and fully uploaded when changed

  • Everytime a file is opened via the storage module, it will be downloaded again

  • (development) Most tests need access to Google Cloud Storage

Unsigned URLS

The module generates signed urls by default. This requires calls to storage API which might take some time if you need to return several objects at a time. You can generate unsigned urls using the following setting:

GCS_USE_UNSIGNED_URLS = True

Keep in mind you might need to set the default object permission to public for the unsigned urls to work.

Contributing

Contributions are welcome, and they are greatly appreciated! Every little bit helps, and credit will always be given.

Report Bugs

Report bugs at https://github.com/strayer/django-gcloud-storage/issues.

If you are reporting a bug, please include:

  • Your operating system name and version.

  • Any details about your local setup that might be helpful in troubleshooting.

  • Detailed steps to reproduce the bug.

Fix Bugs

Look through the GitHub issues for bugs. Anything tagged with “bug” is open to whoever wants to implement it.

Implement Features

Look through the GitHub issues for features. Anything tagged with “feature” is open to whoever wants to implement it.

Write Documentation

django-gcloud-storage could always use more documentation, whether as part of the official django-gcloud-storage docs, in docstrings, or even on the web in blog posts, articles, and such.

Pull Request Guidelines

Before you submit a pull request, check that it meets these guidelines:

  1. The pull request should include tests.

  2. The pull request should work for all supported Python and Django versions (see above). Make sure that the tests pass.

Running Tests

Warning: Most of the tests require a GCS project and will do API requests that may end up costing you money!

You can run the test suite either in a virtualenv with py.test or with tox - both require a valid service account JSON keyfile called test-credentials.json in the project root. The GCS project name will be provided via a command argument.

The tests will create and (hopefully) remove buckets on their own. To be safe, check if there are any leftover buckets in your GCS project after running the tests!

source <YOURVIRTUALENV>/bin/activate
(myenv) $ pip install -r requirements-test.txt
(myenv) $ pip install -e .
(myenv) $ py.test --gcs-project-name="project-name"

or

$ tox -- --gcs-project-name="project-name"

Credits

Inspired by:

Tools (partly) used in rendering this package:

History

0.5.0 (2021-01-28)

  • Added support for Django 4.0, 3.2 and 2.2

  • Added support for Python 3.8, 3.9 and 3.10

  • Added support for PyPy 3.7 and 3.8

  • Dropped suport for now unsupported Python and Django versions:
    • Python 2.7, 3.4, 3.5 and 3.6

    • Django 1.11, 2.1 and 3.0

0.4.0 (2019-06-27)

  • Autodetect and set object Content-Type on upload

  • Added test support for Django 2.2

  • Dropped test support for Django 2.0

0.3.1 (2018-08-08)

  • Updated test support versions for Django 1.11 - 2.1

  • Added test support for Python 3.7

  • Added test support for Pypy 3

  • Dropped support for Python 3.3

  • Dropped support for Django 1.11 or older

  • Tests are much quicker and do less API requests

  • Switched to google-cloud-storage library

0.2.1 (2017-06-23)

  • Use google-cloud package instead of gcloud (package was renamed by Google)

  • Added test support for Django 1.10 and 1.11

  • Deprecated Django 1.7 (should still work, no support guaranteed)

  • Added test support for Python 3.6

  • Added setting for unsigned URLs support

  • Added get_modified_time() for Django 1.11+ support

  • storage.open() will now create new blobs if no existing blob has been found

0.1.0 (2016-02-01)

  • First release on PyPI.

  • Development of this release was kindly sponsored by Craft AG.

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

django-gcloud-storage-0.5.0.tar.gz (13.4 kB view details)

Uploaded Source

Built Distribution

django_gcloud_storage-0.5.0-py2.py3-none-any.whl (7.8 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-gcloud-storage-0.5.0.tar.gz.

File metadata

  • Download URL: django-gcloud-storage-0.5.0.tar.gz
  • Upload date:
  • Size: 13.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.12

File hashes

Hashes for django-gcloud-storage-0.5.0.tar.gz
Algorithm Hash digest
SHA256 8fe97c9858969f7a4c96c74995c5c78ee1242646bbbce133ab5cec7a48ce6bdd
MD5 f861e595f0c4bc3b57316e216873992e
BLAKE2b-256 45dee4bb4dc7fb9d2dc0dc97aa8ae4fedd7e8b4cb3f2ce2181506c794b3556e4

See more details on using hashes here.

File details

Details for the file django_gcloud_storage-0.5.0-py2.py3-none-any.whl.

File metadata

  • Download URL: django_gcloud_storage-0.5.0-py2.py3-none-any.whl
  • Upload date:
  • Size: 7.8 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.7.1 importlib_metadata/4.10.1 pkginfo/1.8.2 requests/2.27.1 requests-toolbelt/0.9.1 tqdm/4.62.3 CPython/3.7.12

File hashes

Hashes for django_gcloud_storage-0.5.0-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 63405475a33142b515a65f3c2bea050a4d6dd25d7418bf13426a8ee4c26fbc54
MD5 ea01760a09c481a3a6ad5ca8ca9f140b
BLAKE2b-256 50e5af4db13910ce58a7eed20be1db7117a22218c3a69689bab963c101c60b34

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