This is a pre-production deployment of Warehouse. Changes made here affect the production instance of PyPI (pypi.python.org).
Help us improve Python packaging - Donate today!

This application allows you easily save media and static files into webdav storage

Project Description

This application allows you easily save media and static files into webdav storage.

Dependencies

Installation

  1. Install the package
pip install django-webdav-storage
  1. Pick the webdav server url in WEBDAV_URL and WEBDAV_PUBLIC_URL:
WEBDAV_URL = 'http://webdav.example.com/',
WEBDAV_PUBLIC_URL = 'http://webdav.example.com/'

If you want use HTTP Basic authorization to webdav access, you can specify your credentials like that:

WEBDAV_URL = 'http://johndoe:secret@webdav.example.com/'
  1. Set the webdav storage class as default:
DEFAULT_FILE_STORAGE = 'django_webdav_storage.storage.WebDavStorage'
  1. If your webdav backend can’t recursively create path (e.g. nginx can do this, while apache can’t), set the WEBDAV_RECURSIVE_MKCOL variable to True:
WEBDAV_RECURSIVE_MKCOL = True
  1. If you use nginx as webdav server and want to enable storage directory listing, set the WEBDAV_LISTING_BACKEND option to:
WEBDAV_LISTING_BACKEND = 'django_webdav_storage.listing.nginx_autoindex'

Autoindex feature must be enabled in your nginx configuration for application servers (see example below). Be careful! Allowing autoindex for any user may lead to security and performance issues.

Also, you may specify path to other function with the following interface:

def listdir(storage_object, path_string):
    return dirs_list, files_list

The nginx webdav configuration example

# Public readonly media server.
server {
    listen 80;
    charset        utf-8;
    server_tokens  off;
    server_name    media.example.com;

    access_log     /var/log/nginx/media_access.log;
    error_log      /var/log/nginx/media_error.log;

    root           /usr/share/nginx/webdav;

}

# WebDAV server
server {
    listen 80;
    charset        utf-8;
    server_tokens  off;
    server_name    webdav.example.com;

    access_log     /var/log/nginx/webdav_access.log;
    error_log      /var/log/nginx/webdav_error.log;

    root           /usr/share/nginx/webdav;

    client_max_body_size    10m;
    client_body_temp_path   /tmp;
    create_full_put_path    on;
    autoindex               on;

    dav_methods             PUT DELETE MKCOL COPY MOVE;
    dav_access              user:rw   group:r   all:r;

    satisfy                 any;

    allow                   127.0.0.1/32;
    deny                    all;

    auth_basic              'My WebDAV area';
    auth_basic_user_file    /usr/share/nginx/.htpasswd;
}

Caveats

  • In python 3.x ContentFile with text mode content (not binary one) will causes TypeError due requests restrictions
Release History

Release History

This version
History Node

0.6.1

History Node

0.6

History Node

0.5

History Node

0.4.2

History Node

0.4

History Node

0.3

History Node

0.2

History Node

0.1

Download Files

Download Files

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

File Name & Checksum SHA256 Checksum Help Version File Type Upload Date
django_webdav_storage-0.6.1-py2.py3-none-any.whl (9.7 kB) Copy SHA256 Checksum SHA256 2.7 Wheel Jun 8, 2015
django-webdav-storage-0.6.1.tar.bz2 (6.7 kB) Copy SHA256 Checksum SHA256 Source Jun 8, 2015
django-webdav-storage-0.6.1.tar.gz (6.3 kB) Copy SHA256 Checksum SHA256 Source Jun 8, 2015
django-webdav-storage-0.6.1.zip (12.6 kB) Copy SHA256 Checksum SHA256 Source Jun 8, 2015

Supported By

WebFaction WebFaction Technical Writing Elastic Elastic Search Pingdom Pingdom Monitoring Dyn Dyn DNS Sentry Sentry Error Logging CloudAMQP CloudAMQP RabbitMQ Heroku Heroku PaaS Kabu Creative Kabu Creative UX & Design Fastly Fastly CDN DigiCert DigiCert EV Certificate Rackspace Rackspace Cloud Servers DreamHost DreamHost Log Hosting