[ZBKBCK-346] change password and forgot password api has been optimised

This commit is contained in:
Ruman Siddiqui
2023-08-18 16:57:42 +05:30
parent 4bc91abebf
commit 71a3e36bf3
4 changed files with 103 additions and 48 deletions

View File

@ -104,10 +104,12 @@ class ResetPasswordSerializer(serializers.Serializer):
return user_opt_details return user_opt_details
return '' return ''
class ChangePasswordSerializer(serializers.Serializer): class ChangePasswordSerializer(serializers.Serializer):
"""Update Password after verification""" """Update Password after verification"""
current_password = serializers.CharField(max_length=100) current_password = serializers.CharField(max_length=100, required=True)
new_password = serializers.CharField(required=True) new_password = serializers.CharField(required=True)
class Meta(object): class Meta(object):
"""Meta info""" """Meta info"""
model = User model = User
@ -118,25 +120,36 @@ class ChangePasswordSerializer(serializers.Serializer):
if self.context.password not in ('', None) and user.check_password(value): if self.context.password not in ('', None) and user.check_password(value):
return value return value
raise serializers.ValidationError(ERROR_CODE['2015']) raise serializers.ValidationError(ERROR_CODE['2015'])
def create(self, validated_data): def create(self, validated_data):
"""
"""
new_password = validated_data.pop('new_password') new_password = validated_data.pop('new_password')
current_password = validated_data.pop('current_password') current_password = validated_data.pop('current_password')
"""Check new password is different from current password""" # Check new password is different from current password
if new_password == current_password: if new_password == current_password:
raise serializers.ValidationError({"details": ERROR_CODE['2026']}) raise serializers.ValidationError({"details": ERROR_CODE['2026']})
user_details = User.objects.filter(email=self.context).last()
if user_details:
user_details.set_password(new_password)
user_details.save()
return {'password':new_password}
return ''
user_details = self.context
user_details.set_password(new_password)
user_details.save()
return {'password':new_password}
class ForgotPasswordSerializer(serializers.Serializer): class ForgotPasswordSerializer(serializers.Serializer):
"""Forget password serializer""" """Forget password serializer"""
email = serializers.EmailField() email = serializers.EmailField(required=True)
def validate_email(self, value):
"""
validate email exist ot not
value: string
return none
"""
if not User.objects.get(email=value):
raise serializers.ValidationError({'details': ERROR_CODE['2004']})
return value
class AdminLoginSerializer(serializers.ModelSerializer): class AdminLoginSerializer(serializers.ModelSerializer):
"""admin login serializer""" """admin login serializer"""

View File

@ -129,6 +129,28 @@ def send_otp_email(recipient_email, otp):
) )
return otp return otp
@shared_task()
def send_all_email(template_name, email, otp):
"""
Send all type of email by passing template name
template_name: string
email: string
otp: string
"""
from_email = settings.EMAIL_FROM_ADDRESS
recipient_list = [email]
send_templated_mail(
template_name=template_name,
from_email=from_email,
recipient_list=recipient_list,
context={
'verification_code': otp
}
)
return otp
@shared_task @shared_task
def user_device_details(user, device_id): def user_device_details(user, device_id):
""" """

View File

