Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

django-safe-filefield

Package Overview
Dependencies
Maintainers
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

django-safe-filefield

Secure file field, which allows you to restrict uploaded file extensions.

  • 1.0.0
  • PyPI
  • Socket score

Maintainers
2

django-safe-filefield

.. image:: https://github.com/mixkorshun/django-safe-filefield/actions/workflows/flake8.yml/badge.svg?branch=master :alt: flake8 :target: https://github.com/mixkorshun/django-safe-filefield .. image:: https://github.com/mixkorshun/django-safe-filefield/actions/workflows/pytest.yml/badge.svg?branch=master :alt: pytest :target: https://github.com/mixkorshun/django-safe-filefield .. image:: https://badge.fury.io/py/django-safe-filefield.svg :alt: pypi :target: https://pypi.python.org/pypi/django-safe-filefield .. image:: https://img.shields.io/badge/code%20style-pep8-orange.svg :alt: pep8 :target: https://www.python.org/dev/peps/pep-0008/ .. image:: https://img.shields.io/badge/License-MIT-yellow.svg :alt: MIT :target: https://opensource.org/licenses/MIT

Secure file field, which allows you to restrict uploaded file extensions. It may be useful for user-uploaded files (attachments).

This package adds model and forms field. What this fields does:

  • restricts allowed file extensions (for example: only *.pdf files)
  • checks file extensions is correct for sent content-type
  • checks sent content type is correct for file content (detects by libmagic)
  • checks uploaded file with anti-virus software

Installation

The package can be installed using:

.. code-block::

pip install django-safe-filefield

Add the following settings:

.. code-block:: python

INSTALLED_APPS += [ 'safe_filefield', ]

django-safe-filefield requires libmagic to be installed.

Usage

Simply add field to your model:

.. code-block:: python

from safe_filefield.models import SafeFileField

class MyModel(models.Model):

   attachment = SafeFileField(
       allowed_extensions=('xls', 'xlsx', 'csv')
   )

Or directly to your form:

.. code-block:: python

from safe_filefield.forms import SafeFileField

class MyForm(forms.Form):

   attachment = SafeFileField(
       allowed_extensions=('xls', 'xlsx', 'csv')
   )

Content type checking +++++++++++++++++++++

To check actual file content type, use check_content_type argument. This will prevent attacker from uploading malicious file just by changing its extension.

.. code-block:: python

class MyForm(forms.Form): attachment = SafeFileField( check_content_type=True )

ClamAV support ++++++++++++++

.. note:: To use this functionality you should have clamd daemon.

This package has ability to check uploaded file with ClamAV antivirus.

To use anti-virus protection simply enable it in your form or model definition:

.. code-block:: python

from safe_filefield.forms import SafeFileField

class MyForm(forms.Form): attachment = SafeFileField( scan_viruses=True, )

You can configure some ClamAV settings:

.. code-block:: python

CLAMAV_SOCKET = 'unix://tmp/clamav.sock' # or tcp://127.0.0.1:3310

CLAMAV_TIMEOUT = 30 # 30 seconds timeout, None by default which means infinite

Contributing

If you have any valuable contribution, suggestion or idea, please let me know as well because I will look into it.

Pull requests are welcome.

Keywords

FAQs


Did you know?

Socket

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.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc