from __future__ import absolute_import, unicode_literals import logging from django.apps import apps from django.db import models from django.utils.timezone import now from documents.models import Document from .events import ( event_document_auto_check_in, event_document_check_in, event_document_forceful_check_in ) from .exceptions import DocumentNotCheckedOut from .literals import STATE_CHECKED_OUT, STATE_CHECKED_IN logger = logging.getLogger(__name__) class DocumentCheckoutManager(models.Manager): def checkout_document(self, document, expiration_datetime, user, block_new_version=True): self.create( document=document, expiration_datetime=expiration_datetime, user=user, block_new_version=block_new_version ) def checked_out_documents(self): return Document.on_organization.filter( pk__in=self.all().values_list( 'document__pk', flat=True ) ) def expired_check_outs(self): expired_list = Document.on_organization.filter( pk__in=self.filter( expiration_datetime__lte=now() ).values_list('document__pk', flat=True) ) logger.debug('expired_list: %s', expired_list) return expired_list def check_in_expired_check_outs(self): for document in self.expired_check_outs(): document.check_in() def is_document_checked_out(self, document): if self.model.on_organization.filter(document=document): return True else: return False def check_in_document(self, document, user=None): try: document_checkout = self.get(document=document) except self.model.DoesNotExist: raise DocumentNotCheckedOut else: if user: if self.document_checkout_info(document).user != user: event_document_forceful_check_in.commit( actor=user, target=document ) else: event_document_check_in.commit(actor=user, target=document) else: event_document_auto_check_in.commit(target=document) document_checkout.delete() def document_checkout_info(self, document): try: return self.get(document=document) except self.model.DoesNotExist: raise DocumentNotCheckedOut def document_checkout_state(self, document): if self.is_document_checked_out(document): return STATE_CHECKED_OUT else: return STATE_CHECKED_IN def are_document_new_versions_allowed(self, document, user=None): try: checkout_info = self.document_checkout_info(document) except DocumentNotCheckedOut: return True else: return not checkout_info.block_new_version class OrganizationDocumentCheckoutManager(DocumentCheckoutManager): def get_queryset(self): Document = apps.get_model('documents', 'Document') return super( OrganizationDocumentCheckoutManager, self ).get_queryset().filter( document__in=Document.on_organization.all() )