Add per document type, workflow list API view. GitLab issue #357, GitLab merge request #!9. cc @jeverling

This commit is contained in:
Roberto Rosario
2017-02-15 20:20:14 -04:00
parent 722007702c
commit 8b20015f64
3 changed files with 50 additions and 5 deletions

View File

@@ -6,7 +6,7 @@ from django.shortcuts import get_object_or_404
from rest_framework import generics from rest_framework import generics
from acls.models import AccessControlList from acls.models import AccessControlList
from documents.models import Document from documents.models import Document, DocumentType
from documents.permissions import permission_document_type_view from documents.permissions import permission_document_type_view
from permissions import Permission from permissions import Permission
from rest_api.filters import MayanObjectPermissionsFilter from rest_api.filters import MayanObjectPermissionsFilter
@@ -27,6 +27,33 @@ from .serializers import (
) )
class APIDocumentTypeWorkflowListView(generics.ListAPIView):
serializer_class = WorkflowSerializer
def get(self, *args, **kwargs):
"""
Returns a list of all the document type workflows.
"""
return super(APIDocumentTypeWorkflowListView, self).get(*args, **kwargs)
def get_document_type(self):
document_type = get_object_or_404(DocumentType, pk=self.kwargs['pk'])
try:
Permission.check_permissions(
self.request.user, (permission_workflow_view,)
)
except PermissionDenied:
AccessControlList.objects.check_access(
permission_workflow_view, self.request.user, document_type
)
return document_type
def get_queryset(self):
return self.get_document_type().workflows.all()
class APIWorkflowDocumentTypeList(generics.ListCreateAPIView): class APIWorkflowDocumentTypeList(generics.ListCreateAPIView):
filter_backends = (MayanObjectPermissionsFilter,) filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = { mayan_object_permissions = {

View File

@@ -186,6 +186,19 @@ class WorkflowAPITestCase(APITestCase):
workflow.refresh_from_db() workflow.refresh_from_db()
self.assertEqual(workflow.label, TEST_WORKFLOW_LABEL_EDITED) self.assertEqual(workflow.label, TEST_WORKFLOW_LABEL_EDITED)
def test_document_type_workflow_list(self):
workflow = self._create_workflow()
workflow.document_types.add(self.document_type)
response = self.client.get(
reverse(
'rest_api:documenttype-workflow-list',
args=(self.document_type.pk,)
),
)
self.assertEqual(response.data['results'][0]['label'], workflow.label)
@override_settings(OCR_AUTO_OCR=False) @override_settings(OCR_AUTO_OCR=False)
class WorkflowStatesAPITestCase(APITestCase): class WorkflowStatesAPITestCase(APITestCase):

View File

@@ -3,10 +3,10 @@ from __future__ import unicode_literals
from django.conf.urls import patterns, url from django.conf.urls import patterns, url
from .api_views import ( from .api_views import (
APIWorkflowDocumentTypeList, APIWorkflowDocumentTypeView, APIDocumentTypeWorkflowListView, APIWorkflowDocumentTypeList,
APIWorkflowInstanceListView, APIWorkflowInstanceView, APIWorkflowDocumentTypeView, APIWorkflowInstanceListView,
APIWorkflowInstanceLogEntryListView, APIWorkflowListView, APIWorkflowInstanceView, APIWorkflowInstanceLogEntryListView,
APIWorkflowStateListView, APIWorkflowStateView, APIWorkflowListView, APIWorkflowStateListView, APIWorkflowStateView,
APIWorkflowTransitionListView, APIWorkflowTransitionView, APIWorkflowView APIWorkflowTransitionListView, APIWorkflowTransitionView, APIWorkflowView
) )
from .views import ( from .views import (
@@ -150,4 +150,9 @@ api_urls = [
APIWorkflowInstanceLogEntryListView.as_view(), APIWorkflowInstanceLogEntryListView.as_view(),
name='workflowinstancelogentry-list' name='workflowinstancelogentry-list'
), ),
url(
r'^document_type/(?P<pk>[0-9]+)/workflows/$',
APIDocumentTypeWorkflowListView.as_view(),
name='documenttype-workflow-list'
),
] ]