Close issue #106, Convert document indexing app actions to Celery
This commit is contained in:
@@ -11,7 +11,6 @@ from navigation.api import register_links, register_top_menu
|
|||||||
from project_setup.api import register_setup
|
from project_setup.api import register_setup
|
||||||
from rest_api.classes import APIEndPoint
|
from rest_api.classes import APIEndPoint
|
||||||
|
|
||||||
from .api import update_indexes, delete_indexes
|
|
||||||
from .links import (document_index_list, document_index_main_menu_link,
|
from .links import (document_index_list, document_index_main_menu_link,
|
||||||
index_parent, index_setup, index_setup_create,
|
index_parent, index_setup, index_setup_create,
|
||||||
index_setup_document_types, index_setup_delete,
|
index_setup_document_types, index_setup_delete,
|
||||||
@@ -19,27 +18,28 @@ from .links import (document_index_list, document_index_main_menu_link,
|
|||||||
rebuild_index_instances, template_node_create,
|
rebuild_index_instances, template_node_create,
|
||||||
template_node_delete, template_node_edit)
|
template_node_delete, template_node_edit)
|
||||||
from .models import Index, IndexTemplateNode, IndexInstanceNode
|
from .models import Index, IndexTemplateNode, IndexInstanceNode
|
||||||
|
from .tasks import task_delete_indexes, task_update_indexes
|
||||||
|
|
||||||
|
|
||||||
@receiver(pre_delete, dispatch_uid='document_index_delete', sender=Document)
|
@receiver(pre_delete, dispatch_uid='document_index_delete', sender=Document)
|
||||||
def document_index_delete(sender, **kwargs):
|
def document_index_delete(sender, **kwargs):
|
||||||
delete_indexes(kwargs['instance'])
|
task_delete_indexes.apply_async(kwargs=dict(document_id=kwargs['instance'].pk), queue='indexing')
|
||||||
|
|
||||||
|
|
||||||
@receiver(post_save, dispatch_uid='document_metadata_index_update', sender=DocumentMetadata)
|
@receiver(post_save, dispatch_uid='document_metadata_index_update', sender=DocumentMetadata)
|
||||||
def document_metadata_index_update(sender, **kwargs):
|
def document_metadata_index_update(sender, **kwargs):
|
||||||
delete_indexes(kwargs['instance'].document)
|
task_delete_indexes.apply_async(kwargs=dict(document_id=kwargs['instance'].document.pk), queue='indexing')
|
||||||
update_indexes(kwargs['instance'].document)
|
task_update_indexes.apply_async(kwargs=dict(document_id=kwargs['instance'].document.pk), queue='indexing')
|
||||||
|
|
||||||
|
|
||||||
@receiver(pre_delete, dispatch_uid='document_metadata_index_delete', sender=DocumentMetadata)
|
@receiver(pre_delete, dispatch_uid='document_metadata_index_delete', sender=DocumentMetadata)
|
||||||
def document_metadata_index_delete(sender, **kwargs):
|
def document_metadata_index_delete(sender, **kwargs):
|
||||||
delete_indexes(kwargs['instance'].document)
|
task_delete_indexes.apply_async(kwargs=dict(document_id=kwargs['instance'].document.pk), queue='indexing')
|
||||||
|
|
||||||
|
|
||||||
@receiver(post_delete, dispatch_uid='document_metadata_index_post_delete', sender=DocumentMetadata)
|
@receiver(post_delete, dispatch_uid='document_metadata_index_post_delete', sender=DocumentMetadata)
|
||||||
def document_metadata_index_post_delete(sender, **kwargs):
|
def document_metadata_index_post_delete(sender, **kwargs):
|
||||||
update_indexes(kwargs['instance'].document)
|
task_update_indexes.apply_async(kwargs=dict(document_id=kwargs['instance'].document.pk), queue='indexing')
|
||||||
|
|
||||||
|
|
||||||
register_maintenance_links([rebuild_index_instances], namespace='document_indexing', title=_(u'Indexes'))
|
register_maintenance_links([rebuild_index_instances], namespace='document_indexing', title=_(u'Indexes'))
|
||||||
|
|||||||
29
mayan/apps/document_indexing/tasks.py
Normal file
29
mayan/apps/document_indexing/tasks.py
Normal file
@@ -0,0 +1,29 @@
|
|||||||
|
import logging
|
||||||
|
|
||||||
|
from django.contrib.auth.models import User
|
||||||
|
from django.core.files import File
|
||||||
|
|
||||||
|
from mayan.celery import app
|
||||||
|
from documents.models import Document
|
||||||
|
|
||||||
|
from .api import update_indexes, delete_indexes
|
||||||
|
from .tools import do_rebuild_all_indexes
|
||||||
|
|
||||||
|
logger = logging.getLogger(__name__)
|
||||||
|
|
||||||
|
|
||||||
|
@app.task(ignore_result=True)
|
||||||
|
def task_delete_indexes(document_id):
|
||||||
|
document = Document.objects.get(pk=document_id)
|
||||||
|
update_indexes(document)
|
||||||
|
|
||||||
|
|
||||||
|
@app.task(ignore_result=True)
|
||||||
|
def task_update_indexes(document_id):
|
||||||
|
document = Document.objects.get(pk=document_id)
|
||||||
|
delete_indexes(document)
|
||||||
|
|
||||||
|
|
||||||
|
@app.task(ignore_result=True)
|
||||||
|
def task_do_rebuild_all_indexes():
|
||||||
|
do_rebuild_all_indexes()
|
||||||
@@ -15,5 +15,3 @@ def do_rebuild_all_indexes():
|
|||||||
DocumentRenameCount.objects.all().delete()
|
DocumentRenameCount.objects.all().delete()
|
||||||
for document in Document.objects.all():
|
for document in Document.objects.all():
|
||||||
update_indexes(document)
|
update_indexes(document)
|
||||||
|
|
||||||
return [] # Warnings - None
|
|
||||||
|
|||||||
@@ -28,10 +28,9 @@ from .permissions import (PERMISSION_DOCUMENT_INDEXING_CREATE,
|
|||||||
PERMISSION_DOCUMENT_INDEXING_REBUILD_INDEXES,
|
PERMISSION_DOCUMENT_INDEXING_REBUILD_INDEXES,
|
||||||
PERMISSION_DOCUMENT_INDEXING_SETUP,
|
PERMISSION_DOCUMENT_INDEXING_SETUP,
|
||||||
PERMISSION_DOCUMENT_INDEXING_VIEW)
|
PERMISSION_DOCUMENT_INDEXING_VIEW)
|
||||||
from .tools import do_rebuild_all_indexes
|
from .tasks import task_do_rebuild_all_indexes
|
||||||
from .widgets import index_instance_item_link, get_breadcrumbs, node_level
|
from .widgets import index_instance_item_link, get_breadcrumbs, node_level
|
||||||
|
|
||||||
|
|
||||||
# Setup views
|
# Setup views
|
||||||
|
|
||||||
|
|
||||||
@@ -381,17 +380,8 @@ def rebuild_index_instances(request):
|
|||||||
'message': _(u'On large databases this operation may take some time to execute.'),
|
'message': _(u'On large databases this operation may take some time to execute.'),
|
||||||
}, context_instance=RequestContext(request))
|
}, context_instance=RequestContext(request))
|
||||||
else:
|
else:
|
||||||
try:
|
task_do_rebuild_all_indexes.apply_async(queue='tools')
|
||||||
warnings = do_rebuild_all_indexes()
|
messages.success(request, _(u'Index rebuild queued successfully.'))
|
||||||
messages.success(request, _(u'Index rebuild completed successfully.'))
|
|
||||||
for warning in warnings:
|
|
||||||
messages.warning(request, warning)
|
|
||||||
|
|
||||||
except Exception as exception:
|
|
||||||
if settings.DEBUG:
|
|
||||||
raise
|
|
||||||
messages.error(request, _(u'Index rebuild error: %s') % exception)
|
|
||||||
|
|
||||||
return HttpResponseRedirect(next)
|
return HttpResponseRedirect(next)
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
Reference in New Issue
Block a user