266 lines
8.5 KiB
Python
266 lines
8.5 KiB
Python
from __future__ import absolute_import, unicode_literals
|
|
|
|
from django.conf import settings
|
|
from django.contrib import messages
|
|
from django.core.exceptions import PermissionDenied
|
|
from django.core.urlresolvers import reverse
|
|
from django.http import HttpResponseRedirect
|
|
from django.shortcuts import get_object_or_404, render_to_response
|
|
from django.template import RequestContext
|
|
from django.utils.translation import ugettext_lazy as _, ungettext
|
|
|
|
from acls.models import AccessControlList
|
|
from common.views import ConfirmView, SingleObjectEditView
|
|
from documents.models import Document, DocumentType, DocumentVersion
|
|
from permissions import Permission
|
|
|
|
from .forms import DocumentContentForm
|
|
from .models import DocumentVersionOCRError
|
|
from .permissions import (
|
|
permission_ocr_content_view, permission_ocr_document,
|
|
permission_ocr_document_delete, permission_document_type_ocr_setup
|
|
)
|
|
|
|
|
|
class DocumentSubmitView(ConfirmView):
|
|
def get_extra_context(self):
|
|
return {
|
|
'object': Document.objects.get(pk=self.kwargs['pk']),
|
|
'title': _('Submit the selected document for OCR?')
|
|
}
|
|
|
|
def object_action(self, request, obj):
|
|
document = obj
|
|
|
|
try:
|
|
Permission.check_permissions(
|
|
request.user, [permission_ocr_document]
|
|
)
|
|
except PermissionDenied:
|
|
AccessControlList.objects.check_access(
|
|
permission_ocr_document, request.user, document
|
|
)
|
|
|
|
document.submit_for_ocr()
|
|
messages.success(
|
|
request,
|
|
_('Document: %(document)s was added to the OCR queue.') % {
|
|
'document': document
|
|
}
|
|
)
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
document = get_object_or_404(Document, pk=self.kwargs['pk'])
|
|
self.object_action(request=request, obj=document)
|
|
|
|
return HttpResponseRedirect(self.get_success_url())
|
|
|
|
|
|
class DocumentAllSubmitView(ConfirmView):
|
|
extra_context = {'title': _('Submit all documents for OCR?')}
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
count = 0
|
|
for document in Document.objects.all():
|
|
document.submit_for_ocr()
|
|
count += 1
|
|
|
|
messages.success(
|
|
request, _('%d documents added to the OCR queue.') % count
|
|
)
|
|
|
|
return HttpResponseRedirect(self.get_success_url())
|
|
|
|
|
|
class DocumentManySubmitView(DocumentSubmitView):
|
|
extra_context = {'title': _('Submit the selected documents for OCR?')}
|
|
|
|
def post(self, request, *args, **kwargs):
|
|
for pk in request.GET.get('id_list', '').split(','):
|
|
document = get_object_or_404(Document, pk=pk)
|
|
try:
|
|
self.object_action(request=request, obj=document)
|
|
except PermissionDenied:
|
|
pass
|
|
|
|
return HttpResponseRedirect(self.get_success_url())
|
|
|
|
|
|
class DocumentTypeSettingsEditView(SingleObjectEditView):
|
|
fields = ('auto_ocr',)
|
|
view_permission = permission_document_type_ocr_setup
|
|
|
|
def get_object(self, queryset=None):
|
|
return get_object_or_404(
|
|
DocumentType, pk=self.kwargs['pk']
|
|
).ocr_settings
|
|
|
|
def get_context_data(self, **kwargs):
|
|
context = super(
|
|
DocumentTypeSettingsEditView, self
|
|
).get_context_data(**kwargs)
|
|
|
|
context.update(
|
|
{
|
|
'title': _(
|
|
'Edit OCR settings for document type: %s'
|
|
) % self.get_object().document_type
|
|
}
|
|
)
|
|
|
|
return context
|
|
|
|
|
|
def document_content(request, document_id):
|
|
document = get_object_or_404(Document, pk=document_id)
|
|
|
|
try:
|
|
Permission.check_permissions(
|
|
request.user, [permission_ocr_content_view]
|
|
)
|
|
except PermissionDenied:
|
|
AccessControlList.objects.check_access(
|
|
permission_ocr_content_view, request.user, document
|
|
)
|
|
|
|
document.add_as_recent_document_for_user(request.user)
|
|
|
|
content_form = DocumentContentForm(document=document)
|
|
|
|
return render_to_response('appearance/generic_form.html', {
|
|
'document': document,
|
|
'form': content_form,
|
|
'hide_labels': True,
|
|
'object': document,
|
|
'read_only': True,
|
|
'title': _('Content of document: %s') % document,
|
|
}, context_instance=RequestContext(request))
|
|
|
|
|
|
def entry_list(request):
|
|
Permission.check_permissions(request.user, [permission_ocr_document])
|
|
|
|
context = {
|
|
'object_list': DocumentVersionOCRError.objects.all(),
|
|
'title': _('OCR errors'),
|
|
'hide_object': True,
|
|
}
|
|
|
|
return render_to_response('appearance/generic_list.html', context,
|
|
context_instance=RequestContext(request))
|
|
|
|
|
|
def entry_delete(request, pk=None, pk_list=None):
|
|
Permission.check_permissions(
|
|
request.user, [permission_ocr_document_delete]
|
|
)
|
|
|
|
if pk:
|
|
entries = [get_object_or_404(DocumentVersionOCRError, pk=pk)]
|
|
elif pk_list:
|
|
entries = [
|
|
get_object_or_404(
|
|
DocumentVersionOCRError, pk=pk
|
|
) for pk in pk_list.split(',')
|
|
]
|
|
else:
|
|
messages.error(request, _('Make at least one selection.'))
|
|
return HttpResponseRedirect(
|
|
request.META.get(
|
|
'HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL)
|
|
)
|
|
)
|
|
|
|
next = request.POST.get('next', request.GET.get('next', request.META.get('HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL))))
|
|
previous = request.POST.get('previous', request.GET.get('previous', request.META.get('HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL))))
|
|
|
|
if request.method == 'POST':
|
|
for entry in entries:
|
|
try:
|
|
entry.delete()
|
|
messages.success(
|
|
request, _('Entry: %(entry)s deleted successfully.') % {
|
|
'entry': entry
|
|
}
|
|
)
|
|
|
|
except Exception as exception:
|
|
messages.error(
|
|
request, _('Error entry: %(entry)s; %(error)s') % {
|
|
'entry': entry, 'error': exception
|
|
}
|
|
)
|
|
return HttpResponseRedirect(next)
|
|
|
|
context = {
|
|
'next': next,
|
|
'previous': previous,
|
|
'delete_view': True,
|
|
}
|
|
|
|
if len(entries) == 1:
|
|
context['object'] = entries[0]
|
|
|
|
context['title'] = ungettext(
|
|
'Delete the selected entry?',
|
|
'Delete the selected entries?',
|
|
len(entries)
|
|
)
|
|
|
|
return render_to_response('appearance/generic_confirm.html', context,
|
|
context_instance=RequestContext(request))
|
|
|
|
|
|
def entry_delete_multiple(request):
|
|
return entry_delete(request, pk_list=request.GET.get('id_list', ''))
|
|
|
|
|
|
def entry_re_queue(request, pk=None, pk_list=None):
|
|
Permission.check_permissions(request.user, [permission_ocr_document])
|
|
|
|
if pk:
|
|
entries = [get_object_or_404(DocumentVersionOCRError, pk=pk)]
|
|
elif pk_list:
|
|
entries = [get_object_or_404(DocumentVersionOCRError, pk=pk) for pk in pk_list.split(',')]
|
|
else:
|
|
messages.error(request, _('Make at least one selection.'))
|
|
return HttpResponseRedirect(request.META.get('HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL)))
|
|
|
|
next = request.POST.get('next', request.GET.get('next', request.META.get('HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL))))
|
|
previous = request.POST.get('previous', request.GET.get('previous', request.META.get('HTTP_REFERER', reverse(settings.LOGIN_REDIRECT_URL))))
|
|
|
|
if request.method == 'POST':
|
|
for entry in entries:
|
|
try:
|
|
entry.document_version.submit_for_ocr()
|
|
messages.success(
|
|
request,
|
|
_('Entry: %(entry)s was re-queued for OCR.') % {
|
|
'entry': entry
|
|
}
|
|
)
|
|
except DocumentVersion.DoesNotExist:
|
|
messages.error(request, _('Document version id#: %d, no longer exists.') % entry.document_version_id)
|
|
return HttpResponseRedirect(next)
|
|
|
|
context = {
|
|
'next': next,
|
|
'previous': previous,
|
|
}
|
|
|
|
if len(entries) == 1:
|
|
context['object'] = entries[0]
|
|
|
|
context['title'] = ungettext(
|
|
'Re-queue the selected entry?',
|
|
'Re-queue the selected entries?',
|
|
len(entries)
|
|
)
|
|
|
|
return render_to_response('appearance/generic_confirm.html', context,
|
|
context_instance=RequestContext(request))
|
|
|
|
|
|
def entry_re_queue_multiple(request):
|
|
return entry_re_queue(request, pk_list=request.GET.get('id_list', []))
|