You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
|
|
|
from rest_framework.generics import CreateAPIView
|
|
|
|
from rest_framework.response import Response
|
|
|
|
|
|
|
|
from authentication.serializers import PasswordVerifySerializer
|
|
|
|
from common.permissions import IsValidUser
|
|
|
|
from authentication.mixins import authenticate
|
|
|
|
from authentication.errors import PasswordInvalid
|
|
|
|
from authentication.mixins import AuthMixin
|
|
|
|
|
|
|
|
|
|
|
|
class UserPasswordVerifyApi(AuthMixin, CreateAPIView):
|
|
|
|
permission_classes = (IsValidUser,)
|
|
|
|
serializer_class = PasswordVerifySerializer
|
|
|
|
|
|
|
|
def create(self, request, *args, **kwargs):
|
|
|
|
serializer = self.get_serializer(data=request.data)
|
|
|
|
serializer.is_valid(raise_exception=True)
|
|
|
|
password = serializer.validated_data['password']
|
|
|
|
user = self.request.user
|
|
|
|
|
|
|
|
user = authenticate(request=request, username=user.username, password=password)
|
|
|
|
if not user:
|
|
|
|
raise PasswordInvalid
|
|
|
|
|
|
|
|
self.mark_password_ok(user)
|
|
|
|
return Response()
|