Files
mayan-edms/mayan/apps/folders/api_views.py
2016-05-30 06:12:57 -04:00

229 lines
6.9 KiB
Python

from __future__ import absolute_import, unicode_literals
from django.core.exceptions import PermissionDenied
from django.shortcuts import get_object_or_404
from rest_framework import generics
from rest_framework.response import Response
from acls.models import AccessControlList
from documents.models import Document
from documents.permissions import permission_document_view
from permissions import Permission
from rest_api.filters import MayanObjectPermissionsFilter
from rest_api.permissions import MayanPermission
from .models import Folder
from .permissions import (
permission_folder_add_document, permission_folder_create,
permission_folder_delete, permission_folder_edit,
permission_folder_remove_document, permission_folder_view
)
from .serializers import (
FolderDocumentSerializer, FolderSerializer, NewFolderDocumentSerializer,
NewFolderSerializer
)
class APIDocumentFolderListView(generics.ListAPIView):
"""
Returns a list of all the folders to which a document belongs.
"""
serializer_class = FolderSerializer
filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = {'GET': (permission_folder_view,)}
def get_queryset(self):
document = get_object_or_404(Document, pk=self.kwargs['pk'])
try:
Permission.check_permissions(
self.request.user, (permission_document_view,)
)
except PermissionDenied:
AccessControlList.objects.check_access(
permission_document_view, self.request.user, document
)
queryset = document.document_folders().all()
return queryset
class APIFolderListView(generics.ListCreateAPIView):
filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = {'GET': (permission_folder_view,)}
mayan_view_permissions = {'POST': (permission_folder_create,)}
permission_classes = (MayanPermission,)
queryset = Folder.on_organization.all()
def get_serializer_class(self):
if self.request.method == 'GET':
return FolderSerializer
elif self.request.method == 'POST':
return NewFolderSerializer
def get(self, *args, **kwargs):
"""
Returns a list of all the folders.
"""
return super(APIFolderListView, self).get(*args, **kwargs)
def post(self, *args, **kwargs):
"""
Create a new folder.
"""
return super(APIFolderListView, self).post(*args, **kwargs)
class APIFolderView(generics.RetrieveUpdateDestroyAPIView):
filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = {
'GET': (permission_folder_view,),
'PUT': (permission_folder_edit,),
'PATCH': (permission_folder_edit,),
'DELETE': (permission_folder_delete,)
}
permission_classes = (MayanPermission,)
queryset = Folder.on_organization.all()
serializer_class = FolderSerializer
def delete(self, *args, **kwargs):
"""
Delete the selected folder.
"""
return super(APIFolderView, self).delete(*args, **kwargs)
def get(self, *args, **kwargs):
"""
Returns the details of the selected folder.
"""
return super(APIFolderView, self).get(*args, **kwargs)
def patch(self, *args, **kwargs):
"""
Edit the selected folder.
"""
return super(APIFolderView, self).patch(*args, **kwargs)
def put(self, *args, **kwargs):
"""
Edit the selected folder.
"""
return super(APIFolderView, self).put(*args, **kwargs)
class APIFolderDocumentListView(generics.ListCreateAPIView):
"""
Returns a list of all the documents contained in a particular folder.
"""
filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = {
'GET': (permission_folder_view,),
'POST': (permission_folder_add_document,)
}
def get_serializer_class(self):
if self.request.method == 'GET':
return FolderDocumentSerializer
elif self.request.method == 'POST':
return NewFolderDocumentSerializer
def get_serializer_context(self):
"""
Extra context provided to the serializer class.
"""
return {
'folder': self.get_folder(),
'format': self.format_kwarg,
'request': self.request,
'view': self
}
def get_folder(self):
return get_object_or_404(Folder, pk=self.kwargs['pk'])
def get_queryset(self):
folder = self.get_folder()
documents = folder.documents.all()
try:
Permission.check_permissions(
self.request.user, (permission_document_view,)
)
except PermissionDenied:
documents = AccessControlList.objects.filter_by_access(
permission_document_view, self.request.user, documents
)
return documents
def perform_create(self, serializer):
serializer.save(folder=self.get_folder())
def post(self, request, *args, **kwargs):
"""
Add a document to the selected folder.
"""
return super(APIFolderDocumentListView, self).post(request, *args, **kwargs)
class APIFolderDocumentView(generics.RetrieveDestroyAPIView):
filter_backends = (MayanObjectPermissionsFilter,)
mayan_object_permissions = {
'GET': (permission_folder_view,),
'DELETE': (permission_folder_remove_document,)
}
serializer_class = FolderDocumentSerializer
def delete(self, request, *args, **kwargs):
"""
Remove a document from the selected folder.
"""
return super(APIFolderDocumentView, self).delete(request, *args, **kwargs)
def get(self, *args, **kwargs):
"""
Returns the details of the selected folder document.
"""
return super(APIFolderDocumentView, self).get(*args, **kwargs)
def get_folder(self):
return get_object_or_404(Folder, pk=self.kwargs['folder_pk'])
def get_queryset(self):
return self.get_folder().documents.all()
def get_serializer_context(self):
"""
Extra context provided to the serializer class.
"""
return {
'folder': self.get_folder(),
'format': self.format_kwarg,
'request': self.request,
'view': self
}
def perform_destroy(self, instance):
self.get_folder().documents.remove(instance)
def retrieve(self, request, *args, **kwargs):
instance = self.get_object()
try:
Permission.check_permissions(
self.request.user, (permission_document_view,)
)
except PermissionDenied:
AccessControlList.objects.check_access(
permission_document_view, self.request.user, instance
)
serializer = self.get_serializer(instance)
return Response(serializer.data)