Don't include the documents contained in the tags or folders results, instead provide a separate, paginates tag and folder endpoint
This commit is contained in:
@@ -49,6 +49,28 @@ class APIFolderView(generics.RetrieveUpdateDestroyAPIView):
|
||||
}
|
||||
|
||||
|
||||
class APIFolderDocumentListView(generics.ListAPIView):
|
||||
"""
|
||||
Returns a list of all the documents contained in a particular folder.
|
||||
"""
|
||||
|
||||
filter_backends = (MayanObjectPermissionsFilter,)
|
||||
mayan_object_permissions = {'GET': [PERMISSION_DOCUMENT_VIEW]}
|
||||
|
||||
def get_serializer_class(self):
|
||||
from documents.serializers import DocumentSerializer
|
||||
return DocumentSerializer
|
||||
|
||||
def get_queryset(self):
|
||||
folder = get_object_or_404(Folder, pk=self.kwargs['pk'])
|
||||
try:
|
||||
Permission.objects.check_permissions(self.request.user, [PERMISSION_FOLDER_VIEW])
|
||||
except PermissionDenied:
|
||||
AccessEntry.objects.check_access(PERMISSION_FOLDER_VIEW, self.request.user, folder)
|
||||
|
||||
queryset = folder.documents.all()
|
||||
return queryset
|
||||
|
||||
class APIDocumentFolderListView(generics.ListAPIView):
|
||||
"""
|
||||
Returns a list of all the folders to which a document belongs.
|
||||
@@ -56,7 +78,6 @@ class APIDocumentFolderListView(generics.ListAPIView):
|
||||
|
||||
serializer_class = FolderSerializer
|
||||
|
||||
permission_classes = (MayanPermission,)
|
||||
filter_backends = (MayanObjectPermissionsFilter,)
|
||||
mayan_object_permissions = {'GET': [PERMISSION_FOLDER_VIEW]}
|
||||
|
||||
|
||||
@@ -6,15 +6,8 @@ from .models import Folder
|
||||
|
||||
|
||||
class FolderSerializer(serializers.HyperlinkedModelSerializer):
|
||||
# FIXME: Doing a: from documents.serializers import DocumentSerializer
|
||||
# causes an unexplained ImportError, so we import it hidden until the issue
|
||||
# is resolved
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
from documents.serializers import DocumentSerializer
|
||||
super(FolderSerializer, self).__init__(*args, **kwargs)
|
||||
self.fields['documents'] = DocumentSerializer()
|
||||
documents = serializers.HyperlinkedIdentityField(view_name='folder-document-list')
|
||||
|
||||
class Meta:
|
||||
fields = ('id', 'url', 'title', 'user', 'datetime_created')
|
||||
fields = ('id', 'url', 'title', 'user', 'datetime_created', 'documents')
|
||||
model = Folder
|
||||
|
||||
@@ -1,7 +1,7 @@
|
||||
from django.conf.urls import patterns, url
|
||||
|
||||
from .api_views import (APIDocumentFolderListView, APIFolderListView,
|
||||
APIFolderView)
|
||||
from .api_views import (APIDocumentFolderListView, APIFolderDocumentListView,
|
||||
APIFolderListView, APIFolderView)
|
||||
from .views import FolderDetailView, FolderListView
|
||||
|
||||
urlpatterns = patterns('folders.views',
|
||||
@@ -20,7 +20,8 @@ urlpatterns = patterns('folders.views',
|
||||
)
|
||||
|
||||
api_urls = patterns('',
|
||||
url(r'^folders/$', APIFolderListView.as_view(), name='folder-list'),
|
||||
url(r'^folders/(?P<pk>[0-9]+)/documents/$', APIFolderDocumentListView.as_view(), name='folder-document-list'),
|
||||
url(r'^folders/(?P<pk>[0-9]+)/$', APIFolderView.as_view(), name='folder-detail'),
|
||||
url(r'^folders/$', APIFolderListView.as_view(), name='folder-list'),
|
||||
url(r'^document/(?P<pk>[0-9]+)/folders/$', APIDocumentFolderListView.as_view(), name='document-folder-list'),
|
||||
)
|
||||
|
||||
@@ -39,6 +39,29 @@ class APITagListView(generics.ListAPIView):
|
||||
mayan_object_permissions = {'GET': [PERMISSION_TAG_VIEW]}
|
||||
|
||||
|
||||
class APITagDocumentListView(generics.ListAPIView):
|
||||
"""
|
||||
Returns a list of all the documents tagged by a particular tag.
|
||||
"""
|
||||
|
||||
filter_backends = (MayanObjectPermissionsFilter,)
|
||||
mayan_object_permissions = {'GET': [PERMISSION_DOCUMENT_VIEW]}
|
||||
|
||||
def get_serializer_class(self):
|
||||
from documents.serializers import DocumentSerializer
|
||||
return DocumentSerializer
|
||||
|
||||
def get_queryset(self):
|
||||
tag = get_object_or_404(Tag, pk=self.kwargs['pk'])
|
||||
try:
|
||||
Permission.objects.check_permissions(self.request.user, [PERMISSION_TAG_VIEW])
|
||||
except PermissionDenied:
|
||||
AccessEntry.objects.check_access(PERMISSION_TAG_VIEW, self.request.user, tag)
|
||||
|
||||
queryset = tag.documents.all()
|
||||
return queryset
|
||||
|
||||
|
||||
class APIDocumentTagListView(generics.ListAPIView):
|
||||
"""
|
||||
Returns a list of all the tags attached to a document.
|
||||
@@ -46,7 +69,6 @@ class APIDocumentTagListView(generics.ListAPIView):
|
||||
|
||||
serializer_class = TagSerializer
|
||||
|
||||
permission_classes = (MayanPermission,)
|
||||
filter_backends = (MayanObjectPermissionsFilter,)
|
||||
mayan_object_permissions = {'GET': [PERMISSION_TAG_VIEW]}
|
||||
|
||||
|
||||
@@ -5,17 +5,9 @@ from taggit.models import Tag
|
||||
|
||||
|
||||
class TagSerializer(serializers.HyperlinkedModelSerializer):
|
||||
# FIXME: Doing a: from documents.serializers import DocumentSerializer
|
||||
# causes an unexplained ImportError, so we import it hidden until the issue
|
||||
# is resolved
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
from documents.serializers import DocumentSerializer
|
||||
super(TagSerializer, self).__init__(*args, **kwargs)
|
||||
self.fields['documents'] = DocumentSerializer()
|
||||
|
||||
color = serializers.CharField(source='properties.get.color')
|
||||
documents = serializers.HyperlinkedIdentityField(view_name='tag-document-list')
|
||||
|
||||
class Meta:
|
||||
fields = ('id', 'url', 'name', 'color', 'slug')
|
||||
fields = ('id', 'url', 'name', 'color', 'slug', 'documents')
|
||||
model = Tag
|
||||
|
||||
@@ -2,7 +2,8 @@ from __future__ import absolute_import
|
||||
|
||||
from django.conf.urls import patterns, url
|
||||
|
||||
from .api_views import APIDocumentTagListView, APITagListView, APITagView
|
||||
from .api_views import (APIDocumentTagListView, APITagDocumentListView,
|
||||
APITagListView, APITagView)
|
||||
from .views import TagTaggedItemListView
|
||||
|
||||
urlpatterns = patterns('tags.views',
|
||||
@@ -25,6 +26,7 @@ urlpatterns = patterns('tags.views',
|
||||
)
|
||||
|
||||
api_urls = patterns('',
|
||||
url(r'^tags/(?P<pk>[0-9]+)/documents/$', APITagDocumentListView.as_view(), name='tag-document-list'),
|
||||
url(r'^tags/(?P<pk>[0-9]+)/$', APITagView.as_view(), name='tag-detail'),
|
||||
url(r'^tags/$', APITagListView.as_view(), name='tag-list'),
|
||||
url(r'^document/(?P<pk>[0-9]+)/tags/$', APIDocumentTagListView.as_view(), name='document-tag-list'),
|
||||
|
||||
Reference in New Issue
Block a user