相关方data filter

This commit is contained in:
曹前明 2022-10-19 19:58:23 +08:00
parent f0ee937af7
commit d7cdca48a6
2 changed files with 78 additions and 39 deletions

View File

@ -27,6 +27,7 @@ class RpartyViewSet(CustomModelViewSet):
update_serializer_class = RpartyCreateUpdateSerializer update_serializer_class = RpartyCreateUpdateSerializer
serializer_class = RpartySerializer serializer_class = RpartySerializer
select_related_fields = ['admin', 'belong_dept'] select_related_fields = ['admin', 'belong_dept']
data_filter = True
def get_queryset(self): def get_queryset(self):
queryset = super().get_queryset() queryset = super().get_queryset()
@ -80,6 +81,8 @@ class RfileViewSet(ListModelMixin, CustomGenericViewSet):
list_serializer_class = RfileListSerializer list_serializer_class = RfileListSerializer
filterset_fields = ['file_cate'] filterset_fields = ['file_cate']
ordering = ['file_cate__sort', 'file_cate__create_time'] ordering = ['file_cate__sort', 'file_cate__create_time']
data_filter = True
data_filter_field = 'rparty__dept'
def get_queryset(self): def get_queryset(self):
queryset = super().get_queryset() queryset = super().get_queryset()
@ -90,13 +93,16 @@ class RfileViewSet(ListModelMixin, CustomGenericViewSet):
class RemployeeViewSet(CustomModelViewSet): class RemployeeViewSet(CustomModelViewSet):
perms_map = {'get': 'remployee.view', 'post': 'remployee.create', 'put': 'remployee.update', 'delete': 'remployee.update'} perms_map = {'get': 'remployee.view', 'post': 'remployee.create',
'put': 'remployee.update', 'delete': 'remployee.update'}
queryset = Remployee.objects.all() queryset = Remployee.objects.all()
create_serializer_class = RemployeeCreateSerializer create_serializer_class = RemployeeCreateSerializer
update_serializer_class = RemployeeUpdateSerializer update_serializer_class = RemployeeUpdateSerializer
serializer_class = RemployeeSerializer serializer_class = RemployeeSerializer
search_fields = ['name', 'phone', 'id_number'] search_fields = ['name', 'phone', 'id_number']
filterset_fields = ['rparty'] filterset_fields = ['rparty']
data_filter = True
data_filter_field = 'rparty__dept'
def get_queryset(self): def get_queryset(self):
queryset = super().get_queryset() queryset = super().get_queryset()
@ -128,12 +134,15 @@ class RemployeeViewSet(CustomModelViewSet):
class RcertificateViewSet(CustomModelViewSet): class RcertificateViewSet(CustomModelViewSet):
perms_map = {'get': 'rcetificate.view', 'post': 'rcetificate.create', 'put': 'rcetificate.update', 'delete': 'rcetificate.update'} perms_map = {'get': 'rcertificate.view', 'post': 'rcertificate.create',
'put': 'rcertificate.update', 'delete': 'rcertificate.update'}
queryset = Rcertificate.objects.all() queryset = Rcertificate.objects.all()
create_serializer_class = RcertificateCreateUpdateSerializer create_serializer_class = RcertificateCreateUpdateSerializer
update_serializer_class = RcertificateCreateUpdateSerializer update_serializer_class = RcertificateCreateUpdateSerializer
serializer_class = RcertificateSerializer serializer_class = RcertificateSerializer
filterset_fields = ['remployee', 'remployee__rparty'] filterset_fields = ['remployee', 'remployee__rparty']
data_filter = True
data_filter_field = 'remployee__rparty__dept'
def get_queryset(self): def get_queryset(self):
queryset = super().get_queryset() queryset = super().get_queryset()
@ -151,6 +160,8 @@ class RpjViewSet(CustomModelViewSet):
select_related_fields = ['rparty', 'belong_dept', 'ticket', 'ticket__state'] select_related_fields = ['rparty', 'belong_dept', 'ticket', 'ticket__state']
search_fields = ['name'] search_fields = ['name']
filterset_class = RpjFilterSet filterset_class = RpjFilterSet
data_filter = True
data_filter_field = 'rparty__dept'
def get_queryset(self): def get_queryset(self):
queryset = super().get_queryset() queryset = super().get_queryset()

