add: add admin panel api for user

This commit is contained in:
behruz-dev
2025-09-02 17:03:43 +05:00
parent f56f9e1c5a
commit 58cc36a9a4
9 changed files with 183 additions and 0 deletions

View File

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

View 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

View 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()),
]
))
]

View File

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

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