jumpserver/apps/users/api/profile.py

91 lines
2.7 KiB
Python
Raw Normal View History

2020-03-20 10:21:27 +00:00
# ~*~ coding: utf-8 ~*~
import uuid
from rest_framework import generics
from common.permissions import IsOrgAdmin
2020-03-20 10:21:27 +00:00
from rest_framework.permissions import IsAuthenticated
from users.notifications import ResetPasswordMsg, ResetPasswordSuccessMsg, ResetSSHKeyMsg
2020-03-20 10:21:27 +00:00
from common.permissions import (
IsCurrentUserOrReadOnly
)
from .. import serializers
from ..models import User
from .mixins import UserQuerysetMixin
__all__ = [
'UserResetPasswordApi', 'UserResetPKApi',
'UserProfileApi', 'UserUpdatePKApi',
'UserPasswordApi', 'UserPublicKeyApi'
2020-03-20 10:21:27 +00:00
]
class UserResetPasswordApi(UserQuerysetMixin, generics.UpdateAPIView):
queryset = User.objects.all()
serializer_class = serializers.UserSerializer
permission_classes = (IsOrgAdmin,)
2020-03-20 10:21:27 +00:00
def perform_update(self, serializer):
# Note: we are not updating the user object here.
# We just do the reset-password stuff.
user = self.get_object()
user.password_raw = str(uuid.uuid4())
user.save()
ResetPasswordMsg(user).publish_async()
2020-03-20 10:21:27 +00:00
class UserResetPKApi(UserQuerysetMixin, generics.UpdateAPIView):
serializer_class = serializers.UserSerializer
permission_classes = (IsOrgAdmin,)
2020-03-20 10:21:27 +00:00
def perform_update(self, serializer):
user = self.get_object()
user.public_key = None
user.save()
ResetSSHKeyMsg(user).publish_async()
2020-03-20 10:21:27 +00:00
# 废弃
class UserUpdatePKApi(UserQuerysetMixin, generics.UpdateAPIView):
serializer_class = serializers.UserPKUpdateSerializer
permission_classes = (IsCurrentUserOrReadOnly,)
def perform_update(self, serializer):
user = self.get_object()
user.public_key = serializer.validated_data['public_key']
user.save()
2020-05-28 07:02:53 +00:00
class UserProfileApi(generics.RetrieveUpdateAPIView):
2020-03-20 10:21:27 +00:00
permission_classes = (IsAuthenticated,)
2020-04-09 02:33:20 +00:00
serializer_class = serializers.UserProfileSerializer
2020-03-20 10:21:27 +00:00
def get_object(self):
return self.request.user
class UserPasswordApi(generics.RetrieveUpdateAPIView):
permission_classes = (IsAuthenticated,)
serializer_class = serializers.UserUpdatePasswordSerializer
def get_object(self):
return self.request.user
2021-09-13 02:56:55 +00:00
def update(self, request, *args, **kwargs):
resp = super().update(request, *args, **kwargs)
ResetPasswordSuccessMsg(self.request.user, request).publish_async()
return resp
class UserPublicKeyApi(generics.RetrieveUpdateAPIView):
permission_classes = (IsAuthenticated,)
serializer_class = serializers.UserUpdatePublicKeySerializer
def get_object(self):
return self.request.user
def perform_update(self, serializer):
super().perform_update(serializer)
ResetPasswordSuccessMsg(self.get_object(), self.request).publish_async()