add: add admin panel api for user
This commit is contained in:
0
core/apps/admin_panel/__init__.py
Normal file
0
core/apps/admin_panel/__init__.py
Normal file
6
core/apps/admin_panel/apps.py
Normal file
6
core/apps/admin_panel/apps.py
Normal file
@@ -0,0 +1,6 @@
|
|||||||
|
from django.apps import AppConfig
|
||||||
|
|
||||||
|
|
||||||
|
class AdminPanelConfig(AppConfig):
|
||||||
|
default_auto_field = 'django.db.models.BigAutoField'
|
||||||
|
name = 'core.apps.admin_panel'
|
||||||
0
core/apps/admin_panel/migrations/__init__.py
Normal file
0
core/apps/admin_panel/migrations/__init__.py
Normal file
0
core/apps/admin_panel/serializers/__init__.py
Normal file
0
core/apps/admin_panel/serializers/__init__.py
Normal file
40
core/apps/admin_panel/serializers/user.py
Normal file
40
core/apps/admin_panel/serializers/user.py
Normal file
@@ -0,0 +1,40 @@
|
|||||||
|
from django.db import transaction
|
||||||
|
|
||||||
|
from rest_framework import serializers
|
||||||
|
|
||||||
|
from core.apps.accounts.models import User
|
||||||
|
|
||||||
|
|
||||||
|
class UserSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = User
|
||||||
|
fields = [
|
||||||
|
'id', 'first_name', 'last_name', 'username', 'password'
|
||||||
|
]
|
||||||
|
extra_kwargs = {'id': {'read_only': True}, 'password': {'write_only': True}}
|
||||||
|
|
||||||
|
def validate_username(self, value):
|
||||||
|
if User.objects.filter(username=value).exists():
|
||||||
|
raise serializers.ValidationError("User with this username already exists")
|
||||||
|
return value
|
||||||
|
|
||||||
|
def create(self, validated_data):
|
||||||
|
with transaction.atomic():
|
||||||
|
user = User.objects.create(
|
||||||
|
first_name=validated_data.get('first_name'),
|
||||||
|
last_name=validated_data.get('last_name'),
|
||||||
|
username=validated_data.get('username'),
|
||||||
|
)
|
||||||
|
user.set_password(validated_data.get('password'))
|
||||||
|
user.save()
|
||||||
|
return user
|
||||||
|
|
||||||
|
def update(self, instance, validated_data):
|
||||||
|
with transaction.atomic():
|
||||||
|
instance.username = validated_data.get('username', instance.username)
|
||||||
|
instance.first_name = validated_data.get('first_name', instance.first_name)
|
||||||
|
instance.last_name = validated_data.get('last_name', instance.last_name)
|
||||||
|
if validated_data.get('password'):
|
||||||
|
instance.set_password(validated_data.get('password'))
|
||||||
|
instance.save()
|
||||||
|
return instance
|
||||||
15
core/apps/admin_panel/urls.py
Normal file
15
core/apps/admin_panel/urls.py
Normal file
@@ -0,0 +1,15 @@
|
|||||||
|
from django.urls import path, include
|
||||||
|
|
||||||
|
from core.apps.admin_panel.views import user as user_views
|
||||||
|
|
||||||
|
urlpatterns = [
|
||||||
|
path('user/', include(
|
||||||
|
[
|
||||||
|
path('create/', user_views.UserCreateApiView.as_view()),
|
||||||
|
path('list/', user_views.UserListApiView.as_view()),
|
||||||
|
path('<uuid:id>/update/', user_views.UserUpdateApiView.as_view()),
|
||||||
|
path('<uuid:id>/delete/', user_views.UserDeleteApiView.as_view()),
|
||||||
|
path('<uuid:id>/', user_views.UserDetailApiView.as_view()),
|
||||||
|
]
|
||||||
|
))
|
||||||
|
]
|
||||||
0
core/apps/admin_panel/views/__init__.py
Normal file
0
core/apps/admin_panel/views/__init__.py
Normal file
74
core/apps/admin_panel/views/user.py
Normal file
74
core/apps/admin_panel/views/user.py
Normal file
@@ -0,0 +1,74 @@
|
|||||||
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
|
from rest_framework import generics, permissions, status
|
||||||
|
from rest_framework.response import Response
|
||||||
|
|
||||||
|
from core.apps.admin_panel.serializers.user import UserSerializer
|
||||||
|
from core.apps.accounts.models import User
|
||||||
|
from core.apps.shared.mixins.response import ResponseMixin
|
||||||
|
|
||||||
|
|
||||||
|
class UserCreateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = UserSerializer
|
||||||
|
queryset = User.objects.all()
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def post(self, request):
|
||||||
|
serializer = self.serializer_class(data=request.data)
|
||||||
|
if serializer.is_valid(raise_exception=True):
|
||||||
|
serializer.save()
|
||||||
|
return self.success_response(
|
||||||
|
message='User qoshildi', status_code=status.HTTP_201_CREATED
|
||||||
|
)
|
||||||
|
return self.error_response(data=serializer.errors, message='User qoshishda xatolik')
|
||||||
|
|
||||||
|
|
||||||
|
class UserListApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = UserSerializer
|
||||||
|
queryset = User.objects.exclude(is_superuser=True)
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def get(self, request):
|
||||||
|
users = self.get_queryset()
|
||||||
|
page = self.paginate_queryset(users)
|
||||||
|
if page is not None:
|
||||||
|
serializer = self.serializer_class(page, many=True)
|
||||||
|
return self.get_paginated_response(serializer.data)
|
||||||
|
serializer = self.serializer_class(users, many=True)
|
||||||
|
return self.success_response(data=serializer.data, message='userlar royxati')
|
||||||
|
|
||||||
|
|
||||||
|
class UserUpdateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = UserSerializer
|
||||||
|
queryset = User.objects.all()
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def patch(self, request, id):
|
||||||
|
user = get_object_or_404(User, id=id)
|
||||||
|
serializer = self.serializer_class(instance=user, data=serializer.data)
|
||||||
|
if serializer.is_valid(raise_exception=True):
|
||||||
|
serializer.save()
|
||||||
|
return self.success_response(message='user tahrirlandi')
|
||||||
|
return self.failure_response(data=serializer.errors, message='user tahrirlashda xatolik')
|
||||||
|
|
||||||
|
|
||||||
|
class UserDeleteApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = None
|
||||||
|
queryset = User.objects.all()
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def delete(self, request, id):
|
||||||
|
user = get_object_or_404(User, id=id)
|
||||||
|
user.delete()
|
||||||
|
return self.success_response(message='user ochirildi', status_code=status.HTTP_204_NO_CONTENT)
|
||||||
|
|
||||||
|
|
||||||
|
class UserDetailApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = UserSerializer
|
||||||
|
queryset = User.objects.all()
|
||||||
|
permissions = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def get(self, request, id):
|
||||||
|
user = get_object_or_404(User, id=id)
|
||||||
|
serializer = self.serializer_class(user)
|
||||||
|
return self.success_response(data=serializer.data, message='user malumotlari')
|
||||||
48
core/apps/shared/mixins/response.py
Normal file
48
core/apps/shared/mixins/response.py
Normal file
@@ -0,0 +1,48 @@
|
|||||||
|
from rest_framework import status
|
||||||
|
from rest_framework.response import Response
|
||||||
|
|
||||||
|
|
||||||
|
class ResponseMixin:
|
||||||
|
SUCCESS = 'success'
|
||||||
|
FAILURE = 'failure'
|
||||||
|
ERROR = 'error'
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def success_response(cls, data=None, message=None, status_code=status.HTTP_200_OK):
|
||||||
|
"""
|
||||||
|
Returns Success response
|
||||||
|
"""
|
||||||
|
response_data = {'status_code': status_code, 'status': cls.SUCCESS}
|
||||||
|
if message is not None:
|
||||||
|
response_data['message'] = message
|
||||||
|
if data is not None:
|
||||||
|
response_data['data'] = data
|
||||||
|
return Response(response_data, status=status_code)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def failure_response(
|
||||||
|
cls, data=None, message=None, status_code=status.HTTP_400_BAD_REQUEST
|
||||||
|
):
|
||||||
|
"""
|
||||||
|
Returns Failure Response
|
||||||
|
"""
|
||||||
|
response_data = {"status_code": status_code, "status": cls.FAILURE}
|
||||||
|
if message is not None:
|
||||||
|
response_data["message"] = message
|
||||||
|
if data is not None:
|
||||||
|
response_data["data"] = data
|
||||||
|
return Response(response_data, status=status_code)
|
||||||
|
|
||||||
|
@classmethod
|
||||||
|
def error_response(
|
||||||
|
cls, data=None, message=None, status_code=status.HTTP_500_INTERNAL_SERVER_ERROR
|
||||||
|
):
|
||||||
|
"""
|
||||||
|
Returns Error Response
|
||||||
|
"""
|
||||||
|
response_data = {"status_code": status_code, "status": cls.ERROR}
|
||||||
|
if message is not None:
|
||||||
|
response_data["message"] = message
|
||||||
|
if data is not None:
|
||||||
|
response_data["data"] = data
|
||||||
|
return Response(response_data, status=status_code)
|
||||||
Reference in New Issue
Block a user