views.py 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950
  1. # coding=utf-8
  2. from django.db import transaction
  3. from utils import response_ok
  4. from utils.custom_modelviewset import CustomModelViewSet
  5. from utils.exceptions import CustomError
  6. from utils.permission import IsTenantUser, permission_required
  7. from apps.tenant import tenant_log
  8. from apps.log.models import BizLog
  9. from .serializers import NoticesSerializer
  10. from .models import Notices
  11. from .filters import NoticesFilter
  12. class NoticesViewSet(CustomModelViewSet):
  13. serializer_class = NoticesSerializer
  14. queryset = Notices.objects.filter()
  15. permission_classes = [IsTenantUser, ]
  16. @permission_required('notices.browse_notices')
  17. def filter_queryset(self, queryset):
  18. queryset = queryset.filter(tenant=self.request.user.employee.tenant)
  19. f = NoticesFilter(self.request.GET, queryset=queryset)
  20. return f.qs
  21. @permission_required('notices.add_notices')
  22. def perform_create(self, serializer):
  23. super(NoticesViewSet, self).perform_create(serializer)
  24. instance = serializer.instance
  25. validated_data = serializer.validated_data
  26. tenant_log(self.request.user.employee, BizLog.INSERT, u'添加通知[%s],id=%d' % (instance.title, instance.id),
  27. validated_data)
  28. @permission_required('notices.add_notices')
  29. def perform_update(self, serializer):
  30. super(NoticesViewSet, self).perform_update(serializer)
  31. instance = serializer.instance
  32. validated_data = serializer.validated_data
  33. tenant_log(self.request.user.employee, BizLog.UPDATE, u'修改通知[%s],id=%d' % (instance.title, instance.id),
  34. validated_data)
  35. @permission_required('notices.delete_notices')
  36. def destroy(self, request, *args, **kwargs):
  37. with transaction.atomic():
  38. instance = self.get_object()
  39. if instance.tenant != request.user.employee.tenant:
  40. raise CustomError(u'禁止跨租户操作!')
  41. super(NoticesViewSet, self).destroy(self, request, *args, **kwargs)
  42. tenant_log(self.request.user.employee, BizLog.DELETE, u'删除通知[%s],id=%d' % (instance.title, instance.id))
  43. return response_ok()