Permission.check_permissions too. Remove duplicity. Signed-off-by: Roberto Rosario <roberto.rosario.gonzalez@gmail.com>
335 lines
9.8 KiB
Python
335 lines
9.8 KiB
Python
from __future__ import absolute_import, unicode_literals
|
|
|
|
from django.shortcuts import get_object_or_404
|
|
|
|
from rest_framework import generics
|
|
|
|
from acls.models import AccessControlList
|
|
from documents.models import Document
|
|
from documents.permissions import permission_document_view
|
|
from rest_api.filters import MayanObjectPermissionsFilter
|
|
from rest_api.permissions import MayanPermission
|
|
|
|
from .models import SmartLink
|
|
from .permissions import (
|
|
permission_smart_link_create, permission_smart_link_delete,
|
|
permission_smart_link_edit, permission_smart_link_view
|
|
)
|
|
from .serializers import (
|
|
ResolvedSmartLinkDocumentSerializer, ResolvedSmartLinkSerializer,
|
|
SmartLinkConditionSerializer, SmartLinkSerializer,
|
|
WritableSmartLinkSerializer
|
|
)
|
|
|
|
|
|
class APIResolvedSmartLinkDocumentListView(generics.ListAPIView):
|
|
filter_backends = (MayanObjectPermissionsFilter,)
|
|
mayan_object_permissions = {'GET': (permission_document_view,)}
|
|
permission_classes = (MayanPermission,)
|
|
serializer_class = ResolvedSmartLinkDocumentSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Returns a list of the smart link documents that apply to the document.
|
|
"""
|
|
return super(APIResolvedSmartLinkDocumentListView, self).get(
|
|
*args, **kwargs
|
|
)
|
|
|
|
def get_document(self):
|
|
document = get_object_or_404(Document, pk=self.kwargs['pk'])
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_document_view, user=self.request.user,
|
|
obj=document
|
|
)
|
|
|
|
return document
|
|
|
|
def get_smart_link(self):
|
|
smart_link = get_object_or_404(
|
|
SmartLink.objects.get_for(document=self.get_document()),
|
|
pk=self.kwargs['smart_link_pk']
|
|
)
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_smart_link_view, user=self.request.user,
|
|
obj=smart_link
|
|
)
|
|
|
|
return smart_link
|
|
|
|
def get_serializer_context(self):
|
|
"""
|
|
Extra context provided to the serializer class.
|
|
"""
|
|
return {
|
|
'document': self.get_document(),
|
|
'format': self.format_kwarg,
|
|
'request': self.request,
|
|
'smart_link': self.get_smart_link(),
|
|
'view': self
|
|
}
|
|
|
|
def get_queryset(self):
|
|
return self.get_smart_link().get_linked_document_for(
|
|
document=self.get_document()
|
|
)
|
|
|
|
|
|
class APIResolvedSmartLinkView(generics.RetrieveAPIView):
|
|
filter_backends = (MayanObjectPermissionsFilter,)
|
|
lookup_url_kwarg = 'smart_link_pk'
|
|
mayan_object_permissions = {'GET': (permission_smart_link_view,)}
|
|
permission_classes = (MayanPermission,)
|
|
serializer_class = ResolvedSmartLinkSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Return the details of the selected resolved smart link.
|
|
"""
|
|
return super(APIResolvedSmartLinkView, self).get(*args, **kwargs)
|
|
|
|
def get_document(self):
|
|
document = get_object_or_404(Document, pk=self.kwargs['pk'])
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_document_view, user=self.request.user,
|
|
obj=document
|
|
)
|
|
|
|
return document
|
|
|
|
def get_serializer_context(self):
|
|
"""
|
|
Extra context provided to the serializer class.
|
|
"""
|
|
return {
|
|
'document': self.get_document(),
|
|
'format': self.format_kwarg,
|
|
'request': self.request,
|
|
'view': self
|
|
}
|
|
|
|
def get_queryset(self):
|
|
return SmartLink.objects.get_for(document=self.get_document())
|
|
|
|
|
|
class APIResolvedSmartLinkListView(generics.ListAPIView):
|
|
filter_backends = (MayanObjectPermissionsFilter,)
|
|
mayan_object_permissions = {'GET': (permission_smart_link_view,)}
|
|
permission_classes = (MayanPermission,)
|
|
serializer_class = ResolvedSmartLinkSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Returns a list of the smart links that apply to the document.
|
|
"""
|
|
return super(APIResolvedSmartLinkListView, self).get(*args, **kwargs)
|
|
|
|
def get_document(self):
|
|
document = get_object_or_404(Document, pk=self.kwargs['pk'])
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_document_view, user=self.request.user,
|
|
obj=document
|
|
)
|
|
|
|
return document
|
|
|
|
def get_serializer_context(self):
|
|
"""
|
|
Extra context provided to the serializer class.
|
|
"""
|
|
return {
|
|
'document': self.get_document(),
|
|
'format': self.format_kwarg,
|
|
'request': self.request,
|
|
'view': self
|
|
}
|
|
|
|
def get_queryset(self):
|
|
return SmartLink.objects.filter(
|
|
document_types=self.get_document().document_type
|
|
)
|
|
|
|
|
|
class APISmartLinkConditionListView(generics.ListCreateAPIView):
|
|
serializer_class = SmartLinkConditionSerializer
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Returns a list of all the smart link conditions.
|
|
"""
|
|
return super(APISmartLinkConditionListView, self).get(*args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
return self.get_smart_link().conditions.all()
|
|
|
|
def get_serializer_context(self):
|
|
"""
|
|
Extra context provided to the serializer class.
|
|
"""
|
|
return {
|
|
'format': self.format_kwarg,
|
|
'request': self.request,
|
|
'smart_link': self.get_smart_link(),
|
|
'view': self
|
|
}
|
|
|
|
def get_smart_link(self):
|
|
if self.request.method == 'GET':
|
|
permission_required = permission_smart_link_view
|
|
else:
|
|
permission_required = permission_smart_link_edit
|
|
|
|
smart_link = get_object_or_404(SmartLink, pk=self.kwargs['pk'])
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_required, user=self.request.user,
|
|
obj=smart_link
|
|
)
|
|
|
|
return smart_link
|
|
|
|
def post(self, *args, **kwargs):
|
|
"""
|
|
Create a new smart link condition.
|
|
"""
|
|
return super(APISmartLinkConditionListView, self).post(*args, **kwargs)
|
|
|
|
|
|
class APISmartLinkConditionView(generics.RetrieveUpdateDestroyAPIView):
|
|
lookup_url_kwarg = 'condition_pk'
|
|
serializer_class = SmartLinkConditionSerializer
|
|
|
|
def delete(self, *args, **kwargs):
|
|
"""
|
|
Delete the selected smart link condition.
|
|
"""
|
|
|
|
return super(APISmartLinkConditionView, self).delete(*args, **kwargs)
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Return the details of the selected smart link condition.
|
|
"""
|
|
|
|
return super(APISmartLinkConditionView, self).get(*args, **kwargs)
|
|
|
|
def get_queryset(self):
|
|
return self.get_smart_link().conditions.all()
|
|
|
|
def get_serializer_context(self):
|
|
"""
|
|
Extra context provided to the serializer class.
|
|
"""
|
|
return {
|
|
'format': self.format_kwarg,
|
|
'request': self.request,
|
|
'smart_link': self.get_smart_link(),
|
|
'view': self
|
|
}
|
|
|
|
def get_smart_link(self):
|
|
if self.request.method == 'GET':
|
|
permission_required = permission_smart_link_view
|
|
else:
|
|
permission_required = permission_smart_link_edit
|
|
|
|
smart_link = get_object_or_404(SmartLink, pk=self.kwargs['pk'])
|
|
|
|
AccessControlList.objects.check_access(
|
|
permissions=permission_required, user=self.request.user,
|
|
obj=smart_link
|
|
)
|
|
|
|
return smart_link
|
|
|
|
def patch(self, *args, **kwargs):
|
|
"""
|
|
Edit the selected smart link condition.
|
|
"""
|
|
|
|
return super(APISmartLinkConditionView, self).patch(*args, **kwargs)
|
|
|
|
def put(self, *args, **kwargs):
|
|
"""
|
|
Edit the selected smart link condition.
|
|
"""
|
|
|
|
return super(APISmartLinkConditionView, self).put(*args, **kwargs)
|
|
|
|
|
|
class APISmartLinkListView(generics.ListCreateAPIView):
|
|
filter_backends = (MayanObjectPermissionsFilter,)
|
|
mayan_object_permissions = {'GET': (permission_smart_link_view,)}
|
|
mayan_view_permissions = {'POST': (permission_smart_link_create,)}
|
|
permission_classes = (MayanPermission,)
|
|
queryset = SmartLink.objects.all()
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Returns a list of all the smart links.
|
|
"""
|
|
|
|
return super(APISmartLinkListView, self).get(*args, **kwargs)
|
|
|
|
def get_serializer_class(self):
|
|
if self.request.method == 'GET':
|
|
return SmartLinkSerializer
|
|
else:
|
|
return WritableSmartLinkSerializer
|
|
|
|
def post(self, *args, **kwargs):
|
|
"""
|
|
Create a new smart link.
|
|
"""
|
|
|
|
return super(APISmartLinkListView, self).post(*args, **kwargs)
|
|
|
|
|
|
class APISmartLinkView(generics.RetrieveUpdateDestroyAPIView):
|
|
filter_backends = (MayanObjectPermissionsFilter,)
|
|
mayan_object_permissions = {
|
|
'DELETE': (permission_smart_link_delete,),
|
|
'GET': (permission_smart_link_view,),
|
|
'PATCH': (permission_smart_link_edit,),
|
|
'PUT': (permission_smart_link_edit,)
|
|
}
|
|
queryset = SmartLink.objects.all()
|
|
|
|
def delete(self, *args, **kwargs):
|
|
"""
|
|
Delete the selected smart link.
|
|
"""
|
|
|
|
return super(APISmartLinkView, self).delete(*args, **kwargs)
|
|
|
|
def get(self, *args, **kwargs):
|
|
"""
|
|
Return the details of the selected smart ink.
|
|
"""
|
|
|
|
return super(APISmartLinkView, self).get(*args, **kwargs)
|
|
|
|
def get_serializer_class(self):
|
|
if self.request.method == 'GET':
|
|
return SmartLinkSerializer
|
|
else:
|
|
return WritableSmartLinkSerializer
|
|
|
|
def patch(self, *args, **kwargs):
|
|
"""
|
|
Edit the selected smart link.
|
|
"""
|
|
|
|
return super(APISmartLinkView, self).patch(*args, **kwargs)
|
|
|
|
def put(self, *args, **kwargs):
|
|
"""
|
|
Edit the selected smart link.
|
|
"""
|
|
|
|
return super(APISmartLinkView, self).put(*args, **kwargs)
|