mirror of https://github.com/jumpserver/jumpserver
[Update] 修改serailizer mixin
parent
f8dae2a3c9
commit
e7031d0ac1
|
@ -37,7 +37,7 @@ class SerializerMixin:
|
|||
serializer_class = None
|
||||
if hasattr(self, 'serializer_classes') and \
|
||||
isinstance(self.serializer_classes, dict):
|
||||
if self.action == 'list' and self.request.query_params.get('draw'):
|
||||
if self.action in ['list', 'metadata'] and self.request.query_params.get('draw'):
|
||||
serializer_class = self.serializer_classes.get('display')
|
||||
if serializer_class is None:
|
||||
serializer_class = self.serializer_classes.get(
|
||||
|
|
|
@ -57,7 +57,7 @@ class UserUpdatePKApi(UserQuerysetMixin, generics.UpdateAPIView):
|
|||
|
||||
class UserProfileApi(generics.RetrieveAPIView):
|
||||
permission_classes = (IsAuthenticated,)
|
||||
serializer_class = serializers.UserSerializer
|
||||
serializer_class = serializers.UserProfileSerializer
|
||||
|
||||
def get_object(self):
|
||||
return self.request.user
|
||||
|
|
|
@ -481,7 +481,7 @@ class User(AuthMixin, TokenMixin, RoleMixin, MFAMixin, AbstractUser):
|
|||
max_length=30, default='', blank=True, verbose_name=_('Created by')
|
||||
)
|
||||
source = models.CharField(
|
||||
max_length=30, default=SOURCE_LOCAL, choices=SOURCE_CHOICES,
|
||||
max_length=30, default=SOURCE_LDAP, choices=SOURCE_CHOICES,
|
||||
verbose_name=_('Source')
|
||||
)
|
||||
date_password_last_updated = models.DateTimeField(
|
||||
|
|
|
@ -23,7 +23,16 @@ class UserOrgSerializer(serializers.Serializer):
|
|||
|
||||
|
||||
class UserSerializer(BulkSerializerMixin, serializers.ModelSerializer):
|
||||
admin_orgs = UserOrgSerializer(many=True, read_only=True)
|
||||
EMAIL_SET_PASSWORD = _('Reset link will be generated and sent to the user')
|
||||
CUSTOM_PASSWORD = _('Set password')
|
||||
PASSWORD_STRATEGY_CHOICES = (
|
||||
(0, EMAIL_SET_PASSWORD),
|
||||
(1, CUSTOM_PASSWORD)
|
||||
)
|
||||
password_strategy = serializers.ChoiceField(
|
||||
choices=PASSWORD_STRATEGY_CHOICES, required=True, initial=0,
|
||||
label=_('Password strategy'), write_only=True
|
||||
)
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
|
@ -33,8 +42,9 @@ class UserSerializer(BulkSerializerMixin, serializers.ModelSerializer):
|
|||
'groups', 'role', 'wechat', 'phone', 'mfa_level',
|
||||
'comment', 'source', 'is_valid', 'is_expired',
|
||||
'is_active', 'created_by', 'is_first_login',
|
||||
'password_strategy',
|
||||
'date_password_last_updated', 'date_expired',
|
||||
'avatar_url', 'admin_orgs',
|
||||
'avatar_url',
|
||||
]
|
||||
extra_kwargs = {
|
||||
'password': {'write_only': True, 'required': False, 'allow_null': True, 'allow_blank': True},
|
||||
|
@ -46,6 +56,16 @@ class UserSerializer(BulkSerializerMixin, serializers.ModelSerializer):
|
|||
'created_by': {'read_only': True, 'allow_blank': True},
|
||||
}
|
||||
|
||||
def __init__(self, *args, **kwargs):
|
||||
super().__init__(*args, **kwargs)
|
||||
self.set_role_choices()
|
||||
|
||||
def set_role_choices(self):
|
||||
role = self.fields['role']
|
||||
choices = role.choices
|
||||
choices.pop('App', None)
|
||||
role.choices = choices
|
||||
|
||||
def validate_role(self, value):
|
||||
request = self.context.get('request')
|
||||
if not request.user.is_superuser and value != User.ROLE_USER:
|
||||
|
@ -92,6 +112,7 @@ class UserSerializer(BulkSerializerMixin, serializers.ModelSerializer):
|
|||
def validate(self, attrs):
|
||||
attrs = self.change_password_to_raw(attrs)
|
||||
attrs = self.clean_auth_fields(attrs)
|
||||
attrs.pop('password_strategy', None)
|
||||
return attrs
|
||||
|
||||
|
||||
|
@ -157,8 +178,17 @@ class ResetOTPSerializer(serializers.Serializer):
|
|||
|
||||
|
||||
class UserProfileSerializer(serializers.ModelSerializer):
|
||||
admin_orgs = UserOrgSerializer(many=True, read_only=True)
|
||||
|
||||
class Meta:
|
||||
model = User
|
||||
fields = [
|
||||
'id', 'username', 'name', 'role', 'email'
|
||||
'id', 'name', 'username', 'email',
|
||||
'role', 'wechat', 'phone', 'mfa_level',
|
||||
'comment', 'source', 'is_valid', 'is_expired',
|
||||
'is_active', 'created_by', 'is_first_login',
|
||||
'date_password_last_updated', 'date_expired',
|
||||
'avatar_url',
|
||||
|
||||
'groups', 'admin_orgs',
|
||||
]
|
||||
|
|
Loading…
Reference in New Issue