45 lines
1.7 KiB
Python
45 lines
1.7 KiB
Python
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()
|