Files
mayan-edms/apps/document_indexing/post_init.py

72 lines
3.0 KiB
Python

from __future__ import absolute_import
import logging
from django.db.models.signals import post_save, pre_delete, post_delete
from django.dispatch import receiver
from django.utils.translation import ugettext_lazy as _
from documents.models import Document
#from maintenance.api import MaintenanceNamespace
from metadata.models import DocumentMetadata
from navigation.api import (register_sidebar_template,
bind_links)
from .api import update_indexes, delete_indexes
from .links import (index_setup_list, index_setup_create,
index_setup_edit, index_setup_delete, index_setup_view,
template_node_create, template_node_edit, template_node_delete,
index_parent, document_index_list, rebuild_index_instances,
index_setup_document_types)
from .models import (Index, IndexTemplateNode, IndexInstanceNode)
from .settings import AVAILABLE_INDEXING_FUNCTIONS
logger = logging.getLogger(__name__)
#namespace = MaintenanceNamespace(_(u'indexes'))
#namespace.create_tool(rebuild_index_instances)
@receiver(post_save, dispatch_uid='document_index_update', sender=Document)
def document_index_update(sender, **kwargs):
# TODO: save result in index log
delete_indexes(kwargs['instance'])
update_indexes(kwargs['instance'])
@receiver(pre_delete, dispatch_uid='document_index_delete', sender=Document)
def document_index_delete(sender, **kwargs):
# TODO: save result in index log
delete_indexes(kwargs['instance'])
@receiver(post_save, dispatch_uid='document_metadata_index_update', sender=DocumentMetadata)
def document_metadata_index_update(sender, **kwargs):
# TODO: save result in index log
delete_indexes(kwargs['instance'].document)
update_indexes(kwargs['instance'].document)
@receiver(pre_delete, dispatch_uid='document_metadata_index_delete', sender=DocumentMetadata)
def document_metadata_index_delete(sender, **kwargs):
# TODO: save result in index log
delete_indexes(kwargs['instance'].document)
@receiver(post_delete, dispatch_uid='document_metadata_index_post_delete', sender=DocumentMetadata)
def document_metadata_index_post_delete(sender, **kwargs):
# TODO: save result in index log
update_indexes(kwargs['instance'].document)
available_indexing_functions_string = (_(u'Available functions: %s') % u','.join([u'%s()' % name for name, function in AVAILABLE_INDEXING_FUNCTIONS.items()])) if AVAILABLE_INDEXING_FUNCTIONS else u''
IndexTemplateNode._meta.get_field('expression').help_text=_(u'Enter a python string expression to be evaluated.%s') % available_indexing_functions_string
register_sidebar_template(['index_instance_list'], 'indexing_help.html')
bind_links([IndexInstanceNode], [index_parent])
bind_links([Document], [document_index_list], menu_name='form_header')
bind_links([Index, 'index_setup_list', 'index_setup_create'], [index_setup_list, index_setup_create], menu_name='secondary_menu')
bind_links([Index], [index_setup_edit, index_setup_delete, index_setup_view, index_setup_document_types])
bind_links([IndexTemplateNode], [template_node_create, template_node_edit, template_node_delete])