Custom Database Storage for Django
Project description
django-db-storage
.. image:: https://travis-ci.org/derekkwok/django-db-storage.svg?branch=master :target: https://travis-ci.org/derekkwok/django-db-storage
.. image:: https://coveralls.io/repos/github/derekkwok/django-db-storage/badge.svg?branch=master :target: https://coveralls.io/github/derekkwok/django-db-storage?branch=master
.. image:: https://badge.fury.io/py/django-db-storage.svg :target: https://badge.fury.io/py/django-db-storage
Overview
Warning: In many cases, storing files in the database is a BAD idea. Your database will easily become bloated and the performance can degrade rapidly. See this StackExchange post
_ for more information.
.. _StackExchange post: http://programmers.stackexchange.com/questions/150669/is-it-a-bad-practice-to-store-large-files-10-mb-in-a-database
This is a custom storage backend for storing files in the database instead of the file system and is a drop-in replacement for Django's FileSystemStorage. Some benefits of this application:
- no changes needed to existing models, it just works (and if it doesn't, open a ticket!)
- django-admin is implemented and can be used to search, upload, download and manage files
- 100% code coverage with unit tests
.. image:: http://i.imgur.com/4g9tmEZt.png :target: http://i.imgur.com/4g9tmEZ.png
.. image:: http://i.imgur.com/A2F8xlrt.png :target: http://i.imgur.com/A2F8xlr.png
Requirements
- Python (3.5+)
- Django (1.11.17+)
Installation
Installation using pip::
$ pip install django-db-storage
Update settings.py
.. code-block:: python
# Add 'dbstorage' to INSTALLED_APPS
INSTALLED_APPS = [
'dbstorage',
]
# Optionally set DEFAULT_FILE_STORAGE
DEFAULT_FILE_STORAGE = 'dbstorage.storage.DBStorage'
# Choose a root url for uploaded files
MEDIA_URL = '/media/'
Update urls.py
.. code-block:: python
urlpatterns = [
...
dbstorage_url(),
]
Run database migrations
::
$ python manage.py migrate
How to Use
No modification are needed for models to work properly.
.. code-block:: python
def user_directory_path(instance, filename):
return 'user_{0}/{1}'.format(instance.user.id, filename)
class MyModel(models.Model):
file_field1 = models.FileField()
file_field2 = models.FileField(upload_to='uploads/%Y/%m/%d/')
file_field3 = models.FileField(upload_to=user_directory_path)
Bugs?
Create an issue at https://github.com/derekkwok/django-db-storage/issues
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 django-db-storage2-2.0.0.tar.gz
.
File metadata
- Download URL: django-db-storage2-2.0.0.tar.gz
- Upload date:
- Size: 8.0 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 1c0338de2059df78b3bdcb23e3d6276ccc7315ac069d27e76bd31ec93e038398 |
|
MD5 | a760e0e90bc903aa880d06479908be6b |
|
BLAKE2b-256 | 9e0c0528d468c65be19fa9501025662b52441e1f6f63558dbc73e016c3a4e337 |
File details
Details for the file django_db_storage2-2.0.0-py2.py3-none-any.whl
.
File metadata
- Download URL: django_db_storage2-2.0.0-py2.py3-none-any.whl
- Upload date:
- Size: 8.6 kB
- Tags: Python 2, Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.3.0 pkginfo/1.7.0 requests/2.25.1 setuptools/53.0.0 requests-toolbelt/0.9.1 tqdm/4.56.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | e5e9596460a215dde19d7e413075a0795cce11269e487d45f3714733dc7fdc3e |
|
MD5 | 3272bedf317af6a23c691d0b9882ca12 |
|
BLAKE2b-256 | a452fbe3b87f3f97b5708b48b6c687e53c8a4331cfc47e58d8071fac1f5bcaba |