Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ryanmcgrath/django-rednoise
An opinionated addon for WhiteNoise, with a focus on Django environments.
https://github.com/ryanmcgrath/django-rednoise
Last synced: 2 months ago
JSON representation
An opinionated addon for WhiteNoise, with a focus on Django environments.
- Host: GitHub
- URL: https://github.com/ryanmcgrath/django-rednoise
- Owner: ryanmcgrath
- License: other
- Archived: true
- Created: 2015-06-04T16:50:54.000Z (over 9 years ago)
- Default Branch: master
- Last Pushed: 2019-06-19T04:37:34.000Z (over 5 years ago)
- Last Synced: 2024-11-15T21:53:55.883Z (2 months ago)
- Language: Python
- Size: 10.7 KB
- Stars: 18
- Watchers: 5
- Forks: 2
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- starred-awesome - django-rednoise - An opinionated addon for WhiteNoise, with a focus on Django environments. (Python)
README
# Notice
If you've used Django Rednoise before, thanks! I'm glad it was helpful. Unfortunately, this project was built for Whitenoise < 2, and I've simply never found the time to update it, hence why I'm archiving it. If you'd like to, feel free to fork it and take ownership of it. :)RedNoise
==========
Django as a framework is great, but file handling within any setup has never been particularly fun to configure. **[WhiteNoise](https://whitenoise.readthedocs.org/)** makes this, to borrow its own term, "radically simplified", and for the most part I've found it to be an ideal solution - though there are a few things I found myself wanting from time to time.RedNoise is a different take on the DjangoWhiteNoise module from WhiteNoise. It aims to be (and as of writing, should be) completely compatible with the existing WhiteNoise API, but takes a different approach on a few things. I consider this an opinionated third-party addon to the WhiteNoise project, however I hope it goes without saying that anything here is up for grabs as a pull request or merge.
Getting Started
====================
1. `pip install django-rednoise`
2. Follow the WhiteNoise configuration guidelines - they all should work.
3. Modify your wsgi file as follows:``` python
from django.core.wsgi import get_wsgi_application
from rednoise import DjangoRedNoiseapplication = get_wsgi_application()
application = DjangoRedNoise(application)
```...and that's it. You can read on for additional configuration options if you think you need them, but the defaults are more or less sane. DjangoRedNoise is the only Class in this package; existing guides/documentation for WhiteNoise should still suffice.
Differences from WhiteNoise
------------------------------------ **RedNoise allows you to serve user-uploaded media**
Note that it performs no gzipping of content or anything; the use case this satisfied (for me, at least) was that users within a CMS
needed to be able to upload images as part of a site; configuring storages and some S3 setup just got annoying to deal with.
- **RedNoise respects Django's DEBUG flag**
When DEBUG is True, RedNoise will mimic the native Django static files handling routine. With this change, RedNoise can be used while
in development (provided you're developing with uwsgi) so your environment can simulate a production server. I've found this to be
faster than using Django's static serving in urls.py solution, YMMV.
- **When DEBUG is false, RedNoise mimics WhiteNoise's original behavior**
...with two exceptions. One, being that Media can also be served, and two - whereas WhiteNoise scans all static files on startup,
RedNoise will look for the file upon user request. If found, it will cache it much like WhiteNoise does - the advantage of this
approach is that one can add static file(s) as necessary after the fact without requiring a restart of the process.
- **RedNoise 404s directly at the uwsgi level, rather than through the Django application**
Personally speaking, I don't see why Django should bother processing a 404 for an image that we know doesn't exist. This is, of
course, a personal opinion of mine.License
-------MIT Licensed
Contact
-------
Questions, concerns? ryan [at] venodesigns dot net