region uchun crud api qoshildig
This commit is contained in:
12
core/apps/dashboard/serializers/region.py
Normal file
12
core/apps/dashboard/serializers/region.py
Normal file
@@ -0,0 +1,12 @@
|
|||||||
|
from rest_framework import serializers
|
||||||
|
|
||||||
|
# shared
|
||||||
|
from core.apps.shared.models import Region
|
||||||
|
|
||||||
|
|
||||||
|
class RegionSerializer(serializers.ModelSerializer):
|
||||||
|
class Meta:
|
||||||
|
model = Region
|
||||||
|
fields = [
|
||||||
|
'id', 'name'
|
||||||
|
]
|
||||||
@@ -11,7 +11,8 @@ from core.apps.dashboard.views import user as user_views
|
|||||||
from core.apps.dashboard.views import district as district_views
|
from core.apps.dashboard.views import district as district_views
|
||||||
# doctor
|
# doctor
|
||||||
from core.apps.dashboard.views.doctor import DoctorViewSet
|
from core.apps.dashboard.views.doctor import DoctorViewSet
|
||||||
|
# region
|
||||||
|
from core.apps.dashboard.views import region as region_views
|
||||||
|
|
||||||
urlpatterns = [
|
urlpatterns = [
|
||||||
# -------------- user --------------
|
# -------------- user --------------
|
||||||
@@ -32,7 +33,15 @@ urlpatterns = [
|
|||||||
path('<int:id>/delete/', district_views.DistrictDeleteApiView.as_view(), name='district-delete-api'),
|
path('<int:id>/delete/', district_views.DistrictDeleteApiView.as_view(), name='district-delete-api'),
|
||||||
]
|
]
|
||||||
)),
|
)),
|
||||||
|
# -------------- region --------------
|
||||||
|
path('region/', include(
|
||||||
|
[
|
||||||
|
path('list/', region_views.RegionListApiView.as_view(), name='region-list-api'),
|
||||||
|
path('create/', region_views.RegionCreateApiView.as_view(), name='region-create-api'),
|
||||||
|
path('<int:id>/update/', region_views.RegionUpdateApiView.as_view(), name='region-update-api'),
|
||||||
|
path('<int:id>/delete/', region_views.RegionDeleteApiView.as_view(), name='region-delete-api'),
|
||||||
|
]
|
||||||
|
)),
|
||||||
]
|
]
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
90
core/apps/dashboard/views/region.py
Normal file
90
core/apps/dashboard/views/region.py
Normal file
@@ -0,0 +1,90 @@
|
|||||||
|
# django
|
||||||
|
from django.shortcuts import get_object_or_404
|
||||||
|
|
||||||
|
# rest framework
|
||||||
|
from rest_framework import generics, permissions, views
|
||||||
|
|
||||||
|
# shared
|
||||||
|
from core.apps.shared.utils.response_mixin import ResponseMixin
|
||||||
|
from core.apps.shared.serializers.region import RegionSerializer
|
||||||
|
from core.apps.shared.models import Region
|
||||||
|
|
||||||
|
|
||||||
|
class RegionListApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = RegionSerializer
|
||||||
|
queryset = Region.objects.all()
|
||||||
|
|
||||||
|
def get(self, request):
|
||||||
|
try:
|
||||||
|
serializer = self.serializer_class(self.get_queryset(), many=True)
|
||||||
|
return self.success_response(
|
||||||
|
data=serializer.data, message='malumotlar fetch qilindi'
|
||||||
|
)
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
class RegionCreateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = RegionSerializer
|
||||||
|
queryset = Region.objects.all()
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def post(self, request):
|
||||||
|
try:
|
||||||
|
serializer = self.serializer_class(data=request.data)
|
||||||
|
if serializer.is_valid():
|
||||||
|
name = serializer.validated_data.get('name')
|
||||||
|
region = Region.objects.create(name=name)
|
||||||
|
return self.success_response(data=RegionSerializer(region).data, message='malumot qoshildi')
|
||||||
|
return self.failure_response(data=serializer.errors, message='malumot qoshilmadi')
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class RegionUpdateApiView(generics.GenericAPIView, ResponseMixin):
|
||||||
|
serializer_class = RegionSerializer
|
||||||
|
queryset = Region.objects.all()
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def patch(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(Region, id=id)
|
||||||
|
serializer = self.serializer_class(data=request.data)
|
||||||
|
if serializer.is_valid():
|
||||||
|
name = serializer.validated_data.get('name')
|
||||||
|
obj.name = name
|
||||||
|
obj.save()
|
||||||
|
return self.success_response(data=RegionSerializer(obj).data, message='malumot tahrirlandi')
|
||||||
|
return self.failure_response(data=serializer.errors, message='malumot tahrirlanmadi')
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
class RegionDeleteApiView(views.APIView, ResponseMixin):
|
||||||
|
permission_classes = [permissions.IsAdminUser]
|
||||||
|
|
||||||
|
def delete(self, request, id):
|
||||||
|
try:
|
||||||
|
obj = get_object_or_404(Region, id=id)
|
||||||
|
obj.delete()
|
||||||
|
return self.success_response(data={}, message='malumot ochirildi')
|
||||||
|
|
||||||
|
except Exception as e:
|
||||||
|
return self.error_response(
|
||||||
|
data=str(e),
|
||||||
|
message="xatolik"
|
||||||
|
)
|
||||||
|
|
||||||
Reference in New Issue
Block a user