提交 ff546774 编写于 作者: B Bai

Merge branch 'lina' of https://github.com/jumpserver/jumpserver into lina

...@@ -57,8 +57,8 @@ class AssetPermissionSerializer(BulkOrgResourceModelSerializer): ...@@ -57,8 +57,8 @@ class AssetPermissionSerializer(BulkOrgResourceModelSerializer):
def setup_eager_loading(cls, queryset): def setup_eager_loading(cls, queryset):
""" Perform necessary eager loading of data. """ """ Perform necessary eager loading of data. """
queryset = queryset.annotate( queryset = queryset.annotate(
users_amount=Count('users'), user_groups_amount=Count('user_groups'), users_amount=Count('users', distinct=True), user_groups_amount=Count('user_groups', distinct=True),
assets_amount=Count('assets'), nodes_amount=Count('nodes'), assets_amount=Count('assets', distinct=True), nodes_amount=Count('nodes', distinct=True),
system_users_amount=Count('system_users') system_users_amount=Count('system_users', distinct=True)
) )
return queryset return queryset
...@@ -13,20 +13,35 @@ __all__ = [ ...@@ -13,20 +13,35 @@ __all__ = [
] ]
class DatabaseAppPermissionSerializer(BulkOrgResourceModelSerializer): class AmountMixin:
@classmethod
def setup_eager_loading(cls, queryset):
""" Perform necessary eager loading of data. """
queryset = queryset.annotate(
users_amount=Count('users', distinct=True), user_groups_amount=Count('user_groups', distinct=True),
database_apps_amount=Count('database_apps', distinct=True),
system_users_amount=Count('system_users', distinct=True)
)
return queryset
class DatabaseAppPermissionSerializer(AmountMixin, BulkOrgResourceModelSerializer):
class Meta: class Meta:
model = models.DatabaseAppPermission model = models.DatabaseAppPermission
list_serializer_class = AdaptedBulkListSerializer list_serializer_class = AdaptedBulkListSerializer
fields = [ fields = [
'id', 'name', 'users', 'user_groups', 'id', 'name', 'users', 'user_groups', 'database_apps', 'system_users',
'database_apps', 'system_users', 'comment', 'is_active', 'comment', 'is_active', 'date_start', 'date_expired', 'is_valid',
'date_start', 'date_expired', 'is_valid', 'created_by', 'date_created', 'users_amount', 'user_groups_amount',
'created_by', 'date_created' 'database_apps_amount', 'system_users_amount',
]
read_only_fields = [
'created_by', 'date_created', 'users_amount', 'user_groups_amount',
'database_apps_amount', 'system_users_amount',
] ]
read_only_fields = ['created_by', 'date_created']
class DatabaseAppPermissionListSerializer(BulkOrgResourceModelSerializer): class DatabaseAppPermissionListSerializer(AmountMixin, BulkOrgResourceModelSerializer):
is_expired = serializers.BooleanField() is_expired = serializers.BooleanField()
class Meta: class Meta:
...@@ -36,13 +51,3 @@ class DatabaseAppPermissionListSerializer(BulkOrgResourceModelSerializer): ...@@ -36,13 +51,3 @@ class DatabaseAppPermissionListSerializer(BulkOrgResourceModelSerializer):
'date_start', 'date_expired', 'is_valid', 'database_apps_amount', 'system_users_amount', 'date_start', 'date_expired', 'is_valid', 'database_apps_amount', 'system_users_amount',
'created_by', 'date_created', 'is_expired' 'created_by', 'date_created', 'is_expired'
] ]
@classmethod
def setup_eager_loading(cls, queryset):
""" Perform necessary eager loading of data. """
queryset = queryset.annotate(
users_amount=Count('users', distinct=True), user_groups_amount=Count('user_groups', distinct=True),
database_apps_amount=Count('database_apps', distinct=True),
system_users_amount=Count('system_users', distinct=True)
)
return queryset
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册