44
mayan/apps/sources/tasks.py
Normal file
44
mayan/apps/sources/tasks.py
Normal file
@@ -0,0 +1,44 @@
|
|||||||
|
import logging
|
||||||
|
|
||||||
|
from mayan.celery import app
|
||||||
|
|
||||||
|
from documents.exceptions import NewDocumentVersionNotAllowed
|
||||||
|
from documents.models import DocumentType
|
||||||
|
|
||||||
|
from .models import Source, StagingFolderSource
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@app.task
|
||||||
|
def task_upload_document(source_id, file_object, filename=None, use_file_name=False, document_type_id=None, expand=False, metadata_dict_list=None, user=None, document_id=None, new_version_data=None, command_line=False, description=None, staging_file=None):
|
||||||
|
source = Source.objects.get_subclass(pk=source_id)
|
||||||
|
|
||||||
|
if document_type_id:
|
||||||
|
document_type = DocumentType.objects.get(pk=document_type_id)
|
||||||
|
else:
|
||||||
|
document_type = None
|
||||||
|
|
||||||
|
if document_id:
|
||||||
|
document = Document.objects.get(pk=document_id)
|
||||||
|
else:
|
||||||
|
document = None
|
||||||
|
|
||||||
|
#try:
|
||||||
|
result = source.upload_file(file_object, filename, use_file_name, document_type, expand, metadata_dict_list, user, document, new_version_data, command_line, description)
|
||||||
|
#except NewDocumentVersionNotAllowed:
|
||||||
|
# messages.error(request, _(u'New version uploads are not allowed for this document.'))
|
||||||
|
|
||||||
|
#if not document:
|
||||||
|
# if result['is_compressed'] is None:
|
||||||
|
# messages.success(request, _(u'File uploaded successfully.'))
|
||||||
|
|
||||||
|
# if result['is_compressed'] is True:
|
||||||
|
# messages.success(request, _(u'File uncompressed successfully and uploaded as individual files.'))
|
||||||
|
|
||||||
|
# if result['is_compressed'] is False:
|
||||||
|
# messages.warning(request, _(u'File was not a compressed file, uploaded as it was.'))
|
||||||
|
|
||||||
|
if isinstance(source, StagingFolderSource):
|
||||||
|
if source.delete_after_upload:
|
||||||
|
staging_file.delete()
|
||||||
@@ -33,6 +33,7 @@ from .permissions import (PERMISSION_SOURCES_SETUP_CREATE,
|
|||||||
PERMISSION_SOURCES_SETUP_DELETE,
|
PERMISSION_SOURCES_SETUP_DELETE,
|
||||||
PERMISSION_SOURCES_SETUP_EDIT,
|
PERMISSION_SOURCES_SETUP_EDIT,
|
||||||
PERMISSION_SOURCES_SETUP_VIEW)
|
PERMISSION_SOURCES_SETUP_VIEW)
|
||||||
|
from .tasks import task_upload_document
|
||||||
|
|
||||||
|
|
||||||
def document_create_siblings(request, document_id):
|
def document_create_siblings(request, document_id):
|
||||||
@@ -170,43 +171,43 @@ def upload_interactive(request, source_id=None, document_pk=None):
|
|||||||
|
|
||||||
if isinstance(source, WebFormSource):
|
if isinstance(source, WebFormSource):
|
||||||
file_object = request.FILES['file']
|
file_object = request.FILES['file']
|
||||||
|
staging_file = None
|
||||||
else:
|
else:
|
||||||
staging_file = source.get_file(encoded_filename=form.cleaned_data['staging_file_id'])
|
staging_file = source.get_file(encoded_filename=form.cleaned_data['staging_file_id'])
|
||||||
file_object = staging_file.as_file()
|
file_object = staging_file.as_file()
|
||||||
|
|
||||||
result = source.upload_file(
|
if document_type:
|
||||||
file_object,
|
document_type_id = document_type.pk
|
||||||
new_filename, use_file_name=form.cleaned_data.get('use_file_name', False),
|
else:
|
||||||
document_type=document_type,
|
document_type_id = None
|
||||||
|
|
||||||
|
if document:
|
||||||
|
document_id = document.pk
|
||||||
|
else:
|
||||||
|
document_id = None
|
||||||
|
|
||||||
|
task_upload_document.apply_async(kwargs=dict(
|
||||||
|
source_id=source.pk,
|
||||||
|
file_object=file_object, filename=new_filename,
|
||||||
|
use_file_name=form.cleaned_data.get('use_file_name', False),
|
||||||
|
document_type_id=document_type_id,
|
||||||
expand=expand,
|
expand=expand,
|
||||||
metadata_dict_list=decode_metadata_from_url(request.GET),
|
metadata_dict_list=decode_metadata_from_url(request.GET),
|
||||||
user=request.user,
|
user=request.user,
|
||||||
document=document,
|
document_id=document_id,
|
||||||
new_version_data=form.cleaned_data.get('new_version_data'),
|
new_version_data=form.cleaned_data.get('new_version_data'),
|
||||||
description=form.cleaned_data.get('description')
|
description=form.cleaned_data.get('description'),
|
||||||
)
|
staging_file=None
|
||||||
|
), queue='uploads')
|
||||||
if isinstance(source, StagingFolderSource):
|
|
||||||
if source.delete_after_upload:
|
|
||||||
staging_file.delete()
|
|
||||||
messages.success(request, _(u'Staging file: %s, deleted successfully.') % staging_file.filename)
|
|
||||||
|
|
||||||
|
# TODO: Notify user
|
||||||
if document:
|
if document:
|
||||||
messages.success(request, _(u'New document version uploaded successfully.'))
|
messages.success(request, _(u'New document version queued for uploaded and will be available shortly.'))
|
||||||
return HttpResponseRedirect(reverse('documents:document_version_list', args=[document.pk]))
|
return HttpResponseRedirect(reverse('documents:document_version_list', args=[document.pk]))
|
||||||
else:
|
else:
|
||||||
if result['is_compressed'] is None:
|
messages.success(request, _(u'New document version queued for uploaded and will be available shortly.'))
|
||||||
messages.success(request, _(u'File uploaded successfully.'))
|
|
||||||
|
|
||||||
if result['is_compressed'] is True:
|
|
||||||
messages.success(request, _(u'File uncompressed successfully and uploaded as individual files.'))
|
|
||||||
|
|
||||||
if result['is_compressed'] is False:
|
|
||||||
messages.warning(request, _(u'File was not a compressed file, uploaded as it was.'))
|
|
||||||
|
|
||||||
return HttpResponseRedirect(request.get_full_path())
|
return HttpResponseRedirect(request.get_full_path())
|
||||||
except NewDocumentVersionNotAllowed:
|
|
||||||
messages.error(request, _(u'New version uploads are not allowed for this document.'))
|
|
||||||
except Exception as exception:
|
except Exception as exception:
|
||||||
if settings.DEBUG:
|
if settings.DEBUG:
|
||||||
raise
|
raise
|
||||||
|
|||||||
Reference in New Issue
Block a user