1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162 |
- # coding=utf-8
- from django.db import transaction
- from rest_framework.views import APIView
- from utils import response_ok
- from utils.custom_modelviewset import CustomModelViewSet
- from utils.permission import IsTenantUser, permission_required
- from .models import Equipment
- from .serializers import EquipmentSerializer
- from .filters import EquipmentFilter
- from apps.tenant import tenant_log
- from apps.log.models import BizLog
- from utils.exceptions import CustomError
- from apps.tenant.option.serializers import OptionSerializer,Option
- class DictView(APIView):
- permission_classes = [IsTenantUser, ]
- def get(self, request):
- tenant=request.user.employee.tenant
- ret = {
- 'types': OptionSerializer(Option.objects.filter(delete=False,type=Option.EQUIPMENT_TYPE, enable=True, tenant=tenant), many=True).data,
- 'suppliers': OptionSerializer(Option.objects.filter(delete=False,type=Option.EQUIPMENT_SUPPLIER, enable=True, tenant=tenant), many=True).data,
- }
- return response_ok(ret)
- class EquipmentViewSet(CustomModelViewSet):
- permission_classes = [IsTenantUser, ]
- queryset = Equipment.objects.all()
- serializer_class = EquipmentSerializer
- @permission_required('equipment.browse_equipment')
- def filter_queryset(self, queryset):
- queryset = queryset.filter(type__tenant=self.request.user.employee.tenant)
- f = EquipmentFilter(self.request.GET, queryset=queryset)
- return f.qs
- @permission_required('equipment.add_equipment')
- def perform_create(self, serializer):
- super(EquipmentViewSet, self).perform_create(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- tenant_log(self.request.user.employee, BizLog.INSERT, u'添加设备[%s],id=%d' % (instance.name, instance.id),
- validated_data)
- @permission_required('equipment.add_equipment')
- def perform_update(self, serializer):
- super(EquipmentViewSet, self).perform_update(serializer)
- instance = serializer.instance
- validated_data = serializer.validated_data
- tenant_log(self.request.user.employee, BizLog.UPDATE, u'修改设备[%s],id=%d' % (instance.name, instance.id),
- validated_data)
- @permission_required('equipment.delete_equipment')
- def destroy(self, request, *args, **kwargs):
- with transaction.atomic():
- with transaction.atomic():
- instance = self.get_object()
- if instance.type.tenant != request.user.employee.tenant:
- raise CustomError(u'禁止跨租户操作!')
- super(EquipmentViewSet, self).destroy(self, request, *args, **kwargs)
- tenant_log(self.request.user.employee, BizLog.DELETE, u'删除设备[%s],id=%d' % (instance.name, instance.id))
- return response_ok()
|