Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
django-binary-database-files
Advanced tools
A storage system for Django that stores uploaded files in both the database and file system.
This is a storage system for Django that stores uploaded files in binary fields in the database. Files can be served from the database (usually a bad idea), the file system, or a CDN.
WARNING: It is generally a bad idea to serve static files from Django, but there are some valid use cases. If your Django app is behind a caching reverse proxy and you need to scale your application servers, it may be simpler to store files in the database.
Based upon django-database-files by Kimetrica, rhunwicks, chrisspen, bfirsh but updated to work with Django 2.2-4.0, Python 3.6+ and to use a binary field for storage.
Requires:
Simply install via pip with:
pip install django-binary-database-files
In settings.py
, add binary_database_files
to your INSTALLED_APPS
and add
this line:
DEFAULT_FILE_STORAGE = 'binary_database_files.storage.DatabaseStorage'
Note, the upload_to
parameter is still used to synchronize the files stored
in the database with those on the file system, so new and existing fields
should still have a value that makes sense from your base media directory.
If you are adding the package to an existing Django installation with pre-existing files, run:
python manage.py database_files_load
Additionally, if you want to export all files in the database back to the file system, run:
python manage.py database_files_dump
Note, that when a field referencing a file is cleared, the corresponding file in the database and on the file system will not be automatically deleted. To delete all files in the database and file system not referenced by any model fields, run:
python manage.py database_files_cleanup
DB_FILES_AUTO_EXPORT_DB_TO_FS
= True
|False
(default True
)
If true, when a file is uploaded or read from the database, a copy will be exported to your media directory corresponding to the FileField's upload_to path, just as it would with the default Django file storage.
If false, the file will only exist in the database.
DATABASE_FILES_URL_METHOD
= 'URL_METHOD_1'
|'URL_METHOD_2'
(default 'URL_METHOD_1'
)
Defines the method to use when rendering the web-accessible URL for a file.
If URL_METHOD_1
, assumes all files have been exported to the filesystem and
uses the path corresponding to your settings.MEDIA_URL
.
If URL_METHOD_2
, uses the URL bound to the database_file
view
to dynamically lookup and serve files from the filesystem or database.
In this case, you will also need to updates your urls.py
to include the view
that serves the files:
urlpatterns = [
# ... the rest of your URLconf goes here ...
# Serve Database Files directly
path(r"", include("binary_database_files.urls")),
]
DATABASE_FILES_BASE_URL
Allows the url
method of the storage backend to return an absolute URL if provided.
Code should be linted with:
./lint.sh
Tests require the Python development headers to be installed, which you can install on Ubuntu with:
sudo apt-get install python3.12-minimal python3.12-dev
To run unittests across multiple Python versions, install:
sudo apt-get install python3.10-minimal python3.10-dev python3.11-minimal python3.11-dev python3.12-minimal python3.12-dev
To run all tests:
export TESTNAME=; tox
To run tests for a specific environment (e.g. Python 3.12 with Django 5.0):
export TESTNAME=; tox -e py312-django50
To run a specific test:
export TESTNAME=.test_adding_file; tox -e py312-django50
To build and deploy a versioned package to PyPI, verify all unittests are passing, then increase (and commit) the version number in binary_database_files/__init__.py
and then run:
python setup.py sdist bdist_wheel
twine check dist/*
twine upload dist/*
FAQs
A storage system for Django that stores uploaded files in both the database and file system.
We found that django-binary-database-files demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 2 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.