@ -39,7 +39,7 @@ from base.messages import ERROR_CODE, SUCCESS_CODE
from base.constants import NUMBER, ZOD, JUN, GRD, USER_TYPE_FLAG from base.constants import NUMBER, ZOD, JUN, GRD, USER_TYPE_FLAG
from guardian.tasks import generate_otp from guardian.tasks import generate_otp
from account.utils import (send_otp_email, send_support_email, custom_response, custom_error_response, from account.utils import (send_otp_email, send_support_email, custom_response, custom_error_response,
generate_code, OTP_EXPIRY, user_device_details) generate_code, OTP_EXPIRY, user_device_details, send_all_email)
from junior.serializers import JuniorProfileSerializer from junior.serializers import JuniorProfileSerializer
from guardian.serializers import GuardianProfileSerializer from guardian.serializers import GuardianProfileSerializer
@ -193,15 +193,30 @@ class UpdateProfileImage(views.APIView):
return custom_error_response(ERROR_CODE['2036'],response_status=status.HTTP_400_BAD_REQUEST) return custom_error_response(ERROR_CODE['2036'],response_status=status.HTTP_400_BAD_REQUEST)
class ChangePasswordAPIView(views.APIView): class ChangePasswordAPIView(views.APIView):
"""change password""" """
change password"
"""
serializer_class = ChangePasswordSerializer serializer_class = ChangePasswordSerializer
permission_classes = [IsAuthenticated] permission_classes = [IsAuthenticated]
def post(self, request): def post(self, request):
serializer = ChangePasswordSerializer(context=request.user, data=request.data) """
POST request to change current login user password
"""
serializer = ChangePasswordSerializer(
context=request.user,
data=request.data
)
if serializer.is_valid(): if serializer.is_valid():
serializer.save() serializer.save()
return custom_response(SUCCESS_CODE['3007'], response_status=status.HTTP_200_OK) return custom_response(
return custom_error_response(serializer.errors, response_status=status.HTTP_400_BAD_REQUEST) SUCCESS_CODE['3007'],
response_status=status.HTTP_200_OK
)
return custom_error_response(
serializer.errors,
response_status=status.HTTP_400_BAD_REQUEST
)
class ResetPasswordAPIView(views.APIView): class ResetPasswordAPIView(views.APIView):
"""Reset password""" """Reset password"""
@ -213,40 +228,40 @@ class ResetPasswordAPIView(views.APIView):
return custom_error_response(serializer.errors, response_status=status.HTTP_400_BAD_REQUEST) return custom_error_response(serializer.errors, response_status=status.HTTP_400_BAD_REQUEST)
class ForgotPasswordAPIView(views.APIView): class ForgotPasswordAPIView(views.APIView):
"""Forgot password""" """
Forgot password
"""
serializer_class = ForgotPasswordSerializer
def post(self, request): def post(self, request):
serializer = ForgotPasswordSerializer(data=request.data) """
if serializer.is_valid(): Post method to validate serializer
email = serializer.validated_data['email'] """
try: serializer = self.serializer_class(data=request.data)
User.objects.get(email=email) serializer.is_valid(raise_exception=True)
except User.DoesNotExist: email = serializer.validated_data['email']
return custom_error_response(ERROR_CODE['2004'], response_status=status.HTTP_404_NOT_FOUND) # generate otp
verification_code = generate_otp() verification_code = generate_otp()
# Send the verification code to the user's email # Send the verification code to the user's email
from_email = settings.EMAIL_FROM_ADDRESS send_all_email.delay(
recipient_list = [email] 'email_reset_verification.email', email, verification_code
send_templated_mail( )
template_name='email_reset_verification.email', expiry = OTP_EXPIRY
from_email=from_email, user_data, created = UserEmailOtp.objects.get_or_create(
recipient_list=recipient_list, email=email
context={ )
'verification_code': verification_code if created:
} user_data.expired_at = expiry
) user_data.save()
expiry = OTP_EXPIRY if user_data:
user_data, created = UserEmailOtp.objects.get_or_create(email=email) user_data.otp = verification_code
if created: user_data.expired_at = expiry
user_data.expired_at = expiry user_data.save()
user_data.save() return custom_response(
if user_data: SUCCESS_CODE['3015'],
user_data.otp = verification_code response_status=status.HTTP_200_OK
user_data.expired_at = expiry )
user_data.save()
return custom_response(SUCCESS_CODE['3015'],
response_status=status.HTTP_200_OK)
return custom_error_response(serializer.errors, response_status=status.HTTP_400_BAD_REQUEST)
class SendPhoneOtp(viewsets.ModelViewSet): class SendPhoneOtp(viewsets.ModelViewSet):
"""Send otp on phone""" """Send otp on phone"""

View File

@ -1,7 +1,12 @@
"""task files""" """task files"""
"""Django import"""
# Django import
import secrets import secrets
def generate_otp(): def generate_otp():
"""generate random otp""" """
generate random otp
"""
digits = "0123456789" digits = "0123456789"
return "".join(secrets.choice(digits) for _ in range(6)) return "".join(secrets.choice(digits) for _ in range(6))