2020-03-20 10:21:27 +00:00
|
|
|
# ~*~ coding: utf-8 ~*~
|
|
|
|
import uuid
|
|
|
|
|
|
|
|
from rest_framework import generics
|
|
|
|
from rest_framework.permissions import IsAuthenticated
|
2023-09-11 06:38:07 +00:00
|
|
|
|
|
|
|
from authentication.models import ConnectionToken
|
2023-10-12 08:17:32 +00:00
|
|
|
from authentication.permissions import IsValidUserOrConnectionToken
|
2022-07-19 07:57:02 +00:00
|
|
|
from common.utils import get_object_or_none
|
|
|
|
from orgs.utils import tmp_to_root_org
|
2021-11-12 07:33:33 +00:00
|
|
|
from users.notifications import (
|
|
|
|
ResetPasswordMsg, ResetPasswordSuccessMsg, ResetSSHKeyMsg,
|
|
|
|
ResetPublicKeySuccessMsg,
|
|
|
|
)
|
2023-09-11 06:38:07 +00:00
|
|
|
from .mixins import UserQuerysetMixin
|
2020-03-20 10:21:27 +00:00
|
|
|
from .. import serializers
|
|
|
|
from ..models import User
|
|
|
|
|
|
|
|
__all__ = [
|
|
|
|
'UserResetPasswordApi', 'UserResetPKApi',
|
2024-07-29 11:37:50 +00:00
|
|
|
'UserProfileApi', 'UserPasswordApi'
|
2020-03-20 10:21:27 +00:00
|
|
|
]
|
|
|
|
|
|
|
|
|
|
|
|
class UserResetPasswordApi(UserQuerysetMixin, generics.UpdateAPIView):
|
|
|
|
queryset = User.objects.all()
|
|
|
|
serializer_class = serializers.UserSerializer
|
|
|
|
|
|
|
|
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()
|
2021-08-24 06:20:54 +00:00
|
|
|
ResetPasswordMsg(user).publish_async()
|
2020-03-20 10:21:27 +00:00
|
|
|
|
|
|
|
|
|
|
|
class UserResetPKApi(UserQuerysetMixin, generics.UpdateAPIView):
|
|
|
|
serializer_class = serializers.UserSerializer
|
|
|
|
|
|
|
|
def perform_update(self, serializer):
|
|
|
|
user = self.get_object()
|
|
|
|
user.public_key = None
|
|
|
|
user.save()
|
2021-08-24 06:20:54 +00:00
|
|
|
ResetSSHKeyMsg(user).publish_async()
|
2020-03-20 10:21:27 +00:00
|
|
|
|
|
|
|
|
2020-05-28 07:02:53 +00:00
|
|
|
class UserProfileApi(generics.RetrieveUpdateAPIView):
|
2022-07-19 07:57:02 +00:00
|
|
|
permission_classes = (IsValidUserOrConnectionToken,)
|
2020-04-09 02:33:20 +00:00
|
|
|
serializer_class = serializers.UserProfileSerializer
|
2020-03-20 10:21:27 +00:00
|
|
|
|
|
|
|
def get_object(self):
|
2022-07-19 07:57:02 +00:00
|
|
|
if self.request.user.is_anonymous:
|
|
|
|
user = self.get_connection_token_user()
|
|
|
|
if user:
|
|
|
|
return user
|
2020-03-20 10:21:27 +00:00
|
|
|
return self.request.user
|
|
|
|
|
2022-07-19 07:57:02 +00:00
|
|
|
def get_connection_token_user(self):
|
|
|
|
token_id = self.request.query_params.get('token')
|
|
|
|
if not token_id:
|
|
|
|
return
|
|
|
|
with tmp_to_root_org():
|
|
|
|
token = get_object_or_none(ConnectionToken, id=token_id)
|
|
|
|
if not token:
|
|
|
|
return
|
|
|
|
return token.user
|
|
|
|
|
2020-05-28 08:10:28 +00:00
|
|
|
|
|
|
|
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
|