admin uchun login api qoshildi
This commit is contained in:
@@ -2,4 +2,11 @@ from rest_framework import serializers
|
|||||||
|
|
||||||
|
|
||||||
class LoginSerializer(serializers.Serializer):
|
class LoginSerializer(serializers.Serializer):
|
||||||
telegram_id = serializers.CharField()
|
telegram_id = serializers.CharField()
|
||||||
|
|
||||||
|
|
||||||
|
class AdminLoginSerializer(serializers.Serializer):
|
||||||
|
username = serializers.CharField()
|
||||||
|
password = serializers.CharField()
|
||||||
|
|
||||||
|
|
||||||
@@ -5,4 +5,5 @@ from core.apps.authentication.views import login
|
|||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
path('login/', login.LoginApiView.as_view(), name='login-api'),
|
path('login/', login.LoginApiView.as_view(), name='login-api'),
|
||||||
|
path('admin_login/', login.AdminLoginApiView.as_view(), name='admin-login-admin'),
|
||||||
]
|
]
|
||||||
@@ -10,12 +10,10 @@ 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
|
||||||
from core.apps.shared.serializers.base import BaseResponseSerializer, SuccessResponseSerializer
|
|
||||||
# accounts
|
# accounts
|
||||||
from core.apps.accounts.models import User
|
from core.apps.accounts.models import User
|
||||||
# authentication
|
# authentication
|
||||||
from core.apps.authentication.serializers.login import LoginSerializer
|
from core.apps.authentication.serializers.login import LoginSerializer, AdminLoginSerializer
|
||||||
from core.apps.authentication.serializers import response as response_serializers
|
|
||||||
|
|
||||||
|
|
||||||
class LoginApiView(generics.GenericAPIView, ResponseMixin):
|
class LoginApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
@@ -69,9 +67,91 @@ class LoginApiView(generics.GenericAPIView, ResponseMixin):
|
|||||||
)
|
)
|
||||||
|
|
||||||
token = RefreshToken.for_user(user)
|
token = RefreshToken.for_user(user)
|
||||||
user_data['token'] = str(token)
|
user_data['token'] = str(token.access_token)
|
||||||
return self.success_response(data=user_data, message='User topildi')
|
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:
|
||||||
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class AdminLoginApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = AdminLoginSerializer
|
||||||
|
queryset = User.objects.all()
|
||||||
|
|
||||||
|
@swagger_auto_schema(
|
||||||
|
operation_description="Admin uchun login api",
|
||||||
|
responses={
|
||||||
|
200: openapi.Response(
|
||||||
|
schema=None,
|
||||||
|
description="Success",
|
||||||
|
examples={
|
||||||
|
"application/json": {
|
||||||
|
"status_code": 200,
|
||||||
|
"success": "success",
|
||||||
|
"message": "Login muvaffaqiyalit amalga oshirildi",
|
||||||
|
"data": {
|
||||||
|
"token": "4jh4j3rbj2fkjb3kfjbwkfjb24kgjb34kgj3kjbkw..."
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
404: openapi.Response(
|
||||||
|
schema=None,
|
||||||
|
description="User not found",
|
||||||
|
examples={
|
||||||
|
"application/json": {
|
||||||
|
"status_code": 404,
|
||||||
|
"success": "failure",
|
||||||
|
"message": "username yoki parol notog'ri",
|
||||||
|
"data": {}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
400: openapi.Response(
|
||||||
|
schema=None,
|
||||||
|
description="Failue error",
|
||||||
|
examples={
|
||||||
|
"application/json": {
|
||||||
|
"status_code": 400,
|
||||||
|
"success": "failure",
|
||||||
|
"message": "foydalanuvchi aktive emas",
|
||||||
|
"data": {},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
),
|
||||||
|
500: openapi.Response(
|
||||||
|
schema=None,
|
||||||
|
description="Server Error",
|
||||||
|
examples={
|
||||||
|
"application/json": {
|
||||||
|
"status_code": 500,
|
||||||
|
"success": "error",
|
||||||
|
"message": "xatolik",
|
||||||
|
"data": "some error...",
|
||||||
|
}
|
||||||
|
}
|
||||||
|
)
|
||||||
|
}
|
||||||
|
)
|
||||||
|
def post(self, request):
|
||||||
|
try:
|
||||||
|
serializer = self.serializer_class(data=request.data)
|
||||||
|
if serializer.is_valid():
|
||||||
|
username = serializer.validated_data.get('username')
|
||||||
|
password = serializer.validated_data.get('password')
|
||||||
|
user = User.objects.filter(username=username).first()
|
||||||
|
if not user or (user and user.check_password(password)):
|
||||||
|
return self.failure_response(message="username yoki parol notog'ri", data={}, status_code=404)
|
||||||
|
if not user.is_active:
|
||||||
|
return self.failure_response(message="foydalanuvchi aktive emas", data={})
|
||||||
|
|
||||||
|
token = RefreshToken.for_user(user)
|
||||||
|
return self.success_response(
|
||||||
|
message="Login muvaffaqiyalit amalga oshirildi",
|
||||||
|
data={"token": str(token.access_token)}
|
||||||
|
)
|
||||||
|
|
||||||
except Exception as e:
|
except Exception as e:
|
||||||
return self.error_response(data=str(e), message='xatolik')
|
return self.error_response(data=str(e), message='xatolik')
|
||||||
Reference in New Issue
Block a user