Skip to main content

django middleware for serving media files ( or protect them )

Project description

[![Build Status](https://travis-ci.org/instapk/django-fileprovider.svg?branch=master)](https://travis-ci.org/instapk/django-fileprovider)

File handler for django, useful when you want to add control or logic to served files.
It uses `sendfile` API supports on different servers and uses pythonic solution on django development server.
Currently it supports,

* Apache
* Nginx
* LightHttpd
* Caddy
* Hiawatha

# INSTALLATION

use pip to install package:
`pip install django-fileprovider`

* add `fileprovider` to django `INSTALLED_APPS` section.
* add `fileprovider.middleware.FileProviderMiddleware` to `MIDDLEWARE_CLASSES` section
* set django `settings` file with `FILEPROVIDER_NAME` any of available providers `python`, `nginx`, `apache`, `lighthttpd`,
`caddy`, `hiawatha`, `xsendfile`, `xaccel`.

```python

# or you can put FILEPROVIDER_NAME as python in your local settings file
if settings.DEBUG:
FILEPROVIDER_NAME = "python"
else:
# or apache, lighthttpd, caddy
FILEPROVIDER_NAME = "nginx"

```

# USAGE

on django views where file response is required, fill response header `X-File` with absolute file path or use `sendfile` wrapper
for example,

```python

from fileprovider.utils import sendfile
def hello(request):
return sendfile('/absolute/path/to/file')

```

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Filename, size & hash SHA256 hash help File type Python version Upload date
django-fileprovider-0.1.4.tar.gz (4.1 kB) Copy SHA256 hash SHA256 Source None

Supported by

Elastic Elastic Search Pingdom Pingdom Monitoring Google Google BigQuery Sentry Sentry Error logging AWS AWS Cloud computing DataDog DataDog Monitoring Fastly Fastly CDN SignalFx SignalFx Supporter DigiCert DigiCert EV certificate StatusPage StatusPage Status page