mirror of https://github.com/jumpserver/jumpserver
[Update] 修改remote app api
parent
8c0bf0b71b
commit
0a7f63cc5e
|
@ -22,10 +22,7 @@ class AssetPermissionViewSet(OrgModelViewSet):
|
||||||
资产授权列表的增删改查api
|
资产授权列表的增删改查api
|
||||||
"""
|
"""
|
||||||
model = AssetPermission
|
model = AssetPermission
|
||||||
serializer_classes = {
|
serializer_class = serializers.AssetPermissionSerializer
|
||||||
'default': serializers.AssetPermissionCreateUpdateSerializer,
|
|
||||||
'display': serializers.AssetPermissionListSerializer
|
|
||||||
}
|
|
||||||
filter_fields = ['name']
|
filter_fields = ['name']
|
||||||
permission_classes = (IsOrgAdmin,)
|
permission_classes = (IsOrgAdmin,)
|
||||||
|
|
||||||
|
|
|
@ -11,7 +11,6 @@ from ..serializers import (
|
||||||
RemoteAppPermissionSerializer,
|
RemoteAppPermissionSerializer,
|
||||||
RemoteAppPermissionUpdateUserSerializer,
|
RemoteAppPermissionUpdateUserSerializer,
|
||||||
RemoteAppPermissionUpdateRemoteAppSerializer,
|
RemoteAppPermissionUpdateRemoteAppSerializer,
|
||||||
RemoteAppPermissionListSerializer,
|
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
@ -26,10 +25,7 @@ class RemoteAppPermissionViewSet(OrgModelViewSet):
|
||||||
model = RemoteAppPermission
|
model = RemoteAppPermission
|
||||||
filter_fields = ('name', )
|
filter_fields = ('name', )
|
||||||
search_fields = filter_fields
|
search_fields = filter_fields
|
||||||
serializer_classes = {
|
serializer_class = RemoteAppPermissionSerializer
|
||||||
'default': RemoteAppPermissionSerializer,
|
|
||||||
'display': RemoteAppPermissionListSerializer,
|
|
||||||
}
|
|
||||||
permission_classes = (IsOrgAdmin,)
|
permission_classes = (IsOrgAdmin,)
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -3,9 +3,9 @@ import logging
|
||||||
from functools import reduce
|
from functools import reduce
|
||||||
|
|
||||||
from django.db import models
|
from django.db import models
|
||||||
from django.db.models import Q
|
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
|
|
||||||
|
from common.utils import lazyproperty
|
||||||
from orgs.models import Organization
|
from orgs.models import Organization
|
||||||
from orgs.utils import get_current_org
|
from orgs.utils import get_current_org
|
||||||
from assets.models import Asset, SystemUser, Node
|
from assets.models import Asset, SystemUser, Node
|
||||||
|
@ -87,6 +87,18 @@ class AssetPermission(BasePermission):
|
||||||
verbose_name = _("Asset permission")
|
verbose_name = _("Asset permission")
|
||||||
ordering = ('name',)
|
ordering = ('name',)
|
||||||
|
|
||||||
|
@lazyproperty
|
||||||
|
def assets_amount(self):
|
||||||
|
return self.assets.count()
|
||||||
|
|
||||||
|
@lazyproperty
|
||||||
|
def nodes_amount(self):
|
||||||
|
return self.nodes.count()
|
||||||
|
|
||||||
|
@lazyproperty
|
||||||
|
def system_users_amount(self):
|
||||||
|
return self.system_users.count()
|
||||||
|
|
||||||
@classmethod
|
@classmethod
|
||||||
def get_queryset_with_prefetch(cls):
|
def get_queryset_with_prefetch(cls):
|
||||||
return cls.objects.all().valid().prefetch_related(
|
return cls.objects.all().valid().prefetch_related(
|
||||||
|
|
|
@ -8,7 +8,7 @@ from django.db.models import Q
|
||||||
from django.utils import timezone
|
from django.utils import timezone
|
||||||
from orgs.mixins.models import OrgModelMixin
|
from orgs.mixins.models import OrgModelMixin
|
||||||
|
|
||||||
from common.utils import date_expired_default
|
from common.utils import date_expired_default, lazyproperty
|
||||||
from orgs.mixins.models import OrgManager
|
from orgs.mixins.models import OrgManager
|
||||||
|
|
||||||
|
|
||||||
|
@ -87,3 +87,11 @@ class BasePermission(OrgModelMixin):
|
||||||
Q(id__in=users_id) | Q(groups__id__in=groups_id)
|
Q(id__in=users_id) | Q(groups__id__in=groups_id)
|
||||||
).distinct()
|
).distinct()
|
||||||
return users
|
return users
|
||||||
|
|
||||||
|
@lazyproperty
|
||||||
|
def users_amount(self):
|
||||||
|
return self.users.count()
|
||||||
|
|
||||||
|
@lazyproperty
|
||||||
|
def user_groups_amount(self):
|
||||||
|
return self.user_groups.count()
|
||||||
|
|
|
@ -3,12 +3,12 @@
|
||||||
|
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
|
|
||||||
from common.fields import StringManyToManyField
|
from django.db.models import Count
|
||||||
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
||||||
from perms.models import AssetPermission, Action
|
from perms.models import AssetPermission, Action
|
||||||
|
|
||||||
__all__ = [
|
__all__ = [
|
||||||
'AssetPermissionCreateUpdateSerializer', 'AssetPermissionListSerializer',
|
'AssetPermissionSerializer',
|
||||||
'ActionsField',
|
'ActionsField',
|
||||||
]
|
]
|
||||||
|
|
||||||
|
@ -34,27 +34,29 @@ class ActionsDisplayField(ActionsField):
|
||||||
return [choices.get(i) for i in values]
|
return [choices.get(i) for i in values]
|
||||||
|
|
||||||
|
|
||||||
class AssetPermissionCreateUpdateSerializer(BulkOrgResourceModelSerializer):
|
class AssetPermissionSerializer(BulkOrgResourceModelSerializer):
|
||||||
actions = ActionsField(required=False, allow_null=True)
|
actions = ActionsField(required=False, allow_null=True)
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = AssetPermission
|
|
||||||
exclude = ('created_by', 'date_created')
|
|
||||||
|
|
||||||
|
|
||||||
class AssetPermissionListSerializer(BulkOrgResourceModelSerializer):
|
|
||||||
users = StringManyToManyField(many=True, read_only=True)
|
|
||||||
user_groups = StringManyToManyField(many=True, read_only=True)
|
|
||||||
assets = StringManyToManyField(many=True, read_only=True)
|
|
||||||
nodes = StringManyToManyField(many=True, read_only=True)
|
|
||||||
system_users = StringManyToManyField(many=True, read_only=True)
|
|
||||||
actions = ActionsDisplayField()
|
|
||||||
is_valid = serializers.BooleanField()
|
is_valid = serializers.BooleanField()
|
||||||
is_expired = serializers.BooleanField()
|
is_expired = serializers.BooleanField()
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = AssetPermission
|
model = AssetPermission
|
||||||
fields = '__all__'
|
mini_fields = ['id', 'name']
|
||||||
|
small_fields = [
|
||||||
|
'is_active', 'is_expired', 'is_valid', 'actions', 'created_by', 'date_created'
|
||||||
|
]
|
||||||
|
m2m_fields = [
|
||||||
|
'users', 'user_groups', 'assets', 'nodes', 'system_users',
|
||||||
|
'users_amount', 'user_groups_amount', 'assets_amount', 'nodes_amount', 'system_users_amount',
|
||||||
|
]
|
||||||
|
fields = small_fields + m2m_fields
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def setup_eager_loading(cls, queryset):
|
||||||
|
""" Perform necessary eager loading of data. """
|
||||||
|
queryset = queryset.annotate(
|
||||||
|
users_amount=Count('users'), user_groups_amount=Count('user_groups'),
|
||||||
|
assets_amount=Count('assets'), nodes_amount=Count('nodes'),
|
||||||
|
system_users_amount=Count('system_users')
|
||||||
|
)
|
||||||
|
return queryset
|
||||||
|
|
|
@ -1,9 +1,7 @@
|
||||||
# coding: utf-8
|
# coding: utf-8
|
||||||
#
|
#
|
||||||
|
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
|
|
||||||
from common.fields import StringManyToManyField
|
|
||||||
from common.serializers import AdaptedBulkListSerializer
|
from common.serializers import AdaptedBulkListSerializer
|
||||||
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
from orgs.mixins.serializers import BulkOrgResourceModelSerializer
|
||||||
from ..models import RemoteAppPermission
|
from ..models import RemoteAppPermission
|
||||||
|
@ -13,7 +11,6 @@ __all__ = [
|
||||||
'RemoteAppPermissionSerializer',
|
'RemoteAppPermissionSerializer',
|
||||||
'RemoteAppPermissionUpdateUserSerializer',
|
'RemoteAppPermissionUpdateUserSerializer',
|
||||||
'RemoteAppPermissionUpdateRemoteAppSerializer',
|
'RemoteAppPermissionUpdateRemoteAppSerializer',
|
||||||
'RemoteAppPermissionListSerializer',
|
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
@ -21,27 +18,18 @@ class RemoteAppPermissionSerializer(BulkOrgResourceModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = RemoteAppPermission
|
model = RemoteAppPermission
|
||||||
list_serializer_class = AdaptedBulkListSerializer
|
list_serializer_class = AdaptedBulkListSerializer
|
||||||
fields = [
|
mini_fields = ['id', 'name']
|
||||||
'id', 'name', 'users', 'user_groups', 'remote_apps', 'system_users',
|
small_fields = mini_fields + [
|
||||||
'comment', 'is_active', 'date_start', 'date_expired', 'is_valid',
|
'comment', 'is_active', 'date_start', 'date_expired', 'is_valid',
|
||||||
'created_by', 'date_created',
|
'create_by', 'date_created'
|
||||||
]
|
]
|
||||||
|
m2m_fields = [
|
||||||
|
'users', 'user_groups', 'remote_apps', 'system_users',
|
||||||
|
]
|
||||||
|
fields = small_fields + m2m_fields
|
||||||
read_only_fields = ['created_by', 'date_created']
|
read_only_fields = ['created_by', 'date_created']
|
||||||
|
|
||||||
|
|
||||||
class RemoteAppPermissionListSerializer(BulkOrgResourceModelSerializer):
|
|
||||||
users = StringManyToManyField(many=True, read_only=True)
|
|
||||||
user_groups = StringManyToManyField(many=True, read_only=True)
|
|
||||||
remote_apps = StringManyToManyField(many=True, read_only=True)
|
|
||||||
system_users = StringManyToManyField(many=True, read_only=True)
|
|
||||||
is_valid = serializers.BooleanField()
|
|
||||||
is_expired = serializers.BooleanField()
|
|
||||||
|
|
||||||
class Meta:
|
|
||||||
model = RemoteAppPermission
|
|
||||||
fields = '__all__'
|
|
||||||
|
|
||||||
|
|
||||||
class RemoteAppPermissionUpdateUserSerializer(serializers.ModelSerializer):
|
class RemoteAppPermissionUpdateUserSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
model = RemoteAppPermission
|
model = RemoteAppPermission
|
||||||
|
|
|
@ -1,5 +1,6 @@
|
||||||
# -*- coding: utf-8 -*-
|
# -*- coding: utf-8 -*-
|
||||||
#
|
#
|
||||||
|
from django.core.cache import cache
|
||||||
from django.utils.translation import ugettext_lazy as _
|
from django.utils.translation import ugettext_lazy as _
|
||||||
from rest_framework import serializers
|
from rest_framework import serializers
|
||||||
|
|
||||||
|
@ -34,9 +35,12 @@ class UserSerializer(CommonSerializerMixin, serializers.ModelSerializer):
|
||||||
label=_('Password strategy'), write_only=True
|
label=_('Password strategy'), write_only=True
|
||||||
)
|
)
|
||||||
mfa_level_display = serializers.ReadOnlyField(source='get_mfa_level_display')
|
mfa_level_display = serializers.ReadOnlyField(source='get_mfa_level_display')
|
||||||
|
login_blocked = serializers.SerializerMethodField()
|
||||||
can_update = serializers.SerializerMethodField()
|
can_update = serializers.SerializerMethodField()
|
||||||
can_delete = serializers.SerializerMethodField()
|
can_delete = serializers.SerializerMethodField()
|
||||||
|
|
||||||
|
key_prefix_block = "_LOGIN_BLOCK_{}"
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
model = User
|
model = User
|
||||||
list_serializer_class = AdaptedBulkListSerializer
|
list_serializer_class = AdaptedBulkListSerializer
|
||||||
|
@ -53,7 +57,7 @@ class UserSerializer(CommonSerializerMixin, serializers.ModelSerializer):
|
||||||
]
|
]
|
||||||
fields = fields_small + [
|
fields = fields_small + [
|
||||||
'groups', 'role', 'groups_display', 'role_display',
|
'groups', 'role', 'groups_display', 'role_display',
|
||||||
'can_update', 'can_delete'
|
'can_update', 'can_delete', 'login_blocked',
|
||||||
]
|
]
|
||||||
|
|
||||||
extra_kwargs = {
|
extra_kwargs = {
|
||||||
|
@ -142,6 +146,11 @@ class UserSerializer(CommonSerializerMixin, serializers.ModelSerializer):
|
||||||
self.context['request'], self.context['view'], obj
|
self.context['request'], self.context['view'], obj
|
||||||
)
|
)
|
||||||
|
|
||||||
|
def get_login_blocked(self, obj):
|
||||||
|
key_block = self.key_prefix_block.format(obj.username)
|
||||||
|
blocked = bool(cache.get(key_block))
|
||||||
|
return blocked
|
||||||
|
|
||||||
|
|
||||||
class UserPKUpdateSerializer(serializers.ModelSerializer):
|
class UserPKUpdateSerializer(serializers.ModelSerializer):
|
||||||
class Meta:
|
class Meta:
|
||||||
|
|
Loading…
Reference in New Issue