97 lines
3.7 KiB
Python
97 lines
3.7 KiB
Python
from __future__ import unicode_literals
|
|
|
|
from datetime import timedelta
|
|
import logging
|
|
|
|
from django.contrib.auth.models import User
|
|
from django.utils.timezone import now
|
|
|
|
from mayan.celery import app
|
|
|
|
from common.models import SharedUploadedFile
|
|
|
|
from .models import (
|
|
DeletedDocument, Document, DocumentPage, DocumentType, DocumentVersion
|
|
)
|
|
|
|
logger = logging.getLogger(__name__)
|
|
|
|
|
|
@app.task(compression='zlib')
|
|
def task_get_document_page_image(document_page_id, *args, **kwargs):
|
|
document_page = DocumentPage.objects.get(pk=document_page_id)
|
|
return document_page.get_image(*args, **kwargs)
|
|
|
|
|
|
@app.task(ignore_result=True)
|
|
def task_clear_image_cache():
|
|
logger.info('Starting document cache invalidation')
|
|
# TODO: Notification of success and of errors
|
|
Document.objects.invalidate_cache()
|
|
logger.info('Finished document cache invalidation')
|
|
|
|
|
|
@app.task(ignore_result=True)
|
|
def task_update_page_count(version_id):
|
|
document_version = DocumentVersion.objects.get(pk=version_id)
|
|
document_version.update_page_count()
|
|
|
|
|
|
@app.task(ignore_result=True)
|
|
def task_upload_new_version(document_id, shared_uploaded_file_id, user_id, comment=None):
|
|
document = Document.objects.get(pk=document_id)
|
|
|
|
shared_file = SharedUploadedFile.objects.get(pk=shared_uploaded_file_id)
|
|
|
|
if user_id:
|
|
user = User.objects.get(pk=user_id)
|
|
else:
|
|
user = None
|
|
|
|
with shared_file.open() as file_object:
|
|
try:
|
|
document_version = DocumentVersion(document=document, comment=comment or '', file=file_object)
|
|
document_version.save(_user=user)
|
|
except Warning as warning:
|
|
logger.info('Warning during attempt to create new document version for document: %s ; %s', document, warning)
|
|
finally:
|
|
shared_file.delete()
|
|
|
|
|
|
@app.task(ignore_result=True)
|
|
def task_check_trash_periods():
|
|
logger.info('Executing')
|
|
|
|
for document_type in DocumentType.objects.all():
|
|
logger.info('Checking trash period of document type: %s', document_type)
|
|
if document_type.trash_time_period and document_type.trash_time_unit:
|
|
delta = timedelta(**{document_type.trash_time_unit: document_type.trash_time_period})
|
|
logger.info('Document type: %s, has a trash period delta of: %s', document_type, delta)
|
|
for document in Document.objects.filter(document_type=document_type):
|
|
if now() > document.date_added + delta:
|
|
logger.info('Document "%s" with id: %d, added on: %s, exceded trash period', document, document.pk, document.date_added)
|
|
document.delete()
|
|
else:
|
|
logger.info('Document type: %s, has a no retention delta', document_type)
|
|
|
|
logger.info('Finshed')
|
|
|
|
|
|
@app.task(ignore_result=True)
|
|
def task_check_delete_periods():
|
|
logger.info('Executing')
|
|
|
|
for document_type in DocumentType.objects.all():
|
|
logger.info('Checking deletion period of document type: %s', document_type)
|
|
if document_type.delete_time_period and document_type.delete_time_unit:
|
|
delta = timedelta(**{document_type.delete_time_unit: document_type.delete_time_period})
|
|
logger.info('Document type: %s, has a deletion period delta of: %s', document_type, delta)
|
|
for document in DeletedDocument.objects.filter(document_type=document_type):
|
|
if now() > document.deleted_date_time + delta:
|
|
logger.info('Document "%s" with id: %d, trashed on: %s, exceded delete period', document, document.pk, document.deleted_date_time)
|
|
document.delete()
|
|
else:
|
|
logger.info('Document type: %s, has a no retention delta', document_type)
|
|
|
|
logger.info('Finshed')
|