add new api
This commit is contained in:
@@ -1,29 +1,29 @@
|
||||
from django.db import transaction
|
||||
from django.contrib.auth import get_user_model
|
||||
from django.db import transaction
|
||||
from django.utils import timezone
|
||||
|
||||
from rest_framework import serializers
|
||||
|
||||
from core.apps.accounts.tasks.user import create_and_send_sms_code
|
||||
from core.apps.accounts.enums.user import ROLE_CHOICES
|
||||
from core.apps.accounts.models.verification_code import VerificationCode
|
||||
from core.apps.accounts.tasks.user import create_and_send_sms_code
|
||||
|
||||
User = get_user_model()
|
||||
|
||||
|
||||
class LoginSerializer(serializers.Serializer):
|
||||
phone = serializers.CharField()
|
||||
password = serializers.CharField()
|
||||
|
||||
def validate(self, data):
|
||||
try:
|
||||
user = User.objects.get(phone=data.get('phone'))
|
||||
user = User.objects.get(phone=data.get("phone"))
|
||||
except User.DoesNotExist:
|
||||
raise serializers.ValidationError({'detail': 'User not found'})
|
||||
if not user.check_password(data.get('password')):
|
||||
raise serializers.ValidationError({'detail': 'User not found, password'})
|
||||
data['user'] = user
|
||||
raise serializers.ValidationError({"detail": "User not found"})
|
||||
if not user.check_password(data.get("password")):
|
||||
raise serializers.ValidationError({"detail": "User not found, password"})
|
||||
data["user"] = user
|
||||
return data
|
||||
|
||||
|
||||
|
||||
class RegisterSerializer(serializers.Serializer):
|
||||
phone = serializers.CharField()
|
||||
@@ -39,7 +39,7 @@ class RegisterSerializer(serializers.Serializer):
|
||||
|
||||
def validate_email(self, value):
|
||||
if User.objects.filter(email=value).exists():
|
||||
raise serializers.ValidationError("User exists with this email")
|
||||
raise serializers.ValidationError("User exists with this email")
|
||||
return value
|
||||
|
||||
|
||||
@@ -48,17 +48,20 @@ class ConfirmUserSerializer(serializers.Serializer):
|
||||
code = serializers.IntegerField()
|
||||
|
||||
def validate(self, data):
|
||||
phone = data['phone']
|
||||
code = data['code']
|
||||
phone = data["phone"]
|
||||
code = data["code"]
|
||||
confirmation = VerificationCode.objects.filter(code=code, phone=phone).first()
|
||||
if confirmation and confirmation.is_verify:
|
||||
raise serializers.ValidationError("Code is verified")
|
||||
if confirmation:
|
||||
if confirmation.is_expired or confirmation.expiration_time < timezone.now().time():
|
||||
if confirmation:
|
||||
if (
|
||||
confirmation.is_expired
|
||||
or confirmation.expiration_time < timezone.now().time()
|
||||
):
|
||||
raise serializers.ValidationError("Code is expired")
|
||||
data['confirmation'] = confirmation
|
||||
data["confirmation"] = confirmation
|
||||
return data
|
||||
|
||||
|
||||
|
||||
class ChoiseRoleSerializer(serializers.Serializer):
|
||||
role = serializers.ChoiceField(choices=ROLE_CHOICES)
|
||||
@@ -67,4 +70,4 @@ class ChoiseRoleSerializer(serializers.Serializer):
|
||||
class UserPhoneListSerializer(serializers.ModelSerializer):
|
||||
class Meta:
|
||||
model = User
|
||||
fields = ['id', 'phone']
|
||||
fields = ["id", "phone"]
|
||||
|
||||
55
core/apps/accounts/serializers/forgot_password.py
Normal file
55
core/apps/accounts/serializers/forgot_password.py
Normal file
@@ -0,0 +1,55 @@
|
||||
from django.utils import timezone
|
||||
|
||||
from rest_framework import serializers
|
||||
|
||||
from core.apps.accounts.models import User, VerificationCode
|
||||
|
||||
|
||||
class SendCodeSerializer(serializers.Serializer):
|
||||
phone = serializers.CharField()
|
||||
|
||||
def validate(self, data):
|
||||
user = User.objects.filter(phone=data['phone']).first()
|
||||
if not user:
|
||||
raise serializers.ValidationError("User not found")
|
||||
data['user'] = user
|
||||
data['phone'] = user.phone
|
||||
return data
|
||||
|
||||
|
||||
class ConfirmPasswordSerializer(serializers.Serializer):
|
||||
code = serializers.IntegerField()
|
||||
phone = serializers.CharField()
|
||||
|
||||
def validate(self, data):
|
||||
phone = data["phone"]
|
||||
code = data["code"]
|
||||
confirmation = VerificationCode.objects.filter(code=code, phone=phone).first()
|
||||
if confirmation and confirmation.is_verify:
|
||||
raise serializers.ValidationError("Code is verified")
|
||||
if confirmation:
|
||||
if (
|
||||
confirmation.is_expired
|
||||
or confirmation.expiration_time < timezone.now().time()
|
||||
):
|
||||
raise serializers.ValidationError("Code is expired")
|
||||
data["confirmation"] = confirmation
|
||||
return data
|
||||
|
||||
|
||||
class ResetPasswordSerializer(serializers.Serializer):
|
||||
phone = serializers.CharField()
|
||||
new_password = serializers.CharField()
|
||||
|
||||
def validate(self, data):
|
||||
user = User.objects.filter(phone=data['phone']).first()
|
||||
if not user:
|
||||
raise serializers
|
||||
data['user'] = user
|
||||
return data
|
||||
|
||||
def save(self, **kwargs):
|
||||
user = self.validated_data.get('user')
|
||||
user.set_password(self.validated_data.get('new_password'))
|
||||
user.save()
|
||||
return super().save(**kwargs)
|
||||
Reference in New Issue
Block a user