Opened 7 years ago

Last modified 7 years ago

#28170 closed Bug

FileField Upload Permissions Denied — at Initial Version

Reported by: Derrick Jackson Owned by: nobody
Component: File uploads/storage Version: 1.11
Severity: Release blocker Keywords:
Cc: pjf@…, derrick.jackson73@… Triage Stage: Ready for checkin
Has patch: yes Needs documentation: no
Needs tests: no Patch needs improvement: no
Easy pickings: no UI/UX: no

Description

I upgraded from DJango 1.10.6 to 1.11 and can no longer use FileField to upload files larger than 2.5 MB. When an attempt is made to upload a larger file I get the error below occurs. Please note if I downgrade to 1.10.6 again the upload feature works just fine.

Django Version: 1.11
Exception Type: PermissionError
Exception Value:
[Errno 1] Operation not permitted
Exception Location: /usr/lib/python3.5/shutil.py in copystat, line 195
Python Executable: /usr/bin/python3
Python Version: 3.5.2

Environment:

Request Method: POST
Request URL: http://localhost:8000/orders/service/vpn/5/

Django Version: 1.11
Python Version: 3.5.2
Installed Applications:
['django.contrib.auth',

'django.contrib.contenttypes',
'django.contrib.sessions',
'django.contrib.sites',
'django.contrib.messages',
'django.contrib.staticfiles',
'impersonate',
'stronghold',
'django.contrib.admin',
'django.contrib.admindocs',
'ajax_select',
'django_object_actions',
'ckeditor',
'mail_templated',
'administrative',
'changes',
'decommission',
'ecm',
'feedback',
'file_manager',
'gunicorn',
'orders',
'old_net_chg_req',
'server_request',
'security',
'shared',
'system',
'utilities',
'downtime',
'debug_toolbar']

Installed Middleware:
('django.middleware.security.SecurityMiddleware',

'django.contrib.sessions.middleware.SessionMiddleware',
'django.contrib.auth.middleware.AuthenticationMiddleware',
'shared.middleware.CustomDowntimeMiddleware',
'stronghold.middleware.LoginRequiredMiddleware',
'django.middleware.common.CommonMiddleware',
'django.middleware.csrf.CsrfViewMiddleware',
'django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'shared.middleware.GlobalRequestMiddleware',
'shared.middleware.UserTracebackMiddleware',
'django.contrib.messages.middleware.MessageMiddleware',
'impersonate.middleware.ImpersonateMiddleware',
'django.middleware.clickjacking.XFrameOptionsMiddleware',
'debug_toolbar.middleware.DebugToolbarMiddleware')

Traceback:

File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/exception.py" in inner

  1. response = get_response(request)

File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py" in _legacy_get_response

  1. response = self._get_response(request)

File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py" in _get_response

  1. response = self.process_exception_by_middleware(e, request)

File "/usr/local/lib/python3.5/dist-packages/django/core/handlers/base.py" in _get_response

  1. response = wrapped_callback(request, *callback_args, callback_kwargs)

File "/vagrant/orders/views_services.py" in service_vpn

  1. service_order_item.save()

File "/vagrant/orders/models.py" in save

  1. super(ServiceOrder, self).save(*args, kwargs)

File "/usr/local/lib/python3.5/dist-packages/django/db/models/base.py" in save

  1. force_update=force_update, update_fields=update_fields)

File "/usr/local/lib/python3.5/dist-packages/django/db/models/base.py" in save_base

  1. updated = self._save_table(raw, cls, force_insert, force_update, using, update_fields)

File "/usr/local/lib/python3.5/dist-packages/django/db/models/base.py" in _save_table

  1. for f in non_pks]

File "/usr/local/lib/python3.5/dist-packages/django/db/models/base.py" in <listcomp>

  1. for f in non_pks]

File "/usr/local/lib/python3.5/dist-packages/django/db/models/fields/files.py" in pre_save

  1. file.save(file.name, file.file, save=False)

File "/usr/local/lib/python3.5/dist-packages/django/db/models/fields/files.py" in save

  1. self.name = self.storage.save(name, content, max_length=self.field.max_length)

File "/usr/local/lib/python3.5/dist-packages/django/core/files/storage.py" in save

  1. return self._save(name, content)

File "/usr/local/lib/python3.5/dist-packages/django/core/files/storage.py" in _save

  1. file_move_safe(content.temporary_file_path(), full_path)

File "/usr/local/lib/python3.5/dist-packages/django/core/files/move.py" in file_move_safe

  1. copystat(old_file_name, new_file_name)

File "/usr/lib/python3.5/shutil.py" in copystat

  1. follow_symlinks=follow)

Exception Type: PermissionError at /orders/service/vpn/5/
Exception Value: [Errno 1] Operation not permitted

Change History (0)

Note: See TracTickets for help on using tickets.
Back to Top