add new api

This commit is contained in:
behruz-dev
2025-10-29 13:37:48 +05:00
parent 7097261131
commit 311a5311bd
7 changed files with 142 additions and 23 deletions

View File

@@ -162,8 +162,9 @@ CORS_ALLOWED_ORIGINS = [
]
CSRF_TRUSTED_ORIGINS = [
"http://trustme.felixits.uz"
"https://trustme.felixits.uz",
"http://localhost:8001",
]
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', env.str("SWAGGER_PROTOCOL", 'https'))
SECURE_PROXY_SSL_HEADER = ('HTTP_X_FORWARDED_PROTO', env.str("SWAGGER_PROTOCOL", env.str('','https')))

View File

@@ -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"]

View 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)

View File

@@ -11,11 +11,11 @@ from core.services.sms import send_sms_eskiz
from core.services.sms_via_bot import send_sms_code
@shared_task
def create_and_send_sms_code(phone):
def create_and_send_sms_code(phone, type):
verification = VerificationCode.objects.create(
code=''.join([str(random.randint(1, 100) % 10) for _ in range(4)]),
phone=phone,
expiration_time=timezone.now() + timedelta(minutes=2)
)
# send_sms_eskiz(user.phone, code)
send_sms_code(verification.code, 'auth', verification.phone)
send_sms_code(verification.code, type, verification.phone)

View File

@@ -1,6 +1,7 @@
from django.urls import path, include
from core.apps.accounts.views.auth import LoginApiView, RegisterApiView, ConfirUserApiView, ChoiceUserRoleApiView, SearchUserPhoneApiView
from core.apps.accounts.views.forgot_password import ConfirmCodeApiView, SendCodeApiView, ResetPasswordApiView
urlpatterns = [
path('auth/', include(
@@ -15,5 +16,12 @@ urlpatterns = [
[
path('<str:number>/search/', SearchUserPhoneApiView.as_view()),
]
))
)),
path('forgot_password/', include(
[
path('send_code/', SendCodeApiView.as_view()),
path('forgot_password/', ConfirmCodeApiView.as_view()),
path('reset_password/', ResetPasswordApiView.as_view()),
]
)),
]

View File

@@ -41,7 +41,7 @@ class RegisterApiView(generics.GenericAPIView):
data['phone'], data['password'], data['first_name'],
data['last_name'], data['email'], 300
)
user_tasks.create_and_send_sms_code.delay(data['phone'])
user_tasks.create_and_send_sms_code.delay(data['phone'], type='auth')
return success_message("code is send", 200)
return error_message(serializer.errors, 400)

View File

@@ -0,0 +1,52 @@
from rest_framework import generics
from rest_framework.response import Response
from core.apps.accounts.serializers import forgot_password as serializers
from core.apps.accounts.tasks.user import create_and_send_sms_code
class SendCodeApiView(generics.GenericAPIView):
serializer_class = serializers.SendCodeSerializer
queryset = None
def post(self, request):
serializer = self.serializer_class(data=request.data)
if serializer.is_valid(raise_exception=True):
data = serializer.data
create_and_send_sms_code.delay(data['phone'], 'forgot password')
return Response({"success": True, "message": "Kod yuborildi"}, status=201)
return Response({"success": False, "message": 'Kod yuborilmadi'}, status=400)
class ConfirmCodeApiView(generics.GenericAPIView):
serializer_class = serializers.ConfirmPasswordSerializer
queryset = None
def post(self, request):
serializer = self.serializer_class(data=request.data)
if serializer.is_valid(raise_exception=True):
serializer.save()
return Response(
{
'success': True,
"message": "tasdiqlandi"
}
)
return Response({'success': True, "message": serializer.errors})
class ResetPasswordApiView(generics.GenericAPIView):
serializer_class = serializers.ResetPasswordSerializer
queryset = None
def post(self, request):
serializer = self.serializer_class(data=request.data)
if serializer.is_valid(raise_exception=True):
serializer.save()
return Response(
{
'success': True,
"message": "ozgartirildi"
}
)
return Response({'success': True, "message": serializer.errors})