View File

@ -36,6 +36,7 @@ class CustomGenericViewSet(MyLoggingMixin, GenericViewSet):
prefetch_related_fields = [] prefetch_related_fields = []
permission_classes = [IsAuthenticated & RbacPermission] permission_classes = [IsAuthenticated & RbacPermission]
data_filter = False # 数据权限过滤是否开启(需要RbacPermission) data_filter = False # 数据权限过滤是否开启(需要RbacPermission)
data_filter_field = 'belong_dept'
def get_serializer_class(self): def get_serializer_class(self):
action_serializer_name = f"{self.action}_serializer_class" action_serializer_name = f"{self.action}_serializer_class"
@ -60,7 +61,7 @@ class CustomGenericViewSet(MyLoggingMixin, GenericViewSet):
if self.data_filter: if self.data_filter:
if self.request.user.is_superuser: if self.request.user.is_superuser:
return queryset return queryset
if hasattr(queryset.model, 'belong_dept'): # if hasattr(queryset.model, 'belong_dept'):
user = self.request.user user = self.request.user
user_perms_map = cache.get('perms_' + user.id, None) user_perms_map = cache.get('perms_' + user.id, None)
if user_perms_map is None: if user_perms_map is None:
@ -80,16 +81,11 @@ class CustomGenericViewSet(MyLoggingMixin, GenericViewSet):
if data_range == DataFilter.ALL: if data_range == DataFilter.ALL:
return queryset return queryset
elif data_range == DataFilter.SAMELEVE_AND_BELOW: elif data_range == DataFilter.SAMELEVE_AND_BELOW:
if dept.parent: queryset = self.filter_s_a_b(queryset, dept)
belong_depts = get_child_queryset2(dept.parent)
else:
belong_depts = get_child_queryset2(dept)
queryset = queryset.filter(belong_dept__in=belong_depts)
elif data_range == DataFilter.THISLEVEL_AND_BELOW: elif data_range == DataFilter.THISLEVEL_AND_BELOW:
belong_depts = get_child_queryset2(dept) queryset = self.filter_t_a_b(queryset, dept)
queryset = queryset.filter(belong_dept__in=belong_depts)
elif data_range == DataFilter.THISLEVEL: elif data_range == DataFilter.THISLEVEL:
queryset = queryset.filter(belong_dept=dept) queryset = self.filter_t(queryset, dept)
elif data_range == DataFilter.MYSELF: elif data_range == DataFilter.MYSELF:
queryset = queryset.filter(create_by=user) queryset = queryset.filter(create_by=user)
new_queryset = new_queryset | queryset new_queryset = new_queryset | queryset
@ -98,6 +94,38 @@ class CustomGenericViewSet(MyLoggingMixin, GenericViewSet):
return queryset.none() return queryset.none()
return queryset return queryset
def filter_s_a_b(self, queryset, dept):
"""过滤同级及以下, 可重写
"""
if hasattr(queryset.model, 'belong_dept'):
if dept.parent:
belong_depts = get_child_queryset2(dept.parent)
else:
belong_depts = get_child_queryset2(dept)
whereis = {self.data_filter_field + '__in': belong_depts}
queryset = queryset.filter(**whereis)
return queryset
return queryset.filter(create_by=self.request.user)
def filter_t_a_b(self, queryset, dept):
"""过滤本级及以下, 可重写
"""
if hasattr(queryset.model, 'belong_dept'):
belong_depts = get_child_queryset2(dept)
whereis = {self.data_filter_field + '__in': belong_depts}
queryset = queryset.filter(**whereis)
return queryset
return queryset.filter(create_by=self.request.user)
def filter_t(self, queryset, dept):
"""过滤本级, 可重写
"""
if hasattr(queryset.model, 'belong_dept'):
whereis = {self.data_filter_field: dept}
queryset = queryset.filter(whereis)
return queryset
return queryset.filter(create_by=self.request.user)
class CustomModelViewSet(CreateModelMixin, UpdateModelMixin, ListModelMixin, class CustomModelViewSet(CreateModelMixin, UpdateModelMixin, ListModelMixin,
RetrieveModelMixin, DestroyModelMixin, CustomGenericViewSet): RetrieveModelMixin, DestroyModelMixin, CustomGenericViewSet):