fix
This commit is contained in:
@@ -10,20 +10,19 @@ from core.apps.accounts.models import User
|
|||||||
from core.apps.shared.models import Region
|
from core.apps.shared.models import Region
|
||||||
|
|
||||||
|
|
||||||
class UserCreateSerializer(serializers.ModelSerializer):
|
class UserCreateSerializer(serializers.Serializer):
|
||||||
class Meta:
|
first_name = serializers.CharField()
|
||||||
model = User
|
last_name = serializers.CharField()
|
||||||
fields = [
|
telegram_id = serializers.CharField()
|
||||||
'first_name', 'last_name', 'telegram_id', 'region'
|
region = serializers.IntegerField()
|
||||||
]
|
|
||||||
|
|
||||||
def validate(self, data):
|
def validate(self, data):
|
||||||
if User.objects.filter(username=data['telegram_id']).exists():
|
if User.objects.filter(username=data['telegram_id']).exists():
|
||||||
raise serializers.ValidationError("User mavjud")
|
raise serializers.ValidationError("User mavjud")
|
||||||
region = Region.objects.filter(id=data['region']).first()
|
region = Region.objects.filter(id=data['region']).first()
|
||||||
if not region:
|
if not region:
|
||||||
raise serializers.ValidationError("Region topilmadi")
|
raise serializers.ValidationError({"region": "Region topilmadi"})
|
||||||
data['region'] = region
|
data['region_obj'] = region
|
||||||
return data
|
return data
|
||||||
|
|
||||||
def create(self, validated_data):
|
def create(self, validated_data):
|
||||||
@@ -32,7 +31,7 @@ class UserCreateSerializer(serializers.ModelSerializer):
|
|||||||
first_name=validated_data.get('first_name'),
|
first_name=validated_data.get('first_name'),
|
||||||
last_name=validated_data.get('last_name'),
|
last_name=validated_data.get('last_name'),
|
||||||
telegram_id=validated_data.get('telegram_id'),
|
telegram_id=validated_data.get('telegram_id'),
|
||||||
region=validated_data.get('region'),
|
region=validated_data.get('region_obj'),
|
||||||
is_active=False,
|
is_active=False,
|
||||||
username=validated_data.get('telegram_id'),
|
username=validated_data.get('telegram_id'),
|
||||||
)
|
)
|
||||||
|
|||||||
@@ -29,7 +29,7 @@ class RegisterUserApiView(generics.GenericAPIView, ResponseMixin):
|
|||||||
def post(self, request):
|
def post(self, request):
|
||||||
try:
|
try:
|
||||||
serializer = self.serializer_class(data=request.data)
|
serializer = self.serializer_class(data=request.data)
|
||||||
if serializer.is_valid(raise_exception=True):
|
if serializer.is_valid():
|
||||||
serializer.save()
|
serializer.save()
|
||||||
return self.success_response(message='Foydalanuvchi qoshildi', status_code=201)
|
return self.success_response(message='Foydalanuvchi qoshildi', status_code=201)
|
||||||
return self.failure_response(data=serializer.errors, message='Foydalanuvchi qoshilmadi')
|
return self.failure_response(data=serializer.errors, message='Foydalanuvchi qoshilmadi')
|
||||||
|
|||||||
@@ -1,9 +1,12 @@
|
|||||||
# rest framework
|
# rest framework
|
||||||
from rest_framework import generics
|
from rest_framework import generics
|
||||||
|
|
||||||
# rest framework simple jwt
|
# rest framework simple jwt
|
||||||
from rest_framework_simplejwt.tokens import RefreshToken
|
from rest_framework_simplejwt.tokens import RefreshToken
|
||||||
|
|
||||||
# drf yasg
|
# drf yasg
|
||||||
from drf_yasg.utils import swagger_auto_schema
|
from drf_yasg.utils import swagger_auto_schema
|
||||||
|
from drf_yasg import openapi
|
||||||
|
|
||||||
# shared
|
# shared
|
||||||
from core.apps.shared.utils.response_mixin import ResponseMixin
|
from core.apps.shared.utils.response_mixin import ResponseMixin
|
||||||
@@ -19,13 +22,32 @@ class LoginApiView(generics.GenericAPIView, ResponseMixin):
|
|||||||
serializer_class = LoginSerializer
|
serializer_class = LoginSerializer
|
||||||
queryset = User.objects.all()
|
queryset = User.objects.all()
|
||||||
|
|
||||||
@swagger_auto_schema(
|
# @swagger_auto_schema(
|
||||||
responses={
|
# operation_summary="Login",
|
||||||
200: SuccessResponseSerializer(data_serializer=response_serializers.LoginResponseSerializer()),
|
# responses={
|
||||||
400: BaseResponseSerializer(),
|
# 200: openapi.Response(
|
||||||
500: BaseResponseSerializer(),
|
# description="Success",
|
||||||
}
|
# schema=openapi.Schema(
|
||||||
)
|
# type=openapi.TYPE_OBJECT
|
||||||
|
# ),
|
||||||
|
# examples={
|
||||||
|
# "application/json": {
|
||||||
|
# "status_code": 200,
|
||||||
|
# "status": "success",
|
||||||
|
# "message": "User topildi",
|
||||||
|
# "data": {
|
||||||
|
# "id": 1,
|
||||||
|
# "first_name": "Behruz",
|
||||||
|
# "last_name": "Xoliqberdiyev",
|
||||||
|
# "region": "nbve",
|
||||||
|
# "is_active": True,
|
||||||
|
# "token": "eyJhbGciOiJIUzI1NiIsInR5cCI6IkpXVCJ9..."
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
# }
|
||||||
|
# )
|
||||||
|
# }
|
||||||
|
# )
|
||||||
def post(self, request):
|
def post(self, request):
|
||||||
try:
|
try:
|
||||||
serializer = self.serializer_class(data=request.data)
|
serializer = self.serializer_class(data=request.data)
|
||||||
@@ -33,12 +55,24 @@ class LoginApiView(generics.GenericAPIView, ResponseMixin):
|
|||||||
telegram_id = serializer.validated_data.get('telegram_id')
|
telegram_id = serializer.validated_data.get('telegram_id')
|
||||||
user = User.objects.filter(telegram_id=telegram_id).first()
|
user = User.objects.filter(telegram_id=telegram_id).first()
|
||||||
if not user:
|
if not user:
|
||||||
return self.failure_response(message="User topilmadi")
|
return self.failure_response(message="User topilmadi", status_code=404)
|
||||||
|
user_data = {
|
||||||
|
'id': user.id,
|
||||||
|
'first_name': user.first_name,
|
||||||
|
'last_name': user.last_name,
|
||||||
|
'region': user.region.name,
|
||||||
|
'is_active': user.is_active,
|
||||||
|
'token': None
|
||||||
|
}
|
||||||
if not user.is_active:
|
if not user.is_active:
|
||||||
return self.failure_response(message="User tasdiqlanmagan")
|
return self.success_response(
|
||||||
|
message="User tasdiqlanmagan",
|
||||||
|
data=user_data
|
||||||
|
)
|
||||||
|
|
||||||
token = RefreshToken.for_user(user)
|
token = RefreshToken.for_user(user)
|
||||||
return self.success_response(data={'token': str(token.access_token)})
|
user_data['token'] = str(token)
|
||||||
|
return self.success_response(data=user_data, message='User topildi')
|
||||||
|
|
||||||
return self.failure_response(data=serializer.errors, message='siz tarafdan xatolik')
|
return self.failure_response(data=serializer.errors, message='siz tarafdan xatolik')
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
|
|||||||
Reference in New Issue
Block a user