Skip to main content

Various implementations for the Django ``FileField/ImageField.upload_to`` model field attribute.

Project description

PyPi MIT TravisCI Coverage Supported Python implementations Supported Python versions

Introduction

This application provides various implementations for the FileField/ImageField.upload_to attribute (https://docs.djangoproject.com/en/dev/ref/models/fields/#django.db.models.FileField.upload_to) (upload_to attribute accepts callable).

These implementations are:

  • auto_cleaned_path will generate {MODEL_NAME}/{SAFE_UPLOADED_FILENAME}{SUFFIX}

  • auto_cleaned_path_uuid4 will generate {MODEL_NAME}/{SAFE_UPLOADED_FILENAME}{SEPARATOR}{UUID4}{SUFFIX}

  • auto_cleaned_path_stripped_uuid4 will generate {MODEL_NAME}/{UUID4}{SUFFIX}

Example

For example, how auto_cleaned_path works: First, the original file name (typically from the user) is always cleaned (using django.utils.text.slugify). Then, a new path is generated that contains the model name.

If you have a MyModel model and the user uploads a foo-bar.txt file, the resulting path will be mymodel/foo-bar.txt.

from django.db import models
from django_upload_path import auto_cleaned_path


class MyModel(models.Model):
    file = models.FileField(upload_to=auto_cleaned_path)

Installation

  • Supported Python versions are: 3.4., 3.5, 3.6 and 3.7-dev.

  • Supported Django versions are: 1.8.x (LTS), 1.9.x, 1.10.x and 1.11.x (LTS).

pip install django-upload-path

Do not add the app to INSTALLED_APPS (it is useless).

Usage

from django.db import models
from django_upload_path.upload_path import auto_cleaned_path, auto_cleaned_path_stripped_uuid4, auto_cleaned_path_uuid4


class MyModel(models.Model):
    file1 = models.FileField(upload_to=auto_cleaned_path)
    file2 = models.FileField(upload_to=auto_cleaned_path_stripped_uuid4)
    file3 = models.FileField(upload_to=auto_cleaned_path_uuid4)

Note: ImageField (https://docs.djangoproject.com/en/dev/ref/models/fields/#django.db.models.ImageField) is also supported.

License

The MIT License (MIT)

Copyright (c) 2017 Vašek Dohnal (@illagrenan)

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the “Software”), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED “AS IS”, WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

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

django-upload-path-0.1.1.tar.gz (4.4 kB view details)

Uploaded Source

Built Distribution

django_upload_path-0.1.1-py2.py3-none-any.whl (7.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file django-upload-path-0.1.1.tar.gz.

File metadata

File hashes

Hashes for django-upload-path-0.1.1.tar.gz
Algorithm Hash digest
SHA256 ec4281f78889ce9295251670931987c9db59de72485b14f3fde64391de76bfd6
MD5 5155ab28882c7eb53690b0ac7b16b5ec
BLAKE2b-256 54e6ada9d82dfa2a02d7120f153abc240c878fe428dd834d897dddb15b0ee8ed

See more details on using hashes here.

File details

Details for the file django_upload_path-0.1.1-py2.py3-none-any.whl.

File metadata

File hashes

Hashes for django_upload_path-0.1.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 1ed79e7896e75af2ba37a03f6d921612e58aa8cf4cf20565824ea1084cfc69ca
MD5 b61a458d168ac4a5a8b2ef2ea783f742
BLAKE2b-256 ff0da8e4ae79900b61a89d724cafb5fef8da2cc35b9303dd7c106717a7844627

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page